mirror of
https://github.com/snazy2000/SnipeitPS.git
synced 2025-12-15 10:45:48 +00:00
Merge pull request #113 from PetriAsi/feature/checkout-in-licences
Feature/checkout in licences seats
This commit is contained in:
commit
ee0d285ab0
3 changed files with 175 additions and 0 deletions
95
SnipeitPS/Public/Get-SnipeItLicenseSeat.ps1
Normal file
95
SnipeitPS/Public/Get-SnipeItLicenseSeat.ps1
Normal file
|
|
@ -0,0 +1,95 @@
|
||||||
|
<#
|
||||||
|
.SYNOPSIS
|
||||||
|
Gets a list of Snipe-it Licenses Seats or specific Seat
|
||||||
|
|
||||||
|
.PARAMETER search
|
||||||
|
A text string to search the Licenses data
|
||||||
|
|
||||||
|
.PARAMETER id
|
||||||
|
A id of specific License
|
||||||
|
|
||||||
|
.PARAMETER seat_id
|
||||||
|
A id of specific seat
|
||||||
|
|
||||||
|
.PARAMETER limit
|
||||||
|
Specify the number of results you wish to return. Defaults to 50. Defines batch size for -all
|
||||||
|
|
||||||
|
.PARAMETER offset
|
||||||
|
Offset to use
|
||||||
|
|
||||||
|
.PARAMETER all
|
||||||
|
A return all results, works with -offset and other parameters
|
||||||
|
|
||||||
|
|
||||||
|
.PARAMETER url
|
||||||
|
URL of Snipeit system, can be set using Set-SnipeItInfo command
|
||||||
|
|
||||||
|
.PARAMETER apiKey
|
||||||
|
Users API Key for Snipeit, can be set using Set-SnipeItInfo command
|
||||||
|
|
||||||
|
.EXAMPLE
|
||||||
|
Get-SnipeItLicenseSeat -id 1
|
||||||
|
|
||||||
|
|
||||||
|
#>
|
||||||
|
|
||||||
|
function Get-SnipeItLicenseSeat() {
|
||||||
|
Param(
|
||||||
|
|
||||||
|
[parameter(mandatory = $true)]
|
||||||
|
[int]$id,
|
||||||
|
|
||||||
|
[int]$seat_id,
|
||||||
|
|
||||||
|
[int]$limit = 50,
|
||||||
|
|
||||||
|
[int]$offset,
|
||||||
|
|
||||||
|
[switch]$all = $false,
|
||||||
|
|
||||||
|
[parameter(mandatory = $true)]
|
||||||
|
[string]$url,
|
||||||
|
|
||||||
|
[parameter(mandatory = $true)]
|
||||||
|
[string]$apiKey
|
||||||
|
)
|
||||||
|
|
||||||
|
Test-SnipeItAlias -invocationName $MyInvocation.InvocationName -commandName $MyInvocation.MyCommand.Name
|
||||||
|
|
||||||
|
$SearchParameter = . Get-ParameterValue $MyInvocation.MyCommand.Parameters
|
||||||
|
|
||||||
|
$apiurl = "$url/api/v1/licenses/$id/seats"
|
||||||
|
|
||||||
|
|
||||||
|
if ($seat_id) {
|
||||||
|
$apiurl= "$url/api/v1/licenses/$id/seats/$seat_id"
|
||||||
|
}
|
||||||
|
|
||||||
|
$Parameters = @{
|
||||||
|
Uri = $apiurl
|
||||||
|
Method = 'Get'
|
||||||
|
Token = $apiKey
|
||||||
|
GetParameters = $SearchParameter
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($all) {
|
||||||
|
$offstart = $(if($offset){$offset} Else {0})
|
||||||
|
$callargs = $SearchParameter
|
||||||
|
$callargs.Remove('all')
|
||||||
|
|
||||||
|
while ($true) {
|
||||||
|
$callargs['offset'] = $offstart
|
||||||
|
$callargs['limit'] = $limit
|
||||||
|
$res=Get-SnipeItLicenseSeat @callargs
|
||||||
|
$res
|
||||||
|
if ($res.count -lt $limit) {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
$offstart = $offstart + $limit
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$result = Invoke-SnipeitMethod @Parameters
|
||||||
|
$result
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
78
SnipeitPS/Public/Set-SnipeItLicenseSeat.ps1
Normal file
78
SnipeitPS/Public/Set-SnipeItLicenseSeat.ps1
Normal file
|
|
@ -0,0 +1,78 @@
|
||||||
|
<#
|
||||||
|
.SYNOPSIS
|
||||||
|
Set license seat or checkout license seat
|
||||||
|
.DESCRIPTION
|
||||||
|
Checkout specific license seat to user, asset or both
|
||||||
|
|
||||||
|
.PARAMETER ID
|
||||||
|
Unique ID For asset to checkout
|
||||||
|
|
||||||
|
.PARAMETER assigned_to
|
||||||
|
Id of target user
|
||||||
|
|
||||||
|
.PARAMETER asset_id
|
||||||
|
Id of target asset
|
||||||
|
|
||||||
|
.PARAMETER note
|
||||||
|
Notes about checkout
|
||||||
|
|
||||||
|
.PARAMETER url
|
||||||
|
URL of Snipeit system, can be set using Set-SnipeItInfo command
|
||||||
|
|
||||||
|
.PARAMETER apiKey
|
||||||
|
User's API Key for Snipeit, can be set using Set-SnipeItInfo command
|
||||||
|
|
||||||
|
.EXAMPLE
|
||||||
|
Set-SnipeItLicenceSeat -ID 1 -seat_id 1 -assigned_id 3 -Verbose
|
||||||
|
Checkout licence to user id 3
|
||||||
|
|
||||||
|
.EXAMPLE
|
||||||
|
Set-SnipeItLicenceSeat -ID 1 -seat_id 1 -asset_id 3 -Verbose
|
||||||
|
Checkout licence to asset id 3
|
||||||
|
|
||||||
|
#>
|
||||||
|
function Set-SnipeItLicenseSeat()
|
||||||
|
{
|
||||||
|
[CmdletBinding(
|
||||||
|
SupportsShouldProcess = $true,
|
||||||
|
ConfirmImpact = "Medium"
|
||||||
|
)]
|
||||||
|
|
||||||
|
Param(
|
||||||
|
[parameter(mandatory = $true)]
|
||||||
|
[int]$id,
|
||||||
|
|
||||||
|
[parameter(mandatory = $true)]
|
||||||
|
[int]$seat_id,
|
||||||
|
|
||||||
|
[int]$assigned_id,
|
||||||
|
|
||||||
|
[int]$asset_id,
|
||||||
|
|
||||||
|
[string]$note,
|
||||||
|
|
||||||
|
[parameter(mandatory = $true)]
|
||||||
|
[string]$url,
|
||||||
|
|
||||||
|
[parameter(mandatory = $true)]
|
||||||
|
[string]$apiKey
|
||||||
|
)
|
||||||
|
|
||||||
|
$Values = . Get-ParameterValue $MyInvocation.MyCommand.Parameters
|
||||||
|
|
||||||
|
$Body = $Values | ConvertTo-Json;
|
||||||
|
|
||||||
|
$Parameters = @{
|
||||||
|
Uri = "$url/api/v1/licenses/$id/seats/$seat_id"
|
||||||
|
Method = 'Patch'
|
||||||
|
Body = $Body
|
||||||
|
Token = $apiKey
|
||||||
|
}
|
||||||
|
|
||||||
|
If ($PSCmdlet.ShouldProcess("ShouldProcess?"))
|
||||||
|
{
|
||||||
|
$result = Invoke-SnipeitMethod @Parameters
|
||||||
|
}
|
||||||
|
|
||||||
|
return $result
|
||||||
|
}
|
||||||
|
|
@ -93,6 +93,8 @@ FunctionsToExport = @(
|
||||||
'New-SnipeItLicense',
|
'New-SnipeItLicense',
|
||||||
'Set-SnipeItLicense',
|
'Set-SnipeItLicense',
|
||||||
'Get-SnipeItLicense',
|
'Get-SnipeItLicense',
|
||||||
|
'Get-SnipeItLicenseSeat',
|
||||||
|
'Set-SnipeItLicenseSeat',
|
||||||
'New-SnipeItLocation',
|
'New-SnipeItLocation',
|
||||||
'New-SnipeItManufacturer',
|
'New-SnipeItManufacturer',
|
||||||
'New-SnipeItModel',
|
'New-SnipeItModel',
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue