mirror of
https://github.com/snazy2000/SnipeitPS.git
synced 2025-12-13 01:42:29 +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',
|
||||
'Set-SnipeItLicense',
|
||||
'Get-SnipeItLicense',
|
||||
'Get-SnipeItLicenseSeat',
|
||||
'Set-SnipeItLicenseSeat',
|
||||
'New-SnipeItLocation',
|
||||
'New-SnipeItManufacturer',
|
||||
'New-SnipeItModel',
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue