Fixed subcontrollers
This commit is contained in:
25
classlib/class/nameserver.cs
Normal file
25
classlib/class/nameserver.cs
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
namespace PS.IPAM;
|
||||||
|
using System;
|
||||||
|
|
||||||
|
[Serializable]
|
||||||
|
public class Nameserver {
|
||||||
|
public int Id { get; }
|
||||||
|
public string Name { get; }
|
||||||
|
public string[] NameSevers { get; }
|
||||||
|
public string Permissions { get; }
|
||||||
|
public DateTime? EditDate { get; }
|
||||||
|
|
||||||
|
public Nameserver(
|
||||||
|
int id,
|
||||||
|
string name,
|
||||||
|
string nameServers,
|
||||||
|
string permissions,
|
||||||
|
DateTime? editDate
|
||||||
|
) {
|
||||||
|
this.Id = id;
|
||||||
|
this.Name = name;
|
||||||
|
this.NameSevers = nameServers.Split(';');
|
||||||
|
this.Permissions = permissions;
|
||||||
|
this.EditDate = editDate;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -26,11 +26,9 @@ function Invoke-Request {
|
|||||||
if ($_tokenStatus -eq "NoToken") { throw "No session available!" }
|
if ($_tokenStatus -eq "NoToken") { throw "No session available!" }
|
||||||
if ($_tokenStatus -eq "Expired") { Update-Session }
|
if ($_tokenStatus -eq "Expired") { Update-Session }
|
||||||
|
|
||||||
$Controller = $Controller
|
|
||||||
|
|
||||||
$_uri = "$($script:psipamSession.URL)/api/$($script:psipamSession.AppID)/$Controller"
|
$_uri = "$($script:psipamSession.URL)/api/$($script:psipamSession.AppID)/$Controller"
|
||||||
if ($SubController) { $_uri += "/$SubController" }
|
if ($SubController -ne $null) { $SubController;$_uri += "/$SubController" }
|
||||||
if ($Identifiers) { $_uri += "/$($Identifiers -join '/')/" }
|
if ($Identifiers -ne $null) { $_uri += "/$($Identifiers -join '/')/" }
|
||||||
|
|
||||||
$_headers = @{
|
$_headers = @{
|
||||||
"Accept" = "application/json"
|
"Accept" = "application/json"
|
||||||
@@ -60,9 +58,18 @@ function Invoke-Request {
|
|||||||
|
|
||||||
Write-Verbose -Message "Invoking web request to $($_uri), with method $($_arguments.Method), headers: $($_arguments.Headers)"
|
Write-Verbose -Message "Invoking web request to $($_uri), with method $($_arguments.Method), headers: $($_arguments.Headers)"
|
||||||
|
|
||||||
|
try {
|
||||||
$_response = Invoke-RestMethod @_arguments
|
$_response = Invoke-RestMethod @_arguments
|
||||||
|
}
|
||||||
|
catch [System.Net.WebException] {
|
||||||
|
switch ($_.Exception.Message) {
|
||||||
|
"The remote server returned an error: (404) Not Found." { Write-Verbose -Message "Not found." }
|
||||||
|
"The remote server returned an error: (400) Bad Request." { Write-Warning -Message "Bad Request." }
|
||||||
|
Default { Write-Verbose -Message "Error occured while requesting api" }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!$_response) { return $null }
|
||||||
|
|
||||||
if ($_response.code -match "20\d") {
|
|
||||||
if ($Type -is [PS.IPAM.types]) {
|
if ($Type -is [PS.IPAM.types]) {
|
||||||
switch ($Type) {
|
switch ($Type) {
|
||||||
"address" {
|
"address" {
|
||||||
@@ -70,32 +77,29 @@ function Invoke-Request {
|
|||||||
|
|
||||||
$_response.data | ForEach-Object {
|
$_response.data | ForEach-Object {
|
||||||
New-Object -TypeName ([PS.IPAM.Address]) -ArgumentList (@(($_ | Select-Object $_paramList).psobject.properties.value) + ($_ | Select-Object -Property custom_* -ExcludeProperty 'custom_\*'))
|
New-Object -TypeName ([PS.IPAM.Address]) -ArgumentList (@(($_ | Select-Object $_paramList).psobject.properties.value) + ($_ | Select-Object -Property custom_* -ExcludeProperty 'custom_\*'))
|
||||||
}; break
|
}
|
||||||
}
|
}
|
||||||
"vlan" {
|
"vlan" {
|
||||||
$_paramList = @("vlanId","domainId","name","number","description","editDate","customer_id","custom_fields")
|
$_paramList = @("vlanId","domainId","name","number","description","editDate","customer_id","custom_fields")
|
||||||
|
|
||||||
$_response.data | ForEach-Object {
|
$_response.data | ForEach-Object {
|
||||||
New-Object -TypeName ([PS.IPAM.Vlan]) -ArgumentList (@(($_ | Select-Object $_paramList).psobject.properties.value) + ($_ | Select-Object -Property custom_* -ExcludeProperty 'custom_\*'))
|
New-Object -TypeName ([PS.IPAM.Vlan]) -ArgumentList (@(($_ | Select-Object $_paramList).psobject.properties.value) + ($_ | Select-Object -Property custom_* -ExcludeProperty 'custom_\*'))
|
||||||
}; break
|
}
|
||||||
}
|
}
|
||||||
"subnetwork" {
|
"subnetwork" {
|
||||||
$_response.data | ForEach-Object {
|
$_response.data | ForEach-Object {
|
||||||
New-Object -TypeName ([PS.IPAM.Subnetwork]) -ArgumentList (@($_.psobject.properties.value[0..30]) + ($_ | Select-Object -Property custom_* -ExcludeProperty 'custom_\*'))
|
New-Object -TypeName ([PS.IPAM.Subnetwork]) -ArgumentList (@($_.psobject.properties.value[0..30]) + ($_ | Select-Object -Property custom_* -ExcludeProperty 'custom_\*'))
|
||||||
}; break
|
}
|
||||||
}
|
}
|
||||||
"vrf" {
|
"vrf" {
|
||||||
$_response.data | ForEach-Object {
|
$_response.data | ForEach-Object {
|
||||||
New-Object -TypeName ([PS.IPAM.Vrf]) -ArgumentList (@($_.psobject.properties.value[0..5]) + ($_ | Select-Object -Property custom_* -ExcludeProperty 'custom_\*'))
|
New-Object -TypeName ([PS.IPAM.Vrf]) -ArgumentList (@($_.psobject.properties.value[0..5]) + ($_ | Select-Object -Property custom_* -ExcludeProperty 'custom_\*'))
|
||||||
}; break
|
}
|
||||||
}
|
}
|
||||||
Default { $_response.data | ForEach-Object { New-Object -TypeName ("PS.IPAM.$Type") -ArgumentList $_.psobject.properties.value } }
|
Default { $_response.data | ForEach-Object { New-Object -TypeName ("PS.IPAM.$Type") -ArgumentList $_.psobject.properties.value } }
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
return $_response.data
|
$_response.data
|
||||||
}
|
|
||||||
} else {
|
|
||||||
throw ("Error - $($_response.code)")
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -39,6 +39,16 @@ function Get-Address {
|
|||||||
[ValidateNotNullOrEmpty()]
|
[ValidateNotNullOrEmpty()]
|
||||||
[string]
|
[string]
|
||||||
$HostName,
|
$HostName,
|
||||||
|
[parameter(
|
||||||
|
Mandatory=$true,
|
||||||
|
ValueFromPipeline=$true,
|
||||||
|
ValueFromPipelineByPropertyName=$true,
|
||||||
|
Position=0,
|
||||||
|
ParameterSetName="ByHostBase"
|
||||||
|
)]
|
||||||
|
[ValidateNotNullOrEmpty()]
|
||||||
|
[string]
|
||||||
|
$HostBase,
|
||||||
[parameter(
|
[parameter(
|
||||||
Mandatory=$true,
|
Mandatory=$true,
|
||||||
ValueFromPipeline=$true,
|
ValueFromPipeline=$true,
|
||||||
@@ -81,6 +91,7 @@ function Get-Address {
|
|||||||
"ByID" { $_identifiers = @($id); break }
|
"ByID" { $_identifiers = @($id); break }
|
||||||
"ByIP" { $_identifiers = ("search",$IP); break }
|
"ByIP" { $_identifiers = ("search",$IP); break }
|
||||||
"ByHostName" { $_identifiers = ("search_hostname",$HostName); break }
|
"ByHostName" { $_identifiers = ("search_hostname",$HostName); break }
|
||||||
|
"ByHostBase" { $_identifiers = ("search_hostbase",$HostBase); break }
|
||||||
"ByTag" { $_identifiers = ("tags",$TagId,[PS.IPAM.controllers]::addresses); break }
|
"ByTag" { $_identifiers = ("tags",$TagId,[PS.IPAM.controllers]::addresses); break }
|
||||||
"BySubnetId" {
|
"BySubnetId" {
|
||||||
if ($IP) {
|
if ($IP) {
|
||||||
|
|||||||
@@ -1,16 +1,34 @@
|
|||||||
function Get-FirstFreeIP {
|
function Get-FirstFreeIP {
|
||||||
[CmdletBinding(DefaultParameterSetName="ByID")]
|
[CmdletBinding(DefaultParameterSetName="ByID")]
|
||||||
param (
|
param (
|
||||||
[parameter(Mandatory=$true,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0,ParameterSetName="ByCIDR")]
|
[parameter(
|
||||||
|
Mandatory=$true,
|
||||||
|
ValueFromPipeline=$true,
|
||||||
|
ValueFromPipelineByPropertyName=$true,
|
||||||
|
Position=0,
|
||||||
|
ParameterSetName="ByCIDR"
|
||||||
|
)]
|
||||||
[ValidateScript({[ipaddress] $_.Split("/")[0] -and $_.Split("/")[1] -match "\d{1,2}"})]
|
[ValidateScript({[ipaddress] $_.Split("/")[0] -and $_.Split("/")[1] -match "\d{1,2}"})]
|
||||||
[ValidateNotNullOrEmpty()]
|
[ValidateNotNullOrEmpty()]
|
||||||
[string]
|
[string]
|
||||||
$CIDR,
|
$CIDR,
|
||||||
[parameter(Mandatory=$true,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0,ParameterSetName="ByID")]
|
[parameter(
|
||||||
|
Mandatory=$true,
|
||||||
|
ValueFromPipeline=$true,
|
||||||
|
ValueFromPipelineByPropertyName=$true,
|
||||||
|
Position=0,
|
||||||
|
ParameterSetName="ByID"
|
||||||
|
)]
|
||||||
[ValidateNotNullOrEmpty()]
|
[ValidateNotNullOrEmpty()]
|
||||||
[int]
|
[int]
|
||||||
$Id,
|
$Id,
|
||||||
[parameter(Mandatory=$false,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0,ParameterSetName="BySubnetObject")]
|
[parameter(
|
||||||
|
Mandatory=$false,
|
||||||
|
ValueFromPipeline=$true,
|
||||||
|
ValueFromPipelineByPropertyName=$true,
|
||||||
|
Position=0,
|
||||||
|
ParameterSetName="BySubnetObject"
|
||||||
|
)]
|
||||||
[ValidateNotNullOrEmpty()]
|
[ValidateNotNullOrEmpty()]
|
||||||
[PS.IPAM.Subnetwork]
|
[PS.IPAM.Subnetwork]
|
||||||
$SubnetObject
|
$SubnetObject
|
||||||
|
|||||||
@@ -2,7 +2,13 @@ function Get-L2Domain {
|
|||||||
[CmdletBinding(DefaultParameterSetName="ByID")]
|
[CmdletBinding(DefaultParameterSetName="ByID")]
|
||||||
[OutputType([PS.IPAM.Domain])]
|
[OutputType([PS.IPAM.Domain])]
|
||||||
param (
|
param (
|
||||||
[parameter(Mandatory=$false,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0,ParameterSetName="ByID")]
|
[parameter(
|
||||||
|
Mandatory=$false,
|
||||||
|
ValueFromPipeline=$true,
|
||||||
|
ValueFromPipelineByPropertyName=$true,
|
||||||
|
Position=0,
|
||||||
|
ParameterSetName="ByID"
|
||||||
|
)]
|
||||||
[ValidateNotNullOrEmpty()]
|
[ValidateNotNullOrEmpty()]
|
||||||
[int]
|
[int]
|
||||||
$Id
|
$Id
|
||||||
|
|||||||
@@ -1,7 +1,13 @@
|
|||||||
function Get-Nameserver {
|
function Get-Nameserver {
|
||||||
[CmdletBinding(DefaultParameterSetName="ByID")]
|
[CmdletBinding(DefaultParameterSetName="ByID")]
|
||||||
param (
|
param (
|
||||||
[parameter(Mandatory=$false,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0,ParameterSetName="ByID")]
|
[parameter(
|
||||||
|
Mandatory=$false,
|
||||||
|
ValueFromPipeline=$true,
|
||||||
|
ValueFromPipelineByPropertyName=$true,
|
||||||
|
Position=0,
|
||||||
|
ParameterSetName="ByID"
|
||||||
|
)]
|
||||||
[ValidateNotNullOrEmpty()]
|
[ValidateNotNullOrEmpty()]
|
||||||
[int]
|
[int]
|
||||||
$Id
|
$Id
|
||||||
|
|||||||
@@ -2,11 +2,21 @@ function Get-Section {
|
|||||||
[CmdletBinding(DefaultParameterSetName="NoParams")]
|
[CmdletBinding(DefaultParameterSetName="NoParams")]
|
||||||
[OutputType([PS.IPAM.Section])]
|
[OutputType([PS.IPAM.Section])]
|
||||||
param (
|
param (
|
||||||
[parameter(Mandatory=$false,ValueFromPipeline=$true,Position=0,ParameterSetName="ByID")]
|
[parameter(
|
||||||
|
Mandatory=$false,
|
||||||
|
ValueFromPipeline=$true,
|
||||||
|
Position=0,
|
||||||
|
ParameterSetName="ByID"
|
||||||
|
)]
|
||||||
[ValidateNotNullOrEmpty()]
|
[ValidateNotNullOrEmpty()]
|
||||||
[int]
|
[int]
|
||||||
$Id,
|
$Id,
|
||||||
[parameter(Mandatory=$true,ValueFromPipeline=$true,Position=0,ParameterSetName="ByName")]
|
[parameter(
|
||||||
|
Mandatory=$true,
|
||||||
|
ValueFromPipeline=$true,
|
||||||
|
Position=0,
|
||||||
|
ParameterSetName="ByName"
|
||||||
|
)]
|
||||||
[ValidateNotNullOrEmpty()]
|
[ValidateNotNullOrEmpty()]
|
||||||
[string]
|
[string]
|
||||||
$Name
|
$Name
|
||||||
|
|||||||
Reference in New Issue
Block a user