NetboxPS/Functions/Tenancy/Contacts/Get-NetboxContact.ps1

120 lines
3 KiB
PowerShell
Raw Normal View History

2023-02-24 15:14:04 -05:00

2023-02-15 15:39:36 -05:00
function Get-NetboxContact {
<#
.SYNOPSIS
Get a contact from Netbox
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.DESCRIPTION
Obtain a contact or contacts from Netbox by ID or query
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.PARAMETER Name
The specific name of the Contact. Must match exactly as is defined in Netbox
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.PARAMETER Id
The database ID of the Contact
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.PARAMETER Query
A standard search query that will match one or more Contacts.
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.PARAMETER Email
Email address of the contact
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.PARAMETER Title
Title of the contact
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.PARAMETER Phone
Telephone number of the contact
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.PARAMETER Address
Physical address of the contact
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.PARAMETER Group
The specific group as defined in Netbox.
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.PARAMETER GroupID
The database ID of the group in Netbox
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.PARAMETER Limit
Limit the number of results to this number
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.PARAMETER Offset
Start the search at this index in results
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.PARAMETER Raw
Return the unparsed data from the HTTP request
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.EXAMPLE
PS C:\> Get-NetboxContact
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
.NOTES
Additional information about the function.
#>
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
[CmdletBinding(DefaultParameterSetName = 'Query')]
param
(
[Parameter(ParameterSetName = 'Query',
Position = 0)]
[string]$Name,
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
[Parameter(ParameterSetName = 'ByID')]
[uint32[]]$Id,
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
[Parameter(ParameterSetName = 'Query')]
[string]$Query,
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
[Parameter(ParameterSetName = 'Query')]
[string]$Email,
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
[Parameter(ParameterSetName = 'Query')]
[string]$Title,
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
[Parameter(ParameterSetName = 'Query')]
[string]$Phone,
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
[Parameter(ParameterSetName = 'Query')]
[string]$Address,
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
[Parameter(ParameterSetName = 'Query')]
[string]$Group,
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
[Parameter(ParameterSetName = 'Query')]
[uint64]$GroupID,
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
[Parameter(ParameterSetName = 'Query')]
[uint16]$Limit,
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
[Parameter(ParameterSetName = 'Query')]
[uint16]$Offset,
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
[switch]$Raw
)
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
switch ($PSCmdlet.ParameterSetName) {
'ById' {
foreach ($Contact_ID in $Id) {
$Segments = [System.Collections.ArrayList]::new(@('tenancy', 'contacts', $Contact_ID))
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
$URIComponents = BuildURIComponents -URISegments $Segments -ParametersDictionary $PSBoundParameters -SkipParameterByName 'Id'
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
$uri = BuildNewURI -Segments $URIComponents.Segments -Parameters $URIComponents.Parameters
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
InvokeNetboxRequest -URI $uri -Raw:$Raw
}
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
break
}
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
default {
$Segments = [System.Collections.ArrayList]::new(@('tenancy', 'contacts'))
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
$URIComponents = BuildURIComponents -URISegments $Segments -ParametersDictionary $PSBoundParameters
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
$uri = BuildNewURI -Segments $URIComponents.Segments -Parameters $URIComponents.Parameters
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
InvokeNetboxRequest -URI $uri -Raw:$Raw
2023-02-24 15:14:04 -05:00
2023-02-15 15:39:36 -05:00
break
}
}
}