mirror of
https://github.com/snazy2000/SnipeitPS.git
synced 2025-12-13 18:02:30 +00:00
182 lines
4.4 KiB
PowerShell
182 lines
4.4 KiB
PowerShell
<#
|
|
.SYNOPSIS
|
|
Creates a licence
|
|
|
|
.DESCRIPTION
|
|
Creates a new licence on Snipe-It system
|
|
|
|
.PARAMETER name
|
|
Name of license being created
|
|
|
|
.PARAMETER seats
|
|
Number of license seats owned.
|
|
|
|
.PARAMETER company_id
|
|
Id number of company license belongs to
|
|
|
|
.PARAMETER expiration_date
|
|
Date of license expiration
|
|
|
|
.PARAMETER expiration_date
|
|
Date of license expiration
|
|
|
|
.PARAMETER license_email
|
|
Email address associated with license
|
|
|
|
.PARAMETER license_name
|
|
Name of license contact person
|
|
|
|
.PARAMETER serial
|
|
Serialnumber of license
|
|
|
|
.PARAMETER maintained
|
|
Maintained status of license
|
|
|
|
.PARAMETER manufacturer_id
|
|
ID number of manufacturer of license.
|
|
|
|
.PARAMETER notes
|
|
License Notes
|
|
|
|
.PARAMETER order_number
|
|
Order number of license purchase
|
|
|
|
.PARAMETER purchase_cost
|
|
Cost of license
|
|
|
|
.PARAMETER purchase_date
|
|
Date of license purchase
|
|
|
|
.PARAMETER purchase_order
|
|
Purchase order number of license purchase
|
|
|
|
.PARAMETER reassignable
|
|
Is license reassignable?
|
|
|
|
.PARAMETER supplier_id
|
|
ID number of license supplier
|
|
|
|
.PARAMETER termination_date
|
|
Termination date for license.
|
|
|
|
.PARAMETER url
|
|
Deprecated parameter, please use Connect-SnipeitPS instead. URL of Snipeit system.
|
|
|
|
.PARAMETER apiKey
|
|
Deprecated parameter, please use Connect-SnipeitPS instead. Users API Key for Snipeit.
|
|
|
|
.EXAMPLE
|
|
New-SnipeitLicence -name "License" -seats 3 -company_id 1
|
|
|
|
#>
|
|
|
|
function New-SnipeitLicense() {
|
|
[CmdletBinding(
|
|
SupportsShouldProcess = $true,
|
|
ConfirmImpact = "Low"
|
|
)]
|
|
|
|
Param(
|
|
[parameter(mandatory = $true)]
|
|
[ValidateLength(3, 255)]
|
|
[string]$name,
|
|
|
|
[parameter(mandatory = $true)]
|
|
[int]$seats,
|
|
|
|
[ValidateRange(1, [int]::MaxValue)]
|
|
[int]$category_id,
|
|
|
|
[ValidateRange(1, [int]::MaxValue)]
|
|
[int]$company_id,
|
|
|
|
[datetime]$expiration_date,
|
|
|
|
[mailaddress]$license_email,
|
|
|
|
[ValidateLength(1, 100)]
|
|
[string]$license_name,
|
|
|
|
[bool]$maintained,
|
|
|
|
[ValidateRange(1, [int]::MaxValue)]
|
|
[int]$manufacturer_id,
|
|
|
|
[string]$notes,
|
|
|
|
[string]$order_number,
|
|
|
|
[float]$purchase_cost,
|
|
|
|
[datetime]$purchase_date,
|
|
|
|
[string]$purchase_order,
|
|
|
|
[bool]$reassignable,
|
|
|
|
[string]$serial,
|
|
|
|
[ValidateRange(1, [int]::MaxValue)]
|
|
[int]$supplier_id,
|
|
|
|
[datetime]$termination_date,
|
|
|
|
[parameter(mandatory = $false)]
|
|
[string]$url,
|
|
|
|
[parameter(mandatory = $false)]
|
|
[string]$apiKey
|
|
)
|
|
begin {
|
|
Test-SnipeitAlias -invocationName $MyInvocation.InvocationName -commandName $MyInvocation.MyCommand.Name
|
|
|
|
$Values = . Get-ParameterValue -Parameters $MyInvocation.MyCommand.Parameters -BoundParameters $PSBoundParameters
|
|
|
|
if ($Values['expiration_date']) {
|
|
$Values['expiration_date'] = $Values['expiration_date'].ToString("yyyy-MM-dd")
|
|
}
|
|
|
|
if ($Values['purchase_date']) {
|
|
$Values['purchase_date'] = $Values['purchase_date'].ToString("yyyy-MM-dd")
|
|
}
|
|
|
|
if ($Values['termination_date']) {
|
|
$Values['termination_date'] = $Values['termination_date'].ToString("yyyy-MM-dd")
|
|
}
|
|
|
|
if ($Values['license_email']) {
|
|
$Values['license_email'] = $Values['license_email'].address
|
|
}
|
|
|
|
$Parameters = @{
|
|
Api = "/api/v1/licenses"
|
|
Method = 'POST'
|
|
Body = $Values
|
|
}
|
|
|
|
if ($PSBoundParameters.ContainsKey('apiKey') -and '' -ne [string]$apiKey) {
|
|
Write-Warning "-apiKey parameter is deprecated, please use Connect-SnipeitPS instead."
|
|
Set-SnipeitPSLegacyApiKey -apiKey $apikey
|
|
}
|
|
|
|
if ($PSBoundParameters.ContainsKey('url') -and '' -ne [string]$url) {
|
|
Write-Warning "-url parameter is deprecated, please use Connect-SnipeitPS instead."
|
|
Set-SnipeitPSLegacyUrl -url $url
|
|
}
|
|
}
|
|
|
|
process {
|
|
if ($PSCmdlet.ShouldProcess("ShouldProcess?")) {
|
|
$result = Invoke-SnipeitMethod @Parameters
|
|
}
|
|
|
|
$result
|
|
}
|
|
end {
|
|
# reset legacy sessions
|
|
if ($PSBoundParameters.ContainsKey('url') -and '' -ne [string]$url -or $PSBoundParameters.ContainsKey('apiKey') -and '' -ne [string]$apiKey) {
|
|
Reset-SnipeitPSLegacyApi
|
|
}
|
|
}
|
|
}
|
|
|