-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathReplicaSMBServer.ps1
75 lines (59 loc) · 2.73 KB
/
ReplicaSMBServer.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
73
74
75
#
# W202202
#
$domain = "smbdemo.dev"
$rg = "bccDevFileShareRG"
$syncservicename = "bccDevFileShareSync"
$sharename = "share1"
$sshuser = "vpndemo"
$sshserver = "ubuntuagent1"
$pfx_cert_file = "w202202.bcc.bz.pfx"
$unix_path = ":~\"
$win_path = ".\"
$sharefullaccessgroup = "smbdemo\Share1Admins"
$sharechangeaccessgroup = "smbdemo\Share1Users"
"Check if domain joined"
if ( $env:USERDNSDomain -ne $domain ){
Add-Computer -DomainName $domain -Restart
} else {
"Setup data disk as drive F"
$disk = Get-Disk | where-object PartitionStyle -eq "RAW"
$disk | Initialize-Disk -PartitionStyle GPT
$partition = $disk | New-Partition -UseMaximumSize -DriveLetter F
$partition | Format-Volume -Confirm:$false -Force
"Create directory for share"
new-item -path F: -name $sharename -itemtype "directory"
"Share directory"
New-SmbShare -Name $sharename -Path F:\$sharename -FolderEnumerationMode AccessBased -FullAccess $sharefullaccessgroup -ChangeAccess $sharechangeaccessgroup
"Download StorageSyncAgent.msi"
Invoke-WebRequest -Uri https://aka.ms/afs/agent/Server2022 -OutFile "StorageSyncAgent.msi"
"Install StorageSyncAgent.msi"
Start-Process -FilePath "StorageSyncAgent.msi" -ArgumentList "/quiet" -Wait
"Install-PackageProvider NuGet"
Install-PackageProvider -Name NuGet -Force -Confirm:$false
"Trust PSGallery"
Set-PSRepository -Name 'PSGallery' -InstallationPolicy Trusted
"Install Az.StorageSync module"
Install-Module -Name Az.StorageSync -Confirm:$false
"Login to Azure"
Connect-AzAccount -DeviceCode
"Register Server in StorageSync Service"
$registeredServer = Register-AzStorageSyncServer -ResourceGroupName $rg -StorageSyncServiceName $syncservicename
"Get the StorageSyncGroup created in SourceSMBServer"
$syncGroup = Get-AzStorageSyncGroup -ResourceGroupName $rg -StorageSyncServiceName $syncservicename
"Create StorageSyncServerEndpoint"
$serverendpoint = New-AzStorageSyncServerEndpoint `
-Name $registeredServer.FriendlyName `
-SyncGroup $syncGroup `
-ServerResourceId $registeredServer.ResourceId `
-ServerLocalPath "F:\$sharename" `
-CloudTiering -VolumeFreeSpacePercent 20
$serverendpoint.ProvisioningState
"Get SSL Certificate as pfx file from SSH server"
$scpcommand = "scp -oStrictHostKeyChecking=no $sshuser@$sshserver$unix_path$pfx_cert_file $win_path"
Invoke-Expression $scpcommand
"Get certificate password"
$mypwd = Get-Credential -UserName 'Enter Cert password' -Message 'Enter Cert password'
"Install certificate"
Import-PfxCertificate -FilePath $win_path$pfx_cert_file -CertStoreLocation Cert:\LocalMachine\My -Password $mypwd.Password
}