Security/New-NCHNAVSuperUser.ps1

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
function New-NCHNAVSuperUser {
    <#
    .SYNOPSIS
    Create a super user on a NAVContainer on a Remote Docker Host
     
    .DESCRIPTION
    Long description
     
    .PARAMETER ContainerName
    The Container
     
    .PARAMETER Username
    The Username
     
    .PARAMETER Password
    The password (will be converted to secure string)
     
    .PARAMETER CreateWebServicesKey
    Switch to create a webserviceskey on the way..
     
    .EXAMPLE
    Create a new user "waldo2"
 
    New-NCHNAVSuperUser `
        -ContainerName $Containername `
        -Username 'waldo2' `
        -Password (ConvertTo-SecureString 'waldo1234' -AsPlainText -Force) `
        -CreateWebServicesKey
    #>

    param(
        [Parameter(Mandatory = $true)]
        [String] $ContainerName,
        [Parameter(Mandatory = $true)]
        [String] $Username,
        [Parameter(Mandatory = $true)]
        [SecureString] $Password,
        [Parameter(Mandatory = $false)]
        [switch] $CreateWebServicesKey        
    )

    Write-Host -ForegroundColor Green "$($MyInvocation.MyCommand.Name) on $env:COMPUTERNAME"

    # $Session = Get-NavContainerSession -containerName $ContainerName
    # Invoke-Command -Session $Session -ScriptBlock {
    Invoke-ScriptInNavContainer -ContainerName $ContainerName -scriptblock {

        param(
            $CreateWebServicesKey, $Username, [SecureString] $Password
        )
        
        $SC = Get-NAVServerInstance

        $SC | 
            New-NAVServerUser `
                -UserName $username  `
                -Password $Password `
                -CreateWebServicesKey:$CreateWebServicesKey 
            
        $SC | 
            New-NAVServerUserPermissionSet `
                -Scope System `
                -PermissionSetId SUPER `
                -UserName $username 
        
        Write-Host "UID: $username successfully created!"
        
        if ($CreateWebServicesKey) {
            write-Host " WS-Key: $(($SC | Get-NAVServerUser | where username -like $username).WebServicesKey)"
        }
    } -ArgumentList $CreateWebServicesKey, $Username, $Password
    
}