exports/Set-SysManPrinter.ps1
<# .Synopsis Updates a printer based on the provided information .Description Updates a printer based on the provided information .Link https://docs.microsoft.com/en-us/powershell/module/sysman.webapi/set-sysmanprinter #> function Set-SysManPrinter { [OutputType('SysMan.Powershell.Models.IPrinter', 'SysMan.Powershell.Models.IApiErrorMessage')] [CmdletBinding(DefaultParameterSetName='Put', PositionalBinding=$false, SupportsShouldProcess, ConfirmImpact='Medium')] [SysMan.Powershell.Description('Updates a printer based on the provided information')] param( [Parameter(Mandatory, HelpMessage='The id of the printer')] [SysMan.Powershell.Category('Path')] [System.Int64] ${Id}, [Parameter(ParameterSetName='Put', ValueFromPipeline, HelpMessage='A printer represent a Queue. A printer can be installed on clients.')] [SysMan.Powershell.Category('Body')] [SysMan.Powershell.Models.IPrinter] ${Printer}, [Parameter(ParameterSetName='PutExpanded', HelpMessage='If the printer can be assigned as default printer during installation')] [SysMan.Powershell.Category('Body')] [System.Management.Automation.SwitchParameter] ${CanBeDefault}, [Parameter(ParameterSetName='PutExpanded', HelpMessage='If the printer can be removed. Usually used by external systems (example: Login script) to handle cases where theprinter should be removed each login and installed again.')] [SysMan.Powershell.Category('Body')] [System.Management.Automation.SwitchParameter] ${CanBeRemoved}, [Parameter(ParameterSetName='PutExpanded', HelpMessage='When the printer was created')] [SysMan.Powershell.Category('Body')] [System.DateTime] ${CreatedDate}, [Parameter(ParameterSetName='PutExpanded', HelpMessage='The description of the printer')] [SysMan.Powershell.Category('Body')] [System.String] ${Description}, [Parameter(ParameterSetName='PutExpanded', HelpMessage='The id of the printer')] [SysMan.Powershell.Category('Body')] [System.Int64] ${Id1}, [Parameter(ParameterSetName='PutExpanded', HelpMessage='The internal version used to flag if the printer should be upgraded or not. Is is external systems responsibility(Example: login script) to handledetection if a version has changed.')] [SysMan.Powershell.Category('Body')] [System.Int32] ${InternalDriverVersion}, [Parameter(ParameterSetName='PutExpanded', HelpMessage='If the printer is active or nor. Inactive printer can be used to filter out printers that should not be handled byusers')] [SysMan.Powershell.Category('Body')] [System.Management.Automation.SwitchParameter] ${IsActive}, [Parameter(ParameterSetName='PutExpanded', HelpMessage='The date the printer was last modified')] [SysMan.Powershell.Category('Body')] [System.DateTime] ${LastModifiedDate}, [Parameter(ParameterSetName='PutExpanded', HelpMessage='The location of the printer. Mostly used as meta data to help technicians which printer to pick when intalling themon clients')] [SysMan.Powershell.Category('Body')] [System.String] ${Location}, [Parameter(ParameterSetName='PutExpanded', Mandatory, HelpMessage='The name. Often used together with Server to create a printer path')] [SysMan.Powershell.Category('Body')] [System.String] ${Name}, [Parameter(ParameterSetName='PutExpanded', Mandatory, HelpMessage='The server. Often used together with Name to create a printer path')] [SysMan.Powershell.Category('Body')] [System.String] ${Server}, [Parameter(DontShow, HelpMessage='Wait for .NET debugger to attach')] [SysMan.Powershell.Category('Runtime')] [System.Management.Automation.SwitchParameter] ${Break}, [Parameter(DontShow, HelpMessage='SendAsync Pipeline Steps to be appended to the front of the pipeline')] [ValidateNotNull()] [SysMan.Powershell.Category('Runtime')] [SysMan.Powershell.Runtime.SendAsyncStep[]] ${HttpPipelineAppend}, [Parameter(DontShow, HelpMessage='SendAsync Pipeline Steps to be prepended to the front of the pipeline')] [ValidateNotNull()] [SysMan.Powershell.Category('Runtime')] [SysMan.Powershell.Runtime.SendAsyncStep[]] ${HttpPipelinePrepend}, [Parameter(DontShow, HelpMessage='The URI for the proxy server to use')] [SysMan.Powershell.Category('Runtime')] [System.Uri] ${Proxy}, [Parameter(DontShow, HelpMessage='Credentials for a proxy server to use for the remote call')] [ValidateNotNull()] [SysMan.Powershell.Category('Runtime')] [System.Management.Automation.PSCredential] ${ProxyCredential}, [Parameter(DontShow, HelpMessage='Use the default credentials for the proxy')] [SysMan.Powershell.Category('Runtime')] [System.Management.Automation.SwitchParameter] ${ProxyUseDefaultCredentials} ) begin { try { $outBuffer = $null if ($PSBoundParameters.TryGetValue('OutBuffer', [ref]$outBuffer)) { $PSBoundParameters['OutBuffer'] = 1 } $parameterSet = $PsCmdlet.ParameterSetName $mapping = @{ Put = 'SysMan.WebApi.private\Set-SysManPrinter_Put'; PutExpanded = 'SysMan.WebApi.private\Set-SysManPrinter_PutExpanded'; } $wrappedCmd = $ExecutionContext.InvokeCommand.GetCommand(($mapping[$parameterSet]), [System.Management.Automation.CommandTypes]::Cmdlet) $scriptCmd = {& $wrappedCmd @PSBoundParameters} $steppablePipeline = $scriptCmd.GetSteppablePipeline($myInvocation.CommandOrigin) $steppablePipeline.Begin($PSCmdlet) } catch { throw } } process { try { $steppablePipeline.Process($_) } catch { throw } } end { try { $steppablePipeline.End() } catch { throw } } } |