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')]
|
2023-07-28 15:38:16 -04:00
|
|
|
|
[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
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|