Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions Functions/Setup/Connect-NetboxAPI.ps1
Original file line number Diff line number Diff line change
Expand Up @@ -138,17 +138,17 @@

Write-Verbose "Checking Netbox version compatibility"
$script:NetboxConfig.NetboxVersion = Get-NetboxVersion
if ([version]$script:NetboxConfig.NetboxVersion.'netbox-version' -lt 2.8) {
if ([version]$script:NetboxConfig.NetboxVersion.'netbox-version' -lt 4.0.1) {
$Script:NetboxConfig.Connected = $false
throw "Netbox version is incompatible with this PS module. Requires >=2.8.*, found version $($script:NetboxConfig.NetboxVersion.'netbox-version')"
throw "Netbox version is incompatible with this PS module. Requires >=4.0, found version $($script:NetboxConfig.NetboxVersion.'netbox-version')"
} else {
Write-Verbose "Found compatible version [$($script:NetboxConfig.NetboxVersion.'netbox-version')]!"
}

$script:NetboxConfig.Connected = $true
Write-Verbose "Successfully connected!"

$script:NetboxConfig.ContentTypes = Get-NetboxContentType -Limit 500
$script:NetboxConfig.ObjectTypes = Get-NetboxObjectType -Limit 500

Write-Verbose "Connection process completed"
}
}
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
function Get-NetboxContentType {
function Get-NetboxObjectType {
<#
.SYNOPSIS
Get a content type definition from Netbox
Get a object type definition from Netbox

.DESCRIPTION
A detailed description of the Get-NetboxContentType function.
A detailed description of the Get-NetboxObjectType function.

.PARAMETER Model
A description of the Model parameter.
Expand All @@ -28,7 +28,7 @@
Return the unparsed data from the HTTP request

.EXAMPLE
PS C:\> Get-NetboxContentType
PS C:\> Get-NetboxObjectType

.NOTES
Additional information about the function.
Expand Down Expand Up @@ -61,8 +61,8 @@

switch ($PSCmdlet.ParameterSetName) {
'ById' {
foreach ($ContentType_ID in $Id) {
$Segments = [System.Collections.ArrayList]::new(@('extras', 'content-types', $ContentType_ID))
foreach ($ObjectType_ID in $Id) {
$Segments = [System.Collections.ArrayList]::new(@('extras', 'object-types', $ObjectType_ID))

$URIComponents = BuildURIComponents -URISegments $Segments -ParametersDictionary $PSBoundParameters -SkipParameterByName 'Id'

Expand All @@ -75,7 +75,7 @@
}

default {
$Segments = [System.Collections.ArrayList]::new(@('extras', 'content-types'))
$Segments = [System.Collections.ArrayList]::new(@('extras', 'object-types'))

$URIComponents = BuildURIComponents -URISegments $Segments -ParametersDictionary $PSBoundParameters

Expand Down
2 changes: 1 addition & 1 deletion Functions/Setup/Support/SetupNetboxConfigVariable.ps1
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
'Choices' = @{
}
'APIDefinition' = $null
'ContentTypes' = $null
'ObjectTypes' = $null
}
}

Expand Down
26 changes: 13 additions & 13 deletions Functions/Tenancy/ContactRoles/Set-NetboxContactRole.ps1
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@


function Set-NetboxContactRole {
<#
.SYNOPSIS
Expand Down Expand Up @@ -28,7 +28,7 @@ function Set-NetboxContactRole {
.NOTES
Additional information about the function.
#>

[CmdletBinding(ConfirmImpact = 'Low',
SupportsShouldProcess = $true)]
[OutputType([pscustomobject])]
Expand All @@ -37,37 +37,37 @@ function Set-NetboxContactRole {
[Parameter(Mandatory = $true,
ValueFromPipelineByPropertyName = $true)]
[uint64[]]$Id,

[Parameter(ValueFromPipelineByPropertyName = $true)]
[ValidateLength(1, 100)]
[string]$Name,

[ValidateLength(1, 100)]
[ValidatePattern('^[-a-zA-Z0-9_]+$')]
[string]$Slug,

[ValidateLength(0, 200)]
[string]$Description,

[hashtable]$Custom_Fields,

[switch]$Raw
)

begin {
$Method = 'PATCH'
}

process {
foreach ($ContactRoleId in $Id) {
$Segments = [System.Collections.ArrayList]::new(@('tenancy', 'contacts', $ContactRoleId))

$URIComponents = BuildURIComponents -URISegments $Segments.Clone() -ParametersDictionary $PSBoundParameters -SkipParameterByName 'Id', 'Force'

$URI = BuildNewURI -Segments $URIComponents.Segments

$CurrentContactRole = Get-NetboxContactRole -Id $ContactRoleId -ErrorAction Stop

if ($Force -or $PSCmdlet.ShouldProcess($CurrentContactRole.Name, 'Update contact role')) {
InvokeNetboxRequest -URI $URI -Method $Method -Body $URIComponents.Parameters -Raw:$Raw
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@

function Add-NetboxVirtualMachineDisk {
[CmdletBinding()]
param
(
[Parameter(Mandatory = $true)]
[string]$Name,

[Parameter(Mandatory = $true)]
[uint64]$Virtual_Machine,

[string]$MAC_Address,

[uint64]$Size,

[string]$Description,

[hashtable]$Custom_Fields,

[switch]$Raw
)

$Segments = [System.Collections.ArrayList]::new(@('virtualization', 'virtual-disks'))

$PSBoundParameters.Enabled = $Enabled

$URIComponents = BuildURIComponents -URISegments $Segments -ParametersDictionary $PSBoundParameters

$uri = BuildNewURI -Segments $URIComponents.Segments

InvokeNetboxRequest -URI $uri -Method POST -Body $URIComponents.Parameters
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@

function Get-NetboxVirtualMachineDisk {
<#
.SYNOPSIS
Gets VM disks

.DESCRIPTION
Obtains the disk objects for one or more VMs

.PARAMETER Limit
Number of results to return per page.

.PARAMETER Offset
The initial index from which to return the results.

.PARAMETER Id
Database ID of the interface

.PARAMETER Name
Name of the disk

.PARAMETER Size
Size of the disk in GB

.PARAMETER Virtual_Machine_Id
ID of the virtual machine to which the interface(s) are assigned.

.PARAMETER Virtual_Machine
Name of the virtual machine to get interfaces

.PARAMETER Raw
A description of the Raw parameter.

.EXAMPLE
PS C:\> Get-NetboxVirtualMachineDisk

.NOTES
Additional information about the function.
#>

[CmdletBinding()]
param
(
[Parameter(ValueFromPipeline = $true)]
[uint64]$Id,

[string]$Name,

[string]$Query,

[uint64]$Size,

[uint64]$Virtual_Machine_Id,

[string]$Virtual_Machine,

[uint16]$Limit,

[uint16]$Offset,

[switch]$Raw
)

process {
$Segments = [System.Collections.ArrayList]::new(@('virtualization', 'virtual-disks'))

$URIComponents = BuildURIComponents -URISegments $Segments -ParametersDictionary $PSBoundParameters

$uri = BuildNewURI -Segments $URIComponents.Segments -Parameters $URIComponents.Parameters

InvokeNetboxRequest -URI $uri -Raw:$Raw
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@

function Remove-NetboxVirtualMachineDisk {
<#
.SYNOPSIS
Delete a virtual machine disk

.DESCRIPTION
Deletes a virtual machine disk from Netbox by ID

.PARAMETER Id
Database ID of the virtual machine disk

.PARAMETER Force
Force deletion without any prompts

.EXAMPLE
PS C:\> Remove-NetboxVirtualMachineDisk -Id $value1

.NOTES
Additional information about the function.
#>

[CmdletBinding(ConfirmImpact = 'High',
SupportsShouldProcess = $true)]
param
(
[Parameter(Mandatory = $true,
ValueFromPipelineByPropertyName = $true)]
[uint64[]]$Id,

[switch]$Force
)

begin {

}

process {
foreach ($DiskId in $Id) {
$CurrentDisk = Get-NetboxVirtualMachineDisk -Id $DiskId -ErrorAction Stop

if ($Force -or $pscmdlet.ShouldProcess("$($CurrentDisk.Name)/$($CurrentDisk.Id)", "Remove")) {
$Segments = [System.Collections.ArrayList]::new(@('virtualization', 'virtual-disks', $CurrentDisk.Id))

$URI = BuildNewURI -Segments $Segments

InvokeNetboxRequest -URI $URI -Method DELETE
}
}
}

end {

}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@

function Set-NetboxVirtualMachineDisk {
[CmdletBinding(ConfirmImpact = 'Medium',
SupportsShouldProcess = $true)]
[OutputType([pscustomobject])]
param
(
[Parameter(Mandatory = $true,
ValueFromPipelineByPropertyName = $true)]
[uint64[]]$Id,

[string]$Name,

[uint64]$Size,

[string]$Description,

[uint64]$Virtual_Machine,

[hashtable]$Custom_Fields,

[switch]$Force
)

begin {

}

process {
foreach ($VMI_ID in $Id) {
Write-Verbose "Obtaining VM virtual disk..."
$CurrentVMI = Get-NetboxVirtualMachinedisk -Id $VMI_ID -ErrorAction Stop
Write-Verbose "Finished obtaining VM disk"

$Segments = [System.Collections.ArrayList]::new(@('virtualization', 'virtual-disks', $CurrentVMI.Id))

if ($Force -or $pscmdlet.ShouldProcess("Disk $($CurrentVMI.Id) on VM $($CurrentVMI.Virtual_Machine.Name)", "Set")) {
$URIComponents = BuildURIComponents -URISegments $Segments -ParametersDictionary $PSBoundParameters -SkipParameterByName 'Id', 'Force'

$URI = BuildNewURI -Segments $URIComponents.Segments

InvokeNetboxRequest -URI $URI -Body $URIComponents.Parameters -Method PATCH
}
}
}

end {

}
}
Loading