-
Notifications
You must be signed in to change notification settings - Fork 78
/
Copy pathdeploy_tron.ps1
554 lines (440 loc) · 25.3 KB
/
deploy_tron.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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
<#
Purpose: Deploys Tron
Requirements: 1. Expects master copy directory to look like this:
\resources
\functions
- initialize_environment.bat
changelog-vX.Y.X-updated-yyyy-mm-dd.txt
Instructions -- YES ACTUALLY READ THEM.txt
tron.bat
2. Expects initialize_environment.bat to have accurate "set TRON_DATE=yyyy-mm-dd" and "set TRON_VERSION=x.y.z" strings because these are parsed and used to name everything correctly
3. Expects seed server directory structure to look like this:
\resiliosync\tron
\tron
- changelog-vX.Y.Z-updated-YYYY-MM-DD.txt
- Instructions -- YES ACTUALLY READ THEM.txt
- Tron.bat
\integrity_verification
- checksums.txt
- checksums.txt.asc
- vocatus-public-key.asc
\syncthing\tron
\tron
- changelog-vX.Y.Z-updated-YYYY-MM-DD.txt
- Instructions -- YES ACTUALLY READ THEM.txt
- Tron.bat
\integrity_verification
- checksums.txt
- checksums.txt.asc
- vocatus-public-key.asc
Author: reddit.com/user/vocatus ( [email protected] ) // PGP key: 0x07d1490f82a211a2
Version: 1.5.0 + Add deletion of any existing UPLOAD binary in $env:temp to prevent accidentally uploading an old version
1.4.9 - Remove --verbose from all GPG commands
1.4.8 + Add -resume command to WinSCP FTP upload script for the new binary exe only
1.4.7 + Add -speed=xxx (KB) command to WinSCP FTP upload script because Cox is stupid and auto-kills any FTP upload that goes above a certain rate
1.4.6 / Rename $SeedFolderBTS to $SeedFolderRS to reflect name change from BT Sync to Resilio Sync
/ Rename all instances of btsync directory to resiliosync
1.4.5 * Change renaming of .exe pack during FTP upload to UPLOADING_$NewBinary instead of $NewBinary.UPLOADING to be more readily visible in the browser
1.4.4 * Update version parsing code to handle new v10+ versions of Tron
1.4.3 - Remove all DEV shares since they're not really used any more
1.4.2 + Add creation of torrent seed directory
1.4.1 + Add job near start of script to wipe any temp files left in the \resources directory (tron_stage.txt, etc), usually leftover from testing
1.4.0 + Add automatic creation of .torrent file for the release. We save it locally and upload to the autoloader folder on the seed server
1.3.5 * Cleanup sanity check section and loopify the entire thing. Thanks to jrace (AQ)
1.3.4 + Add check for existence of hashdeep prior to running
1.3.3 + Add dev shares to list of Syncthing and BT Sync shares to wipe and upload to
1.3.2 ! Re-order FTP upload commands to remove .UPLOADING from the new binary name PRIOR to uploading new sha256sums.txt
1.3.1 / Move "Are you sure?" dialog to after sanity checks; this way when we see the dialog we know all sanity checks passed
+ Add note at beginning of script telling us which version we're replacing and with what version it's being replaced
* Minor formatting and log cleanup
1.3.0 ! Fix bug where we appended .UPLOADING to the new binary pack too soon
+ Add automatic PGP signature verification of new Tron binary pack
1.2.9 + Add additional checks to look for Tron's stage-specific sub-scripts (Tron modularization project)
1.2.8 * Add automatic PGP signature verification of Tron's internal checksums.txt
1.2.7 * Add ability to handle two seed directories (one for BT Sync and one for Syncthing)
* Add reporting of the date of the version we're replacing
1.2.6 / Disable all use of PortablePGP since we're reverting to using gpg4win
1.2.5 + Add auto-killing of PortablePGP window after checksums.txt signature file appears
1.2.4 ! Fix binary pack hash calculation by removing ".\" prefix on new binary path, which was breaking the update checker in Tron.bat
1.2.3 / Suppress 7-Zip output (redirect to log file)
1.2.2 + Add automatic launching of PortablePGP.exe to signing portion, along with associated $PortablePGP variable
1.2.1 / Update to account for changed Tron sub-folder and new integrity_verification directory
+ Add $OldVersion variable and associated code to display the version we replaced
1.2.0 + Replace built-in Windows FTP client with WinSCP and add associated $WinSCP variable and checks
1.1.0 * Add calculation of SHA256 sum of the binary pack and upload of respective sha256sums.txt to prepare for moving the Tron update checker away from using MD5 sums
1.0.0 . Initial write
Behavior/steps:
1. Delete content from seed server
2. Calculate sha256 hashes of all files in \tron
3. PGP-sign checksums.txt
3. Make .torrent file, save locally and upload to the autoloader folder
4. Create binary pack
5. PGP-sign the binary pack
6. Background upload the binary pack to the seed server
7. Fetch sha256sums.txt from repo and update it with sha256sum of the new binary pack
8. Delete current version from repo server; upload .exe pack and sha256sums.txt to repo server; cleans up residual temp files; notifies of completion and advises to restart BT Sync
9. Build FTP upload script
10. Upload via FTP
11. Clean up (deletes temp files used)
#>
#############
# VARIABLES # ---------------------- Set these to match your environment ------------------------ #
#############
# Rules for variables:
# * NO quotes! (bad: "c:\directory\path" )
# * NO trailing slashes on paths! (bad: c:\directory\ )
# * Spaces are okay (okay: c:\my folder\with spaces )
# * Network paths are okay (okay: \\server\share name )
param (
# Logging information
[string]$logpath = "$env:systemdrive\Logs",
[string]$logfile = "deploy_tron.log",
# Path to 7z.exe
[string]$SevenZip = "C:\Program Files\7-Zip\7z.exe",
# Path to WinSCP.com
[string]$WinSCP = "R:\applications\WinSCP\WinSCP.com",
# Path to hashdeep.exe
[string]$HashDeep = "R:\utilities\cli_utils\hashdeep.exe", # e.g. "$env:SystemRoot\system32\hashdeep.exe"
# Path to gpg.exe (for signing)
[string]$gpg = "${env:ProgramFiles(x86)}\GnuPG\bin\gpg.exe", # e.g. "$env:ProgramFiles\gpg4win\bin\gpg.exe"
# Path to mktorrent.exe (for .torrent generation)
[string]$mktorrent = "R:\applications\mktorrent\mktorrent.exe", # e.g. "R:\applications\mktorrent\mktorrent.exe"
# List of torrent trackers to pack into the .torrent
[string]$TorrentTracker1 = "udp://tracker.coppersurfer.tk:6969/announce",
[string]$TorrentTracker2 = "udp://tracker.ccc.de:80/announce",
[string]$TorrentTracker3 = "udp://tracker.publicbt.com:80",
[string]$TorrentTracker4 = "udp://tracker.istole.it:80",
[string]$TorrentTracker5 = "http://tracker.openbittorrent.com:80/announce",
[string]$TorrentTracker6 = "http://tracker.ipv6tracker.org:80/announce",
[string]$TorrentTracker7 = "http://9.rarbg.com:2710/announce",
# Master copy of Tron. Directory path, not file path. This directory
# should contain \resources and \integrity_verification subfolders
# Cygwin path format is required for mktorrent.exe
[string]$MasterCopy = "r:\utilities\security\cleanup-repair\tron", # e.g. "r:\utilities\security\cleanup-repair\tron"
[string]$MasterCopyCygwinFormat = "/cygdrive/r/utilities/security/cleanup-repair/tron/tron", # e.g. "/cygdrive/r/utilities/security/cleanup-repair/tron/tron"
# .torrent output folder, e.g. where to spit out the generated .torrent file. Supply path
# in both standard Windows format and in cygwin format. No trailing slash
[string]$TorrentSaveLocation = "R:\documents\logs\torrents", # e.g. "R:\documents\logs\torrents"
[string]$TorrentSaveLocationCygwinFormat = "/cygdrive/r/documents/logs/torrents", # e.g. "/cygdrive/r/unsorted"
# Server holding the Tron seed directories
[string]$SeedServer = "\\10.0.0.4", # e.g. "\\thebrain"
# Torrent upload directory. e.g. where to copy the .torrent file so it can be loaded by the Bittorrent software
# Relative path to $SeedServer
[string]$TorrentAutoloaderLocation = "downloads\torrent_files\autoloader", # e.g. "downloads\torrent_files\autoloader"
# Seeding subdirectories containing \tron and \integrity_verification directories (relative paths). No leading or trailing slashes
# RELEASE seeds
[string]$SeedFolderRS = "downloads\seeders\resiliosync\tron", # e.g. "downloads\seeders\resiliosync\tron"
[string]$SeedFolderST = "downloads\seeders\syncthing\tron", # e.g. "downloads\seeders\syncthing\tron"
[string]$SeedFolderTorrent = "downloads\seeders\torrent", # e.g. "downloads\seeders\torrent"
# Static pack storage location. RELATIVE path from root on the
# local deployment server. Where we stash the compiled .exe
# after uploading to the repo server.
# No leading or trailing slashes
[string]$StaticPackStorageLocation = "downloads\seeders\static_packs", # e.g. "downloads\seeders\static packs"
# Repository server where we'll fetch sha256sums.txt from
[string]$Repo_URL = "https://bmrf.org/repos/tron", # e.g. "http://bmrf.org/repos/tron"
# FTP information for where we'll upload the final sha256sums.txt and "Tron vX.Y.Z (yyyy-mm-dd).exe" file to
[string]$Repo_FTP_Host = "bmrf.org", # e.g. "bmrf.org"
[string]$Repo_FTP_Username = "bmrforg",
[string]$Repo_FTP_Password = "7Ek78m4Hnt",
[string]$Repo_FTP_DepositPath = "/public_html/repos/tron/", # e.g. "/public_html/repos/tron/"
# PGP key authentication information
[string]$gpgUsername = "vocatus.gate",
[string]$gpgPassphrase = "blue9"
)
# ----------------------------- Don't edit anything below this line ----------------------------- #
###################
# PREP AND CHECKS #
###################
$SCRIPT_VERSION = "1.5.0"
$SCRIPT_UPDATED = "2019-07-16"
$CUR_DATE=get-date -f "yyyy-MM-dd"
# Extract version number of current version from the seed server and stash it in $OldVersion
# The "split" command/method is similar to variable cutting in batch (e.g. %myVar:~3,0%)
$OldVersion = gc $SeedServer\$SeedFolderRS\tron\resources\functions\initialize_environment.bat -ea SilentlyContinue | Select-String -pattern "set TRON_VERSION"
$OldVersion = "$OldVersion".Split("=")[1]
# Extract release date of current version from the seed server and stash it in $OldDate
$OldDate = gc $SeedServer\$SeedFolderRS\tron\resources\functions\initialize_environment.bat -ea SilentlyContinue | Select-String -pattern "set TRON_DATE"
$OldDate = "$OldDate".Split("=")[1]
# Extract version number from the master copy and stash it in $NewVersion, then calculate and store the full .exe name for the new binary we'll be building
# The "split" command/method is similar to variable cutting in batch (e.g. %myVar:~3,0%)
$NewVersion = gc $MasterCopy\tron\resources\functions\initialize_environment.bat -ea SilentlyContinue | Select-String -pattern "set TRON_VERSION"
$NewVersion = "$NewVersion".Split("=")[1]
$NewBinary = "Tron v$NewVersion ($CUR_DATE).exe"
#################
# SANITY CHECKS #
#################
# List of items to make sure they exist before running the script
$pathsToCheck = @(
# Local machine: 7z.exe
"$SevenZip",
# Local machine: WinSCP.com
"$WinSCP",
# Local machine: hashdeep
"$HashDeep",
# Local machine: gpg.exe
"$gpg",
# Master copy: Tron's \resources subfolder
"$MasterCopy\tron\resources",
# Master copy: tron.bat inside the tron subfolder
"$MasterCopy\tron\tron.bat",
# Master copy: stage_0_prep.bat inside the resources subfolder
"$MasterCopy\tron\resources\stage_0_prep\stage_0_prep.bat",
# Master copy: stage_1_tempclean.bat inside the resources subfolder
"$MasterCopy\tron\resources\stage_1_tempclean\stage_1_tempclean.bat",
# Master copy: stage_2_de-bloat.bat inside the resources subfolder
"$MasterCopy\tron\resources\stage_2_de-bloat\stage_2_de-bloat.bat",
# Master copy: stage_3_disinfect.bat inside the resources subfolder
"$MasterCopy\tron\resources\stage_3_disinfect\stage_3_disinfect.bat",
# Master copy: stage_4_repair.bat inside the resources subfolder
"$MasterCopy\tron\resources\stage_4_repair\stage_4_repair.bat",
# Master copy: stage_5_patch.bat inside the resources subfolder
"$MasterCopy\tron\resources\stage_5_patch\stage_5_patch.bat",
# Master copy: stage_6_optimize.bat inside the resources subfolder
"$MasterCopy\tron\resources\stage_6_optimize\stage_6_optimize.bat",
# Master copy: the changelog
"$MasterCopy\tron\changelog-v$NewVersion-updated-$CUR_DATE.txt",
# Master copy: the Instructions file
"$MasterCopy\tron\Instructions -- YES ACTUALLY READ THEM.txt",
# Seed server: top level Tron folder (Resilio Sync)
"$SeedServer\$SeedFolderRS",
# Seed server: top level Tron folder (Syncthing)
"$SeedServer\$SeedFolderST",
# Seed server: \tron\integrity_verification sub-folder (Resilio Sync)
"$SeedServer\$SeedFolderRS\integrity_verification",
# Seed server: \tron\integrity_verification sub-folder (Syncthing)
"$SeedServer\$SeedFolderST\integrity_verification",
# Seed server: the public key (Resilio Sync)
"$SeedServer\$SeedFolderRS\integrity_verification\vocatus-public-key.asc",
# Seed server: the public key (Syncthing)
"$SeedServer\$SeedFolderST\integrity_verification\vocatus-public-key.asc"
)
# Run the check
foreach ($i in $pathstoCheck) {
if ( -not (test-path -LiteralPath $i)) {
""
write-host -n " ["; write-host -n "ERROR" -f red; write-host -n "]";
write-host " Couldn't find the following required item:"
""
write-host " $i"
""
write-host " Check paths and permissions and make sure it exists"
$null = $Host.UI.RawUI.ReadKey('NoEcho,IncludeKeyDown');
return
}
}
# Are you sure?
""
write-host " Build passed sanity checks." -f green
""
write-host " About to replace Tron v$OldVersion ($OldDate) with v$NewVersion ($CUR_DATE)"
""
write-host " Are you sure?" -f red
""
write-host " Don't forget to input GPG pin at the prompt!" -f red
""
pause
clear
###########
# EXECUTE #
###########
# The rest of the script is wrapped in the "main" function. This is literally just so we can put the logging function at the bottom of the script instead of at the top
function main() {
""
log " Tron deployment script v$SCRIPT_VERSION" blue
""
log " Replacing v$OldVersion ($OldDate) with v$NewVersion ($CUR_DATE)" green
# JOB: Make sure no testing files are sitting in the Tron directory
log " Wiping any existing test files from resources directory..." green
remove-item $MasterCopy\tron\resources\*.txt -force -ea SilentlyContinue | out-null
log " Done" darkgreen
# JOB: Clear target area
log " Clearing RELEASE targets on local seed server..." green
remove-item $SeedServer\$SeedFolderRS\tron\* -force -recurse -ea SilentlyContinue | out-null
remove-item $SeedServer\$SeedFolderRS\integrity_verification\*txt* -force -recurse -ea SilentlyContinue | out-null
remove-item $SeedServer\$SeedFolderST\tron\* -force -recurse -ea SilentlyContinue | out-null
remove-item $SeedServer\$SeedFolderST\integrity_verification\*txt* -force -recurse -ea SilentlyContinue | out-null
log " Done" darkgreen
# JOB: Calculate hashes of every single file in the \tron directory structure
log " Calculating individual hashes of all included files, please wait..." green
pushd $MasterCopy
del $env:temp\checksum* -force -recurse | out-null
& $HashDeep -s -e -c sha256 -l -r .\ | Out-File $env:temp\checksums.txt -encoding ascii
mv $env:temp\checksums.txt $MasterCopy\integrity_verification\checksums.txt -force
log " Done" darkgreen
# JOB: PGP sign the resulting checksums.txt then upload master directory to seed locations
log " PGP signing checksums.txt..." green
""
remove-item $MasterCopy\integrity_verification\checksums.txt.asc -force -recurse -ea SilentlyContinue | out-null
& $gpg --batch --yes --local-user $gpgUsername --passphrase $gpgPassphrase --armor --detach-sign $MasterCopy\integrity_verification\checksums.txt
while (1 -eq 1) {
if (test-path $MasterCopy\integrity_verification\checksums.txt.asc) {
""
log " Done" darkgreen
break
}
# sleep before looking again
start-sleep -s 2
}
# JOB: Verify PGP signature before FTP upload
log " Verifying PGP signature of checksums.txt..." green
""
& $gpg --batch --yes --verify $MasterCopy\integrity_verification\checksums.txt.asc $MasterCopy\integrity_verification\checksums.txt
if ($? -eq "True") {
""
log " Done" darkgreen
} else {
log " ! There was a problem verifying the signature!" red
pause
}
# JOB: Create .torrent file for the release
log " Generating .torrent file and saving to $TorrentSaveLocationCygwinFormat..." green
& $mktorrent -n "Tron v$NewVersion ($CUR_DATE)" -c "Instructions and support at https://old.reddit.com/r/TronScript" -a $TorrentTracker1,$TorrentTracker2,$TorrentTracker3,$TorrentTracker4,$TorrentTracker5,$TorrentTracker6,$TorrentTracker7 -o "$TorrentSaveLocationCygwinFormat/Tron v$NewVersion ($CUR_DATE).torrent" $MasterCopyCygwinFormat
if ($? -eq "True") { log " Done" darkgreen } else { log " ! There was a problem creating the .torrent" red }
# JOB: Upload from master copy to seed server directories
log " Master copy is gold. Copying from master to local seed directories..." green
log " Loading Resilio Sync RELEASE seed..." green
cp $MasterCopy\* $SeedServer\$SeedFolderRS\ -recurse -force
log " Done" darkgreen
log " Loading Syncthing RELEASE seed..." green
cp $MasterCopy\* $SeedServer\$SeedFolderST\ -recurse -force
log " Done" darkgreen
log " Loading .torrent seed..." green
mkdir "$SeedServer\$SeedFolderTorrent\Tron v$NewVersion ($CUR_DATE)" -ea silentlycontinue | out-null
cp $MasterCopy\tron\* "$SeedServer\$SeedFolderTorrent\Tron v$NewVersion ($CUR_DATE)" -recurse -force
log " Done" darkgreen
log " Uploading .torrent to $TorrentAutoloaderLocation..." green
cp "$TorrentSaveLocation\Tron v$NewVersion ($CUR_DATE).torrent" $SeedServer\$TorrentAutoloaderLocation
if ($? -eq "True") {
log " Done" darkgreen
} else {
log " ! There was a problem copying the .torrent to the autoloader folder" red
}
log " Done, seed server loaded." darkgreen
# Notify that we're done loading the seed server and are starting deployment to the master repo
log " Updating master repo (remote)..." green
# JOB: Pack Tron to into a binary pack (.exe archive) using 7z and stash it in the TEMP directory.
# Create the file name using the new version number extracted from tron.bat and exclude any
# files with "sync" in the title (these are Resilio Sync hidden files, we don't need to pack them
log " Building binary pack, please wait..." green
& "$SevenZip" a -sfx "$env:temp\$NewBinary" ".\*" -x!*sync* -x!*ini* >> $LOGPATH\$LOGFILE
log " Done" darkgreen
# JOB: Background upload the binary pack to the static pack folder on the local seed server
log " Background uploading $NewBinary to $SeedServer\$StaticPackStorageLocation..." green
start-job -name tron_copy_pack_to_seed_server -scriptblock {cp "$env:temp\$($args[0])" "$($args[1])\$($args[2])" -force} -ArgumentList $NewBinary, $SeedServer, $StaticPackStorageLocation
""
# JOB: Fetch sha256sums.txt from the repo for updating
log " Fetching repo copy of sha256sums.txt to update..." green
Invoke-WebRequest $Repo_URL/sha256sums.txt -outfile $env:temp\sha256sums.txt
log " Done" darkgreen
# JOB: Calculate SHA256 hash of newly-created binary pack and append it to sha256sums.txt
log " Calculating SHA256 hash for binary pack and appending it to sha256sums.txt..." green
pushd $env:temp
# First hash the file
& $HashDeep -s -e -l -c sha256 "Tron v$NewVersion ($CUR_DATE).exe" | Out-File .\sha256sums_TEMP.txt -Encoding utf8
# Strip out the annoying hashdeep header
gc .\sha256sums_TEMP.txt | Where-Object {$_ -notmatch '#'} | where-object {$_ -notmatch '%'} | sc .\sha256sums_TEMP2.txt
# Strip out blank lines and trailing spaces (not needed?)
#(gc .\sha256sums_TEMP2.txt) | ? {$_.trim() -ne "" } | sc .\sha256sums_TEMP2.txt
# Append the result to the sha256sums.txt we pulled from the repo
gc .\sha256sums_TEMP2.txt | out-file .\sha256sums.txt -encoding utf8 -append
# Sleep for a few seconds to make sure the pack has had time to finish uploading to the local seed server static pack location
start-sleep -s 12
# Nuke any old version that might be lingering in temp
remove-item "$env:temp\UPLOADING" -force -recurse -ea SilentlyContinue | out-null
# Rename the file to prepare it for uploading
ren "$env:temp\$NewBinary" "$env:temp\UPLOADING"
popd
log " Done" darkgreen
# JOB: PGP sign sha256sums.txt
log " PGP signing sha256sums.txt..." green
""
remove-item $env:temp\sha256sums.txt.asc -force -recurse -ea SilentlyContinue | out-null
& $gpg --batch --yes --local-user $gpgUsername --passphrase $gpgPassphrase --armor --detach-sign $env:temp\sha256sums.txt
while (1 -eq 1) {
if (test-path $env:temp\sha256sums.txt.asc) {
""
log " Done" darkgreen
break
}
# sleep before looking again
start-sleep -s 2
}
# JOB: Verify PGP signature of sha256sums.txt
log " Verifying PGP signature of sha256sums.txt..." green
& $gpg --batch --yes --verify $env:temp\sha256sums.txt.asc $env:temp\sha256sums.txt
if ($? -eq "True") {
log " Done" darkgreen
} else {
log " ! There was a problem verifying the signature!" red
}
# JOB: Build FTP upload script
# Tron exe will be called UPLOADING until transfer is complete
log " Building FTP deployment script..." green
"option batch abort" | Out-File $env:temp\deploy_tron_ftp_script.txt -encoding ascii
"option confirm off" | Out-File $env:temp\deploy_tron_ftp_script.txt -append -encoding ascii
"open ftp://$Repo_FTP_Username`:$Repo_FTP_Password@$Repo_FTP_Host" | Out-File $env:temp\deploy_tron_ftp_script.txt -append -encoding ascii
"cd $Repo_FTP_DepositPath" | Out-File $env:temp\deploy_tron_ftp_script.txt -append -encoding ascii
"rm *.exe" | Out-File $env:temp\deploy_tron_ftp_script.txt -append -encoding ascii
"rm *.torrent" | Out-File $env:temp\deploy_tron_ftp_script.txt -append -encoding ascii
"rm sha256sums*" | Out-File $env:temp\deploy_tron_ftp_script.txt -append -encoding ascii
add-content -path $env:temp\deploy_tron_ftp_script.txt -value "put -transfer=binary `"$TorrentSaveLocation\Tron v$NewVersion ($CUR_DATE).torrent`""
add-content -path $env:temp\deploy_tron_ftp_script.txt -value "put -transfer=binary -resume `"$env:temp\UPLOADING`""
add-content -path $env:temp\deploy_tron_ftp_script.txt -value "mv `"UPLOADING`" `"$NewBinary`""
add-content -path $env:temp\deploy_tron_ftp_script.txt -value "put -transfer=binary `"$env:temp\sha256sums.txt`""
add-content -path $env:temp\deploy_tron_ftp_script.txt -value "put -transfer=ascii `"$env:temp\sha256sums.txt.asc`""
#write-output "mv "UPLOADING_$NewBinary" "$NewBinary"" | Out-File $env:temp\deploy_tron_ftp_script.txt -append -encoding ascii
"exit" | Out-File $env:temp\deploy_tron_ftp_script.txt -append -encoding ascii
log " Done" darkgreen
# JOB: Upload binary pack and hash files to FTP repo server
# Get in TEMP directory and call WinSCP to run the script we just created
log " Uploading $NewBinary to $Repo_FTP_Host..." green
""
pushd $env:temp
& $WinSCP /script=.\deploy_tron_ftp_script.txt
popd
""
log " Done" darkgreen
# JOB: Clean up after ourselves
log " Cleaning up..." green
remove-item $env:temp\sha256sums* -force -recurse -ea SilentlyContinue | out-null
remove-item $env:temp\$NewBinary* -force -recurse -ea SilentlyContinue | out-null
remove-item $env:temp\deploy_tron_ftp_script.txt -force -recurse -ea SilentlyContinue | out-null
# Remove our background upload job from the job list
get-job | remove-job
log " Done" darkgreen
############
# Finished #
############
log " Deployment done " green
log " Version deployed: v$NewVersion ($CUR_DATE)"
log " Version replaced: v$OldVersion ($OldDate)"
log " Local seed server: $SeedServer"
log " Local seed directories:"
log " Resilio Sync (RELEASE): $SeedFolderRS"
log " Syncthing (RELEASE): $SeedFolderST"
log " Local torrent autoloader location: $TorrentAutoloaderLocation"
log " Local torrent save location: $TorrentSaveLocation"
log " Local static pack storage: $StaticPackStorageLocation"
log " Remote repo host: $Repo_FTP_Host"
log " Remote repo upload path: $Repo_FTP_Host$Repo_FTP_DepositPath"
log " Log file: $LOGPATH\$LOGFILE"
log " Notify mirror ops, post release to Reddit" blue
log " and start the .torrent file" blue
pause
# Close the main() function. End of the script
}
#############
# FUNCTIONS #
#############
function log($message, $color)
{
if ($color -eq $null) {$color = "gray"}
#console
write-host (get-date -f "yyyy-MM-dd hh:mm:ss") -n -f darkgray; write-host "$message" -f $color
#log
#(get-date -f "yyyy-mm-dd hh:mm:ss") +"$message" | out-file -Filepath "$logpath\$logfile" -append
(get-date -f "yyyy-MM-dd hh:mm:ss") +"$message" | out-file -Filepath "C:\logs\deploy_tron.log" -append
}
# call the main script
main