499 Commits

Author SHA1 Message Date
Armin Briegel
2a236e9b2c fixed stray whitespace at the end of camtasia2019.sh, closes #547 2022-05-19 10:23:47 +02:00
Armin Briegel
a22e656146 Update README.md 2022-05-18 17:27:34 +02:00
Armin Briegel
dd98c13e40 Many new links and clarifications 2022-05-18 17:21:35 +02:00
Armin Briegel
89c4d4fa5c Update CONTRIBUTING.md 2022-05-18 17:09:52 +02:00
Armin Briegel
9b229085bd Merge branch 'dev' 2022-05-18 10:29:42 +02:00
Armin Briegel
7e93eb6471 updated version.sh 2022-05-18 10:29:13 +02:00
Armin Briegel
b56276612a Merge branch 'main' into dev 2022-05-16 20:15:55 +02:00
Armin Briegel
fa5f052d5a updated changelog 2022-05-16 20:14:32 +02:00
Armin Briegel
ed8e9ef913 general cleanup in prep for release 2022-05-16 20:12:48 +02:00
Armin Briegel
08fd69ae7b Merge pull request #514 from micahflee/1password8
1Password 8
2022-05-16 19:25:45 +02:00
Armin Briegel
4e8748d4fa Merge pull request #494 from sidbena/fix-for-missed-comment-in-header
Fix for missing comment in header
2022-05-16 19:19:46 +02:00
Armin Briegel
8576bdffbb merged #512 into main 2022-05-16 19:16:36 +02:00
Armin Briegel
5cf34c8ed8 Merge pull request #512 from FletcherS7/dev
New Label: Egnyte WebEdit
2022-05-16 16:02:18 +02:00
Armin Briegel
d6564d0e33 Merge pull request #510 from FletcherS7/main
New Label: WeChat
2022-05-16 16:01:47 +02:00
Armin Briegel
7c433785c9 Merge pull request #509 from worthypants/Installomator2
Create new label idrivethin
2022-05-16 15:54:14 +02:00
Armin Briegel
db1621cfb7 Merge pull request #507 from worthypants/main
Create new label iDrive
2022-05-16 15:42:08 +02:00
worthypants
84b9a98e13 updated label idrive
corrected downloadURL and appNewVersion
2022-05-16 14:46:10 +02:00
worthypants
e8d56b585c Updated idrivethin
revised downloadurl and appnewversion
2022-05-16 14:37:05 +02:00
Armin Briegel
4420ce2cf9 Update README.md 2022-05-16 12:47:29 +02:00
Armin Briegel
f77cd4467e Merge pull request #531 from FletcherS7/patch-1
Update README.md shields.io badges urls
2022-05-16 10:19:40 +02:00
Fletcher Salesky
bd41912310 Update README.md shields.io badges urls
Now pointed to Installomator/Installomator instead of scriptingosx/Installomator
Fixes Release and Downloads badges showing "no releases or repo found" error
2022-05-13 12:06:13 -07:00
Armin Briegel
00a0f583b6 Merge pull request #527 from madtice/XeroxWorkCentre7800
adding Xerox Workcentre 7800 drivers
2022-05-13 09:52:08 +02:00
Armin Briegel
fc33a03447 Merge pull request #526 from madtice/Pika
Adding app Pika
2022-05-13 09:50:15 +02:00
Armin Briegel
c889a2d735 Merge pull request #525 from madtice/imageoptim
adding app imageoptim
2022-05-13 09:46:57 +02:00
madtice
3aafdde178 adding Xerox Workcentre 7800 drivers
2022-05-13 09:43:48 : REQ   : xeroxworkcentre7800 : ################## Start Installomator v. 9.2beta, date 2022-05-13
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : ################## Version: 9.2beta
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : ################## Date: 2022-05-13
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : ################## xeroxworkcentre7800
2022-05-13 09:43:48 : DEBUG : xeroxworkcentre7800 : DEBUG mode 1 enabled.
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : BLOCKING_PROCESS_ACTION=tell_user
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : NOTIFY=success
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : LOGGING=DEBUG
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : Label type: pkgInDmg
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : archiveName: XeroxWorkCentre.dmg
2022-05-13 09:43:48 : DEBUG : xeroxworkcentre7800 : Changing directory to /Users/thijs/gits/Installomator/build
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : Custom App Version detection is used, found 5.10.1
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : appversion: 5.10.1
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : Latest version of XeroxWorkCentre is 5.10.1
2022-05-13 09:43:48 : WARN  : xeroxworkcentre7800 : DEBUG mode 1 enabled, not exiting, but there is no new version of app.
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : XeroxWorkCentre.dmg exists and DEBUG mode 1 enabled, skipping download
2022-05-13 09:43:48 : REQ   : xeroxworkcentre7800 : Installing XeroxWorkCentre
2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : Mounting /Users/thijs/gits/Installomator/build/XeroxWorkCentre.dmg
2022-05-13 09:43:48 : DEBUG : xeroxworkcentre7800 : Debugging enabled, dmgmount output was:
expected CRC32 $562A7F63
/dev/disk2          	GUID_partition_scheme
/dev/disk2s1        	Apple_HFS                      	/Volumes/Xerox Drivers 5.10.1

2022-05-13 09:43:48 : INFO  : xeroxworkcentre7800 : Mounted: /Volumes/Xerox Drivers 5.10.1
2022-05-13 09:43:49 : DEBUG : xeroxworkcentre7800 : Found pkg(s):
/Volumes/Xerox Drivers 5.10.1/Xerox Drivers 5.10.1.pkg
2022-05-13 09:43:49 : INFO  : xeroxworkcentre7800 : found pkg: /Volumes/Xerox Drivers 5.10.1/Xerox Drivers 5.10.1.pkg
2022-05-13 09:43:49 : INFO  : xeroxworkcentre7800 : Verifying: /Volumes/Xerox Drivers 5.10.1/Xerox Drivers 5.10.1.pkg
2022-05-13 09:43:49 : DEBUG : xeroxworkcentre7800 : File list: -rw-r--r--  1 root  staff    85M Apr 19 15:58 /Volumes/Xerox Drivers 5.10.1/Xerox Drivers 5.10.1.pkg
2022-05-13 09:43:49 : DEBUG : xeroxworkcentre7800 : File type: /Volumes/Xerox Drivers 5.10.1/Xerox Drivers 5.10.1.pkg: xar archive compressed TOC: 31493, SHA-1 checksum
2022-05-13 09:43:49 : DEBUG : xeroxworkcentre7800 : spctlOut is /Volumes/Xerox Drivers 5.10.1/Xerox Drivers 5.10.1.pkg: accepted
2022-05-13 09:43:49 : DEBUG : xeroxworkcentre7800 : source=Notarized Developer ID
2022-05-13 09:43:49 : DEBUG : xeroxworkcentre7800 : origin=Developer ID Installer: Xerox Corporation (G59Y3XFNFR)
2022-05-13 09:43:49 : INFO  : xeroxworkcentre7800 : Team ID: G59Y3XFNFR (expected: G59Y3XFNFR )
2022-05-13 09:43:49 : DEBUG : xeroxworkcentre7800 : DEBUG enabled, skipping installation
2022-05-13 09:43:49 : INFO  : xeroxworkcentre7800 : Finishing...
2022-05-13 09:43:59 : INFO  : xeroxworkcentre7800 : Custom App Version detection is used, found 5.10.1
2022-05-13 09:43:59 : REQ   : xeroxworkcentre7800 : Installed XeroxWorkCentre, version 5.10.1
2022-05-13 09:43:59 : INFO  : xeroxworkcentre7800 : notifying
2022-05-13 09:43:59 : DEBUG : xeroxworkcentre7800 : Unmounting /Volumes/Xerox Drivers 5.10.1
2022-05-13 09:43:59 : DEBUG : xeroxworkcentre7800 : Debugging enabled, Unmounting output was:
"disk2" ejected.
2022-05-13 09:43:59 : DEBUG : xeroxworkcentre7800 : DEBUG mode 1, not reopening anything
2022-05-13 09:43:59 : REQ   : xeroxworkcentre7800 : All done!
2022-05-13 09:43:59 : REQ   : xeroxworkcentre7800 : ################## End Installomator, exit code 0
2022-05-13 09:44:41 +02:00
Armin Briegel
05e4cc92ea Merge pull request #524 from madtice/Hype
Adding hype (4)
2022-05-13 09:42:32 +02:00
madtice
9a154b80b7 Adding app Pika
2022-05-13 09:41:32 : REQ   : pika : ################## Start Installomator v. 9.2beta, date 2022-05-13
2022-05-13 09:41:32 : INFO  : pika : ################## Version: 9.2beta
2022-05-13 09:41:32 : INFO  : pika : ################## Date: 2022-05-13
2022-05-13 09:41:32 : INFO  : pika : ################## pika
2022-05-13 09:41:32 : DEBUG : pika : DEBUG mode 1 enabled.
2022-05-13 09:41:33 : INFO  : pika : BLOCKING_PROCESS_ACTION=tell_user
2022-05-13 09:41:33 : INFO  : pika : NOTIFY=success
2022-05-13 09:41:33 : INFO  : pika : LOGGING=DEBUG
2022-05-13 09:41:33 : INFO  : pika : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-05-13 09:41:33 : INFO  : pika : Label type: dmg
2022-05-13 09:41:33 : INFO  : pika : archiveName: Pika.dmg
2022-05-13 09:41:33 : DEBUG : pika : Changing directory to /Users/thijs/gits/Installomator/build
2022-05-13 09:41:33 : INFO  : pika : No version found using packageID com.superhighfives.Pika
2022-05-13 09:41:33 : INFO  : pika : App(s) found: /Applications/Pika.app
2022-05-13 09:41:33 : INFO  : pika : found app at /Applications/Pika.app, version 0.0.12, on versionKey CFBundleShortVersionString
2022-05-13 09:41:33 : INFO  : pika : appversion: 0.0.12
2022-05-13 09:41:33 : INFO  : pika : Latest version of Pika is 0.0.12
2022-05-13 09:41:33 : WARN  : pika : DEBUG mode 1 enabled, not exiting, but there is no new version of app.
2022-05-13 09:41:33 : INFO  : pika : Pika.dmg exists and DEBUG mode 1 enabled, skipping download
2022-05-13 09:41:33 : REQ   : pika : Installing Pika
2022-05-13 09:41:33 : INFO  : pika : Mounting /Users/thijs/gits/Installomator/build/Pika.dmg
2022-05-13 09:41:33 : DEBUG : pika : Debugging enabled, dmgmount output was:
expected CRC32 $02D39DFE
/dev/disk2          	GUID_partition_scheme
/dev/disk2s1        	Apple_HFS                      	/Volumes/Pika

2022-05-13 09:41:34 : INFO  : pika : Mounted: /Volumes/Pika
2022-05-13 09:41:34 : INFO  : pika : Verifying: /Volumes/Pika/Pika.app
2022-05-13 09:41:34 : DEBUG : pika : App size: 8.0M	/Volumes/Pika/Pika.app
2022-05-13 09:41:34 : DEBUG : pika : Debugging enabled, App Verification output was:
/Volumes/Pika/Pika.app: accepted
source=Notarized Developer ID
origin=Developer ID Application: Charlie Gleason (TGHU37N6EX)

2022-05-13 09:41:34 : INFO  : pika : Team ID matching: TGHU37N6EX (expected: TGHU37N6EX )
2022-05-13 09:41:34 : INFO  : pika : Downloaded version of Pika is 0.0.12 on versionKey CFBundleShortVersionString, same as installed.
2022-05-13 09:41:34 : DEBUG : pika : Unmounting /Volumes/Pika
2022-05-13 09:41:34 : DEBUG : pika : Debugging enabled, Unmounting output was:
"disk2" ejected.
2022-05-13 09:41:34 : DEBUG : pika : DEBUG mode 1, not reopening anything
2022-05-13 09:41:34 : REG   : pika : No new version to install
2022-05-13 09:41:34 : REQ   : pika : ################## End Installomator, exit code 0
2022-05-13 09:41:49 +02:00
Armin Briegel
1de072bdbf Merge pull request #523 from madtice/fontexplorer
adding FontExplorer
2022-05-13 09:40:38 +02:00
madtice
5c43199ee6 adding imageoptim
2022-05-13 09:37:14 : REQ   : imageoptim : ################## Start Installomator v. 9.2beta, date 2022-05-13
2022-05-13 09:37:14 : INFO  : imageoptim : ################## Version: 9.2beta
2022-05-13 09:37:15 : INFO  : imageoptim : ################## Date: 2022-05-13
2022-05-13 09:37:15 : INFO  : imageoptim : ################## imageoptim
2022-05-13 09:37:15 : DEBUG : imageoptim : DEBUG mode 1 enabled.
2022-05-13 09:37:15 : INFO  : imageoptim : BLOCKING_PROCESS_ACTION=tell_user
2022-05-13 09:37:15 : INFO  : imageoptim : NOTIFY=success
2022-05-13 09:37:15 : INFO  : imageoptim : LOGGING=DEBUG
2022-05-13 09:37:15 : INFO  : imageoptim : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-05-13 09:37:15 : INFO  : imageoptim : Label type: tbz
2022-05-13 09:37:15 : INFO  : imageoptim : archiveName: imageoptim.tbz
2022-05-13 09:37:15 : DEBUG : imageoptim : Changing directory to /Users/thijs/gits/Installomator/build
2022-05-13 09:37:15 : INFO  : imageoptim : No version found using packageID net.pornel.ImageOptim
2022-05-13 09:37:15 : INFO  : imageoptim : App(s) found: /Applications/imageoptim.app
2022-05-13 09:37:15 : INFO  : imageoptim : found app at /Applications/imageoptim.app, version 1.8.8, on versionKey CFBundleShortVersionString
2022-05-13 09:37:15 : INFO  : imageoptim : appversion: 1.8.8
2022-05-13 09:37:15 : INFO  : imageoptim : Latest version of imageoptim is 1.8.8
2022-05-13 09:37:15 : WARN  : imageoptim : DEBUG mode 1 enabled, not exiting, but there is no new version of app.
2022-05-13 09:37:15 : INFO  : imageoptim : imageoptim.tbz exists and DEBUG mode 1 enabled, skipping download
2022-05-13 09:37:15 : REQ   : imageoptim : Installing imageoptim
2022-05-13 09:37:15 : INFO  : imageoptim : Unzipping imageoptim.tbz
2022-05-13 09:37:16 : INFO  : imageoptim : Verifying: /Users/thijs/gits/Installomator/build/imageoptim.app
2022-05-13 09:37:16 : DEBUG : imageoptim : App size:  11M	/Users/thijs/gits/Installomator/build/imageoptim.app
2022-05-13 09:37:16 : DEBUG : imageoptim : Debugging enabled, App Verification output was:
/Users/thijs/gits/Installomator/build/imageoptim.app: accepted
source=Notarized Developer ID
origin=Developer ID Application: Kornel Lesinski (59KZTZA4XR)

2022-05-13 09:37:16 : INFO  : imageoptim : Team ID matching: 59KZTZA4XR (expected: 59KZTZA4XR )
2022-05-13 09:37:16 : INFO  : imageoptim : Downloaded version of imageoptim is 1.8.8 on versionKey CFBundleShortVersionString, same as installed.
2022-05-13 09:37:16 : DEBUG : imageoptim : DEBUG mode 1, not reopening anything
2022-05-13 09:37:16 : REG   : imageoptim : No new version to install
2022-05-13 09:37:16 : REQ   : imageoptim : ################## End Installomator, exit code 0
2022-05-13 09:38:58 +02:00
Armin Briegel
2efdd45759 Merge pull request #522 from madtice/main
Create filezilla.sh
2022-05-13 09:37:03 +02:00
madtice
f7d903bc87 Adding hype (4)
2022-05-13 09:32:43 : REQ   : hype : ################## Start Installomator v. 9.2beta, date 2022-05-13
2022-05-13 09:32:43 : INFO  : hype : ################## Version: 9.2beta
2022-05-13 09:32:43 : INFO  : hype : ################## Date: 2022-05-13
2022-05-13 09:32:43 : INFO  : hype : ################## hype
2022-05-13 09:32:43 : DEBUG : hype : DEBUG mode 1 enabled.
2022-05-13 09:32:43 : INFO  : hype : BLOCKING_PROCESS_ACTION=tell_user
2022-05-13 09:32:43 : INFO  : hype : NOTIFY=success
2022-05-13 09:32:43 : INFO  : hype : LOGGING=DEBUG
2022-05-13 09:32:43 : INFO  : hype : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-05-13 09:32:43 : INFO  : hype : Label type: dmg
2022-05-13 09:32:43 : INFO  : hype : archiveName: Hype4.dmg
2022-05-13 09:32:44 : DEBUG : hype : Changing directory to /Users/thijs/gits/Installomator/build
2022-05-13 09:32:44 : INFO  : hype : No version found using packageID com.tumult.Hype4
2022-05-13 09:32:44 : INFO  : hype : App(s) found: /Applications/Hype4.app
2022-05-13 09:32:44 : INFO  : hype : found app at /Applications/Hype4.app, version 4.1.8, on versionKey CFBundleShortVersionString
2022-05-13 09:32:44 : INFO  : hype : appversion: 4.1.8
2022-05-13 09:32:44 : INFO  : hype : Latest version of Hype4 is 4.1.8
2022-05-13 09:32:44 : WARN  : hype : DEBUG mode 1 enabled, not exiting, but there is no new version of app.
2022-05-13 09:32:44 : INFO  : hype : Hype4.dmg exists and DEBUG mode 1 enabled, skipping download
2022-05-13 09:32:44 : REQ   : hype : Installing Hype4
2022-05-13 09:32:44 : INFO  : hype : Mounting /Users/thijs/gits/Installomator/build/Hype4.dmg
2022-05-13 09:32:44 : DEBUG : hype : Debugging enabled, dmgmount output was:
/dev/disk2          	Apple_partition_scheme
/dev/disk2s1        	Apple_partition_map
/dev/disk2s2        	Apple_HFS                      	/Volumes/Hype 4.1.8

2022-05-13 09:32:44 : INFO  : hype : Mounted: /Volumes/Hype 4.1.8
2022-05-13 09:32:44 : INFO  : hype : Verifying: /Volumes/Hype 4.1.8/Hype4.app
2022-05-13 09:32:44 : DEBUG : hype : App size:  50M	/Volumes/Hype 4.1.8/Hype4.app
2022-05-13 09:32:47 : DEBUG : hype : Debugging enabled, App Verification output was:
/Volumes/Hype 4.1.8/Hype4.app: accepted
source=Notarized Developer ID
origin=Developer ID Application: Tumult Inc. (8J356DM772)

2022-05-13 09:32:47 : INFO  : hype : Team ID matching: 8J356DM772 (expected: 8J356DM772 )
2022-05-13 09:32:47 : INFO  : hype : Downloaded version of Hype4 is 4.1.8 on versionKey CFBundleShortVersionString, same as installed.
2022-05-13 09:32:47 : DEBUG : hype : Unmounting /Volumes/Hype 4.1.8
2022-05-13 09:32:47 : DEBUG : hype : Debugging enabled, Unmounting output was:
"disk2" ejected.
2022-05-13 09:32:47 : DEBUG : hype : DEBUG mode 1, not reopening anything
2022-05-13 09:32:47 : REG   : hype : No new version to install
2022-05-13 09:32:47 : REQ   : hype : ################## End Installomator, exit code 0
2022-05-13 09:33:55 +02:00
Armin Briegel
5808bcc8dd Merge pull request #519 from imfromthebay/patch-1
New App: Linear (https://linear.app/)
2022-05-13 09:33:10 +02:00
Armin Briegel
c6dbf15995 add missing ;; at end of label 2022-05-13 09:31:45 +02:00
madtice
ce857dd372 adding FontExplorer
2022-05-13 09:28:24 : REQ   : fontexplorer : ################## Start Installomator v. 9.2beta, date 2022-05-13
2022-05-13 09:28:24 : INFO  : fontexplorer : ################## Version: 9.2beta
2022-05-13 09:28:24 : INFO  : fontexplorer : ################## Date: 2022-05-13
2022-05-13 09:28:24 : INFO  : fontexplorer : ################## fontexplorer
2022-05-13 09:28:24 : DEBUG : fontexplorer : DEBUG mode 1 enabled.
2022-05-13 09:28:24 : INFO  : fontexplorer : BLOCKING_PROCESS_ACTION=tell_user
2022-05-13 09:28:24 : INFO  : fontexplorer : NOTIFY=success
2022-05-13 09:28:24 : INFO  : fontexplorer : LOGGING=DEBUG
2022-05-13 09:28:24 : INFO  : fontexplorer : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-05-13 09:28:24 : INFO  : fontexplorer : Label type: dmg
2022-05-13 09:28:24 : INFO  : fontexplorer : archiveName: FontExplorer X Pro.dmg
2022-05-13 09:28:24 : INFO  : fontexplorer : no blocking processes defined, using FontExplorer X Pro as default
2022-05-13 09:28:24 : DEBUG : fontexplorer : Changing directory to /Users/thijs/gits/Installomator/build
2022-05-13 09:28:24 : INFO  : fontexplorer : No version found using packageID com.linotype.FontExplorerX
2022-05-13 09:28:24 : INFO  : fontexplorer : App(s) found: /Applications/FontExplorer X Pro.app
2022-05-13 09:28:24 : INFO  : fontexplorer : found app at /Applications/FontExplorer X Pro.app, version 7.3.0, on versionKey CFBundleShortVersionString
2022-05-13 09:28:24 : INFO  : fontexplorer : appversion: 7.3.0
2022-05-13 09:28:24 : INFO  : fontexplorer : Latest version of FontExplorer X Pro is 7.3.0
2022-05-13 09:28:24 : WARN  : fontexplorer : DEBUG mode 1 enabled, not exiting, but there is no new version of app.
2022-05-13 09:28:24 : INFO  : fontexplorer : FontExplorer X Pro.dmg exists and DEBUG mode 1 enabled, skipping download
2022-05-13 09:28:24 : DEBUG : fontexplorer : DEBUG mode 1, not checking for blocking processes
2022-05-13 09:28:24 : REQ   : fontexplorer : Installing FontExplorer X Pro
2022-05-13 09:28:25 : INFO  : fontexplorer : Mounting /Users/thijs/gits/Installomator/build/FontExplorer X Pro.dmg
2022-05-13 09:28:25 : DEBUG : fontexplorer : Debugging enabled, dmgmount output was:
/dev/disk2          	Apple_partition_scheme
/dev/disk2s1        	Apple_partition_map
/dev/disk2s2        	Apple_HFS                      	/Volumes/FontExplorer X Pro

2022-05-13 09:28:25 : INFO  : fontexplorer : Mounted: /Volumes/FontExplorer X Pro
2022-05-13 09:28:25 : INFO  : fontexplorer : Verifying: /Volumes/FontExplorer X Pro/FontExplorer X Pro.app
2022-05-13 09:28:25 : DEBUG : fontexplorer : App size: 353M	/Volumes/FontExplorer X Pro/FontExplorer X Pro.app
2022-05-13 09:28:28 : DEBUG : fontexplorer : Debugging enabled, App Verification output was:
/Volumes/FontExplorer X Pro/FontExplorer X Pro.app: accepted
source=Notarized Developer ID
origin=Developer ID Application: Linotype GmbH (2V7G2B7WG4)

2022-05-13 09:28:28 : INFO  : fontexplorer : Team ID matching: 2V7G2B7WG4 (expected: 2V7G2B7WG4 )
2022-05-13 09:28:28 : INFO  : fontexplorer : Downloaded version of FontExplorer X Pro is 7.3.0 on versionKey CFBundleShortVersionString, same as installed.
2022-05-13 09:28:28 : DEBUG : fontexplorer : Unmounting /Volumes/FontExplorer X Pro
2022-05-13 09:28:28 : DEBUG : fontexplorer : Debugging enabled, Unmounting output was:
"disk2" ejected.
2022-05-13 09:28:28 : DEBUG : fontexplorer : DEBUG mode 1, not reopening anything
2022-05-13 09:28:28 : REG   : fontexplorer : No new version to install
2022-05-13 09:28:28 : REQ   : fontexplorer : ################## End Installomator, exit code 0
2022-05-13 09:29:51 +02:00
Armin Briegel
867c152ae5 add label shottr, closes #516 2022-05-13 09:28:40 +02:00
Armin Briegel
27157e00c7 added missing linebreak at end 2022-05-13 09:28:04 +02:00
Armin Briegel
d580ace737 Merge pull request #516 from DavidTaylor19/Add-Label-Shottr
Add label: Shottr
2022-05-13 09:25:30 +02:00
Armin Briegel
389fa83fdc Merge pull request #515 from drtaru/main
Update Label: Grammarly
2022-05-13 09:22:27 +02:00
Armin Briegel
83df589092 adding missing line break at end of file 2022-05-13 09:18:43 +02:00
Armin Briegel
047c44b507 Merge pull request #508 from marcelpogorzelski/Update-Citrix-Workspace
Fixed Citrix Workspace appNewVersion
2022-05-13 09:10:59 +02:00
madtice
a73eb14436 Delete hype.sh 2022-05-12 20:54:33 +02:00
madtice
183ad615f8 Merge branch 'main' of https://github.com/madtice/Installomator 2022-05-12 20:53:44 +02:00
madtice
069651cf9f added L flag to curl
Changed curl -fs to curl -fsL to cleanup logging. The usual -fsIL doesn't give me the newest version number.

2022-05-12 20:52:03 : REQ   : filezilla : ################## Start Installomator v. 9.2beta, date 2022-05-12
2022-05-12 20:52:03 : INFO  : filezilla : ################## Version: 9.2beta
2022-05-12 20:52:03 : INFO  : filezilla : ################## Date: 2022-05-12
2022-05-12 20:52:03 : INFO  : filezilla : ################## filezilla
2022-05-12 20:52:03 : DEBUG : filezilla : DEBUG mode 1 enabled.
2022-05-12 20:52:03 : INFO  : filezilla : BLOCKING_PROCESS_ACTION=tell_user
2022-05-12 20:52:03 : INFO  : filezilla : NOTIFY=success
2022-05-12 20:52:03 : INFO  : filezilla : LOGGING=DEBUG
2022-05-12 20:52:04 : INFO  : filezilla : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-05-12 20:52:04 : INFO  : filezilla : Label type: tbz
2022-05-12 20:52:04 : INFO  : filezilla : archiveName: FileZilla.tbz
2022-05-12 20:52:04 : DEBUG : filezilla : Changing directory to /Users/thijs/gits/Installomator/build
2022-05-12 20:52:04 : INFO  : filezilla : No version found using packageID org.filezilla-project.filezilla
2022-05-12 20:52:04 : INFO  : filezilla : App(s) found: /Applications/FileZilla.app
2022-05-12 20:52:04 : INFO  : filezilla : found app at /Applications/FileZilla.app, version 3.59.0, on versionKey CFBundleShortVersionString
2022-05-12 20:52:04 : INFO  : filezilla : appversion: 3.59.0
2022-05-12 20:52:04 : INFO  : filezilla : Latest version of FileZilla is 3.59.0
2022-05-12 20:52:04 : WARN  : filezilla : DEBUG mode 1 enabled, not exiting, but there is no new version of app.
2022-05-12 20:52:04 : INFO  : filezilla : FileZilla.tbz exists and DEBUG mode 1 enabled, skipping download
2022-05-12 20:52:04 : REQ   : filezilla : Installing FileZilla
2022-05-12 20:52:04 : INFO  : filezilla : Unzipping FileZilla.tbz
2022-05-12 20:52:07 : INFO  : filezilla : Verifying: /Users/thijs/gits/Installomator/build/FileZilla.app
2022-05-12 20:52:07 : DEBUG : filezilla : App size:  44M	/Users/thijs/gits/Installomator/build/FileZilla.app
2022-05-12 20:52:07 : DEBUG : filezilla : Debugging enabled, App Verification output was:
/Users/thijs/gits/Installomator/build/FileZilla.app: accepted
source=Notarized Developer ID
origin=Developer ID Application: Tim Kosse (5VPGKXL75N)

2022-05-12 20:52:07 : INFO  : filezilla : Team ID matching: 5VPGKXL75N (expected: 5VPGKXL75N )
2022-05-12 20:52:07 : INFO  : filezilla : Downloaded version of FileZilla is 3.59.0 on versionKey CFBundleShortVersionString, same as installed.
2022-05-12 20:52:07 : DEBUG : filezilla : DEBUG mode 1, not reopening anything
2022-05-12 20:52:07 : REG   : filezilla : No new version to install
2022-05-12 20:52:07 : REQ   : filezilla : ################## End Installomator, exit code 0
2022-05-12 20:53:23 +02:00
madtice
a1f0864b7d Delete fontexplorer.sh 2022-05-12 20:47:57 +02:00
madtice
5eeabef079 Create fontexplorer.sh
2022-05-12 20:40:36 : REQ   : fontexplorer : ################## Start Installomator v. 9.2beta, date 2022-05-12
2022-05-12 20:40:36 : INFO  : fontexplorer : ################## Version: 9.2beta
2022-05-12 20:40:36 : INFO  : fontexplorer : ################## Date: 2022-05-12
2022-05-12 20:40:36 : INFO  : fontexplorer : ################## fontexplorer
2022-05-12 20:40:36 : DEBUG : fontexplorer : DEBUG mode 1 enabled.
2022-05-12 20:40:36 : INFO  : fontexplorer : BLOCKING_PROCESS_ACTION=tell_user
2022-05-12 20:40:36 : INFO  : fontexplorer : NOTIFY=success
2022-05-12 20:40:36 : INFO  : fontexplorer : LOGGING=DEBUG
2022-05-12 20:40:36 : INFO  : fontexplorer : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-05-12 20:40:37 : INFO  : fontexplorer : Label type: dmg
2022-05-12 20:40:37 : INFO  : fontexplorer : archiveName: FontExplorer X Pro.dmg
2022-05-12 20:40:37 : INFO  : fontexplorer : no blocking processes defined, using FontExplorer X Pro as default
2022-05-12 20:40:37 : DEBUG : fontexplorer : Changing directory to /Users/thijs/gits/Installomator/build
2022-05-12 20:40:37 : INFO  : fontexplorer : No version found using packageID com.linotype.FontExplorerX
2022-05-12 20:40:37 : INFO  : fontexplorer : App(s) found: /Applications/FontExplorer X Pro.app
2022-05-12 20:40:37 : INFO  : fontexplorer : found app at /Applications/FontExplorer X Pro.app, version 7.3.0, on versionKey CFBundleShortVersionString
2022-05-12 20:40:37 : INFO  : fontexplorer : appversion: 7.3.0
2022-05-12 20:40:37 : INFO  : fontexplorer : Latest version of FontExplorer X Pro is 7.3.0
2022-05-12 20:40:37 : WARN  : fontexplorer : DEBUG mode 1 enabled, not exiting, but there is no new version of app.
2022-05-12 20:40:37 : REQ   : fontexplorer : Downloading http://www.fontexplorerx.com/download/free-trial/Mac/ to FontExplorer X Pro.dmg
2022-05-12 20:40:58 : DEBUG : fontexplorer : File list: -rw-r--r--  1 root  staff   219M May 12 20:40 FontExplorer X Pro.dmg
2022-05-12 20:40:58 : DEBUG : fontexplorer : File type: FontExplorer X Pro.dmg: bzip2 compressed data, block size = 100k
2022-05-12 20:40:58 : DEBUG : fontexplorer : curl output was:
*   Trying 104.18.180.24:80...
* Connected to www.fontexplorerx.com (104.18.180.24) port 80 (#0)
> GET /download/free-trial/Mac/ HTTP/1.1
> Host: www.fontexplorerx.com
> User-Agent: curl/7.79.1
> Accept: */*
>
* Mark bundle as not supporting multiuse
< HTTP/1.1 301 Moved Permanently
< Date: Thu, 12 May 2022 18:40:37 GMT
< Transfer-Encoding: chunked
< Connection: keep-alive
< Cache-Control: max-age=3600
< Expires: Thu, 12 May 2022 19:40:37 GMT
< Location: https://www.fontexplorerx.com/download/free-trial/Mac/
< Set-Cookie: __cf_bm=kZPes1jyXmAENecQ_jHVQct9Dvv_ISHMkgRcS4glo0I-1652380837-0-AQPVHegSUW/AmyCHfCgPmZVwgpJlX+4Jhdd51CRneVeNlhg4cWjwzSZp1L+1T+G40HCB/aPfP1oHNCNBbcRLTS6YT7jub4dfXfD26HdNm7S8; path=/; expires=Thu, 12-May-22 19:10:37 GMT; domain=.fontexplorerx.com; HttpOnly; SameSite=None
< Server: cloudflare
< CF-RAY: 70a548a99c75972d-AMS
<
* Ignoring the response-body
{ [5 bytes data]
* Connection #0 to host www.fontexplorerx.com left intact
* Issue another request to this URL: 'https://www.fontexplorerx.com/download/free-trial/Mac/'
*   Trying 104.18.180.24:443...
* Connected to www.fontexplorerx.com (104.18.180.24) port 443 (#1)
* ALPN, offering h2
* ALPN, offering http/1.1
* successfully set certificate verify locations:
*  CAfile: /etc/ssl/cert.pem
*  CApath: none
* (304) (OUT), TLS handshake, Client hello (1):
} [326 bytes data]
* (304) (IN), TLS handshake, Server hello (2):
{ [122 bytes data]
* (304) (IN), TLS handshake, Unknown (8):
{ [19 bytes data]
* (304) (IN), TLS handshake, Certificate (11):
{ [2992 bytes data]
* (304) (IN), TLS handshake, CERT verify (15):
{ [264 bytes data]
* (304) (IN), TLS handshake, Finished (20):
{ [52 bytes data]
* (304) (OUT), TLS handshake, Finished (20):
} [52 bytes data]
* SSL connection using TLSv1.3 / AEAD-AES256-GCM-SHA384
* ALPN, server accepted to use h2
* Server certificate:
*  subject: C=US; ST=Massachusetts; L=Woburn; O=Monotype Imaging Inc.; CN=*.fontexplorerx.com
*  start date: Oct  7 00:00:00 2021 GMT
*  expire date: Nov  7 23:59:59 2022 GMT
*  subjectAltName: host "www.fontexplorerx.com" matched cert's "*.fontexplorerx.com"
*  issuer: C=US; O=DigiCert Inc; CN=DigiCert TLS RSA SHA256 2020 CA1
*  SSL certificate verify ok.
* Using HTTP2, server supports multiplexing
* Connection state changed (HTTP/2 confirmed)
* Copying HTTP/2 data in stream buffer to connection buffer after upgrade: len=0
* Using Stream ID: 1 (easy handle 0x7fc1df00d200)
> GET /download/free-trial/Mac/ HTTP/2
> Host: www.fontexplorerx.com
> user-agent: curl/7.79.1
> accept: */*
>
* Connection state changed (MAX_CONCURRENT_STREAMS == 256)!
< HTTP/2 302
< date: Thu, 12 May 2022 18:40:37 GMT
< content-type: text/html; charset=utf-8
< location: https://fex.linotype.com/download/mac/FontExplorerXPro.dmg
< cache-control: no-cache, no-store, must-revalidate
< pragma: no-cache
< expires: -1
< x-content-type-options: nosniff
< content-security-policy: frame-ancestors 'none'
< strict-transport-security: max-age=31536002
< cf-cache-status: DYNAMIC
< expect-ct: max-age=604800, report-uri="https://report-uri.cloudflare.com/cdn-cgi/beacon/expect-ct"
< set-cookie: __cf_bm=dYYK6Y7iXYOgbnA4M2wcaGi_3TSiOjfbcxSSw3Zbino-1652380837-0-AVfDaWLwFR6cAPkneaotOxDc7uxHiUEPuV92v30LSBVarfBz2BmbAgyBtIlmQBVorqV7i4ihmfqfHx+toFnCJJTxa6tymS6p9Cg6cp6Gs6hU; path=/; expires=Thu, 12-May-22 19:10:37 GMT; domain=.fontexplorerx.com; HttpOnly; Secure; SameSite=None
< server: cloudflare
< cf-ray: 70a548aa1d8e0b43-AMS
<
* Ignoring the response-body
{ [175 bytes data]
* Connection #1 to host www.fontexplorerx.com left intact
* Issue another request to this URL: 'https://fex.linotype.com/download/mac/FontExplorerXPro.dmg'
*   Trying 104.16.65.114:443...
* Connected to fex.linotype.com (104.16.65.114) port 443 (#2)
* ALPN, offering h2
* ALPN, offering http/1.1
* successfully set certificate verify locations:
*  CAfile: /etc/ssl/cert.pem
*  CApath: none
* (304) (OUT), TLS handshake, Client hello (1):
} [321 bytes data]
* (304) (IN), TLS handshake, Server hello (2):
{ [122 bytes data]
* (304) (IN), TLS handshake, Unknown (8):
{ [19 bytes data]
* (304) (IN), TLS handshake, Certificate (11):
{ [2979 bytes data]
* (304) (IN), TLS handshake, CERT verify (15):
{ [264 bytes data]
* (304) (IN), TLS handshake, Finished (20):
{ [52 bytes data]
* (304) (OUT), TLS handshake, Finished (20):
} [52 bytes data]
* SSL connection using TLSv1.3 / AEAD-AES256-GCM-SHA384
* ALPN, server accepted to use h2
* Server certificate:
*  subject: C=US; ST=Massachusetts; L=Woburn; O=Monotype Imaging Inc.; CN=*.linotype.com
*  start date: Oct 19 00:00:00 2021 GMT
*  expire date: Nov 19 23:59:59 2022 GMT
*  subjectAltName: host "fex.linotype.com" matched cert's "*.linotype.com"
*  issuer: C=US; O=DigiCert Inc; CN=DigiCert TLS RSA SHA256 2020 CA1
*  SSL certificate verify ok.
* Using HTTP2, server supports multiplexing
* Connection state changed (HTTP/2 confirmed)
* Copying HTTP/2 data in stream buffer to connection buffer after upgrade: len=0
* Using Stream ID: 1 (easy handle 0x7fc1df00d200)
> GET /download/mac/FontExplorerXPro.dmg HTTP/2
> Host: fex.linotype.com
> user-agent: curl/7.79.1
> accept: */*
>
* Connection state changed (MAX_CONCURRENT_STREAMS == 256)!
< HTTP/2 301
< date: Thu, 12 May 2022 18:40:37 GMT
< content-type: text/html; charset=iso-8859-1
< location: https://fex.linotype.com/download/mac/FontExplorerXPro730.dmg
< x-content-type-options: nosniff
< strict-transport-security: max-age=600
< cf-cache-status: HIT
< age: 434
< expires: Thu, 12 May 2022 22:40:37 GMT
< cache-control: public, max-age=14400
< expect-ct: max-age=604800, report-uri="https://report-uri.cloudflare.com/cdn-cgi/beacon/expect-ct"
< set-cookie: __cf_bm=SlfrZLCGpjb6KyGZO8AA0rwgarMWV7kPmFXBLTzy5W4-1652380837-0-AbVvJxFnFOqL80rmdoW6+BJoGPtsSkZracJNOqpaUuwfkPqWxPXamLI3d94NaQ7loSyoYWq7sQEi2MBI2EVzhlg=; path=/; expires=Thu, 12-May-22 19:10:37 GMT; domain=.linotype.com; HttpOnly; Secure; SameSite=None
< server: cloudflare
< cf-ray: 70a548acfe324c61-AMS
<
* Ignoring the response-body
{ [269 bytes data]
* Connection #2 to host fex.linotype.com left intact
* Issue another request to this URL: 'https://fex.linotype.com/download/mac/FontExplorerXPro730.dmg'
* Found bundle for host fex.linotype.com: 0x600000236f70 [can multiplex]
* Re-using existing connection! (#2) with host fex.linotype.com
* Connected to fex.linotype.com (104.16.65.114) port 443 (#2)
* Using Stream ID: 3 (easy handle 0x7fc1df00d200)
> GET /download/mac/FontExplorerXPro730.dmg HTTP/2
> Host: fex.linotype.com
> user-agent: curl/7.79.1
> accept: */*
>
< HTTP/2 301
< date: Thu, 12 May 2022 18:40:37 GMT
< content-type: text/html; charset=iso-8859-1
< location: https://fast.fontexplorerx.com/FontExplorerXPro730.dmg
< x-content-type-options: nosniff
< strict-transport-security: max-age=600
< cf-cache-status: HIT
< age: 433
< expires: Thu, 12 May 2022 22:40:37 GMT
< cache-control: public, max-age=14400
< expect-ct: max-age=604800, report-uri="https://report-uri.cloudflare.com/cdn-cgi/beacon/expect-ct"
< set-cookie: __cf_bm=Q4TbFu6Pl0l_HkUJCmCaf5rQaPllv5YED.XM2SL79U8-1652380837-0-AW4DU7pcHEiy+fHl61+ok4XgWh0nEcH+xQmqFXKJiv7H+3qCrGMgF3VX72WPtXrPszVJXl5V0uRNL2er8uChQpk=; path=/; expires=Thu, 12-May-22 19:10:37 GMT; domain=.linotype.com; HttpOnly; Secure; SameSite=None
< server: cloudflare
< cf-ray: 70a548ad2e6d4c61-AMS
<
* Ignoring the response-body
{ [262 bytes data]
* Connection #2 to host fex.linotype.com left intact
* Issue another request to this URL: 'https://fast.fontexplorerx.com/FontExplorerXPro730.dmg'
*   Trying 104.18.181.24:443...
* Connected to fast.fontexplorerx.com (104.18.181.24) port 443 (#3)
* ALPN, offering h2
* ALPN, offering http/1.1
* successfully set certificate verify locations:
*  CAfile: /etc/ssl/cert.pem
*  CApath: none
* (304) (OUT), TLS handshake, Client hello (1):
} [327 bytes data]
* (304) (IN), TLS handshake, Server hello (2):
{ [122 bytes data]
* (304) (IN), TLS handshake, Unknown (8):
{ [19 bytes data]
* (304) (IN), TLS handshake, Certificate (11):
{ [2992 bytes data]
* (304) (IN), TLS handshake, CERT verify (15):
{ [264 bytes data]
* (304) (IN), TLS handshake, Finished (20):
{ [52 bytes data]
* (304) (OUT), TLS handshake, Finished (20):
} [52 bytes data]
* SSL connection using TLSv1.3 / AEAD-AES256-GCM-SHA384
* ALPN, server accepted to use h2
* Server certificate:
*  subject: C=US; ST=Massachusetts; L=Woburn; O=Monotype Imaging Inc.; CN=*.fontexplorerx.com
*  start date: Oct  7 00:00:00 2021 GMT
*  expire date: Nov  7 23:59:59 2022 GMT
*  subjectAltName: host "fast.fontexplorerx.com" matched cert's "*.fontexplorerx.com"
*  issuer: C=US; O=DigiCert Inc; CN=DigiCert TLS RSA SHA256 2020 CA1
*  SSL certificate verify ok.
* Using HTTP2, server supports multiplexing
* Connection state changed (HTTP/2 confirmed)
* Copying HTTP/2 data in stream buffer to connection buffer after upgrade: len=0
* Using Stream ID: 1 (easy handle 0x7fc1df00d200)
> GET /FontExplorerXPro730.dmg HTTP/2
> Host: fast.fontexplorerx.com
> user-agent: curl/7.79.1
> accept: */*
>
* Connection state changed (MAX_CONCURRENT_STREAMS == 256)!
< HTTP/2 200
< date: Thu, 12 May 2022 18:40:38 GMT
< content-type: application/x-apple-diskimage
< content-length: 229482072
< x-amz-id-2: rrcC6JFnkN2jtYk94tMm+523tEdrKttw5CAFgpRxGam9Q+CbHoM/Uh574h1Tiej44o+/Y/NwdLY=
< x-amz-request-id: CB8VSYEZ9B03GME4
< last-modified: Wed, 02 Mar 2022 10:13:51 GMT
< etag: "1e88553987c85a58640ed89b09b3905a-14"
< x-amz-version-id: cnP65ReMq6hht_tJxn6vOaTLvOrEPBC8
< cf-cache-status: HIT
< age: 434
< expires: Thu, 12 May 2022 22:40:38 GMT
< cache-control: public, max-age=14400
< accept-ranges: bytes
< expect-ct: max-age=604800, report-uri="https://report-uri.cloudflare.com/cdn-cgi/beacon/expect-ct"
< set-cookie: __cf_bm=fXzImTkInEiKHLNXQKjb4ssMB7TRhWIvw3OZqbnDGYA-1652380838-0-AVO+uwdFQxX4T6ttCaCyQ0IvfqwyaOvkySC4KiaQDqZv7Z9xZDH9qDg1jUHyTJNVdZEnTT1Z7YH3I3xRC4NWKJOHeHnD3lmDBXorIH2I7uRv; path=/; expires=Thu, 12-May-22 19:10:38 GMT; domain=.fontexplorerx.com; HttpOnly; Secure; SameSite=None
< server: cloudflare
< cf-ray: 70a548ad99424bef-AMS
<
{ [701 bytes data]
* Connection #3 to host fast.fontexplorerx.com left intact

2022-05-12 20:40:58 : DEBUG : fontexplorer : DEBUG mode 1, not checking for blocking processes
2022-05-12 20:40:58 : REQ   : fontexplorer : Installing FontExplorer X Pro
2022-05-12 20:40:59 : INFO  : fontexplorer : Mounting /Users/thijs/gits/Installomator/build/FontExplorer X Pro.dmg
2022-05-12 20:41:20 : DEBUG : fontexplorer : Debugging enabled, dmgmount output was:
FontExplorer X Software License Agreement We recommend that you
print this Agreement for further reference. This FontExplorer X
Software License Agreement (this “Agreement”) becomes a binding
contract between you and Monotype, when you click on the area marked
“ACCEPT LICENSE AGREEMENT” (or such similar language). If you do
not wish to be bound by this Agreement, you may not Use the
FontExplorer X Software. Please read all of this Agreement before
you agree to be bound by its terms and conditions.  1.      Definitions
Defined terms used throughout this Agreement: “Critical Patch
Releases” means updates to the FontExplorer X Software that Monotype
determines, in its sole discretion, will be made available on a
general basis to all of its customers. Critical Patch Releases may
or may not include certain changes that are included in an Update
and may be released before or after any such Update is provided to
eligible customers. A Critical Patch Release may, in Monotype’s
sole discretion, be released prior to completion of Monotype’s
complete quality assurance testing process.  “Device” means any
piece of electronic equipment or mechanism designed to serve a
special purpose or perform a special function, including, but not
limited to, a desktop computer, server or laptop.  “FontExplorer X
Pro Software” means all the contents of the files, CD-ROM, DVD-ROM
or other media relating to Monotype’s proprietary FontExplorer X
Pro Software product if such product is provided to you under this
Agreement. The FontExplorer X Pro Software may include Plugins
delivered as part of the FontExplorer X Pro Software package,
Updates, Upgrades, Critical Patch Releases, permitted copies, and
related documentation, in each case which may be provided to you
by Monotype in its sole discretion.  “FontExplorer X Server Software”
means all the contents of the files, CD-ROM, DVD-ROM or other media
relating to Monotype’s proprietary FontExplorer X Server Software
product if such product is provided to you under this Agreement.
The FontExplorer X Server Software may include Updates, Upgrades,
Critical Patch Releases, permitted copies, and related documentation,
in each case which may be provided to you by Monotype in its sole
discretion.  “FontExplorer X Software” means the FontExplorer X Pro
Software or the FontExplorer X Thin Client Software and, as the
case may be, the FontExplorer X Server Software.  “FontExplorer X
Thin Client Software” means the all contents of the files, CD-ROM,
DVD-ROM or other media relating to Monotype’s proprietary FontExplorer
X Thin Client Software product if such product is provided to you
under this Agreement. The FontExplorer X Thin Client Software may
include Plugins delivered as part of the FontExplorer X Thin Client
Software package, Updates, Upgrades, Critical Patch Releases,
permitted copies, and related documentation, in each case which may
be provided to you by Monotype in its sole discretion.  “Licensed
Server” means a Device that the FontExplorer X Server Software runs
on, regardless of other purposes the Device may be used for, and
which shall remain in your sole care, custody and control (or, if
the Licensed Server is hosted by an internet service provider for
your benefit, you shall be responsible for all content on the
Licensed Server, as well as access to and security for such content).
“Licensed User” means you and, so long as they have been notified
by you of the terms and conditions of this Agreement and have agreed
to be bound by it, (i) if you are an individual, members of your
immediate household or (ii) if you are a business entity, your
employees and any contractors, in each case subject to the limit
of the number of users specified in the respective invoice(s) or
licensing document(s).  “Monotype” means collectively Monotype
Imaging Inc., 600 Unicorn Park Drive, Woburn, Massachusetts 01801,
USA, its successors and assigns, its parent and affiliated corporations,
its authorized distributors, and any third party which has licensed
to Monotype any or all of the components of the FontExplorer X
Software supplied to you pursuant to this Agreement.  “Software
Releases” are newly named products which provide unique functionality
beyond the scope of previously released software products and which
will be made available to customers for an additional fee.  “Trial
Period” is a period defined by the communication between you and
Monotype to evaluate FontExplorer X Software in accordance with the
terms of this Agreement.  “Update” means any bug fixes or minor
debugging that revises or corrects inefficiencies or defects in the
FontExplorer X Software. Some specific updates may include a Critical
Patch Release in Monotype’s sole discretion. Updates shall not
include any Upgrades or Software Releases.  “Upgrade” means a new
version of the FontExplorer X Software which provides product
updates, feature enhancements and/or the foundation for additional
functionality beyond that contained in the most recent version of
the FontExplorer X Software. Upgrades shall not include any Software
Releases.  “Use” of the FontExplorer X Software shall occur when
it is downloaded, installed, executed, accessed or an individual
or entity otherwise benefits from the FontExplorer X Software.  2.
Scope
You are bound by this Agreement and you acknowledge that
all Use of the FontExplorer X Software is governed by this
Agreement. You are responsible for any breach of this
Agreement by a Licensed User.
3.      License Grants 3.1     FontExplorer X Server Software. If
the quotation appertaining to this Agreement references the
FontExplorer X Server Software you are hereby granted, unless you
obtain the FontExplorer X Server Software for a Trial Period, subject
to the payment of the applicable license fees, and subject to the
terms and conditions of this Agreement, a non-exclusive, non-assignable,
non-transferable (if the FontExplorer X Software was not acquired
through a subscription except as expressly permitted in Section 9
of this Agreement) license to (i) Use the FontExplorer X Server
Software on Licensed Servers and (ii) to permit Licensed Users to
access and Use the FontExplorer X Server Software through Devices
or through an internal local area network (LAN) which includes
connections though a Virtual Private Network (VPN).  3.2
FontExplorer X Pro Software or FontExplorer X Thin Client Software.
Subject to the payment of the applicable license fees, and subject
to the terms and conditions of this Agreement, each Licensed User
is hereby granted a non-exclusive, non-assignable, non-transferable
(if the FontExplorer X Software or the FontExplorer X Thin Client
Software was not acquired through a subscription except as expressly
permitted in Section 9 of this Agreement) license to copy and Use
the FontExplorer X Pro Software or FontExplorer X Thin Client
Software on Devices which a Licensed User may access under the
condition that persons other than Licensed Users are excluded from
Use of the FontExplorer X Pro Software or FontExplorer X Thin Client
Software. The FontExplorer X Pro Software or FontExplorer X Thin
Client Software may be Used from a server (through a LAN or external
network system) as long as such Use is restricted to Licensed Users.
4.      Copies and Modifications 4.1     FontExplorer X Server
Software. If the quotation appertaining to this Agreement references
the FontExplorer X Server Software you may make one back-up copy
of the FontExplorer X Server Software for archival purposes only,
and you shall retain exclusive custody and control over such copy.
Such copy must contain the same copyright, trademark, and other
proprietary notices that appear on or in the FontExplorer X Server
Software.  4.2     FontExplorer X Pro Software or FontExplorer X
Thin Client Software. With the exception of making copies of the
FontExplorer X Pro Software or FontExplorer X Thin Client Software
for Devices which a Licensed User may access as provided by 3.2, a
Licensed User may make one back-up copy of the FontExplorer X Pro
Software or FontExplorer X Thin Client Software for archival purposes
only, and such Licensed User shall retain exclusive custody and
control over such copy. Such copy must contain the same copyright,
trademark, and other proprietary notices that appear on or in the
FontExplorer X Pro Software or FontExplorer X Thin Client Software.
4.3     Additional Restrictions. You may not, and you will not
encourage, assist or authorize any other person to: ¥       Install
the FontExplorer X Server Software on Devices other than on a
Licensed Server; ¥       Use the FontExplorer X Software if such
person is not a Licensed User; ¥       sublicense, rent or lease,
adapt, modify, alter, translate, convert, create any derivative
work or otherwise change the FontExplorer X Software or any portion
thereof; or ¥       reverse engineer, decompile, disassemble, or
otherwise attempt to discover the source code of the FontExplorer X
Software or any portion thereof, provided, however, that if you are
located in a European Community member country or any other country
which provides rights materially similar to the rights set forth
in this proviso, you may reverse engineer or decompile the
FontExplorer X Software only to the extent that sufficient information
is not available for the purpose of creating an interoperable
software program (but only for such purpose and only to the extent
that sufficient information is not provided by Monotype upon written
request). You agree not to publish, or make otherwise accessible
to the public, the information arrived at through reverse engineering
and/or decompiling for the purpose of achieving interoperability.
4.4     Ownership. If you modify or create a derivative work of the
FontExplorer X Software, Monotype becomes the owner of the modified
data and/or derivative work.  5.      Purchases of Font Software
through the FontExplorer X Pro Software 5.1     In order to purchase
font software products through the FontExplorer X Pro Software, a
Licensed User must register with Monotype. You agree to provide
accurate, current, and complete information and to maintain and
update the registration data as required. Personal data will be
collected, processed and used only by Monotype and its affiliated
companies to provide the services specified herein. In accordance
with the principle of the efficient collection of data, Monotype
will only collect personal data that is necessary to fulfill the
contract and provide the services hereunder.  5.2     Any purchase
of font software products made through the FontExplorer X Pro
Software is subject to the respective foundries’ End User License
Agreement (EULA). The EULAs may be updated by the respective foundry
from time to time and the EULA in effect at the time a Licensed
User purchases a particular font software product shall apply to
that font software product. A breach of any such EULA will also
constitute a breach of this Agreement.  6.      Licensing Information
The FontExplorer X Software may contain license information
about the fonts that are loaded in its repository (e. g.
number of licenses per font). To the extent that you or a
Licensed User enter or change such license information, you
agree that such information is and will be at all times
correct and complete.
7.      Reservation of Rights 7.1     You acknowledge that the
FontExplorer X Software is protected by the copyright of the United
States of America, by the copyright laws of other nations, and by
international treaties. Neither you nor any Licensed User has rights
to the FontExplorer X Software other than as expressly set forth
in this Agreement. You agree that Monotype or its licensors owns
all right, title and interest in and to the FontExplorer X Software,
its structure, organization, code, and related files, including all
property rights therein such as copyright, design and trademarks
rights. You agree that the FontExplorer X Software, its structure,
organization, code, and related files (including, without limitation,
its metrics) are valuable property of Monotype and that any intentional
Use of the FontExplorer X Software not expressly permitted by this
Agreement constitutes a theft of valuable property. You agree to
treat the FontExplorer X Software as you would any other copyrighted
material, such as a book. All rights not expressly granted in this
Agreement are expressly reserved to Monotype.  7.2     Monotype,
the Monotype logo, FontExplorer X and other Monotype trademarks
used in connection with the FontExplorer X Software are trademarks
or registered trademarks of Monotype Imaging Inc. or Monotype GmbH
in the U.S., Germany and/or other countries. Neither you nor any
Licensed User is granted any right or license with respect to any
of the aforementioned trademarks or any use of such trademarks. You
agree to use trademarks associated with the FontExplorer X Software
according to accepted trademark practice, including identification
of the trademark owner’s name. The use of any trademark as herein
authorized does not give you any rights of ownership in that trademark
and all use of any trademark shall inure to the sole benefit of
Monotype.  8.      Warranty; Disclaimer of Warranty; Liability
Limitations 8.1     Monotype warrants to you that the FontExplorer X
Software will perform in accordance with its documentation for the
ninety (90) day period following delivery. To make a warranty claim,
you must, within the ninety (90) day warranty period, notify Monotype.
8.2     MONOTYPE DOES NOT WARRANT THE PERFORMANCE OR RESULTS YOU
MAY OBTAIN BY USING THE FONTEXPLORER X SOFTWARE. TO THE GREATEST
EXTENT PERMITTED BY LAW THE FOREGOING STATES THE SOLE AND EXCLUSIVE
REMEDIES FOR MONOTYPE’S BREACH OF WARRANTY. EXCEPT FOR THE FOREGOING
LIMITED WARRANTY, MONOTYPE MAKES NO REPRESENTATIONS OR WARRANTIES,
EXPRESS OR IMPLIED, AS TO NON-INFRINGEMENT OF THIRD PARTY RIGHTS,
MERCHANTABILITY, OR FITNESS FOR ANY PARTICULAR PURPOSE.  8.3     TO
THE EXTENT PERMITTED BY THE APPLICABLE LAW MONOTYPE WILL NOT BE
LIABLE TO YOU OR ANYONE ELSE (I) FOR ANY CONSEQUENTIAL, INCIDENTAL
OR SPECIAL DAMAGES, INCLUDING WITHOUT LIMITATION ANY LOST PROFITS,
LOST DATA, LOST BUSINESS OPPORTUNITIES, OR LOST SAVINGS, EVEN IF
MONOTYPE HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES, OR
(II) FOR ANY CLAIM AGAINST YOU BY ANY THIRD PARTY SEEKING SUCH
DAMAGES EVEN IF MONOTYPE HAS BEEN ADVISED OF THE POSSIBILITY OF
SUCH DAMAGES.  8.4     THE ABOVE LIMITATIONS OF LIABILITY WILL NOT
APPLY IF THE CAUSE OF THE DAMAGE WAS DELIBERATE OR DUE TO GROSS
NEGLIGENCE OR IF PERSONAL INJURY HAS OCCURRED. NEITHER WILL IT APPLY
IF YOU RAISE COMPULSORILY LEGALLY-BASED CLAIMS.  8.5     IN NO EVENT
SHALL MONOTYPE’S LIABILITY EXCEED ONE HUNDRED THOUSAND EURO (€
100,000.00), PROVIDED THAT THE APPLICABLE LAW PERMITS SUCH LIMITATION
OF LIABILITY.  8.6     To the greatest extent permitted by law, any
implied warranties not effectively excluded by this Agreement are
limited to thirty (30) days.  9.      Transfers
Unless you acquire the FontExplorer X Software through a
subscription or for a Trial Period you may transfer all
your rights to Use the FontExplorer X Software to another
person or legal entity provided that (i) all such software
must be transferred simultaneously, (ii) the transferee
accepts and agrees in writing to be bound by all the terms
and conditions of this Agreement, (iii) you forward a copy
of such writing to Monotype, (iv) you destroy all copies
of the FontExplorer X Software not transferred to the
transferee, including all copies stored in the memory of a
hardware device, and (v) you cease all Use of the FontExplorer X
Software.
10.     Term and Termination 10.1    If you acquire the FontExplorer
X Software through a subscription, this Agreement shall be effective
as of the date of acceptance of this Agreement and subscription to
the Monotype Web Fonts Service and will remain in effect for the
term of such subscription unless earlier terminated in accordance
with the terms hereof. If you acquire the FontExplorer X Software
for a Trial Period, the term of a Trial Period shall be from the
date of delivery of the FontExplorer X Software and shall terminate
automatically after the period defined in the communication between
you and Monotype. If no term is communicated then the Trial Period’s
term shall automatically end thirty (30) days after the delivery.
If you acquire the FontExplorer X Software by other means, this
Agreement shall be effective as of the date of acceptance of this
Agreement and will remain in effect unless terminated in accordance
with the terms hereof.  10.2    If you or any Licensed User fails
to comply with any of the provisions of this Agreement or any
Licensed User fails to comply with the terms of a EULA relating to
font software purchased through the FontExplorer X Pro Software,
Monotype, at its sole discretion, may (i) terminate this Agreement
and/or the account of any Licensed User, (ii) terminate any license
to font software purchased through the FontExplorer X Pro Software,
and/or (iii) preclude access to the service offered through the
FontExplorer X Software. The termination of this Agreement shall
not preclude Monotype from suing you for damages resulting from any
breach of this Agreement or any EULA relating to purchased font
software products.  10.3    You will remain liable for all amounts
due to Monotype up to and including the date of termination.  10.4
Upon termination of this Agreement, you must destroy the original
and any and all copies of, and cease all Use of, the FontExplorer X
Software.  11.     Miscellaneous 11.1    Governing Law and Forum.
Unless you enter into this agreement through the Monotype affiliate
Monotype Ltd. or Monotype GmbH, or unless otherwise set forth in
writing in the agreement between you and Monotype, the agreement
entered into between you and Monotype is governed by the laws of
Massachusetts applicable to contracts wholly entered and performable
within such Commonwealth (without regard to applicable conflict of
laws provisions). The United States District Court for the District
of Massachusetts or, if federal subject matter jurisdiction is
lacking, the Superior Court of the Commonwealth of Massachusetts
in Middlesex County, shall be the exclusive forum for any disputes
arising out of or related to such agreement. Both you and Monotype
agree to the personal jurisdiction and venue of these courts in any
action related to such agreement.
If you enter into this agreement through the Monotype
affiliate Monotype Ltd. the agreement is governed by the
laws of England and Wales (without regard to applicable
conflict of laws provisions). The courts of London, England,
shall be the exclusive forum for any disputes arising out
of or related to such agreement. Both you and Monotype Ltd.
agree to the personal jurisdiction and venue of these courts
in any action related to such agreement.  If you enter into
this agreement through the Monotype affiliate Monotype GmbH
the agreement is governed by the laws of Germany (without
regard to applicable conflict of laws provisions). The
courts of Frankfurt/Main, Germany, shall be the exclusive
forum for any disputes arising out of or related to such
agreement. Both you and Monotype GmbH agree to the personal
jurisdiction and venue of these courts in any action related
to such agreement.  The agreement will not be governed by
the United Nations Convention of Contracts for the International
Sale of Goods, the application of which is expressly excluded.
11.2            Supplementary Support. If you have entered into a
separate FontExplorer X Software support agreement or into another
prior FontExplorer X Software agreement that included support, the
support may continue as specified in the support agreement or prior
FontExplorer X Software agreement, notwithstanding any change of
the terms of this Agreement. The continued support may require a
renewal of the respective agreement.  11.3    Entire Agreement.
This Agreement, together with any agreement “clicked through” by
you in connection with the installation of the FontExplorer X Pro
Software or FontExplorer X Thin Client Software, constitutes the
entire agreement between you and Monotype that governs the use of
the FontExplorer X Software, superseding any prior agreements between
you and Monotype. Each party owes to the other party a duty to
co-operate in order to give full effect to this Agreement.  11.4
Severability. If any part of this Agreement is held invalid or
unenforceable, that portion shall be construed in a manner consistent
with applicable law to reflect, as nearly as possible, the original
intention of the parties, and the remaining portions shall remain
in full force and effect.  11.5    No Waiver. Monotype’s failure
to enforce any right or provisions in this Agreement will not
constitute a waiver of such provision, or any other provision of
this Agreement.  11.6    Government End Users. If this product is
acquired under the terms of a (i) GSA contract - use, reproduction
or disclosure is subject to the restrictions set forth in the
applicable ADP Schedule contract, (ii) DOD contract - use, duplication
or disclosure by the Government is subject to the applicable
restrictions set forth in DFARS 252.277-7013; (iii) Civilian agency
contract - use, reproduction, or disclosure is subject to FAR
52.277-19(a) through (d) and restrictions set forth in the Agreement.

FontExplorer X Software License Agreement clickthrough (v160909)
Checksumming Driver Descriptor Map (DDM : 0)…
Driver Descriptor Map (DDM : 0): verified CRC32 $DA8F7176
Checksumming Apple (Apple_partition_map : 1)…
Apple (Apple_partition_map : 1): verified CRC32 $73B16945
Checksumming disk image (Apple_HFS : 2)…
disk image (Apple_HFS : 2): verified CRC32 $256DD0EC
Checksumming  (Apple_Free : 3)…
(Apple_Free : 3): verified CRC32 $00000000
verified CRC32 $2B19FAF6
/dev/disk2          	Apple_partition_scheme
/dev/disk2s1        	Apple_partition_map
/dev/disk2s2        	Apple_HFS                      	/Volumes/FontExplorer X Pro

2022-05-12 20:41:20 : INFO  : fontexplorer : Mounted: /Volumes/FontExplorer X Pro
2022-05-12 20:41:20 : INFO  : fontexplorer : Verifying: /Volumes/FontExplorer X Pro/FontExplorer X Pro.app
2022-05-12 20:41:20 : DEBUG : fontexplorer : App size: 353M	/Volumes/FontExplorer X Pro/FontExplorer X Pro.app
2022-05-12 20:42:04 : DEBUG : fontexplorer : Debugging enabled, App Verification output was:
/Volumes/FontExplorer X Pro/FontExplorer X Pro.app: accepted
source=Notarized Developer ID
origin=Developer ID Application: Linotype GmbH (2V7G2B7WG4)

2022-05-12 20:42:04 : INFO  : fontexplorer : Team ID matching: 2V7G2B7WG4 (expected: 2V7G2B7WG4 )
2022-05-12 20:42:04 : INFO  : fontexplorer : Downloaded version of FontExplorer X Pro is 7.3.0 on versionKey CFBundleShortVersionString, same as installed.
2022-05-12 20:42:04 : DEBUG : fontexplorer : Unmounting /Volumes/FontExplorer X Pro
2022-05-12 20:42:15 : DEBUG : fontexplorer : Debugging enabled, Unmounting output was:
"disk2" ejected.
2022-05-12 20:42:15 : DEBUG : fontexplorer : DEBUG mode 1, not reopening anything
2022-05-12 20:42:15 : REG   : fontexplorer : No new version to install
2022-05-12 20:42:15 : REQ   : fontexplorer : ################## End Installomator, exit code 0
2022-05-12 20:43:43 +02:00
madtice
ab86ff3a45 Create filezilla.sh
Committing FileZilla install label.

2022-05-12 20:26:36 : REQ   : filezilla : ################## Start Installomator v. 9.2beta, date 2022-05-12
2022-05-12 20:26:36 : INFO  : filezilla : ################## Version: 9.2beta
2022-05-12 20:26:36 : INFO  : filezilla : ################## Date: 2022-05-12
2022-05-12 20:26:36 : INFO  : filezilla : ################## filezilla
2022-05-12 20:26:36 : DEBUG : filezilla : DEBUG mode 1 enabled.
2022-05-12 20:26:37 : INFO  : filezilla : BLOCKING_PROCESS_ACTION=tell_user
2022-05-12 20:26:37 : INFO  : filezilla : NOTIFY=success
2022-05-12 20:26:37 : INFO  : filezilla : LOGGING=DEBUG
2022-05-12 20:26:37 : INFO  : filezilla : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-05-12 20:26:37 : INFO  : filezilla : Label type: tbz
2022-05-12 20:26:37 : INFO  : filezilla : archiveName: FileZilla.tbz
2022-05-12 20:26:37 : DEBUG : filezilla : Changing directory to /Users/thijs/gits/Installomator/build
2022-05-12 20:26:37 : INFO  : filezilla : No version found using packageID org.filezilla-project.filezilla
2022-05-12 20:26:37 : INFO  : filezilla : App(s) found: /Applications/FileZilla.app
2022-05-12 20:26:37 : INFO  : filezilla : found app at /Applications/FileZilla.app, version 3.59.0, on versionKey CFBundleShortVersionString
2022-05-12 20:26:37 : INFO  : filezilla : appversion: 3.59.0
2022-05-12 20:26:37 : INFO  : filezilla : Latest version of FileZilla is 3.59.0
2022-05-12 20:26:37 : WARN  : filezilla : DEBUG mode 1 enabled, not exiting, but there is no new version of app.
2022-05-12 20:26:37 : REQ   : filezilla : Downloading https://dl1.cdn.filezilla-project.org/client/FileZilla_3.59.0_macosx-x86.app.tar.bz2?h=EVqCnT_iz7cNzenu63lrtA&x=1652383597 to FileZilla.tbz
2022-05-12 20:26:39 : DEBUG : filezilla : File list: -rw-r--r--  1 root  staff    14M May 12 20:26 FileZilla.tbz
2022-05-12 20:26:39 : DEBUG : filezilla : File type: FileZilla.tbz: bzip2 compressed data, block size = 900k
2022-05-12 20:26:39 : DEBUG : filezilla : curl output was:
*   Trying 195.201.43.134:443...
* Connected to dl1.cdn.filezilla-project.org (195.201.43.134) port 443 (#0)
* ALPN, offering h2
* ALPN, offering http/1.1
* successfully set certificate verify locations:
*  CAfile: /etc/ssl/cert.pem
*  CApath: none
* (304) (OUT), TLS handshake, Client hello (1):
} [334 bytes data]
* (304) (IN), TLS handshake, Server hello (2):
{ [122 bytes data]
* (304) (IN), TLS handshake, Unknown (8):
{ [15 bytes data]
* (304) (IN), TLS handshake, Certificate (11):
{ [4056 bytes data]
* (304) (IN), TLS handshake, CERT verify (15):
{ [264 bytes data]
* (304) (IN), TLS handshake, Finished (20):
{ [52 bytes data]
* (304) (OUT), TLS handshake, Finished (20):
} [52 bytes data]
* SSL connection using TLSv1.3 / AEAD-AES256-GCM-SHA384
* ALPN, server accepted to use h2
* Server certificate:
*  subject: CN=dl1.cdn.filezilla-project.org
*  start date: Apr 27 04:25:27 2022 GMT
*  expire date: Jul 26 04:25:26 2022 GMT
*  subjectAltName: host "dl1.cdn.filezilla-project.org" matched cert's "dl1.cdn.filezilla-project.org"
*  issuer: C=US; O=Let's Encrypt; CN=R3
*  SSL certificate verify ok.
* Using HTTP2, server supports multiplexing
* Connection state changed (HTTP/2 confirmed)
* Copying HTTP/2 data in stream buffer to connection buffer after upgrade: len=0
* Using Stream ID: 1 (easy handle 0x7fd08180ca00)
> GET /client/FileZilla_3.59.0_macosx-x86.app.tar.bz2?h=EVqCnT_iz7cNzenu63lrtA&x=1652383597 HTTP/2
> Host: dl1.cdn.filezilla-project.org
> user-agent: curl/7.79.1
> accept: */*
>
* Connection state changed (MAX_CONCURRENT_STREAMS == 128)!
< HTTP/2 200
< server: nginx
< date: Thu, 12 May 2022 18:26:37 GMT
< content-type: application/octet-stream
< content-length: 14669261
< last-modified: Fri, 08 Apr 2022 14:36:35 GMT
< etag: "62504873-dfd5cd"
< x-robots-tag: noindex, nofollow
< strict-transport-security: max-age=31536000; includeSubDomains; preload
< accept-ranges: bytes
<
{ [16160 bytes data]
* Connection #0 to host dl1.cdn.filezilla-project.org left intact

2022-05-12 20:26:39 : REQ   : filezilla : Installing FileZilla
2022-05-12 20:26:39 : INFO  : filezilla : Unzipping FileZilla.tbz
2022-05-12 20:26:41 : INFO  : filezilla : Verifying: /Users/thijs/gits/Installomator/build/FileZilla.app
2022-05-12 20:26:41 : DEBUG : filezilla : App size:  44M	/Users/thijs/gits/Installomator/build/FileZilla.app
2022-05-12 20:26:42 : DEBUG : filezilla : Debugging enabled, App Verification output was:
/Users/thijs/gits/Installomator/build/FileZilla.app: accepted
source=Notarized Developer ID
origin=Developer ID Application: Tim Kosse (5VPGKXL75N)

2022-05-12 20:26:42 : INFO  : filezilla : Team ID matching: 5VPGKXL75N (expected: 5VPGKXL75N )
2022-05-12 20:26:42 : INFO  : filezilla : Downloaded version of FileZilla is 3.59.0 on versionKey CFBundleShortVersionString, same as installed.
2022-05-12 20:26:42 : DEBUG : filezilla : DEBUG mode 1, not reopening anything
2022-05-12 20:26:42 : REG   : filezilla : No new version to install
2022-05-12 20:26:42 : REQ   : filezilla : ################## End Installomator, exit code 0
2022-05-12 20:27:32 +02:00
Armin Briegel
0ff286b701 Merge branch 'pr/394', closes #394 2022-05-12 15:48:19 +02:00
Armin Briegel
ad5ad5f408 Merge pull request #394 from willpolley/dev
Added label propresenter7
2022-05-12 15:47:22 +02:00
Armin Briegel
c9fc5d6676 Merge pull request #484 from 0x4448/bugfix-googlechromepkg-missing-appnewversion
Add latest version check for googlechromepkg
2022-05-12 15:41:39 +02:00
Armin Briegel
e1dc3cc464 Merge branch 'pr/492' into main, closes #492 2022-05-12 15:37:42 +02:00
Armin Briegel
aed48ea4b4 Merge new label slab, closes #487 2022-05-12 15:36:09 +02:00
Armin Briegel
343785781a fixed line ending 2022-05-12 15:34:58 +02:00
Armin Briegel
1e8253ca41 Merge pull request #490 from jasmania2/New-Label-SonoBus
New Label- SonoBus
2022-05-12 15:25:45 +02:00
Armin Briegel
69fbc31078 Merge pull request #492 from lart2150/bugfix/ringcentralapp
updates for ringcentral app
2022-05-12 15:24:13 +02:00
Armin Briegel
77e04922e5 merged firefox_intl, closes #495 2022-05-12 15:09:59 +02:00
Armin Briegel
ac80aa1f3a Merge branch 'main' of github.com:Installomator/Installomator 2022-05-12 15:04:21 +02:00
Armin Briegel
a87122409a merged firefoxesr_intl, closes #496 2022-05-12 15:04:11 +02:00
Armin Briegel
963282dbe1 Merge pull request #497 from sidbena/thunderbird_intl
Added support for label thunderbird_intl
2022-05-12 14:45:54 +02:00
Armin Briegel
7cc01840e0 merge snagit updates, closes #498 2022-05-12 14:40:53 +02:00
Armin Briegel
8d0f037983 fixed label name for snagit2021 2022-05-12 14:40:21 +02:00
Armin Briegel
abbf22455f Merge pull request #499 from marcelpogorzelski/Update-Camtasia
Update Camtasia 2021
2022-05-12 14:32:26 +02:00
Armin Briegel
d86aef9ede Merge pull request #502 from unfo33/unfo33-patch-1
Create macoslaps.sh
2022-05-12 14:25:25 +02:00
Armin Briegel
35f3b938bc Merge pull request #503 from patrix87/main
Fix Adobe Acrobat Reader DC download & Add Unnatural Scroll Wheels
2022-05-12 14:23:50 +02:00
Armin Briegel
fad95d156a merges updates for firefoxpkg and gpgsuite, closes #465 2022-05-12 14:14:28 +02:00
Armin Briegel
2012395021 Merge pull request #501 from MacMike077/main
Create NewLabel Flycut.sh
2022-05-12 14:07:36 +02:00
Armin Briegel
e21d8d4ef2 Merge pull request #485 from Installomator/README-members
Change the mentioning of members with link to profiles.
2022-05-12 14:02:15 +02:00
Armin Briegel
d4b2200ca9 merge atextlegacy, closes #464 2022-05-12 13:56:46 +02:00
Armin Briegel
4700957764 added new label file for atextlegacy, see #464 2022-05-12 13:55:55 +02:00
Armin Briegel
8ba02428a0 Merge pull request #463 from adibue/adibue-update-rancherdesktop
Update 'rancherdesktop' to support arm64
2022-05-12 11:08:11 +02:00
Armin Briegel
a3021011c0 update label amazoncorretto8jdk, closes 461 2022-05-12 10:53:48 +02:00
Armin Briegel
f0a91934de update label postman, closes #458 2022-05-12 10:51:37 +02:00
Armin Briegel
412fcca624 Merge branch 'pr/457' 2022-05-12 10:45:50 +02:00
Armin Briegel
4e31bd16a0 reset version.sh 2022-05-12 10:45:28 +02:00
Armin Briegel
cbdc1c6876 Merge pull request #454 from adibue/adibue-update-onlyofficedesktop
Updated 'onlyofficedesktop'
2022-05-12 10:40:27 +02:00
Armin Briegel
e4f5b9cb47 Merge pull request #453 from buckbanzai/buckbanzai-improvements-talkdeskcallbar
Update talkdeskcallbar label
2022-05-12 10:37:46 +02:00
Armin Briegel
046df34e45 reset version.sh 2022-05-12 10:36:09 +02:00
Armin Briegel
fc3ba293ae Merge pull request #452 from buckbanzai/buckbanzai-add-talkdeskcxcloud
Add Label for Talkdesk CX Cloud Desktop
2022-05-12 10:32:32 +02:00
Armin Briegel
e1de1433ff Merge branch 'pr/450' 2022-05-12 10:28:41 +02:00
Armin Briegel
cd5a4b2b5e Merge pull request #450 from bbenkle/dev
DBeaverCE
2022-05-12 10:24:17 +02:00
Armin Briegel
d1bb003a8d Merge branch 'main' of github.com:Installomator/Installomator 2022-05-12 10:12:19 +02:00
Armin Briegel
8a9a94540a Merge pull request #479 from marcelpogorzelski/MindManager
Create MindManager Label
2022-05-12 10:10:34 +02:00
Armin Briegel
d20dec9e2e Merge branch 'pr/480' 2022-05-12 09:54:14 +02:00
Armin Briegel
6bb5fedc21 missing linebreak 2022-05-12 09:53:52 +02:00
Armin Briegel
5a5addcb2e Merge pull request #480 from samess-flowers/DrawIO
Draw io
2022-05-12 09:51:41 +02:00
Armin Briegel
3e89333395 Merge pull request #481 from marcelpogorzelski/Clue
Label for both Clue appliations
2022-05-12 09:46:04 +02:00
Armin Briegel
aa762ecee2 Merge pull request #455 from Installomator/Theile-labels-2022-03
Theile labels 2022 03
2022-05-12 09:43:02 +02:00
Armin Briegel
c89f704817 Merge pull request #466 from Installomator/Extra-warning-log-for-googlechrome-and-firefox-labels
Extra logging for firefox and googlechrome labels.
2022-05-12 09:41:57 +02:00
Armin Briegel
bf353dc538 Merge branch 'main' of github.com:Installomator/Installomator 2022-05-12 09:40:51 +02:00
Armin Briegel
07d51c3239 Merge pull request #434 from Installomator/Fix-for-applist-line
Update functions.sh
2022-05-12 09:39:59 +02:00
Armin Briegel
973de91ff4 Merge branch 'main-v9.2' 2022-05-12 09:38:56 +02:00
Armin Briegel
3cf7b585ef added displaylinkmananger, closes #448 2022-05-12 09:37:38 +02:00
Armin Briegel
da5585a702 logitechoptions update, closes #478 2022-05-12 09:34:05 +02:00
Greg R
1571dec014 New App: Linear (https://linear.app/)
adding in a new app label for the Linear app.
2022-05-10 13:55:56 -07:00
DavidTaylor
2b3da07cdb Add Label: Shottr 2022-05-05 23:30:59 -07:00
Andrew Clark
259afeec3a Update Grammarly Label 2022-05-05 16:07:08 +00:00
Micah Lee
13864a0cd7 Add appName and archiveName for 1password8 2022-05-04 15:23:04 -07:00
Micah Lee
66f3275741 Add 1Password 8 2022-05-04 15:06:22 -07:00
Fletcher Salesky
b76d9fe26a Create egnytewebedit.sh 2022-05-04 12:24:14 -07:00
Fletcher Salesky
4d365aa960 Create wechat.sh 2022-05-03 14:28:49 -07:00
worthypants
589747f0ad Create new label idrivethin 2022-05-03 17:00:22 +02:00
worthypants
3294751e63 Revert "Create new label idrivethin"
This reverts commit 03f3e258e4.
2022-05-03 16:54:22 +02:00
worthypants
03f3e258e4 Create new label idrivethin 2022-05-03 16:52:58 +02:00
marcelpogorzelski
78eec85809 Fixed appNewVersion
Cut didn't work so I changed it to awk
2022-05-03 16:42:24 +02:00
worthypants
dd50a618e9 Revert "Create new label idrivethin"
This reverts commit 8b5f5d40c9.
2022-05-03 16:42:02 +02:00
worthypants
8b5f5d40c9 Create new label idrivethin 2022-05-03 16:41:40 +02:00
marcelpogorzelski
143967e29c New Line fix 2022-05-03 16:38:21 +02:00
marcelpogorzelski
ad1ddc22cd Camtasia 2021 download URL improvement 2022-05-03 16:37:06 +02:00
worthypants
01d00aa361 Revert "Create new label idrivethin"
This reverts commit 0141b8334e.
2022-05-03 16:35:14 +02:00
marcelpogorzelski
f90c9c960a Saparated Snagit installers by year 2022-05-03 16:30:07 +02:00
worthypants
0141b8334e Create new label idrivethin 2022-05-03 16:28:31 +02:00
marcelpogorzelski
f7d822a54e Added separate Camtasia 2020 and 2019 labels 2022-05-03 16:11:19 +02:00
worthypants
ed01f6d741 Create new label iDrive 2022-05-03 15:51:45 +02:00
MacMike077
0266f74e46 Create UltimakerCura.sh
2022-05-02 16:45:27 : REQ   : ultimakercura : ################## Start Installomator v. 9.1, date 2022-03-18
2022-05-02 16:45:27 : INFO  : ultimakercura : ################## Version: 9.1
2022-05-02 16:45:27 : INFO  : ultimakercura : ################## Date: 2022-03-18
2022-05-02 16:45:27 : INFO  : ultimakercura : ################## ultimakercura
2022-05-02 16:45:28 : INFO  : ultimakercura : BLOCKING_PROCESS_ACTION=tell_user
2022-05-02 16:45:28 : INFO  : ultimakercura : NOTIFY=success
2022-05-02 16:45:28 : INFO  : ultimakercura : LOGGING=INFO
2022-05-02 16:45:28 : INFO  : ultimakercura : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-05-02 16:45:28 : INFO  : ultimakercura : Label type: dmg
2022-05-02 16:45:28 : INFO  : ultimakercura : archiveName: Ultimaker_Cura-[0-9].*-Darwin.dmg
2022-05-02 16:45:28 : INFO  : ultimakercura : no blocking processes defined, using Ultimaker Cura as default
2022-05-02 16:45:28 : INFO  : ultimakercura : name: Ultimaker Cura, appName: Ultimaker Cura.app
2022-05-02 16:45:28 : INFO  : ultimakercura : App(s) found: 
2022-05-02 16:45:28 : WARN  : ultimakercura : could not find Ultimaker Cura.app
2022-05-02 16:45:28 : INFO  : ultimakercura : appversion: 
2022-05-02 16:45:28 : INFO  : ultimakercura : Latest version of Ultimaker Cura is 4.13.1
2022-05-02 16:45:28 : REQ   : ultimakercura : Downloading https://github.com/Ultimaker/Cura/releases/download/4.13.1/Ultimaker_Cura-4.13.1-Darwin.dmg to Ultimaker_Cura-[0-9].*-Darwin.dmg
2022-05-02 16:45:34 : REQ   : ultimakercura : no more blocking processes, continue with update
2022-05-02 16:45:34 : REQ   : ultimakercura : Installing Ultimaker Cura
2022-05-02 16:45:34 : INFO  : ultimakercura : Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.WFz2hZIw/Ultimaker_Cura-[0-9].*-Darwin.dmg
2022-05-02 16:45:38 : INFO  : ultimakercura : Mounted: /Volumes/Ultimaker_Cura-4.13.1-Darwin
2022-05-02 16:45:38 : INFO  : ultimakercura : Verifying: /Volumes/Ultimaker_Cura-4.13.1-Darwin/Ultimaker Cura.app
2022-05-02 16:45:51 : INFO  : ultimakercura : Team ID matching: V4B3JXRRQS (expected: V4B3JXRRQS )
2022-05-02 16:45:51 : INFO  : ultimakercura : Installing Ultimaker Cura version 4.13 on versionKey CFBundleShortVersionString.
2022-05-02 16:45:51 : INFO  : ultimakercura : Copy /Volumes/Ultimaker_Cura-4.13.1-Darwin/Ultimaker Cura.app to /Applications
2022-05-02 16:46:04 : WARN  : ultimakercura : No user logged in or SYSTEMOWNER=1, setting owner to root:wheel
2022-05-02 16:46:04 : INFO  : ultimakercura : Finishing...
2022-05-02 16:46:14 : INFO  : ultimakercura : App(s) found: /Applications/Ultimaker Cura.app
2022-05-02 16:46:14 : INFO  : ultimakercura : found app at /Applications/Ultimaker Cura.app, version 4.13, on versionKey CFBundleShortVersionString
2022-05-02 16:46:14 : REQ   : ultimakercura : Installed Ultimaker Cura, version 4.13
2022-05-02 16:46:14 : INFO  : ultimakercura : notifying
2022-05-02 16:46:15 : INFO  : ultimakercura : App not closed, so no reopen.
2022-05-02 16:46:15 : REQ   : ultimakercura : All done!
2022-05-02 16:46:15 : REQ   : ultimakercura : ################## End Installomator, exit code 0
2022-05-02 16:47:59 +02:00
Søren Theilgaard
744ce4949d Update remotedesktopmanagerenterprise.sh 2022-04-29 14:31:10 +02:00
Søren Theilgaard
5dc137dcbe Remote Desktop Manager changed domain
Result free version
```
➜  Installomator/utils/assemble.sh remotedesktopmanagerfree DEBUG=0
Password:
2022-04-29 13:33:24 : WARN  : remotedesktopmanagerfree : setting variable from argument DEBUG=0
2022-04-29 13:33:24 : REQ   : remotedesktopmanagerfree : ################## Start Installomator v. 10dev, date 2022-04-29
2022-04-29 13:33:24 : INFO  : remotedesktopmanagerfree : ################## Version: 10dev
2022-04-29 13:33:24 : INFO  : remotedesktopmanagerfree : ################## Date: 2022-04-29
2022-04-29 13:33:24 : INFO  : remotedesktopmanagerfree : ################## remotedesktopmanagerfree
2022-04-29 13:33:35 : INFO  : remotedesktopmanagerfree : BLOCKING_PROCESS_ACTION=tell_user
2022-04-29 13:33:35 : INFO  : remotedesktopmanagerfree : NOTIFY=success
2022-04-29 13:33:35 : INFO  : remotedesktopmanagerfree : LOGGING=INFO
2022-04-29 13:33:35 : INFO  : remotedesktopmanagerfree : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-04-29 13:33:35 : INFO  : remotedesktopmanagerfree : Label type: dmg
2022-04-29 13:33:35 : INFO  : remotedesktopmanagerfree : archiveName: Remote Desktop Manager Free.dmg
2022-04-29 13:33:35 : INFO  : remotedesktopmanagerfree : no blocking processes defined, using Remote Desktop Manager Free as default
2022-04-29 13:33:35 : INFO  : remotedesktopmanagerfree : App(s) found: /Applications/Remote Desktop Manager Free.app
2022-04-29 13:33:35 : INFO  : remotedesktopmanagerfree : found app at /Applications/Remote Desktop Manager Free.app, version 2021.2.14.0, on versionKey CFBundleShortVersionString
2022-04-29 13:33:35 : INFO  : remotedesktopmanagerfree : appversion: 2021.2.14.0
2022-04-29 13:33:35 : INFO  : remotedesktopmanagerfree : Latest version of Remote Desktop Manager Free is 2022.1.12.0
2022-04-29 13:33:35 : REQ   : remotedesktopmanagerfree : Downloading https://cdn.devolutions.net/download/Mac/Devolutions.RemoteDesktopManager.Free.Mac.2022.1.12.0.dmg to Remote Desktop Manager Free.dmg
2022-04-29 13:34:05 : REQ   : remotedesktopmanagerfree : no more blocking processes, continue with update
2022-04-29 13:34:05 : REQ   : remotedesktopmanagerfree : Installing Remote Desktop Manager Free
2022-04-29 13:34:05 : INFO  : remotedesktopmanagerfree : Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.isdXwxzs/Remote Desktop Manager Free.dmg
2022-04-29 13:34:10 : INFO  : remotedesktopmanagerfree : Mounted: /Volumes/Remote Desktop Manager Free.app Installer
2022-04-29 13:34:10 : INFO  : remotedesktopmanagerfree : Verifying: /Volumes/Remote Desktop Manager Free.app Installer/Remote Desktop Manager Free.app
2022-04-29 13:34:21 : INFO  : remotedesktopmanagerfree : Team ID matching: N592S9ASDB (expected: N592S9ASDB )
2022-04-29 13:34:21 : INFO  : remotedesktopmanagerfree : Downloaded version of Remote Desktop Manager Free is 2022.1.12.0 on versionKey CFBundleShortVersionString (replacing version 2021.2.14.0).
2022-04-29 13:34:21 : INFO  : remotedesktopmanagerfree : App has LSMinimumSystemVersion: 10.10
2022-04-29 13:34:21 : WARN  : remotedesktopmanagerfree : Removing existing /Applications/Remote Desktop Manager Free.app
2022-04-29 13:34:21 : INFO  : remotedesktopmanagerfree : Copy /Volumes/Remote Desktop Manager Free.app Installer/Remote Desktop Manager Free.app to /Applications
2022-04-29 13:34:24 : WARN  : remotedesktopmanagerfree : Changing owner to st
2022-04-29 13:34:24 : INFO  : remotedesktopmanagerfree : Finishing...
2022-04-29 13:34:34 : INFO  : remotedesktopmanagerfree : App(s) found: /Applications/Remote Desktop Manager Free.app
2022-04-29 13:34:34 : INFO  : remotedesktopmanagerfree : found app at /Applications/Remote Desktop Manager Free.app, version 2022.1.12.0, on versionKey CFBundleShortVersionString
2022-04-29 13:34:34 : REQ   : remotedesktopmanagerfree : Installed Remote Desktop Manager Free, version 2022.1.12.0
2022-04-29 13:34:34 : INFO  : remotedesktopmanagerfree : notifying
2022-04-29 13:34:35 : INFO  : remotedesktopmanagerfree : App not closed, so no reopen.
2022-04-29 13:34:35 : REQ   : remotedesktopmanagerfree : All done!
2022-04-29 13:34:35 : REQ   : remotedesktopmanagerfree : ################## End Installomator, exit code 0
```

Enterprise version:
```
➜  Installomator/utils/assemble.sh remotedesktopmanagerenterprise DEBUG=0 INSTALL=force
2022-04-29 13:35:51 : WARN  : remotedesktopmanagerenterprise : setting variable from argument DEBUG=0
2022-04-29 13:35:51 : WARN  : remotedesktopmanagerenterprise : setting variable from argument INSTALL=force
2022-04-29 13:35:51 : REQ   : remotedesktopmanagerenterprise : ################## Start Installomator v. 10dev, date 2022-04-29
2022-04-29 13:35:51 : INFO  : remotedesktopmanagerenterprise : ################## Version: 10dev
2022-04-29 13:35:51 : INFO  : remotedesktopmanagerenterprise : ################## Date: 2022-04-29
2022-04-29 13:35:51 : INFO  : remotedesktopmanagerenterprise : ################## remotedesktopmanagerenterprise
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : BLOCKING_PROCESS_ACTION=tell_user
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : NOTIFY=success
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : LOGGING=INFO
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : Label type: dmg
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : archiveName: Remote Desktop Manager.dmg
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : no blocking processes defined, using Remote Desktop Manager as default
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : name: Remote Desktop Manager, appName: Remote Desktop Manager.app
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : App(s) found: /Applications/Remote Desktop Manager Free.app
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : found app at /Applications/Remote Desktop Manager Free.app, version 2022.1.12.0, on versionKey CFBundleShortVersionString
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : appversion: 2022.1.12.0
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : Label is not of type “updateronly”, and it’s set to use force to install or ignoring app store apps, so not using updateTool.
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : Latest version of Remote Desktop Manager is 2022.1.12.0
2022-04-29 13:35:52 : INFO  : remotedesktopmanagerenterprise : There is no newer version available.
2022-04-29 13:35:52 : REQ   : remotedesktopmanagerenterprise : Downloading https://cdn.devolutions.net/download/Mac/Devolutions.RemoteDesktopManager.Mac.2022.1.12.0.dmg to Remote Desktop Manager.dmg
2022-04-29 13:36:24 : REQ   : remotedesktopmanagerenterprise : no more blocking processes, continue with update
2022-04-29 13:36:24 : REQ   : remotedesktopmanagerenterprise : Installing Remote Desktop Manager
2022-04-29 13:36:24 : INFO  : remotedesktopmanagerenterprise : Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.cOMzga0I/Remote Desktop Manager.dmg
2022-04-29 13:36:27 : INFO  : remotedesktopmanagerenterprise : Mounted: /Volumes/Remote Desktop Manager.app Installer
2022-04-29 13:36:27 : INFO  : remotedesktopmanagerenterprise : Verifying: /Volumes/Remote Desktop Manager.app Installer/Remote Desktop Manager.app
2022-04-29 13:36:32 : INFO  : remotedesktopmanagerenterprise : Team ID matching: N592S9ASDB (expected: N592S9ASDB )
2022-04-29 13:36:32 : INFO  : remotedesktopmanagerenterprise : Downloaded version of Remote Desktop Manager is 2022.1.12.0 on versionKey CFBundleShortVersionString, same as installed.
2022-04-29 13:36:32 : INFO  : remotedesktopmanagerenterprise : Using force to install anyway.
2022-04-29 13:36:32 : INFO  : remotedesktopmanagerenterprise : App has LSMinimumSystemVersion: 10.10
2022-04-29 13:36:32 : INFO  : remotedesktopmanagerenterprise : Copy /Volumes/Remote Desktop Manager.app Installer/Remote Desktop Manager.app to /Applications
2022-04-29 13:36:35 : WARN  : remotedesktopmanagerenterprise : Changing owner to st
2022-04-29 13:36:35 : INFO  : remotedesktopmanagerenterprise : Finishing...
2022-04-29 13:36:45 : INFO  : remotedesktopmanagerenterprise : App(s) found: /Applications/Remote Desktop Manager.app
2022-04-29 13:36:45 : INFO  : remotedesktopmanagerenterprise : found app at /Applications/Remote Desktop Manager.app, version 2022.1.12.0, on versionKey CFBundleShortVersionString
2022-04-29 13:36:45 : REQ   : remotedesktopmanagerenterprise : Installed Remote Desktop Manager, version 2022.1.12.0
2022-04-29 13:36:45 : INFO  : remotedesktopmanagerenterprise : notifying
2022-04-29 13:36:45 : INFO  : remotedesktopmanagerenterprise : App not closed, so no reopen.
2022-04-29 13:36:45 : REQ   : remotedesktopmanagerenterprise : All done!
2022-04-29 13:36:45 : REQ   : remotedesktopmanagerenterprise : ################## End Installomator, exit code 0
```
2022-04-29 13:44:41 +02:00
Patrick Veilleux
e464efeb82 Unnatural Scroll Wheels 2022-04-28 15:11:33 -04:00
Patrick Veilleux
4bfbe5e404 fix adobe acrobat reader DC download 2022-04-28 15:10:07 -04:00
Thomas Bartlett
7e6d394c68 Create macoslaps.sh 2022-04-28 11:58:15 -04:00
Søren Theilgaard
2589d2ec38 Update to duckduckgo as appcast was changed
The appcast url now has the newest version at the top. I guess we should sort the list if the newest will be moved again.
Now this result:
```
➜  Installomator/utils/assemble.sh duckduckgo DEBUG=0
2022-04-26 21:51:22 : WARN  : duckduckgo : setting variable from argument DEBUG=0
2022-04-26 21:51:22 : REQ   : duckduckgo : ################## Start Installomator v. 10dev, date 2022-04-26
2022-04-26 21:51:22 : INFO  : duckduckgo : ################## Version: 10dev
2022-04-26 21:51:22 : INFO  : duckduckgo : ################## Date: 2022-04-26
2022-04-26 21:51:22 : INFO  : duckduckgo : ################## duckduckgo
2022-04-26 21:51:22 : INFO  : duckduckgo : BLOCKING_PROCESS_ACTION=tell_user
2022-04-26 21:51:22 : INFO  : duckduckgo : NOTIFY=success
2022-04-26 21:51:22 : INFO  : duckduckgo : LOGGING=INFO
2022-04-26 21:51:22 : INFO  : duckduckgo : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-04-26 21:51:22 : INFO  : duckduckgo : Label type: dmg
2022-04-26 21:51:22 : INFO  : duckduckgo : archiveName: DuckDuckGo.dmg
2022-04-26 21:51:22 : INFO  : duckduckgo : no blocking processes defined, using DuckDuckGo as default
2022-04-26 21:51:22 : INFO  : duckduckgo : App(s) found: /Applications/DuckDuckGo.app
2022-04-26 21:51:22 : INFO  : duckduckgo : found app at /Applications/DuckDuckGo.app, version 0.22.3, on versionKey CFBundleShortVersionString
2022-04-26 21:51:22 : INFO  : duckduckgo : appversion: 0.22.3
2022-04-26 21:51:22 : INFO  : duckduckgo : Latest version of DuckDuckGo is 0.23.0
2022-04-26 21:51:22 : REQ   : duckduckgo : Downloading https://staticcdn.duckduckgo.com/macos-desktop-browser/duckduckgo-0.23.0.dmg to DuckDuckGo.dmg
2022-04-26 21:51:24 : REQ   : duckduckgo : no more blocking processes, continue with update
2022-04-26 21:51:24 : REQ   : duckduckgo : Installing DuckDuckGo
2022-04-26 21:51:24 : INFO  : duckduckgo : Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.lQwUqkMi/DuckDuckGo.dmg
2022-04-26 21:51:28 : INFO  : duckduckgo : Mounted: /Volumes/DuckDuckGo
2022-04-26 21:51:28 : INFO  : duckduckgo : Verifying: /Volumes/DuckDuckGo/DuckDuckGo.app
2022-04-26 21:51:29 : INFO  : duckduckgo : Team ID matching: HKE973VLUW (expected: HKE973VLUW )
2022-04-26 21:51:29 : INFO  : duckduckgo : Downloaded version of DuckDuckGo is 0.23.0 on versionKey CFBundleShortVersionString (replacing version 0.22.3).
2022-04-26 21:51:29 : INFO  : duckduckgo : App has LSMinimumSystemVersion: 10.15
2022-04-26 21:51:29 : WARN  : duckduckgo : Removing existing /Applications/DuckDuckGo.app
2022-04-26 21:51:29 : INFO  : duckduckgo : Copy /Volumes/DuckDuckGo/DuckDuckGo.app to /Applications
2022-04-26 21:51:29 : WARN  : duckduckgo : Changing owner to st
2022-04-26 21:51:29 : INFO  : duckduckgo : Finishing...
2022-04-26 21:51:39 : INFO  : duckduckgo : App(s) found: /Applications/DuckDuckGo.app
2022-04-26 21:51:39 : INFO  : duckduckgo : found app at /Applications/DuckDuckGo.app, version 0.23.0, on versionKey CFBundleShortVersionString
2022-04-26 21:51:39 : REQ   : duckduckgo : Installed DuckDuckGo, version 0.23.0
2022-04-26 21:51:39 : INFO  : duckduckgo : notifying
2022-04-26 21:51:40 : INFO  : duckduckgo : App not closed, so no reopen.
2022-04-26 21:51:40 : REQ   : duckduckgo : All done!
2022-04-26 21:51:40 : REQ   : duckduckgo : ################## End Installomator, exit code 0
```
2022-04-26 21:53:57 +02:00
Søren Theilgaard
9307374775 mightymike now has now been signed
```
➜  Installomator/utils/assemble.sh mightymike DEBUG=0
2022-04-26 20:50:59 : WARN  : mightymike : setting variable from argument DEBUG=0
2022-04-26 20:50:59 : REQ   : mightymike : ################## Start Installomator v. 10dev, date 2022-04-26
2022-04-26 20:50:59 : INFO  : mightymike : ################## Version: 10dev
2022-04-26 20:51:00 : INFO  : mightymike : ################## Date: 2022-04-26
2022-04-26 20:51:00 : INFO  : mightymike : ################## mightymike
2022-04-26 20:51:00 : INFO  : mightymike : BLOCKING_PROCESS_ACTION=tell_user
2022-04-26 20:51:00 : INFO  : mightymike : NOTIFY=success
2022-04-26 20:51:00 : INFO  : mightymike : LOGGING=INFO
2022-04-26 20:51:00 : INFO  : mightymike : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-04-26 20:51:00 : INFO  : mightymike : Label type: dmg
2022-04-26 20:51:00 : INFO  : mightymike : archiveName: Mighty Mike.dmg
2022-04-26 20:51:00 : INFO  : mightymike : no blocking processes defined, using Mighty Mike as default
2022-04-26 20:51:00 : INFO  : mightymike : name: Mighty Mike, appName: Mighty Mike.app
2022-04-26 20:51:00 : INFO  : mightymike : App(s) found:
2022-04-26 20:51:00 : WARN  : mightymike : could not find Mighty Mike.app
2022-04-26 20:51:00 : INFO  : mightymike : appversion:
2022-04-26 20:51:00 : INFO  : mightymike : Latest version of Mighty Mike is 3.0.1
2022-04-26 20:51:00 : REQ   : mightymike : Downloading https://github.com/jorio/MightyMike/releases/download/v3.0.1/MightyMike-3.0.1-mac.dmg to Mighty Mike.dmg
2022-04-26 20:51:02 : REQ   : mightymike : no more blocking processes, continue with update
2022-04-26 20:51:02 : REQ   : mightymike : Installing Mighty Mike
2022-04-26 20:51:02 : INFO  : mightymike : Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.fKf0WTjS/Mighty Mike.dmg
2022-04-26 20:51:05 : INFO  : mightymike : Mounted: /Volumes/Mighty Mike 3.0.1
2022-04-26 20:51:05 : INFO  : mightymike : Verifying: /Volumes/Mighty Mike 3.0.1/Mighty Mike.app
2022-04-26 20:51:06 : INFO  : mightymike : Team ID matching: RVNL7XC27G (expected: RVNL7XC27G )
2022-04-26 20:51:06 : INFO  : mightymike : Installing Mighty Mike version 3.0.1 on versionKey CFBundleShortVersionString.
2022-04-26 20:51:06 : INFO  : mightymike : App has LSMinimumSystemVersion: 10.11
2022-04-26 20:51:06 : INFO  : mightymike : Copy /Volumes/Mighty Mike 3.0.1/Mighty Mike.app to /Applications
2022-04-26 20:51:06 : WARN  : mightymike : Changing owner to st
2022-04-26 20:51:06 : INFO  : mightymike : Finishing...
2022-04-26 20:51:16 : INFO  : mightymike : App(s) found: /Applications/Mighty Mike.app
2022-04-26 20:51:16 : INFO  : mightymike : found app at /Applications/Mighty Mike.app, version 3.0.1, on versionKey CFBundleShortVersionString
2022-04-26 20:51:16 : REQ   : mightymike : Installed Mighty Mike, version 3.0.1
2022-04-26 20:51:16 : INFO  : mightymike : notifying
2022-04-26 20:51:16 : INFO  : mightymike : App not closed, so no reopen.
2022-04-26 20:51:16 : REQ   : mightymike : All done!
2022-04-26 20:51:16 : REQ   : mightymike : ################## End Installomator, exit code 0
```
2022-04-26 21:40:23 +02:00
MacMike077
8d2d82df5a Create NewLabel Flycut.sh
2022-04-26 15:12:45 : REQ   : flycut : ################## Start Installomator v. 9.1, date 2022-03-18
2022-04-26 15:12:45 : INFO  : flycut : ################## Version: 9.1
2022-04-26 15:12:45 : INFO  : flycut : ################## Date: 2022-03-18
2022-04-26 15:12:45 : INFO  : flycut : ################## flycut
2022-04-26 15:12:45 : INFO  : flycut : BLOCKING_PROCESS_ACTION=tell_user
2022-04-26 15:12:45 : INFO  : flycut : NOTIFY=success
2022-04-26 15:12:45 : INFO  : flycut : LOGGING=INFO
2022-04-26 15:12:45 : INFO  : flycut : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-04-26 15:12:45 : INFO  : flycut : Label type: zip
2022-04-26 15:12:45 : INFO  : flycut : archiveName: Flycut.[0-9.]*.zip
2022-04-26 15:12:45 : INFO  : flycut : no blocking processes defined, using Flycut as default
2022-04-26 15:12:45 : INFO  : flycut : name: Flycut, appName: Flycut.app
2022-04-26 15:12:46 : INFO  : flycut : App(s) found: 
2022-04-26 15:12:46 : WARN  : flycut : could not find Flycut.app
2022-04-26 15:12:46 : INFO  : flycut : appversion: 
2022-04-26 15:12:46 : INFO  : flycut : Latest version of Flycut is 1.9.6
2022-04-26 15:12:46 : REQ   : flycut : Downloading https://github.com/TermiT/Flycut/releases/download/1.9.6/Flycut.1.9.6.zip to Flycut.[0-9.]*.zip
2022-04-26 15:12:47 : REQ   : flycut : no more blocking processes, continue with update
2022-04-26 15:12:47 : REQ   : flycut : Installing Flycut
2022-04-26 15:12:47 : INFO  : flycut : Unzipping Flycut.[0-9.]*.zip
2022-04-26 15:12:47 : INFO  : flycut : Verifying: /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.ScqcA2X3/Flycut.app
2022-04-26 15:12:48 : INFO  : flycut : Team ID matching: S8JLSG5ES7 (expected: S8JLSG5ES7 )
2022-04-26 15:12:48 : INFO  : flycut : Installing Flycut version 1.9.6 on versionKey CFBundleShortVersionString.
2022-04-26 15:12:48 : INFO  : flycut : App has LSMinimumSystemVersion: 10.10
2022-04-26 15:12:48 : INFO  : flycut : Copy /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.ScqcA2X3/Flycut.app to /Applications
2022-04-26 15:12:48 : WARN  : flycut : Changing owner to maikelwork
2022-04-26 15:12:48 : INFO  : flycut : Finishing...
2022-04-26 15:12:58 : INFO  : flycut : App(s) found: /Applications/Flycut.app
2022-04-26 15:12:58 : INFO  : flycut : found app at /Applications/Flycut.app, version 1.9.6, on versionKey CFBundleShortVersionString
2022-04-26 15:12:58 : REQ   : flycut : Installed Flycut, version 1.9.6
2022-04-26 15:12:58 : INFO  : flycut : notifying
2022-04-26 15:12:58 : INFO  : flycut : App not closed, so no reopen.
2022-04-26 15:12:58 : REQ   : flycut : All done!
2022-04-26 15:12:58 : REQ   : flycut : ################## End Installomator, exit code 0
2022-04-26 15:13:41 +02:00
marcelpogorzelski
026c399e0c Update Camtasia to 2021
Fixed name and added appNewVersion
2022-04-26 11:26:08 +02:00
marcelpogorzelski
1ce70bc8f3 Update Snagit
Added appNewVersion
2022-04-26 09:47:10 +02:00
marcelpogorzelski
9407918bd7 Update Snagit name
Updated Snagit name to Snagit 2022
2022-04-26 08:42:43 +02:00
Ted Jangius
522b0c5bf2 Added support for label thunderbird_intl
Uses similar code as firefox_intl and firefoxesr_intl.
2022-04-25 11:42:34 +02:00
Ted Jangius
9e336d1e3b Code update and fix for firefoxesr_intl
Fixed $userLanguage to use dash separator instead of underscore, since that is what is used in the $releaseURL.
2022-04-25 11:32:05 +02:00
Ted Jangius
24f99366cc Code update and fix for firefox_intl
Fixed $userLanguage to use dash separator instead of underscore, since that is what is used in the $releaseURL.
2022-04-25 11:30:35 +02:00
Søren Theilgaard
c6470fdd79 duckduckgo web browser
It’s only in preview now, and you need an invitation code to run the app, but now we are ready for this.
2022-04-25 09:02:27 +02:00
Ted Jangius
e74d0ab413 Fix for missing comment in header 2022-04-21 16:43:43 +02:00
Brian Engert
fca59f554b updates for ringcentral app
* update installers to install latest version
* add arm installer (no universal installer yet)
2022-04-18 16:55:40 -05:00
jasmania2
a089d607ac New Label- SonoBus
2022-04-15 12:02:19 sonobus ################## Start Installomator v. 9.0dev
2022-04-15 12:02:19 sonobus ################## sonobus
2022-04-15 12:02:19 sonobus DEBUG mode 1 enabled.
2022-04-15 12:02:20 sonobus BLOCKING_PROCESS_ACTION=kill
2022-04-15 12:02:20 sonobus NOTIFY=all
2022-04-15 12:02:20 sonobus LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-04-15 12:02:20 sonobus no blocking processes defined, using Sonobus as default
2022-04-15 12:02:20 sonobus Changing directory to /Library/Application Support/JAMF/tmp
2022-04-15 12:02:20 sonobus App(s) found: /Applications/Sonobus.app
2022-04-15 12:02:20 sonobus found app at /Applications/Sonobus.app, version 1.5.1
2022-04-15 12:02:20 sonobus appversion: 1.5.1
2022-04-15 12:02:20 sonobus Latest version of Sonobus is 1.5.1
2022-04-15 12:02:20 sonobus DEBUG mode enabled, not exiting, but there is no new version of app.
2022-04-15 12:02:20 sonobus Downloading https://www.sonobus.net/releases/sonobus-1.5.1-mac.dmg to Sonobus.dmg
2022-04-15 12:02:20 sonobus notifying
2022-04-15 12:02:22 sonobus DEBUG mode, not checking for blocking processes
2022-04-15 12:02:22 sonobus Installing Sonobus
2022-04-15 12:02:22 sonobus notifying
2022-04-15 12:02:22 sonobus Mounting /Library/Application Support/JAMF/tmp/Sonobus.dmg
2022-04-15 12:02:23 sonobus Mounted: /Volumes/SonoBus v1.5.1
2022-04-15 12:02:23 sonobus found pkg: /Volumes/SonoBus v1.5.1/SonoBus Installer.pkg
2022-04-15 12:02:23 sonobus Verifying: /Volumes/SonoBus v1.5.1/SonoBus Installer.pkg
2022-04-15 12:02:24 sonobus Team ID: XCS435894D (expected: XCS435894D )
2022-04-15 12:02:24 sonobus DEBUG enabled, skipping installation
2022-04-15 12:02:24 sonobus Finishing...
2022-04-15 12:02:34 sonobus App(s) found: /Applications/Sonobus.app
2022-04-15 12:02:34 sonobus found app at /Applications/Sonobus.app, version 1.5.1
2022-04-15 12:02:34 sonobus Installed Sonobus, version 1.5.1
2022-04-15 12:02:34 sonobus notifying
2022-04-15 12:02:34 sonobus Unmounting /Volumes/SonoBus v1.5.1
"disk2" ejected.
2022-04-15 12:02:34 sonobus DEBUG mode, not reopening anything
2022-04-15 12:02:34 sonobus ################## End Installomator, exit code 0
2022-04-15 14:23:14 -04:00
DavidTaylor
d32c1bae9b Create slab.sh 2022-04-13 16:24:16 -07:00
Søren Theilgaard
79b2b43cd0 Dropbox with appNewVersion
Output:
```
sudo /Users/st/Documents/GitHub/Installomator/utils/assemble.sh dropbox DEBUG=0
Password:
2022-04-13 13:55:33 : WARN  : dropbox : setting variable from argument DEBUG=0
2022-04-13 13:55:33 : REQ   : dropbox : ################## Start Installomator v. 10dev, date 2022-04-13
2022-04-13 13:55:33 : INFO  : dropbox : ################## Version: 10dev
2022-04-13 13:55:33 : INFO  : dropbox : ################## Date: 2022-04-13
2022-04-13 13:55:33 : INFO  : dropbox : ################## dropbox
2022-04-13 13:55:34 : INFO  : dropbox : BLOCKING_PROCESS_ACTION=tell_user
2022-04-13 13:55:34 : INFO  : dropbox : NOTIFY=success
2022-04-13 13:55:34 : INFO  : dropbox : LOGGING=INFO
2022-04-13 13:55:34 : INFO  : dropbox : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-04-13 13:55:34 : INFO  : dropbox : Label type: dmg
2022-04-13 13:55:34 : INFO  : dropbox : archiveName: Dropbox.dmg
2022-04-13 13:55:34 : INFO  : dropbox : no blocking processes defined, using Dropbox as default
2022-04-13 13:55:34 : INFO  : dropbox : name: Dropbox, appName: Dropbox.app
2022-04-13 13:55:34 : INFO  : dropbox : App(s) found:
2022-04-13 13:55:34 : WARN  : dropbox : could not find Dropbox.app
2022-04-13 13:55:34 : INFO  : dropbox : appversion:
2022-04-13 13:55:34 : INFO  : dropbox : Latest version of Dropbox is 145.4.4921
2022-04-13 13:55:34 : REQ   : dropbox : Downloading https://www.dropbox.com/download?plat=mac&full=1 to Dropbox.dmg
2022-04-13 13:55:37 : REQ   : dropbox : no more blocking processes, continue with update
2022-04-13 13:55:37 : REQ   : dropbox : Installing Dropbox
2022-04-13 13:55:37 : INFO  : dropbox : Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.HdtYqL07/Dropbox.dmg
2022-04-13 13:55:38 : INFO  : dropbox : Mounted: /Volumes/Dropbox Offline Installer
2022-04-13 13:55:38 : INFO  : dropbox : Verifying: /Volumes/Dropbox Offline Installer/Dropbox.app
2022-04-13 13:55:42 : INFO  : dropbox : Team ID matching: G7HH3F8CAK (expected: G7HH3F8CAK )
2022-04-13 13:55:42 : INFO  : dropbox : Installing Dropbox version 145.4.4921 on versionKey CFBundleShortVersionString.
2022-04-13 13:55:42 : INFO  : dropbox : App has LSMinimumSystemVersion: 10.10
2022-04-13 13:55:42 : INFO  : dropbox : Copy /Volumes/Dropbox Offline Installer/Dropbox.app to /Applications
2022-04-13 13:55:45 : WARN  : dropbox : Changing owner to st
2022-04-13 13:55:45 : INFO  : dropbox : Finishing...
2022-04-13 13:55:55 : INFO  : dropbox : App(s) found: /Applications/Dropbox.app
2022-04-13 13:55:55 : INFO  : dropbox : found app at /Applications/Dropbox.app, version 145.4.4921, on versionKey CFBundleShortVersionString
2022-04-13 13:55:55 : REQ   : dropbox : Installed Dropbox, version 145.4.4921
2022-04-13 13:55:55 : INFO  : dropbox : notifying
2022-04-13 13:55:56 : INFO  : dropbox : App not closed, so no reopen.
2022-04-13 13:55:56 : REQ   : dropbox : All done!
2022-04-13 13:55:56 : REQ   : dropbox : ################## End Installomator, exit code 0
```
2022-04-13 13:57:36 +02:00
Søren Theilgaard
972a319bb9 Change the mentioning of members with link to profiles. 2022-04-13 13:33:38 +02:00
0x4448
237648004a Add latest version check for googlechromepkg 2022-04-13 03:44:24 +00:00
marcelpogorzelski
2e291eb6c1 Label for both Clue appliations 2022-04-11 13:14:28 +02:00
Sam Ess
8ff6a0f9ca Added draw.io blocking process 2022-04-08 19:29:16 -04:00
Sam Ess
0f892f5868 Add draw.io label 2022-04-08 19:20:26 -04:00
Søren Theilgaard
1c2d8d9c17 Fixed downloadURL in sketch 2022-04-08 21:14:49 +02:00
Adam Codega
401d5ad138 Delete grammarly.sh
Committed incorrectly to root of repo.
2022-04-08 09:43:23 -04:00
Adam Codega
3ef215c22b Delete grammarly.sh
Committed incorrectly to root of repo.
2022-04-08 09:43:00 -04:00
marcelpogorzelski
ed07b2af2b Create MindManager Label
MindJet MindManager Label
2022-04-08 10:06:42 +02:00
marcelpogorzelski
251b2a14a8 Update logitechoptions.sh
Application name change
2022-04-08 08:20:51 +02:00
Søren Theilgaard
3578f9cbe9 Extra logging for firefox and googlechrome labels. 2022-04-05 20:05:47 +02:00
Maarten Wijnants
351cc07afa Add latest version check to gpgsuite 2022-04-05 16:12:08 +02:00
Gabe Marchan
229e2c76bb Add aText Legacy which provides aText 2 for those with older licenses. 2022-04-04 11:09:05 -05:00
Adrian Bühler
a27ca5a5d3 Update 'rancherdesktop' to support arm64
The `archiveName` was no longer valid. Added support for i386 and arm64. Also made `name` look more beautiful :-)
2022-04-01 16:36:18 +02:00
Maarten Wijnants
5109597f1a Add latest version check to firefoxpkg 2022-03-31 08:44:52 +02:00
Søren Theilgaard
f8a3104470 MDM scripts updated 2022-03-30 13:39:23 +02:00
Søren Theilgaard
7fa9d3c24a Zoho WorkDrive Genie
```
➜  Installomator/utils/assemble.sh zohoworkdrivegenie DEBUG=0 INSTALL=force
2022-03-30 13:20:44 : WARN  : zohoworkdrivegenie : setting variable from argument DEBUG=0
2022-03-30 13:20:44 : WARN  : zohoworkdrivegenie : setting variable from argument INSTALL=force
2022-03-30 13:20:44 : REQ   : zohoworkdrivegenie : ################## Start Installomator v. 10dev, date 2022-03-30
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : ################## Version: 10dev
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : ################## Date: 2022-03-30
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : ################## zohoworkdrivegenie
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : BLOCKING_PROCESS_ACTION=tell_user
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : NOTIFY=success
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : LOGGING=INFO
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : Label type: dmg
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : archiveName: Zoho WorkDrive Genie.dmg
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : no blocking processes defined, using Zoho WorkDrive Genie as default
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : App(s) found: /Applications/Zoho WorkDrive Genie.app
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : found app at /Applications/Zoho WorkDrive Genie.app, version 1.0, on versionKey CFBundleShortVersionString
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : appversion: 1.0
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : Label is not of type “updateronly”, and it’s set to use force to install or ignoring app store apps, so not using updateTool.
2022-03-30 13:20:44 : INFO  : zohoworkdrivegenie : Latest version not specified.
2022-03-30 13:20:44 : REQ   : zohoworkdrivegenie : Downloading https://www.zoho.com/workdrive/downloads/edit-tool/Zoho_WorkDrive_Genie.dmg to Zoho WorkDrive Genie.dmg
2022-03-30 13:20:49 : REQ   : zohoworkdrivegenie : no more blocking processes, continue with update
2022-03-30 13:20:49 : REQ   : zohoworkdrivegenie : Installing Zoho WorkDrive Genie
2022-03-30 13:20:49 : INFO  : zohoworkdrivegenie : Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.J1mdaQJZ/Zoho WorkDrive Genie.dmg
2022-03-30 13:20:52 : INFO  : zohoworkdrivegenie : Mounted: /Volumes/Zoho WorkDrive Genie
2022-03-30 13:20:52 : INFO  : zohoworkdrivegenie : Verifying: /Volumes/Zoho WorkDrive Genie/Zoho WorkDrive Genie.app
2022-03-30 13:20:54 : INFO  : zohoworkdrivegenie : Team ID matching: TZ824L8Y37 (expected: TZ824L8Y37 )
2022-03-30 13:20:54 : INFO  : zohoworkdrivegenie : Downloaded version of Zoho WorkDrive Genie is 1.0 on versionKey CFBundleShortVersionString, same as installed.
2022-03-30 13:20:54 : INFO  : zohoworkdrivegenie : Using force to install anyway.
2022-03-30 13:20:54 : INFO  : zohoworkdrivegenie : App has LSMinimumSystemVersion: 10.13
2022-03-30 13:20:54 : INFO  : zohoworkdrivegenie : CLIInstaller exists, running installer command /Volumes/Zoho WorkDrive Genie/Zoho WorkDrive Genie.app/Contents/MacOS/Zoho WorkDrive Genie
2022-03-30 13:21:00 : INFO  : zohoworkdrivegenie : Succesfully ran /Volumes/Zoho WorkDrive Genie/Zoho WorkDrive Genie.app/Contents/MacOS/Zoho WorkDrive Genie
2022-03-30 13:21:00 : INFO  : zohoworkdrivegenie : Finishing...
2022-03-30 13:21:10 : INFO  : zohoworkdrivegenie : App(s) found: /Applications/Zoho WorkDrive Genie.app
2022-03-30 13:21:10 : INFO  : zohoworkdrivegenie : found app at /Applications/Zoho WorkDrive Genie.app, version 1.0, on versionKey CFBundleShortVersionString
2022-03-30 13:21:10 : REQ   : zohoworkdrivegenie : Installed Zoho WorkDrive Genie, version 1.0
2022-03-30 13:21:10 : INFO  : zohoworkdrivegenie : notifying
2022-03-30 13:21:11 : INFO  : zohoworkdrivegenie : App not closed, so no reopen.
2022-03-30 13:21:11 : REQ   : zohoworkdrivegenie : All done!
2022-03-30 13:21:11 : REQ   : zohoworkdrivegenie : ################## End Installomator, exit code 0
```
2022-03-30 13:25:23 +02:00
Bradley Benkle
02435b25ad Update amazoncorretto8jdk.sh 2022-03-29 11:23:59 -04:00
Bradley Benkle
a4b02197d8 Update postman.sh 2022-03-25 14:37:23 -04:00
Bradley Benkle
a058a6594b Create androidstudio.sh 2022-03-24 17:05:44 -04:00
Bradley Benkle
20e87458ad Revert "Create androidstudio.sh"
This reverts commit 1797bb645b.
2022-03-24 16:44:33 -04:00
Bradley Benkle
1797bb645b Create androidstudio.sh 2022-03-24 16:37:23 -04:00
Søren Theilgaard
95684b6ecf CraftManager for Sketch
Result:
```
➜  Installomator/utils/assemble.sh craftmanagerforsketch DEBUG=0 INSTALL=force
2022-03-23 16:12:43 : WARN  : craftmanagerforsketch : setting variable from argument DEBUG=0
2022-03-23 16:12:43 : WARN  : craftmanagerforsketch : setting variable from argument INSTALL=force
2022-03-23 16:12:43 : REQ   : craftmanagerforsketch : ################## Start Installomator v. 10dev, date 2022-03-23
2022-03-23 16:12:43 : INFO  : craftmanagerforsketch : ################## Version: 10dev
2022-03-23 16:12:43 : INFO  : craftmanagerforsketch : ################## Date: 2022-03-23
2022-03-23 16:12:43 : INFO  : craftmanagerforsketch : ################## craftmanagerforsketch
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : BLOCKING_PROCESS_ACTION=tell_user
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : NOTIFY=success
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : LOGGING=INFO
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : Label type: zip
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : archiveName: CraftManager.zip
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : no blocking processes defined, using CraftManager as default
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : App(s) found: /Applications/CraftManager.app
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : found app at /Applications/CraftManager.app, version 1.1.1, on versionKey CFBundleShortVersionString
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : appversion: 1.1.1
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : Label is not of type “updateronly”, and it’s set to use force to install or ignoring app store apps, so not using updateTool.
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : Latest version of CraftManager is 1.1.1
2022-03-23 16:12:44 : INFO  : craftmanagerforsketch : There is no newer version available.
2022-03-23 16:12:44 : REQ   : craftmanagerforsketch : Downloading https://craft-assets.invisionapp.com/CraftManager/production/CraftManager.zip to CraftManager.zip
2022-03-23 16:13:06 : REQ   : craftmanagerforsketch : no more blocking processes, continue with update
2022-03-23 16:13:06 : REQ   : craftmanagerforsketch : Installing CraftManager
2022-03-23 16:13:06 : INFO  : craftmanagerforsketch : Unzipping CraftManager.zip
2022-03-23 16:13:06 : INFO  : craftmanagerforsketch : Verifying: /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.JOfEecvm/CraftManager.app
2022-03-23 16:13:07 : INFO  : craftmanagerforsketch : Team ID matching: VRXQSNCL5W (expected: VRXQSNCL5W )
2022-03-23 16:13:07 : INFO  : craftmanagerforsketch : Downloaded version of CraftManager is 1.1.1 on versionKey CFBundleShortVersionString, same as installed.
2022-03-23 16:13:07 : INFO  : craftmanagerforsketch : Using force to install anyway.
2022-03-23 16:13:07 : INFO  : craftmanagerforsketch : App has LSMinimumSystemVersion: 10.15
2022-03-23 16:13:07 : WARN  : craftmanagerforsketch : Removing existing /Applications/CraftManager.app
2022-03-23 16:13:07 : INFO  : craftmanagerforsketch : Copy /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.JOfEecvm/CraftManager.app to /Applications
2022-03-23 16:13:07 : WARN  : craftmanagerforsketch : Changing owner to st
2022-03-23 16:13:08 : INFO  : craftmanagerforsketch : Finishing...
2022-03-23 16:13:18 : INFO  : craftmanagerforsketch : App(s) found: /Applications/CraftManager.app
2022-03-23 16:13:18 : INFO  : craftmanagerforsketch : found app at /Applications/CraftManager.app, version 1.1.1, on versionKey CFBundleShortVersionString
2022-03-23 16:13:18 : REQ   : craftmanagerforsketch : Installed CraftManager, version 1.1.1
2022-03-23 16:13:18 : INFO  : craftmanagerforsketch : notifying
2022-03-23 16:13:18 : INFO  : craftmanagerforsketch : App not closed, so no reopen.
2022-03-23 16:13:18 : REQ   : craftmanagerforsketch : All done!
2022-03-23 16:13:18 : REQ   : craftmanagerforsketch : ################## End Installomator, exit code 0

➜  Installomator/utils/assemble.sh craftmanagerforsketch DEBUG=0
2022-03-23 16:13:23 : WARN  : craftmanagerforsketch : setting variable from argument DEBUG=0
2022-03-23 16:13:23 : REQ   : craftmanagerforsketch : ################## Start Installomator v. 10dev, date 2022-03-23
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : ################## Version: 10dev
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : ################## Date: 2022-03-23
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : ################## craftmanagerforsketch
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : BLOCKING_PROCESS_ACTION=tell_user
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : NOTIFY=success
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : LOGGING=INFO
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : Label type: zip
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : archiveName: CraftManager.zip
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : no blocking processes defined, using CraftManager as default
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : App(s) found: /Applications/CraftManager.app
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : found app at /Applications/CraftManager.app, version 1.1.1, on versionKey CFBundleShortVersionString
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : appversion: 1.1.1
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : Latest version of CraftManager is 1.1.1
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : There is no newer version available.
2022-03-23 16:13:23 : INFO  : craftmanagerforsketch : App not closed, so no reopen.
2022-03-23 16:13:23 : REQ   : craftmanagerforsketch : No newer version.
2022-03-23 16:13:23 : REQ   : craftmanagerforsketch : ################## End Installomator, exit code 0
```
2022-03-23 16:14:35 +01:00
Søren Theilgaard
affe0f4073 log levels on localization 2022-03-23 14:11:05 +01:00
Søren Theilgaard
37f6290d34 firefoxpkg_intl
Trying to determine the language of the user, and then installing that localized version, instead of en_US. But it will fall back to en_US if something goes wrong.
2022-03-23 14:04:43 +01:00
Søren Theilgaard
cec9d53ff8 QGIS software latest release "pr"
This will download the release called "Latest release (richest on features)".

```
$ Installomator/utils/assemble.sh qgis-pr DEBUG=0
2022-03-22 16:23:41 : WARN  : qgis-pr : setting variable from argument DEBUG=0
2022-03-22 16:23:41 : REQ   : qgis-pr : ################## Start Installomator v. 10dev, date 2022-03-22
2022-03-22 16:23:41 : INFO  : qgis-pr : ################## Version: 10dev
2022-03-22 16:23:41 : INFO  : qgis-pr : ################## Date: 2022-03-22
2022-03-22 16:23:41 : INFO  : qgis-pr : ################## qgis-pr
2022-03-22 16:23:42 : INFO  : qgis-pr : BLOCKING_PROCESS_ACTION=tell_user
2022-03-22 16:23:42 : INFO  : qgis-pr : NOTIFY=success
2022-03-22 16:23:42 : INFO  : qgis-pr : LOGGING=INFO
2022-03-22 16:23:42 : INFO  : qgis-pr : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-03-22 16:23:42 : INFO  : qgis-pr : Label type: dmg
2022-03-22 16:23:42 : INFO  : qgis-pr : archiveName: QGIS.dmg
2022-03-22 16:23:42 : INFO  : qgis-pr : no blocking processes defined, using QGIS as default
2022-03-22 16:23:42 : INFO  : qgis-pr : name: QGIS, appName: QGIS.app
2022-03-22 16:23:42 : INFO  : qgis-pr : App(s) found:
2022-03-22 16:23:42 : WARN  : qgis-pr : could not find QGIS.app
2022-03-22 16:23:42 : INFO  : qgis-pr : appversion:
2022-03-22 16:23:42 : INFO  : qgis-pr : Latest version of QGIS is 3.24.1
2022-03-22 16:23:42 : REQ   : qgis-pr : Downloading https://download.qgis.org/downloads/macos/qgis-macos-pr.dmg to QGIS.dmg
2022-03-22 16:25:31 : REQ   : qgis-pr : no more blocking processes, continue with update
2022-03-22 16:25:31 : REQ   : qgis-pr : Installing QGIS
2022-03-22 16:25:31 : INFO  : qgis-pr : Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.DTKj8N3Y/QGIS.dmg
2022-03-22 16:26:48 : INFO  : qgis-pr : Mounted: /Volumes/QGIS.app 1
2022-03-22 16:26:48 : INFO  : qgis-pr : Verifying: /Volumes/QGIS.app 1/QGIS.app
2022-03-22 16:29:55 : INFO  : qgis-pr : Team ID matching: 4F7N4UDA22 (expected: 4F7N4UDA22 )
2022-03-22 16:29:55 : INFO  : qgis-pr : Installing QGIS version 3.24.1 on versionKey CFBundleShortVersionString.
2022-03-22 16:29:55 : INFO  : qgis-pr : App has LSMinimumSystemVersion: 10.13.0
2022-03-22 16:29:55 : INFO  : qgis-pr : Copy /Volumes/QGIS.app 1/QGIS.app to /Applications
2022-03-22 16:32:56 : WARN  : qgis-pr : Changing owner to st
2022-03-22 16:32:57 : INFO  : qgis-pr : Finishing...
2022-03-22 16:33:07 : INFO  : qgis-pr : App(s) found: /Applications/QGIS.app
2022-03-22 16:33:07 : INFO  : qgis-pr : found app at /Applications/QGIS.app, version 3.24.1, on versionKey CFBundleShortVersionString
2022-03-22 16:33:07 : REQ   : qgis-pr : Installed QGIS, version 3.24.1
2022-03-22 16:33:07 : INFO  : qgis-pr : notifying
2022-03-22 16:33:08 : INFO  : qgis-pr : App not closed, so no reopen.
2022-03-22 16:33:08 : REQ   : qgis-pr : All done!
2022-03-22 16:33:08 : REQ   : qgis-pr : ################## End Installomator, exit code 0

$ Installomator/utils/assemble.sh qgis-pr DEBUG=0
2022-03-22 16:36:26 : WARN  : qgis-pr : setting variable from argument DEBUG=0
2022-03-22 16:36:26 : REQ   : qgis-pr : ################## Start Installomator v. 10dev, date 2022-03-22
2022-03-22 16:36:26 : INFO  : qgis-pr : ################## Version: 10dev
2022-03-22 16:36:26 : INFO  : qgis-pr : ################## Date: 2022-03-22
2022-03-22 16:36:26 : INFO  : qgis-pr : ################## qgis-pr
2022-03-22 16:36:26 : INFO  : qgis-pr : BLOCKING_PROCESS_ACTION=tell_user
2022-03-22 16:36:26 : INFO  : qgis-pr : NOTIFY=success
2022-03-22 16:36:26 : INFO  : qgis-pr : LOGGING=INFO
2022-03-22 16:36:26 : INFO  : qgis-pr : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-03-22 16:36:26 : INFO  : qgis-pr : Label type: dmg
2022-03-22 16:36:26 : INFO  : qgis-pr : archiveName: QGIS.dmg
2022-03-22 16:36:26 : INFO  : qgis-pr : no blocking processes defined, using QGIS as default
2022-03-22 16:36:26 : INFO  : qgis-pr : App(s) found: /Applications/QGIS.app
2022-03-22 16:36:26 : INFO  : qgis-pr : found app at /Applications/QGIS.app, version 3.24.1, on versionKey CFBundleShortVersionString
2022-03-22 16:36:26 : INFO  : qgis-pr : appversion: 3.24.1
2022-03-22 16:36:26 : INFO  : qgis-pr : Latest version of QGIS is 3.24.1
2022-03-22 16:36:26 : INFO  : qgis-pr : There is no newer version available.
2022-03-22 16:36:26 : INFO  : qgis-pr : App not closed, so no reopen.
2022-03-22 16:36:26 : REQ   : qgis-pr : No newer version.
2022-03-22 16:36:26 : REQ   : qgis-pr : ################## End Installomator, exit code 0
```
2022-03-22 16:39:30 +01:00
Adrian Bühler
600657b074 Add downloadURL for ARM. Add appNewVersion
Unfortunately I could not find any other version source for `appNewVersion`.
Should work just fine tho.
2022-03-22 11:40:43 +01:00
Liam Steckler
c728c25fc4 Updated label sed and downloadURL 2022-03-21 17:06:26 -07:00
Liam Steckler
bb935516d1 removed unneeded -L paramater from curl 2022-03-21 16:50:48 -07:00
Liam Steckler
7456bdad04 Add Talkdesk CX Cloud Label 2022-03-21 16:41:58 -07:00
Bradley Benkle
38f2f45d97 Update dbeaverce.sh 2022-03-21 12:52:07 -04:00
marcelpogorzelski
034ac45ba0 Update displaylinkmanager.sh
Added appNewVersion
2022-03-18 15:45:19 +01:00
Armin Briegel
f0f4ff5747 updated version 2022-03-18 14:03:21 +01:00
Armin Briegel
579862274a updated version 2022-03-18 14:02:32 +01:00
Armin Briegel
72fdc2365e Merge branch 'main' of github.com:Installomator/Installomator 2022-03-18 13:54:55 +01:00
Armin Briegel
ac042bc700 preparing v9.1 release 2022-03-18 13:51:25 +01:00
Armin Briegel
f001a829bd new label autodeskfusion360admininstall, closes #447 2022-03-18 13:18:38 +01:00
Armin Briegel
9736e1dbfa changed name for cosmetic reasons 2022-03-18 13:17:47 +01:00
Armin Briegel
d78c6fdd5c Merge pull request #446 from Installomator/Micosorft-Endpoint-Manager-(Intune)
Micosorft endpoint manager (intune)
2022-03-18 13:12:21 +01:00
Armin Briegel
65b16dc1ed new label grammarly, closes #444 2022-03-18 13:04:35 +01:00
Armin Briegel
9f5b89c37e moved grammarly.sh to the right location 2022-03-18 13:04:03 +01:00
Armin Briegel
05c1bf7cfc updated label microsoftdefender, closes #440 2022-03-18 12:59:09 +01:00
Armin Briegel
e07b4dd08f new label axurerp10, closes #439 2022-03-18 11:14:07 +01:00
Armin Briegel
88da86d4f0 new lable microsoftazuredatastudio, closes #438 2022-03-18 11:11:12 +01:00
Armin Briegel
b512ae17a3 merged #436 2022-03-18 11:08:46 +01:00
Armin Briegel
1787842366 added new label dialog/swiftdialog, closes #435 2022-03-18 11:04:39 +01:00
Armin Briegel
3e0ad885d8 closes #424 2022-03-18 11:01:03 +01:00
Armin Briegel
001cd592b0 added new label dockutil, closes #432 2022-03-18 10:56:49 +01:00
Armin Briegel
de93df0f85 added new label macadminspython, closes #431 2022-03-18 10:55:03 +01:00
Armin Briegel
0d9628b587 always download Google Chrome universal, closes #430 2022-03-18 10:52:32 +01:00
Armin Briegel
41e828f87a new label 1passwordcli, closes #429 2022-03-18 10:48:08 +01:00
Armin Briegel
eb25c271e3 updated label for appcleaner, closes #428 2022-03-18 10:45:13 +01:00
Armin Briegel
25c419b50d merged logging fixes, closes #427 2022-03-18 10:42:06 +01:00
Armin Briegel
7025efe566 added label for amazoncorretto8jdk, closes #425 2022-03-18 10:38:56 +01:00
Armin Briegel
22a34c45c9 added label for clipy, closes #412 2022-03-18 10:37:13 +01:00
Armin Briegel
cc06b77611 fixed filename for houdahspot label 2022-03-18 10:29:39 +01:00
marcelpogorzelski
30f1f1b43c Create displaylinkmanager.sh
Created a DisplayLink Manager label
2022-03-18 09:43:41 +01:00
glowlace
70c4d59df7 Added autodeskfusion360admininstall.sh label 2022-03-18 00:13:21 -05:00
Søren Theilgaard
7fcba4cb6e Merge branch 'main' into Micosorft-Endpoint-Manager-(Intune) 2022-03-15 15:14:30 +01:00
Søren Theilgaard
00ebfa35fd Correct MDM profile name and LOGO path now 2022-03-15 15:13:22 +01:00
Søren Theilgaard
2d813bce80 Microsoft Endpoint Manager (Intune) 2022-03-14 10:19:47 +01:00
Søren Theilgaard
69e4cdd216 Microsoft Endpoint Manager (Intune) added for LOGO 2022-03-14 10:18:58 +01:00
unfo33
55eb9e2d89 Create grammarly.sh 2022-03-11 20:57:58 -05:00
marcelpogorzelski
2349f456bc Fixed Microsoft Defender label
Change applications name to Microsoft Defender and added microsoftdefender as label.

Tested with Intel and Apple Silicon
2022-03-08 11:10:47 +01:00
Macnichol, Christopher
8fd949a567 Create axurerp10.sh 2022-03-07 17:17:56 -05:00
Macnichol, Christopher
f9997623f1 Create microsoftazuredatastudio.sh 2022-03-07 14:57:11 -05:00
Søren Theilgaard
4b14b31ff3 Fixed version
Issue #433 fixed.
2022-03-07 15:11:02 +01:00
Søren Theilgaard
ed737510bb Fixed bad copy-paste 2022-03-07 09:42:51 +01:00
Søren Theilgaard
ec9f1bb9a2 Update to label name as well 2022-03-07 09:38:06 +01:00
Bart Reardon
9022d8e74d Merge branch 'dev' into follow-git-redirects
# Conflicts:
#	fragments/version.sh
2022-03-06 09:02:13 +11:00
Bart Reardon
2a9b73dba7 update downloadURLFromGit() and versionFromGit() to follow redirects 2022-03-06 08:50:49 +11:00
Pro4TLZZ
40f20b3536 update dialog name 2022-03-05 21:31:37 +00:00
Pro4TLZZ
3a0c104f48 update dialog name 2022-03-05 21:30:54 +00:00
Pro4TLZZ
7629acf6a5 update dialog name 2022-03-05 21:30:17 +00:00
Søren Theilgaard
9f79cf4d65 Update functions.sh 2022-03-03 21:35:22 +01:00
Armin Briegel
54070273bc Merge pull request #424 from jamesrampton/README-tweak
Fix a minor typo in README
2022-03-03 15:00:04 +01:00
Armin Briegel
3d84300665 added label for dockutil 2022-03-03 14:53:59 +01:00
Søren Theilgaard
bbae9356c4 appCustomVersion for getting installed version 2022-03-03 14:53:47 +01:00
Armin Briegel
57733423b1 added label for MacAdmins Python 2022-03-03 14:48:36 +01:00
Maarten Wijnants
c3f751bad8 Always download Chrome universal 2022-03-03 11:33:49 +01:00
Rob Smithers
56bf2a3dc4 Create 1passwordcli.sh 2022-03-02 16:04:44 -05:00
Søren Theilgaard
28ddefbd57 Update tembo.sh 2022-03-01 15:07:43 +01:00
Søren Theilgaard
3a0373af60 Few DEVONtechnologies labels 2022-03-01 15:06:32 +01:00
Søren Theilgaard
fb7d9c43a8 Nanosaur now signed
```
$ Installomator/utils/assemble.sh nanosaur DEBUG=0
2022-03-01 09:12:25 : REQ   : nanosaur : setting variable from argument DEBUG=0
2022-03-01 09:12:25 : REQ   : nanosaur : ################## Start Installomator v. 9.1beta, date 2022-03-01
2022-03-01 09:12:25 : INFO  : nanosaur : ################## Version: 9.1beta
2022-03-01 09:12:25 : INFO  : nanosaur : ################## Date: 2022-03-01
2022-03-01 09:12:25 : INFO  : nanosaur : ################## nanosaur
2022-03-01 09:12:25 : INFO  : nanosaur : BLOCKING_PROCESS_ACTION=tell_user
2022-03-01 09:12:25 : INFO  : nanosaur : NOTIFY=success
2022-03-01 09:12:25 : INFO  : nanosaur : LOGGING=INFO
2022-03-01 09:12:25 : INFO  : nanosaur : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-03-01 09:12:25 : INFO  : nanosaur : Label type: dmg
2022-03-01 09:12:25 : INFO  : nanosaur : archiveName: Nanosaur.dmg
2022-03-01 09:12:25 : INFO  : nanosaur : no blocking processes defined, using Nanosaur as default
2022-03-01 09:12:25 : INFO  : nanosaur : name: Nanosaur, appName: Nanosaur.app
2022-03-01 09:12:25 : INFO  : nanosaur : App(s) found:
2022-03-01 09:12:25 : WARN  : nanosaur : could not find Nanosaur.app
2022-03-01 09:12:25 : INFO  : nanosaur : appversion:
2022-03-01 09:12:25 : INFO  : nanosaur : Latest version of Nanosaur is 1.4.3
2022-03-01 09:12:25 : REQ   : nanosaur : Downloading https://github.com/jorio/Nanosaur/releases/download/v1.4.3/Nanosaur-1.4.3-mac.dmg to Nanosaur.dmg
2022-03-01 09:12:27 : REQ   : nanosaur : no more blocking processes, continue with update
2022-03-01 09:12:27 : REQ   : nanosaur : Installing Nanosaur
2022-03-01 09:12:27 : INFO  : nanosaur : Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.EyqBn1xp/Nanosaur.dmg
2022-03-01 09:12:31 : INFO  : nanosaur : Mounted: /Volumes/Nanosaur 1.4.3
2022-03-01 09:12:31 : INFO  : nanosaur : Verifying: /Volumes/Nanosaur 1.4.3/Nanosaur.app
2022-03-01 09:12:31 : INFO  : nanosaur : Team ID matching: RVNL7XC27G (expected: RVNL7XC27G )
2022-03-01 09:12:31 : INFO  : nanosaur : Installing Nanosaur version 1.4.3 on versionKey CFBundleShortVersionString.
2022-03-01 09:12:31 : INFO  : nanosaur : App has LSMinimumSystemVersion: 10.11
2022-03-01 09:12:31 : INFO  : nanosaur : Copy /Volumes/Nanosaur 1.4.3/Nanosaur.app to /Applications
2022-03-01 09:12:31 : INFO  : nanosaur : Changing owner to st
2022-03-01 09:12:31 : INFO  : nanosaur : Finishing...
2022-03-01 09:12:41 : INFO  : nanosaur : App(s) found: /Applications/Nanosaur.app
2022-03-01 09:12:41 : INFO  : nanosaur : found app at /Applications/Nanosaur.app, version 1.4.3, on versionKey CFBundleShortVersionString
2022-03-01 09:12:41 : INFO  : nanosaur : Installed Nanosaur, version 1.4.3
2022-03-01 09:12:41 : INFO  : nanosaur : notifying
2022-03-01 09:12:53 : INFO  : nanosaur : App not closed, so no reopen.
2022-03-01 09:12:53 : INFO  : nanosaur :
2022-03-01 09:12:53 : REQ   : nanosaur : ################## End Installomator, exit code 0
```
2022-03-01 09:13:38 +01:00
Søren Theilgaard
ebed623837 Houdah Tembo
```
Installomator/utils/assemble.sh houdahtembo DEBUG=0 INSTALL=force
2022-02-25 11:27:28 : REQ   : houdahtembo : setting variable from argument DEBUG=0
2022-02-25 11:27:28 : REQ   : houdahtembo : setting variable from argument INSTALL=force
2022-02-25 11:27:28 : REQ   : houdahtembo : ################## Start Installomator v. 9.1beta, date 2022-02-25
2022-02-25 11:27:28 : INFO  : houdahtembo : ################## Version: 9.1beta
2022-02-25 11:27:28 : INFO  : houdahtembo : ################## Date: 2022-02-25
2022-02-25 11:27:28 : INFO  : houdahtembo : ################## houdahtembo
2022-02-25 11:27:30 : INFO  : houdahtembo : BLOCKING_PROCESS_ACTION=tell_user
2022-02-25 11:27:30 : INFO  : houdahtembo : NOTIFY=success
2022-02-25 11:27:30 : INFO  : houdahtembo : LOGGING=INFO
2022-02-25 11:27:30 : INFO  : houdahtembo : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-02-25 11:27:30 : INFO  : houdahtembo : Label type: zip
2022-02-25 11:27:30 : INFO  : houdahtembo : archiveName: Tembo.zip
2022-02-25 11:27:30 : INFO  : houdahtembo : no blocking processes defined, using Tembo as default
2022-02-25 11:27:30 : INFO  : houdahtembo : App(s) found: /Applications/Tembo.app
2022-02-25 11:27:30 : INFO  : houdahtembo : found app at /Applications/Tembo.app, version 2.6, on versionKey CFBundleShortVersionString
2022-02-25 11:27:30 : INFO  : houdahtembo : appversion: 2.6
2022-02-25 11:27:30 : INFO  : houdahtembo : Label is not of type “updateronly”, and it’s set to use force to install or ignoring app store apps, so not using updateTool.
2022-02-25 11:27:30 : INFO  : houdahtembo : Latest version of Tembo is 2.6
2022-02-25 11:27:30 : INFO  : houdahtembo : There is no newer version available.
2022-02-25 11:27:30 : REQ   : houdahtembo : Downloading https://dl.houdah.com/tembo/updates/cast2_assets/Tembo2.6.zip to Tembo.zip
2022-02-25 11:27:35 : REQ   : houdahtembo : no more blocking processes, continue with update
2022-02-25 11:27:35 : REQ   : houdahtembo : Installing Tembo
2022-02-25 11:27:35 : INFO  : houdahtembo : Unzipping Tembo.zip
2022-02-25 11:27:35 : INFO  : houdahtembo : Verifying: /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.RzdJx8SQ/Tembo.app
2022-02-25 11:27:35 : INFO  : houdahtembo : Team ID matching: DKGQD8H8ZY (expected: DKGQD8H8ZY )
2022-02-25 11:27:35 : INFO  : houdahtembo : Downloaded version of Tembo is 2.6 on versionKey CFBundleShortVersionString, same as installed.
2022-02-25 11:27:35 : INFO  : houdahtembo : Using force to install anyway.
2022-02-25 11:27:35 : INFO  : houdahtembo : App has LSMinimumSystemVersion: 10.11
2022-02-25 11:27:36 : INFO  : houdahtembo : Copy /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.RzdJx8SQ/Tembo.app to /Applications
2022-02-25 11:27:36 : INFO  : houdahtembo : Changing owner to st
2022-02-25 11:27:36 : INFO  : houdahtembo : Finishing...
2022-02-25 11:27:46 : INFO  : houdahtembo : App(s) found: /Applications/Tembo.app
2022-02-25 11:27:46 : INFO  : houdahtembo : found app at /Applications/Tembo.app, version 2.6, on versionKey CFBundleShortVersionString
2022-02-25 11:27:46 : INFO  : houdahtembo : Installed Tembo, version 2.6
2022-02-25 11:27:46 : INFO  : houdahtembo : notifying
2022-02-25 11:27:46 : INFO  : houdahtembo : App not closed, so no reopen.
2022-02-25 11:27:46 : INFO  : houdahtembo :
2022-02-25 11:27:46 : REQ   : houdahtembo : ################## End Installomator, exit code 0
```
2022-02-25 11:28:30 +01:00
Søren Theilgaard
b18aac905e HoudahSpot
```
Installomator/utils/assemble.sh houdahspot DEBUG=0 INSTALL=force
2022-02-25 09:22:23 : REQ   : houdahspot : setting variable from argument DEBUG=0
2022-02-25 09:22:23 : REQ   : houdahspot : setting variable from argument INSTALL=force
2022-02-25 09:22:23 : REQ   : houdahspot : ################## Start Installomator v. 9.1beta, date 2022-02-25
2022-02-25 09:22:23 : INFO  : houdahspot : ################## Version: 9.1beta
2022-02-25 09:22:23 : INFO  : houdahspot : ################## Date: 2022-02-25
2022-02-25 09:22:23 : INFO  : houdahspot : ################## houdahspot
2022-02-25 09:22:25 : INFO  : houdahspot : BLOCKING_PROCESS_ACTION=tell_user
2022-02-25 09:22:25 : INFO  : houdahspot : NOTIFY=success
2022-02-25 09:22:25 : INFO  : houdahspot : LOGGING=INFO
2022-02-25 09:22:25 : INFO  : houdahspot : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-02-25 09:22:25 : INFO  : houdahspot : Label type: zip
2022-02-25 09:22:25 : INFO  : houdahspot : archiveName: HoudahSpot.zip
2022-02-25 09:22:25 : INFO  : houdahspot : no blocking processes defined, using HoudahSpot as default
2022-02-25 09:22:25 : INFO  : houdahspot : App(s) found: /Applications/HoudahSpot.app
2022-02-25 09:22:25 : INFO  : houdahspot : found app at /Applications/HoudahSpot.app, version 6.1.11, on versionKey CFBundleShortVersionString
2022-02-25 09:22:25 : INFO  : houdahspot : appversion: 6.1.11
2022-02-25 09:22:25 : INFO  : houdahspot : Label is not of type “updateronly”, and it’s set to use force to install or ignoring app store apps, so not using updateTool.
2022-02-25 09:22:25 : INFO  : houdahspot : Latest version of HoudahSpot is 6.1.11
2022-02-25 09:22:25 : INFO  : houdahspot : There is no newer version available.
2022-02-25 09:22:25 : REQ   : houdahspot : Downloading https://dl.houdah.com/houdahSpot/updates/cast6_assets/HoudahSpot6.1.11.zip to HoudahSpot.zip
2022-02-25 09:22:32 : REQ   : houdahspot : no more blocking processes, continue with update
2022-02-25 09:22:32 : REQ   : houdahspot : Installing HoudahSpot
2022-02-25 09:22:32 : INFO  : houdahspot : Unzipping HoudahSpot.zip
2022-02-25 09:22:32 : INFO  : houdahspot : Verifying: /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.O8lA89oA/HoudahSpot.app
2022-02-25 09:22:33 : INFO  : houdahspot : Team ID matching: DKGQD8H8ZY (expected: DKGQD8H8ZY )
2022-02-25 09:22:33 : INFO  : houdahspot : Downloaded version of HoudahSpot is 6.1.11 on versionKey CFBundleShortVersionString, same as installed.
2022-02-25 09:22:33 : INFO  : houdahspot : Using force to install anyway.
2022-02-25 09:22:33 : INFO  : houdahspot : App has LSMinimumSystemVersion: 10.14
2022-02-25 09:22:33 : INFO  : houdahspot : Copy /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.O8lA89oA/HoudahSpot.app to /Applications
2022-02-25 09:22:33 : INFO  : houdahspot : Changing owner to st
2022-02-25 09:22:33 : INFO  : houdahspot : Finishing...
2022-02-25 09:22:43 : INFO  : houdahspot : App(s) found: /Applications/HoudahSpot.app
2022-02-25 09:22:43 : INFO  : houdahspot : found app at /Applications/HoudahSpot.app, version 6.1.11, on versionKey CFBundleShortVersionString
2022-02-25 09:22:43 : INFO  : houdahspot : Installed HoudahSpot, version 6.1.11
2022-02-25 09:22:43 : INFO  : houdahspot : notifying
2022-02-25 09:22:43 : INFO  : houdahspot : App not closed, so no reopen.
2022-02-25 09:22:43 : INFO  : houdahspot :
2022-02-25 09:22:43 : REQ   : houdahspot : ################## End Installomator, exit code 0
```
2022-02-25 09:23:26 +01:00
Adrian Bühler
4f1c56177a Update appcleaner.sh
Fix downloadURL to use `item[last()]`.
Add `appNewVersion`.
2022-02-24 16:26:40 +01:00
Søren Theilgaard
0a3b7af338 EasyFind from DEVONtechnologies 2022-02-24 12:28:26 +01:00
Søren Theilgaard
9b6c337d7a Improved logging for app copy with ditto
And a few lines changed to `WARN`.
2022-02-21 21:53:18 +01:00
Søren Theilgaard
9fd2b87e3c Few logging levels changed
I want to return a valid explanation for log level REQ for why the script stops.
2022-02-21 16:47:57 +01:00
Søren Theilgaard
a16cd44b0e Merge branch 'main' into Theile-labels-2022-02 2022-02-21 13:43:19 +01:00
Søren Theilgaard
74f6b569dd Support App fixed
Now `supportapp` label have been fixed, so that it will be quit, and can be installed if it is running.
2022-02-21 13:41:51 +01:00
Armin Briegel
d475b2b8ab added label file for amazoncorretto8jdk, #423 2022-02-21 09:39:37 +01:00
James Rampton
d79886b88f Fix a minor typo in README 2022-02-21 08:21:48 +00:00
Armin Briegel
56125c07b1 updated version 2022-02-20 13:08:25 +01:00
Armin Briegel
a3dbf75818 updated version 2022-02-20 13:07:53 +01:00
Armin Briegel
afbd1e363e updated changelog 2022-02-20 12:57:15 +01:00
Armin Briegel
22bc0ecbf6 updated version 2022-02-20 12:48:46 +01:00
Armin Briegel
24f729d357 updated Labels.txt 2022-02-18 17:17:46 +01:00
Armin Briegel
81b02e3932 updated Installomator.sh 2022-02-18 17:16:43 +01:00
Armin Briegel
800912be0c Merge branch 'pr/417' into dev-v9.0.1 2022-02-18 17:08:59 +01:00
Armin Briegel
1e3a50c07f Merge branch 'app-searching-changes-in-getAppVersion' into dev-v9.0.1 2022-02-18 16:56:22 +01:00
Armin Briegel
693164c9a0 Merge branch 'packages-app' into dev-v9.0.1 2022-02-18 16:54:33 +01:00
Fletcher Salesky
0c12343fbb Added support for Loom Apple Silicon version 2022-02-11 15:08:57 -08:00
Søren Theilgaard
cba0e8c766 Merge branch 'Logging-level-improvements' of https://github.com/Installomator/Installomator into Logging-level-improvements 2022-02-09 16:24:40 +01:00
Søren Theilgaard
a25c904ba7 Update functions.sh 2022-02-09 16:23:52 +01:00
Armin Briegel
d64c18df93 Merge branch 'Logging-level-improvements' into packages-app 2022-02-09 15:49:25 +01:00
Armin Briegel
9afdc233f9 replaced a stray 'tmpdir' 2022-02-09 15:49:05 +01:00
Armin Briegel
bc7d005fb9 Merge branch 'Logging-level-improvements' into packages-app 2022-02-09 15:43:21 +01:00
Armin Briegel
175f682b43 re-enabled packages label 2022-02-09 15:41:45 +01:00
Søren Theilgaard
ff8a9c2c3a Few more DEBUG loggings 2022-02-09 14:38:58 +01:00
Søren Theilgaard
bf740d1ffe Update functions.sh 2022-02-09 14:23:32 +01:00
Søren Theilgaard
1da37a13ca Another ls that could return an error 2022-02-09 14:10:01 +01:00
Søren Theilgaard
b30d4da703 Update functions.sh 2022-02-09 14:04:23 +01:00
Søren Theilgaard
c3714d855c Missing spaces
After manually moving Firefox to Utilities I have tested with this:
```
$ sudo /Installomator/utils/assemble.sh firefox DEBUG=0 INSTALL=force
2022-02-09 09:44:04 : INFO  : firefox : setting variable from argument DEBUG=0
2022-02-09 09:44:04 : INFO  : firefox : setting variable from argument INSTALL=force
2022-02-09 09:44:04 : REQ   : firefox : ################## Start Installomator v. 9.1beta, date 2022-02-09
2022-02-09 09:44:04 : INFO  : firefox : ################## Version: 9.1beta
2022-02-09 09:44:04 : INFO  : firefox : ################## Date: 2022-02-09
2022-02-09 09:44:04 : INFO  : firefox : ################## firefox
2022-02-09 09:44:04 : INFO  : firefox : BLOCKING_PROCESS_ACTION=tell_user
2022-02-09 09:44:04 : INFO  : firefox : NOTIFY=success
2022-02-09 09:44:04 : INFO  : firefox : LOGGING=INFO
2022-02-09 09:44:04 : INFO  : firefox : LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-02-09 09:44:04 : INFO  : firefox : Label type: dmg
2022-02-09 09:44:04 : INFO  : firefox : targetDir for installation: /Applications/Utilities
2022-02-09 09:44:04 : INFO  : firefox : found app at /Applications/Utilities/Firefox.app, version 97.0, on versionKey CFBundleShortVersionString
2022-02-09 09:44:04 : INFO  : firefox : appversion: 97.0
2022-02-09 09:44:04 : INFO  : firefox : Label is not of type “updateronly”, and it’s set to use force to install or ignoring app store apps, so not using updateTool.
2022-02-09 09:44:04 : INFO  : firefox : Latest version of Firefox is 97.0
2022-02-09 09:44:04 : INFO  : firefox : There is no newer version available.
2022-02-09 09:44:04 : REQ   : firefox : Downloading https://download.mozilla.org/?product=firefox-latest&os=osx&lang=en-US to Firefox.dmg
2022-02-09 09:44:16 : REQ   : firefox : no more blocking processes, continue with update
2022-02-09 09:44:16 : REQ   : firefox : Installing Firefox
2022-02-09 09:44:16 : INFO  : firefox : Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.NMItuUfS/Firefox.dmg
2022-02-09 09:44:24 : INFO  : firefox : Mounted: /Volumes/Firefox
2022-02-09 09:44:24 : INFO  : firefox : Verifying: /Volumes/Firefox/Firefox.app
2022-02-09 09:44:33 : INFO  : firefox : Team ID matching: 43AQ936H96 (expected: 43AQ936H96 )
2022-02-09 09:44:33 : INFO  : firefox : Downloaded version of Firefox is 97.0 on versionKey CFBundleShortVersionString, same as installed.
2022-02-09 09:44:33 : INFO  : firefox : Using force to install anyway.
2022-02-09 09:44:33 : INFO  : firefox : App has LSMinimumSystemVersion: 10.12.0
2022-02-09 09:44:33 : INFO  : firefox : Copy /Volumes/Firefox/Firefox.app to /Applications/Utilities
2022-02-09 09:44:40 : INFO  : firefox : Changing owner to st
2022-02-09 09:44:40 : INFO  : firefox : Finishing...
2022-02-09 09:44:50 : INFO  : firefox : targetDir for installation: /Applications/Utilities
2022-02-09 09:44:50 : INFO  : firefox : found app at /Applications/Utilities/Firefox.app, version 97.0, on versionKey CFBundleShortVersionString
2022-02-09 09:44:50 : INFO  : firefox : Installed Firefox, version 97.0
2022-02-09 09:44:50 : INFO  : firefox : notifying
2022-02-09 09:44:50 : REQ   : firefox : ################## End Installomator, exit code 0
```
2022-02-09 09:46:24 +01:00
Søren Theilgaard
dd83f6bd75 Update functions.sh 2022-02-09 09:41:03 +01:00
Søren Theilgaard
c55cc788bb Update functions.sh 2022-02-09 09:21:46 +01:00
bull
df616d2f51 Create clipy.sh
Support Clipy
https://github.com/Clipy/Clipy
2022-02-09 14:07:32 +09:00
Søren Theilgaard
557d63a4f3 If we exit a 0 we should still get the exit message 2022-02-08 13:48:33 +01:00
Søren Theilgaard
0432eb62d3 Improved logging levels
Also fixes #340
2022-02-08 12:36:16 +01:00
Armin Briegel
071586e43c updated version 2022-02-08 11:13:49 +01:00
Armin Briegel
aea7d282fe updated contributing.md 2022-02-08 11:13:03 +01:00
Armin Briegel
cd6b1397c8 updated version 2022-02-08 10:50:55 +01:00
Armin Briegel
1d405de70a re-built Installomator.sh 2022-02-08 10:41:30 +01:00
Armin Briegel
0645ff6335 Merge branch '2022-02-02_Theile-base' into dev 2022-02-08 10:38:57 +01:00
Armin Briegel
c9d1d458f3 final touches for 9.0 release 2022-02-08 10:38:40 +01:00
Armin Briegel
19c1275f12 updated version 2022-02-08 10:12:05 +01:00
Armin Briegel
aa53b0be68 Merge pull request #406 from Installomator/2022-02-02_Theile-base
Version 9.0 fixed, from branch 2022 02 02 theile base
2022-02-08 10:10:40 +01:00
Armin Briegel
9b58f57ae1 Merge pull request #405 from Installomator/zulujdk13-fix
fixed zulujdk13 downloadURLs
2022-02-08 10:08:47 +01:00
Søren Theilgaard
806c87266b Update CHANGELOG.md 2022-02-07 19:38:48 +01:00
Søren Theilgaard
7d60f0a11f Can handle .gz archives 2022-02-07 19:19:57 +01:00
Søren Theilgaard
435a60ac9f Minor additions 2022-02-07 19:11:28 +01:00
Søren Theilgaard
cf414f7dc6 Fixing wacomdrivers 2022-02-07 16:52:17 +01:00
Søren Theilgaard
ae3f711738 Further logging, finding pkg only return files
Important change, when we use `find` to locate pkgs. Now only files will be returned.
2022-02-07 16:32:23 +01:00
Søren Theilgaard
c238f94a9b Update checkLabels.sh 2022-02-07 14:31:34 +01:00
Armin Briegel
9275e0c045 fixed zulujdk13 downloadURLs 2022-02-07 14:21:35 +01:00
Søren Theilgaard
b3d3f25e19 Update checkInstallomator.sh 2022-02-07 14:12:06 +01:00
Søren Theilgaard
2a1176a947 Different check for file
The ls command to check for this file will throw an error when the file does not exist. Better to simply test for the file (with size greater than zero).
2022-02-07 12:56:13 +01:00
Søren Theilgaard
842b1e19cb Testing SYSTEMOWNER=1 2022-02-07 12:08:50 +01:00
Søren Theilgaard
d34f3102fc Update checkInstallomator.sh 2022-02-07 11:40:31 +01:00
Søren Theilgaard
d74036e853 Update logitechoptions.sh 2022-02-07 09:42:18 +01:00
Søren Theilgaard
bb4a396788 Renaming file to match primary label name 2022-02-04 14:37:03 +01:00
Søren Theilgaard
4bc67f3de3 Minor logging correction 2022-02-04 14:36:44 +01:00
Søren Theilgaard
08e9e63422 Align a function and improve checking in checkLabels
Will now also go through labels with warnings in the, to figure out if the label works. Many warnings are about version checking, so those will be verified now.
2022-02-04 11:59:51 +01:00
Søren Theilgaard
378b166164 Labels fixed 2022-02-04 10:55:14 +01:00
Søren Theilgaard
83c1911248 Ended up with double-log-lines 2022-02-04 09:26:42 +01:00
Søren Theilgaard
ee9861c0f5 Extra space to align log output 2022-02-04 09:02:56 +01:00
Søren Theilgaard
516f05a4cb No packageID in eshareosx 2022-02-03 06:32:23 +01:00
Søren Theilgaard
e181a02838 Update checkInstallomator.sh 2022-02-02 22:09:40 +01:00
Søren Theilgaard
f2782989ce Minor changes 2022-02-02 22:01:41 +01:00
Søren Theilgaard
36fc48682e Testing improved
Will now ask for admin credentials to run a real installation of 3 different labels with different notifications
2022-02-02 21:58:06 +01:00
Søren Theilgaard
890c26e2e1 Logging correction for app delete 2022-02-02 21:47:59 +01:00
Søren Theilgaard
f1616d0d02 Logging fixes 2022-02-02 21:23:41 +01:00
Søren Theilgaard
0a05b533a5 Logging info and a fix 2022-02-02 19:59:14 +01:00
Søren Theilgaard
d36b42acf4 Isaac logging improvements/fixes
Moved the variable declarations from `functions.sh` to `arguments.sh`. We need the argument parsing before setting the logging level and other variables.
2022-02-02 19:39:48 +01:00
Søren Theilgaard
434b755946 Renamed to promiseutility
Not sure why the "r" was there in the first place.
2022-02-02 16:13:33 +01:00
Søren Theilgaard
62734a2acc 403 labels! 2022-02-02 16:00:23 +01:00
Søren Theilgaard
29fadb78b4 Update checkInstallomator.sh 2022-02-02 15:57:30 +01:00
Søren Theilgaard
3a397c5881 Label name and better handling 2022-02-02 15:37:08 +01:00
Søren Theilgaard
bbf4b22296 Fix for Apple signed software
Somehow went missing in the Isaac logging.
2022-02-02 15:23:46 +01:00
Søren Theilgaard
790dabaa27 Comment on exit value if only label name is requested 2022-02-02 15:08:39 +01:00
Søren Theilgaard
ded71fdf8d Error in cleanupAndExit fixed
Unmounted drive after we deleted the temporary items. Reversed order.
2022-02-02 15:02:31 +01:00
Søren Theilgaard
952683310a Merge branch 'pr/268' into 2022-02-02_Theile-base 2022-02-02 14:46:47 +01:00
Søren Theilgaard
5991ce2287 Merge branch 'checkInstallomator.sh' into 2022-02-02_Theile-base 2022-02-02 14:44:19 +01:00
Søren Theilgaard
19137f6d94 Merge branch 'Fixing-if-LSMinimumSystemVersion-doesn't-exist' into 2022-02-02_Theile-base 2022-02-02 14:42:26 +01:00
Søren Theilgaard
fe21c1395a Merge branch 'README-overhaul' into 2022-02-02_Theile-base 2022-02-02 14:42:04 +01:00
Søren Theilgaard
5b54eb7674 Merge branch 'Improved-Isaac-logging' into 2022-02-02_Theile-base 2022-02-02 14:38:18 +01:00
Søren Theilgaard
6559d84075 Merge branch 'Download-with-more-headers' into 2022-02-02_Theile-base 2022-02-02 14:36:43 +01:00
Søren Theilgaard
168abdb32e Merge branch 'versionKey-improvements' into 2022-02-02_Theile-base 2022-02-02 14:34:01 +01:00
Søren Theilgaard
f53e20e313 Update functions.sh
If only returning label name, then we exit with 0.
2022-02-02 13:49:00 +01:00
Søren Theilgaard
9416700da2 Update checkInstallomator.sh
More description on what to test
2022-02-01 09:12:50 +01:00
Søren Theilgaard
dd2af4a40e Create checkInstallomator.sh
This script will check certain labels. It's meant to check all (or most) of Installomator, to see if the code is working. We need labels that are representative for alle the functionality in the script.

(Bug-fix for LSMinimumSystemVersion is needed for some of these to work)
2022-02-01 00:13:51 +01:00
Søren Theilgaard
bc26aa0ca6 Update functions.sh
Had a problem with `dbeaverce` that claimed LSMinimumSystemVersion was used even though it was not, so improved the handling.
2022-01-31 23:41:07 +01:00
Søren Theilgaard
ec2debc9a8 Update README.md 2022-01-31 12:57:31 +01:00
Søren Theilgaard
1e68b7e501 Update README.md 2022-01-31 10:00:07 +01:00
Søren Theilgaard
64a33a7f6b Update README.md 2022-01-31 09:49:47 +01:00
Søren Theilgaard
3bf9299218 Merge pull request #392 from Installomator/Labels-Theile-9
Canva
2022-01-30 11:28:13 +01:00
Søren Theilgaard
ac9c5096cd Update canva.sh
Results:
```
checkLabels.sh canva

Total labels:
canva

Architecture: i386

########## canva
Name: Canva
Download URL: https://desktop-release.canva.com/Canva-latest.dmg
Type: dmg
Version: 1.38.0
OK: downloadURL works OK
OK: download extension MATCH on dmg

Architecture: arm64

########## canva
Name: Canva
Download URL: https://desktop-release.canva.com/Canva-latest-arm64.dmg
Type: dmg
Version: 1.38.0
OK: downloadURL works OK
OK: download extension MATCH on dmg

Warnings counted: 0
ERRORS counted: 0
Done!

assemble.sh canva
2022-01-30 11:16:01 canva ################## Start Installomator v. 9.0dev
2022-01-30 11:16:01 canva ################## canva
2022-01-30 11:16:01 canva DEBUG mode 1 enabled.
2022-01-30 11:16:02 canva BLOCKING_PROCESS_ACTION=tell_user
2022-01-30 11:16:02 canva NOTIFY=success
2022-01-30 11:16:02 canva LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-01-30 11:16:02 canva no blocking processes defined, using Canva as default
2022-01-30 11:16:02 canva Changing directory to /Users/st/Documents/GitHub/Installomator/build
2022-01-30 11:16:02 canva App(s) found: /Applications/Canva.app
2022-01-30 11:16:02 canva found app at /Applications/Canva.app, version 1.38.0
2022-01-30 11:16:02 canva appversion: 1.38.0
2022-01-30 11:16:02 canva Latest version of Canva is 1.38.0
2022-01-30 11:16:02 canva DEBUG mode 1 enabled, not exiting, but there is no new version of app.
2022-01-30 11:16:02 canva Downloading https://desktop-release.canva.com/Canva-latest-arm64.dmg to Canva.dmg
2022-01-30 11:16:10 canva DEBUG mode 1, not checking for blocking processes
2022-01-30 11:16:10 canva Installing Canva
2022-01-30 11:16:10 canva Mounting /Users/st/Documents/GitHub/Installomator/build/Canva.dmg
2022-01-30 11:16:15 canva Mounted: /Volumes/Canva 1.38.0-arm64 1
2022-01-30 11:16:15 canva Verifying: /Volumes/Canva 1.38.0-arm64 1/Canva.app
2022-01-30 11:16:17 canva Team ID matching: 5HD2ARTBFS (expected: 5HD2ARTBFS )
2022-01-30 11:16:17 canva Downloaded version of Canva is 1.38.0, same as installed.
2022-01-30 11:16:17 canva Unmounting /Volumes/Canva 1.38.0-arm64 1
"disk6" ejected.
2022-01-30 11:16:17 canva DEBUG mode 1, not reopening anything
2022-01-30 11:16:17 canva ################## End Installomator, exit code 0
```
2022-01-30 11:18:22 +01:00
Søren Theilgaard
22395d00a5 Merge pull request #395 from SmithersJr/Rancher-Desktop-label 2022-01-29 14:07:20 +01:00
Rob Smithers
a994a8497c Create rancherdesktop.sh
Adding label for Rancher Desktop
2022-01-28 14:20:44 -05:00
Will Polley
e7f4f86b58 Added label propresenter7
To retrieve a response from the update feed, certain variables were required. Changing those variables did not seem to change the output of the update service.

installormator.sh propresenter7 DEBUG=0
2022-01-23 11:47:26 propresenter7 setting variable from argument DEBUG=0
2022-01-23 11:47:26 propresenter7 ################## Start Installomator v. 9.0dev
2022-01-23 11:47:26 propresenter7 ################## propresenter7
2022-01-23 11:47:26 propresenter7 BLOCKING_PROCESS_ACTION=tell_user
2022-01-23 11:47:26 propresenter7 NOTIFY=success
2022-01-23 11:47:26 propresenter7 LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-01-23 11:47:26 propresenter7 Changing directory to /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.K74BOKe5
2022-01-23 11:47:26 propresenter7 App(s) found:
2022-01-23 11:47:26 propresenter7 could not find ProPresenter.app
2022-01-23 11:47:26 propresenter7 appversion:
2022-01-23 11:47:26 propresenter7 Latest version of ProPresenter 7 is 7.8
2022-01-23 11:47:26 propresenter7 Downloading https://renewedvision.com/downloads/propresenter/mac/ProPresenter_7.8_117964825.zip to ProPresenter 7.zip
2022-01-23 11:47:28 propresenter7 no more blocking processes, continue with update
2022-01-23 11:47:28 propresenter7 Installing ProPresenter 7
2022-01-23 11:47:28 propresenter7 Unzipping ProPresenter 7.zip
2022-01-23 11:47:29 propresenter7 Verifying: /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.K74BOKe5/ProPresenter.app
2022-01-23 11:47:31 propresenter7 Team ID matching: 97GAAZ6CPX (expected: 97GAAZ6CPX )
2022-01-23 11:47:31 propresenter7 Downloaded version of ProPresenter 7 is 7.8 (replacing version ).
2022-01-23 11:47:31 propresenter7 Copy /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.K74BOKe5/ProPresenter.app to /Applications
2022-01-23 11:47:33 propresenter7 Changing owner to will.polley
2022-01-23 11:47:33 propresenter7 Finishing...
2022-01-23 11:47:43 propresenter7 App(s) found: /Applications/ProPresenter.app
2022-01-23 11:47:43 propresenter7 found app at /Applications/ProPresenter.app, version 7.8
2022-01-23 11:47:43 propresenter7 Installed ProPresenter 7, version 7.8
2022-01-23 11:47:43 propresenter7 notifying
2022-01-23 11:47:43 propresenter7 Deleting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.K74BOKe5
2022-01-23 11:47:44 propresenter7 App not closed, so no reopen.
2022-01-23 11:47:44 propresenter7 ################## End Installomator, exit code 0
2022-01-23 12:02:38 -05:00
Søren Theilgaard
621d6df346 Update arguments.sh 2022-01-22 06:18:00 +01:00
Søren Theilgaard
9bd11b6826 wireshark version update 2022-01-20 14:36:51 +01:00
Søren Theilgaard
6e76685721 Android file transfer 2022-01-20 14:18:27 +01:00
Søren Theilgaard
64a91bff36 MDM script correction
I seems to have seen that `caffeinate` is not really stopped, so I added `pkill caffeinate`.
2022-01-20 11:34:18 +01:00
Søren Theilgaard
7d02cf1da4 tageditor label fix 2022-01-20 10:05:31 +01:00
Søren Theilgaard
2baf2abb91 Merge branch 'dev' of https://github.com/Installomator/Installomator into dev 2022-01-20 09:58:38 +01:00
Søren Theilgaard
5068ebcfd0 iina label fix in filename 2022-01-20 09:58:28 +01:00
Søren Theilgaard
2571744a65 Merge pull request #390 from pythoninthegrass/tableaupublic
Added Tableau Public to labels
2022-01-20 09:54:00 +01:00
Søren Theilgaard
f2354ec755 Update tableaupublic.sh 2022-01-20 09:03:08 +01:00
Søren Theilgaard
f218889f7c Merge pull request #389 from fleish/dev
Update GPG Suite for blocking process & add DaisyDisk app
2022-01-20 08:47:24 +01:00
Søren Theilgaard
449f7e5261 Update daisydisk.sh 2022-01-20 08:35:06 +01:00
pythoninthegrass
197e07ed99 Added Tableau Public to 2022-01-19 17:48:21 -06:00
fleish
ad4692e9bf Create daisydisk.sh
DaisyDisk app from https://daisydiskapp.com/
2022-01-19 15:08:42 -08:00
fleish
195b7df5f5 GPG Suite blocking process update
Looks for GPG Keychain as there is no GPG Suite.app
2022-01-19 15:07:19 -08:00
Adam Codega
6f4d9b5e81 Merge pull request #388 from Installomator/revert-370-dev
Revert "Update gpgsuite blockingProcesses for GPG Keychain & add DaisyDisk label"
2022-01-19 16:55:44 -05:00
Adam Codega
4745138258 Revert "Update gpgsuite blockingProcesses for GPG Keychain & add DaisyDisk label" 2022-01-19 16:55:17 -05:00
Søren Theilgaard
c64dced024 Merge pull request #386 from apizz/patch-5
Add Code42 arm64 downloadURL introduced with 8.8.2 release
2022-01-19 14:44:57 +01:00
AP Orlebeke
dd7344b838 Remove credit per request 2022-01-19 08:42:09 -05:00
Søren Theilgaard
49337a4ae8 versionKey improved
If `versionKey` is used as part of `valuesfromarguments` it will currently be replaced by our standard value `CFBundleShortVersionString` (it was only testet on labels). So added an `if...then` to know if it was already set as part of the arguments.
Also improved logging to show what `versionKey` is.
2022-01-19 14:36:05 +01:00
AP Orlebeke
cfaa94c51f Add arm64 downloadURL introduced with 8.8.2 2022-01-18 19:41:09 -05:00
Søren Theilgaard
83459a83d6 Merge pull request #384 from Installomator/remotedesktopmanager-ent-free
Remote Desktop Manager Enterprise and Free, and front update
2022-01-18 20:31:05 +01:00
Søren Theilgaard
08435381a1 Update front.sh 2022-01-18 20:30:39 +01:00
Søren Theilgaard
df40501291 Remote Desktop Manager Enterprise and Free
Two more apps
2022-01-18 11:27:44 +01:00
Søren Theilgaard
197b34fe02 Update buildLabel.sh 2022-01-17 15:40:03 +01:00
Søren Theilgaard
0f448404e2 Merge branch 'dev' into fullscreen-check 2022-01-17 09:53:11 +01:00
Søren Theilgaard
c98fd8f26c Update CHANGELOG.md 2022-01-17 09:46:41 +01:00
Søren Theilgaard
244e4bb25a Merge pull request #354 from acodega/acodegaPromptUserHelpText
Improve documentation on prompt_user and related variables
2022-01-17 09:34:45 +01:00
Søren Theilgaard
c60999ac7d Update README.md 2022-01-17 09:34:14 +01:00
Søren Theilgaard
dc520726f8 Merge branch 'dev' into acodegaPromptUserHelpText 2022-01-17 09:29:57 +01:00
Søren Theilgaard
c7165f2154 Merge pull request #378 from adibue/adibue-wireshark-add-arm
Added downloadURL for ARM
2022-01-17 09:18:12 +01:00
Søren Theilgaard
717d7f46a6 Merge pull request #377 from adibue/adibue-docker-xpath-correction
Docker: Changed xpath to use 'last()'
2022-01-17 09:17:39 +01:00
Søren Theilgaard
35921e5893 Merge pull request #381 from Installomator/lowprofile-label
Create lowprofile.sh
2022-01-17 09:16:41 +01:00
Søren Theilgaard
fb777c7038 Merge pull request #380 from fleish/dev
Fix authydesktop downloadURL
2022-01-17 09:16:29 +01:00
Søren Theilgaard
c7eeaeee19 Create lowprofile.sh
Installing app with force to replace currently installed version:
```
Installomator/utils/assemble.sh lowprofile DEBUG=0 INSTALL=force
2022-01-14 21:24:43 lowprofile setting variable from argument DEBUG=0
2022-01-14 21:24:43 lowprofile setting variable from argument INSTALL=force
2022-01-14 21:24:43 lowprofile ################## Start Installomator v. 9.0dev
2022-01-14 21:24:43 lowprofile ################## lowprofile
2022-01-14 21:24:43 lowprofile BLOCKING_PROCESS_ACTION=tell_user
2022-01-14 21:24:43 lowprofile NOTIFY=success
2022-01-14 21:24:43 lowprofile LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-01-14 21:24:43 lowprofile no blocking processes defined, using Low Profile as default
2022-01-14 21:24:43 lowprofile Changing directory to /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.sTvDinhT
2022-01-14 21:24:43 lowprofile App(s) found: /Applications/Low Profile.app
2022-01-14 21:24:43 lowprofile found app at /Applications/Low Profile.app, version 2.0
2022-01-14 21:24:43 lowprofile appversion: 2.0
2022-01-14 21:24:43 lowprofile Label is not of type “updateronly”, and it’s set to use force to install or ignoring app store apps, so not using updateTool.
2022-01-14 21:24:43 lowprofile Latest version of Low Profile is 2.0
2022-01-14 21:24:43 lowprofile There is no newer version available.
2022-01-14 21:24:43 lowprofile Downloading https://github.com/ninxsoft/LowProfile/releases/download/v2.0/Low.Profile.2.0.dmg to Low Profile.dmg
2022-01-14 21:24:45 lowprofile no more blocking processes, continue with update
2022-01-14 21:24:45 lowprofile Installing Low Profile
2022-01-14 21:24:45 lowprofile Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.sTvDinhT/Low Profile.dmg
2022-01-14 21:24:48 lowprofile Mounted: /Volumes/Low Profile 1
2022-01-14 21:24:48 lowprofile Verifying: /Volumes/Low Profile 1/Low Profile.app
2022-01-14 21:24:48 lowprofile Team ID matching: 7K3HVCLV7Z (expected: 7K3HVCLV7Z )
2022-01-14 21:24:48 lowprofile Downloaded version of Low Profile is 2.0, same as installed.
2022-01-14 21:24:48 lowprofile Using force to install anyway.
2022-01-14 21:24:48 lowprofile App has LSMinimumSystemVersion: 12.0
2022-01-14 21:24:48 lowprofile Removing existing /Applications/Low Profile.app
2022-01-14 21:24:48 lowprofile Copy /Volumes/Low Profile 1/Low Profile.app to /Applications
2022-01-14 21:24:48 lowprofile Changing owner to st
2022-01-14 21:24:48 lowprofile Finishing...
2022-01-14 21:24:58 lowprofile App(s) found: /Applications/Low Profile.app
2022-01-14 21:24:58 lowprofile found app at /Applications/Low Profile.app, version 2.0
2022-01-14 21:24:58 lowprofile Installed Low Profile, version 2.0
2022-01-14 21:24:58 lowprofile notifying
2022-01-14 21:24:58 lowprofile Deleting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.sTvDinhT
2022-01-14 21:24:58 lowprofile Unmounting /Volumes/Low Profile 1
"disk5" ejected.
2022-01-14 21:24:58 lowprofile App not closed, so no reopen.
2022-01-14 21:24:58 lowprofile ################## End Installomator, exit code 0
```
2022-01-14 21:26:03 +01:00
fleish
d470867c10 Fix authydesktop downloadURL
Checks for redirect_url and replaces space to be urlencoded
2022-01-14 11:55:02 -08:00
Adrian Bühler
0916d618b6 Added downloadURL for ARM
Added Download URL to the Apple Silicon DMG.
2022-01-14 14:54:22 +01:00
Søren Theilgaard
e4a5f47272 Label on each log line (again) 2022-01-14 10:14:29 +01:00
Søren Theilgaard
fee9394751 Few more DEBUG loggings 2022-01-14 10:02:00 +01:00
Adrian Bühler
d2381d2053 Changed xpath to use 'last()'
When I created PR #374, the sparkle feed had just one entry. Turns out, that Docker uses the last entry of the feed for the latest version.
With simply changing xpath to use `[last()]`, the version checking now behaves as expected.
2022-01-14 09:33:42 +01:00
Søren Theilgaard
7f2bdfb1df Local logging improvements
Improved first lines of logs to be required and show `VERSION` and `VERSIONDATE` on separate lines.
Logging sent to Datadog will have `VERSION` on each line.
2022-01-13 21:52:15 +01:00
Søren Theilgaard
69372e4929 Merge pull request #368 from adibue/adibue-libreoffice-patch
Update libreoffice.sh
2022-01-13 20:45:01 +01:00
Søren Theilgaard
b45bb0c39a Merge pull request #370 from fleish/dev
Update gpgsuite blockingProcesses for GPG Keychain & add DaisyDisk label
2022-01-13 20:39:06 +01:00
Søren Theilgaard
e6b58010d5 Merge pull request #374 from adibue/adibue-docker-fix-appnewversion
Fixed 'appNewVersion' for 'docker'
2022-01-13 20:19:33 +01:00
Søren Theilgaard
82faf74eb3 Update functions.sh 2022-01-13 14:12:51 +01:00
Søren Theilgaard
f96cd178c6 CLIInstaller included
and a few other displaylog lines changed
2022-01-13 09:44:34 +01:00
Søren Theilgaard
99b908f646 Logging 2022-01-12 21:34:16 +01:00
Adrian Bühler
59c7590107 Fixed 'appNewVersion' for 'docker'
URLs for version checking have changed. It's now using the `shortVersionString` from the sparkle feed.

Example run for M1:

```
$ sudo zsh Installomator.sh docker DEBUG=0

2022-01-12 18:16:35 docker setting variable from argument DEBUG=0
2022-01-12 18:16:35 docker ################## Start Installomator v. 8.0
2022-01-12 18:16:35 docker ################## docker
2022-01-12 18:16:35 docker BLOCKING_PROCESS_ACTION=tell_user
2022-01-12 18:16:35 docker NOTIFY=success
2022-01-12 18:16:35 docker LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-01-12 18:16:35 docker no blocking processes defined, using Docker as default
2022-01-12 18:16:35 docker Changing directory to /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.t4N46qTN
2022-01-12 18:16:35 docker App(s) found: /Applications/Docker.app
2022-01-12 18:16:35 docker found app at /Applications/Docker.app, version 4.3.2
2022-01-12 18:16:35 docker appversion: 4.3.2
2022-01-12 18:16:35 docker Latest version of Docker is 4.3.2
2022-01-12 18:16:35 docker There is no newer version available.
2022-01-12 18:16:35 docker Deleting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.t4N46qTN
2022-01-12 18:16:35 docker App not closed, so no reopen.
2022-01-12 18:16:35 docker ################## End Installomator, exit code 0
```
2022-01-12 18:22:36 +01:00
Søren Theilgaard
180ca0952b Update checkLabels.sh 2022-01-12 14:03:30 +01:00
Søren Theilgaard
c0ce59a1ec Update functions.sh 2022-01-12 13:55:40 +01:00
Søren Theilgaard
a36e9fce43 Isaac Logging
Improvements to logging:
- Logging levels as DEBUG 0 INFO 1 WARN 2 ERROR 3 REQ 4
- External logging to Datadog
- A function to shorten duplicate lines in installation logs
- Ability to extract install.log in the time when Installomator was running, if further investigations needs to be done to logs
2022-01-12 13:53:48 +01:00
Søren Theilgaard
da21ea8582 Update checkLabels.sh
Need `INSTAL=force` and `IGNORE_APP_STORE_APPS=yes` to be able test any title on any system.
2022-01-12 12:53:07 +01:00
Søren Theilgaard
c8071a2a63 Create diskspace.sh 2022-01-12 12:48:45 +01:00
Søren Theilgaard
0fc7761fb9 Label fixed 2022-01-12 09:26:46 +01:00
Søren Theilgaard
4df1a6dbaa canva and logitechoptions labels fixed 2022-01-11 23:39:55 +01:00
Søren Theilgaard
cd0204bb04 Update checkLabels.sh 2022-01-11 23:05:53 +01:00
Søren Theilgaard
901ea4babd Update checkLabels.sh 2022-01-11 23:03:51 +01:00
Søren Theilgaard
504e8528ce Update checkLabels.sh 2022-01-11 22:56:38 +01:00
Søren Theilgaard
6f229b0b8c Update buildLabel.sh 2022-01-11 21:38:49 +01:00
Søren Theilgaard
36b7148e30 Update checkLabels.sh 2022-01-11 20:39:53 +01:00
Søren Theilgaard
0cdc780a5f Update checkLabels.sh 2022-01-11 19:06:50 +01:00
Søren Theilgaard
59eaff7d26 Update CHANGELOG.md 2022-01-11 18:58:39 +01:00
fleish
8532baf8a5 Add DaisyDisk label 2022-01-11 09:46:07 -08:00
fleish
9d021e012c Merge pull request #1 from fleish/fleish-patch-gpgsuite
Update gpgsuite blockingProcesses for GPG Keychain
2022-01-11 09:42:07 -08:00
fleish
22129c7220 Update gpgsuite blockingProcesses for GPG Keychain 2022-01-11 09:41:15 -08:00
Søren Theilgaard
ca1759abd9 Update checkLabels.sh 2022-01-11 18:37:34 +01:00
Søren Theilgaard
1360b51eae removed the debug set -x 2022-01-11 16:35:09 +01:00
Søren Theilgaard
193d51d49f curlOptions as array. 2022-01-11 16:32:18 +01:00
Søren Theilgaard
bd07ee6c76 More to curlOptions 2022-01-11 12:53:06 +01:00
Søren Theilgaard
01eabca204 Introducing curlOptions to labels. 2022-01-11 11:54:54 +01:00
Søren Theilgaard
732181c3a6 Delete main.sh 2022-01-11 11:42:29 +01:00
Søren Theilgaard
a8c9fdbab7 Download with extra sets of headers 2022-01-10 20:26:53 +01:00
Adrian Bühler
27fd0b0347 Update libreoffice.sh
Added `downloadURL` for Apple Silicon. Also added `blockingProcesses`, so open documents are not quit anymore while updating.
2022-01-10 17:44:28 +01:00
Søren Theilgaard
3c7d570249 Update brave.sh 2022-01-10 13:07:39 +01:00
Søren Theilgaard
fe4c8a96da brave fix 2022-01-10 13:04:04 +01:00
Søren Theilgaard
9603ef3552 Merge pull request #337 from kdrwygvh/zulu-jdk-17-newlabel
New label for Azul Zulu JDK 17
2022-01-09 21:46:36 +01:00
Søren Theilgaard
e41cf16945 Merge pull request #336 from kdrwygvh/zulu-jdk-15-urlupdate
Updated URL
2022-01-09 21:44:40 +01:00
Søren Theilgaard
d88712be1d Merge pull request #335 from kdrwygvh/zulu-jdk-11-urlupdate
Updated URL
2022-01-09 21:44:08 +01:00
Søren Theilgaard
bb6bf1c526 Merge pull request #341 from apizz/flux
Add Flux
2022-01-09 21:42:37 +01:00
Søren Theilgaard
4e21a99fd7 Update flux.sh 2022-01-09 21:41:32 +01:00
Søren Theilgaard
320757c747 Merge pull request #359 from Installomator/Theile-labels-9.0
Theile labels 9.0
2022-01-09 21:33:08 +01:00
Søren Theilgaard
18e3024604 Merge branch 'dev' into Theile-labels-9.0 2022-01-09 21:32:59 +01:00
Søren Theilgaard
188689f1fd Merge pull request #353 from Installomator/pkgInDMGExpansionFix
Pkg in dmg expansion fix
2022-01-09 21:29:41 +01:00
Søren Theilgaard
1b6d7929d3 Merge pull request #348 from AustinLeath/dev
Grammar fixes for fragments/header.sh
2022-01-09 21:28:27 +01:00
Søren Theilgaard
b61f18e6f4 Merge pull request #366 from Installomator/LSMinimumSystemVersion-check
LSMinimumSystemVersion handling
2022-01-09 21:24:44 +01:00
Søren Theilgaard
899dbaa6b3 Merge branch 'dev' into LSMinimumSystemVersion-check 2022-01-09 21:24:27 +01:00
Søren Theilgaard
cd91fd5b2f Merge pull request #365 from Installomator/Return-label-name
`RETURN_LABEL_NAME` implemented
2022-01-09 21:23:32 +01:00
Søren Theilgaard
cd1d05b21f Merge branch 'dev' into Return-label-name 2022-01-09 21:23:24 +01:00
Søren Theilgaard
d74eab2ae7 Merge pull request #343 from Installomator/Fix-for-app-store-replacement-when-label-have-updatetool
Change to App Store replacement logic
2022-01-09 21:22:35 +01:00
Søren Theilgaard
88367cf6b2 Merge branch 'dev' into Fix-for-app-store-replacement-when-label-have-updatetool 2022-01-09 21:22:27 +01:00
Søren Theilgaard
cced10b1c6 Merge pull request #346 from Installomator/Systemowner
possibility to have root:wheel on copied apps
2022-01-09 21:19:44 +01:00
Søren Theilgaard
79cdaa2b40 Merge pull request #349 from adibue/adibue-add-tidal
Added 'tidal'
2022-01-09 21:18:23 +01:00
Søren Theilgaard
4d9348761b Update tidal.sh 2022-01-09 21:15:52 +01:00
Søren Theilgaard
6e5a5d0a41 Merge pull request #351 from dvreijen/patch-1
New label for Itsycal
2022-01-09 20:56:48 +01:00
Søren Theilgaard
02b0829877 Update itsycal.sh 2022-01-09 20:55:13 +01:00
Søren Theilgaard
c1734bac7f Update itsycal.sh 2022-01-09 20:28:22 +01:00
Søren Theilgaard
31fe45e61a Merge pull request #352 from Installomator/applefontsfix
updated teamID for apple fonts labels
2022-01-09 20:16:54 +01:00
Søren Theilgaard
9711d53d5e Merge pull request #355 from apizz/secretive
Add secretive
2022-01-09 20:14:35 +01:00
Søren Theilgaard
7e059581ad Update secretive.sh 2022-01-09 20:13:49 +01:00
Søren Theilgaard
294dd3c58f Merge pull request #363 from apizz/textexpander-patch
Update textexpander download URL
2022-01-09 20:12:37 +01:00
Søren Theilgaard
ea58d0e48b Merge pull request #356 from kdrwygvh/box-url-update
Updated URL for Box Drive
2022-01-09 20:09:08 +01:00
Søren Theilgaard
85a8fd09d9 Update boxdrive.sh 2022-01-09 20:08:46 +01:00
Søren Theilgaard
67212af6d7 Merge pull request #357 from jeff-finlay/patch-2
Create iina
2022-01-09 20:07:26 +01:00
Søren Theilgaard
a78bd9a285 Merge pull request #358 from nestyurkin/nestyurkin-patch-1
Create Pritunl
2022-01-09 20:05:01 +01:00
Søren Theilgaard
791fd45bae Update CHANGELOG.md 2022-01-09 11:23:57 +01:00
Søren Theilgaard
264dc99a97 Update CHANGELOG.md 2022-01-09 10:47:30 +01:00
Søren Theilgaard
aa2f4146f7 Update CHANGELOG.md 2022-01-09 10:45:06 +01:00
Søren Theilgaard
9b47ed2e3f pkgName can be searched for.
In `logitechoptions` we do not know what the app-name is that contains the pkg in the bundle-package, so now we only give the name of the pkg, and then Installomator will find it.
2022-01-09 10:42:45 +01:00
Søren Theilgaard
130764696d New URL and version
But Installomator does not handle regex in the pkgName, so this doesn't work, yet.
2022-01-09 10:05:03 +01:00
Søren Theilgaard
6a9ffeb101 Create sdnotary.sh
Great app for signing AppleScript and Automator Apps.

```
Installomator/utils/assemble.sh sdnotary DEBUG=0
2022-01-08 20:02:33 sdnotary setting variable from argument DEBUG=0
2022-01-08 20:02:33 sdnotary ################## Start Installomator v. 9.0dev
2022-01-08 20:02:33 sdnotary ################## sdnotary
2022-01-08 20:02:35 sdnotary BLOCKING_PROCESS_ACTION=tell_user
2022-01-08 20:02:35 sdnotary NOTIFY=success
2022-01-08 20:02:35 sdnotary LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-01-08 20:02:35 sdnotary no blocking processes defined, using SD Notary as default
2022-01-08 20:02:35 sdnotary Changing directory to /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.Y3LciW3v
2022-01-08 20:02:35 sdnotary App(s) found: /Applications/SD Notary.app
2022-01-08 20:02:35 sdnotary found app at /Applications/SD Notary.app, version 1.4.9
2022-01-08 20:02:35 sdnotary appversion: 1.4.9
2022-01-08 20:02:35 sdnotary Latest version of SD Notary is 1.4.9
2022-01-08 20:02:35 sdnotary There is no newer version available.
2022-01-08 20:02:35 sdnotary Deleting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.Y3LciW3v
2022-01-08 20:02:35 sdnotary App not closed, so no reopen.
2022-01-08 20:02:35 sdnotary ################## End Installomator, exit code 0

Installomator/utils/assemble.sh sdnotary DEBUG=0 INSTALL=force
2022-01-08 20:02:55 sdnotary setting variable from argument DEBUG=0
2022-01-08 20:02:55 sdnotary setting variable from argument INSTALL=force
2022-01-08 20:02:55 sdnotary ################## Start Installomator v. 9.0dev
2022-01-08 20:02:55 sdnotary ################## sdnotary
2022-01-08 20:02:57 sdnotary BLOCKING_PROCESS_ACTION=tell_user
2022-01-08 20:02:57 sdnotary NOTIFY=success
2022-01-08 20:02:57 sdnotary LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-01-08 20:02:57 sdnotary no blocking processes defined, using SD Notary as default
2022-01-08 20:02:57 sdnotary Changing directory to /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.Pt3uud5W
2022-01-08 20:02:57 sdnotary App(s) found: /Applications/SD Notary.app
2022-01-08 20:02:57 sdnotary found app at /Applications/SD Notary.app, version 1.4.9
2022-01-08 20:02:57 sdnotary appversion: 1.4.9
2022-01-08 20:02:57 sdnotary Using force to install, so not using updateTool.
2022-01-08 20:02:57 sdnotary Latest version of SD Notary is 1.4.9
2022-01-08 20:02:57 sdnotary There is no newer version available.
2022-01-08 20:02:57 sdnotary Downloading https://s3.amazonaws.com/latenightsw.com/SDNotary1.4.9-65.zip to SD Notary.zip
2022-01-08 20:02:58 sdnotary no more blocking processes, continue with update
2022-01-08 20:02:58 sdnotary Installing SD Notary
2022-01-08 20:02:58 sdnotary Unzipping SD Notary.zip
2022-01-08 20:02:58 sdnotary Verifying: /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.Pt3uud5W/SD Notary.app
2022-01-08 20:02:59 sdnotary Team ID matching: Z7S6X96M3X (expected: Z7S6X96M3X )
2022-01-08 20:02:59 sdnotary Downloaded version of SD Notary is 1.4.9, same as installed.
2022-01-08 20:02:59 sdnotary Using force to install anyway.
2022-01-08 20:02:59 sdnotary Removing existing /Applications/SD Notary.app
2022-01-08 20:02:59 sdnotary Copy /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.Pt3uud5W/SD Notary.app to /Applications
2022-01-08 20:02:59 sdnotary Changing owner to st
2022-01-08 20:02:59 sdnotary Finishing...
2022-01-08 20:03:09 sdnotary App(s) found: /Applications/SD Notary.app
2022-01-08 20:03:09 sdnotary found app at /Applications/SD Notary.app, version 1.4.9
2022-01-08 20:03:09 sdnotary Installed SD Notary, version 1.4.9
2022-01-08 20:03:09 sdnotary notifying
2022-01-08 20:03:09 sdnotary Deleting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.Pt3uud5W
2022-01-08 20:03:09 sdnotary App not closed, so no reopen.
2022-01-08 20:03:09 sdnotary ################## End Installomator, exit code 0
```
2022-01-08 20:04:47 +01:00
Søren Theilgaard
a1afc4727e Update functions.sh
Now return one `#` when unknown label is given, not a whole bunch of them.

```
Installomator/utils/assemble.sh strangelabel RETURN_LABEL_NAME=1 DEBUG=0 | tail -1
#
```
2022-01-08 15:37:08 +01:00
Søren Theilgaard
d80c76a4d3 mocha-software and buildLabel.sh
Improved buildLabel.sh to handle another set of headers when trying to download, and that can handle the mocha-software.

But mocha-software has been disabled, as Installomator does not offer the headers when that is trying to download.
2022-01-07 20:41:35 +01:00
Søren Theilgaard
c3ddd4f8c7 Update buildLabel.sh
Different set of headers.
2022-01-07 19:40:51 +01:00
Søren Theilgaard
75e550acfe notification
Now with notification:
```
Installomator/utils/assemble.sh omnidisksweeper DEBUG=0 INSTALL=force NOTIFY=all
2022-01-07 14:05:25 omnidisksweeper setting variable from argument DEBUG=0
2022-01-07 14:05:25 omnidisksweeper setting variable from argument INSTALL=force
2022-01-07 14:05:25 omnidisksweeper setting variable from argument NOTIFY=all
2022-01-07 14:05:25 omnidisksweeper ################## Start Installomator v. 9.0dev
2022-01-07 14:05:25 omnidisksweeper ################## omnidisksweeper
2022-01-07 14:05:25 omnidisksweeper BLOCKING_PROCESS_ACTION=tell_user
2022-01-07 14:05:25 omnidisksweeper NOTIFY=all
2022-01-07 14:05:25 omnidisksweeper LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-01-07 14:05:26 omnidisksweeper no blocking processes defined, using OmniDiskSweeper as default
2022-01-07 14:05:26 omnidisksweeper Changing directory to /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.11IcaInb
2022-01-07 14:05:26 omnidisksweeper App(s) found: /Applications/OmniDiskSweeper.app
2022-01-07 14:05:26 omnidisksweeper found app at /Applications/OmniDiskSweeper.app, version 1.13
2022-01-07 14:05:26 omnidisksweeper appversion: 1.13
2022-01-07 14:05:26 omnidisksweeper Using force to install, so not using updateTool.
2022-01-07 14:05:26 omnidisksweeper Latest version of OmniDiskSweeper is 1.13
2022-01-07 14:05:26 omnidisksweeper There is no newer version available.
2022-01-07 14:05:26 omnidisksweeper Downloading https://downloads.omnigroup.com/software/MacOSX/10.14/OmniDiskSweeper-1.13.dmg to OmniDiskSweeper.dmg
2022-01-07 14:05:26 omnidisksweeper notifying
2022-01-07 14:05:28 omnidisksweeper no more blocking processes, continue with update
2022-01-07 14:05:28 omnidisksweeper Installing OmniDiskSweeper
2022-01-07 14:05:28 omnidisksweeper notifying
2022-01-07 14:05:28 omnidisksweeper Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.11IcaInb/OmniDiskSweeper.dmg
2022-01-07 14:05:29 omnidisksweeper Mounted: /Volumes/OmniDiskSweeper
2022-01-07 14:05:29 omnidisksweeper Verifying: /Volumes/OmniDiskSweeper/OmniDiskSweeper.app
2022-01-07 14:05:31 omnidisksweeper Team ID matching: 34YW5XSRB7 (expected: 34YW5XSRB7 )
2022-01-07 14:05:31 omnidisksweeper Downloaded version of OmniDiskSweeper is 1.13, same as installed.
2022-01-07 14:05:31 omnidisksweeper Using force to install anyway.
2022-01-07 14:05:31 omnidisksweeper App has LSMinimumSystemVersion: 10.14
2022-01-07 14:05:32 omnidisksweeper App requires higher System Version than installed: 10.13.5
2022-01-07 14:05:32 omnidisksweeper notifying
2022-01-07 14:05:32 omnidisksweeper ERROR: Installed macOS is too old for this app.
2022-01-07 14:05:32 omnidisksweeper Deleting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.11IcaInb
2022-01-07 14:05:32 omnidisksweeper Unmounting /Volumes/OmniDiskSweeper
"disk4" ejected.
2022-01-07 14:05:32 omnidisksweeper App not closed, so no reopen.
2022-01-07 14:05:32 omnidisksweeper ################## End Installomator, exit code 6
```
2022-01-07 14:07:21 +01:00
Søren Theilgaard
6c498dbf31 LSMinimumSystemVersion handling
If an app has `LSMinimumSystemVersion` in the `Info.plist`, then we will check if the installed macOS lives up to this, and exit if not.

First a normal run on Monterey:
```
Installomator/utils/assemble.sh omnidisksweeper DEBUG=0 INSTALL=force
2022-01-07 13:37:43 omnidisksweeper setting variable from argument DEBUG=0
2022-01-07 13:37:43 omnidisksweeper setting variable from argument INSTALL=force
2022-01-07 13:37:43 omnidisksweeper ################## Start Installomator v. 9.0dev
2022-01-07 13:37:43 omnidisksweeper ################## omnidisksweeper
2022-01-07 13:37:44 omnidisksweeper BLOCKING_PROCESS_ACTION=tell_user
2022-01-07 13:37:44 omnidisksweeper NOTIFY=success
2022-01-07 13:37:44 omnidisksweeper LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-01-07 13:37:44 omnidisksweeper no blocking processes defined, using OmniDiskSweeper as default
2022-01-07 13:37:44 omnidisksweeper Changing directory to /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.41qqoUEN
2022-01-07 13:37:44 omnidisksweeper App(s) found: /Applications/OmniDiskSweeper.app
2022-01-07 13:37:44 omnidisksweeper found app at /Applications/OmniDiskSweeper.app, version 1.13
2022-01-07 13:37:44 omnidisksweeper appversion: 1.13
2022-01-07 13:37:44 omnidisksweeper Using force to install, so not using updateTool.
2022-01-07 13:37:44 omnidisksweeper Latest version of OmniDiskSweeper is 1.13
2022-01-07 13:37:44 omnidisksweeper There is no newer version available.
2022-01-07 13:37:44 omnidisksweeper Downloading https://downloads.omnigroup.com/software/MacOSX/10.14/OmniDiskSweeper-1.13.dmg to OmniDiskSweeper.dmg
2022-01-07 13:37:45 omnidisksweeper no more blocking processes, continue with update
2022-01-07 13:37:45 omnidisksweeper Installing OmniDiskSweeper
2022-01-07 13:37:45 omnidisksweeper Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.41qqoUEN/OmniDiskSweeper.dmg
2022-01-07 13:37:46 omnidisksweeper Mounted: /Volumes/OmniDiskSweeper
2022-01-07 13:37:46 omnidisksweeper Verifying: /Volumes/OmniDiskSweeper/OmniDiskSweeper.app
2022-01-07 13:37:49 omnidisksweeper Team ID matching: 34YW5XSRB7 (expected: 34YW5XSRB7 )
2022-01-07 13:37:49 omnidisksweeper App has LSMinimumSystemVersion: 10.14
2022-01-07 13:37:49 omnidisksweeper Downloaded version of OmniDiskSweeper is 1.13, same as installed.
2022-01-07 13:37:49 omnidisksweeper Using force to install anyway.
2022-01-07 13:37:49 omnidisksweeper Removing existing /Applications/OmniDiskSweeper.app
2022-01-07 13:37:49 omnidisksweeper Copy /Volumes/OmniDiskSweeper/OmniDiskSweeper.app to /Applications
2022-01-07 13:37:49 omnidisksweeper Changing owner to st
2022-01-07 13:37:49 omnidisksweeper Finishing...
2022-01-07 13:37:59 omnidisksweeper App(s) found: /Applications/OmniDiskSweeper.app
2022-01-07 13:37:59 omnidisksweeper found app at /Applications/OmniDiskSweeper.app, version 1.13
2022-01-07 13:37:59 omnidisksweeper Installed OmniDiskSweeper, version 1.13
2022-01-07 13:37:59 omnidisksweeper notifying
2022-01-07 13:37:59 omnidisksweeper Deleting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.41qqoUEN
2022-01-07 13:37:59 omnidisksweeper Unmounting /Volumes/OmniDiskSweeper
"disk4" ejected.
2022-01-07 13:38:00 omnidisksweeper App not closed, so no reopen.
2022-01-07 13:38:00 omnidisksweeper ################## End Installomator, exit code 0
```

Trying where I manually change OS version to 10.13:
```
Installomator/utils/assemble.sh omnidisksweeper DEBUG=0 INSTALL=force
2022-01-07 13:38:39 omnidisksweeper setting variable from argument DEBUG=0
2022-01-07 13:38:39 omnidisksweeper setting variable from argument INSTALL=force
2022-01-07 13:38:39 omnidisksweeper ################## Start Installomator v. 9.0dev
2022-01-07 13:38:39 omnidisksweeper ################## omnidisksweeper
2022-01-07 13:38:39 omnidisksweeper BLOCKING_PROCESS_ACTION=tell_user
2022-01-07 13:38:39 omnidisksweeper NOTIFY=success
2022-01-07 13:38:39 omnidisksweeper LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2022-01-07 13:38:39 omnidisksweeper no blocking processes defined, using OmniDiskSweeper as default
2022-01-07 13:38:39 omnidisksweeper Changing directory to /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.PXjTfPiA
2022-01-07 13:38:39 omnidisksweeper App(s) found: /Applications/OmniDiskSweeper.app
2022-01-07 13:38:39 omnidisksweeper found app at /Applications/OmniDiskSweeper.app, version 1.13
2022-01-07 13:38:40 omnidisksweeper appversion: 1.13
2022-01-07 13:38:40 omnidisksweeper Using force to install, so not using updateTool.
2022-01-07 13:38:40 omnidisksweeper Latest version of OmniDiskSweeper is 1.13
2022-01-07 13:38:40 omnidisksweeper There is no newer version available.
2022-01-07 13:38:40 omnidisksweeper Downloading https://downloads.omnigroup.com/software/MacOSX/10.14/OmniDiskSweeper-1.13.dmg to OmniDiskSweeper.dmg
2022-01-07 13:38:40 omnidisksweeper no more blocking processes, continue with update
2022-01-07 13:38:40 omnidisksweeper Installing OmniDiskSweeper
2022-01-07 13:38:40 omnidisksweeper Mounting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.PXjTfPiA/OmniDiskSweeper.dmg
2022-01-07 13:38:41 omnidisksweeper Mounted: /Volumes/OmniDiskSweeper
2022-01-07 13:38:41 omnidisksweeper Verifying: /Volumes/OmniDiskSweeper/OmniDiskSweeper.app
2022-01-07 13:38:43 omnidisksweeper Team ID matching: 34YW5XSRB7 (expected: 34YW5XSRB7 )
2022-01-07 13:38:43 omnidisksweeper App has LSMinimumSystemVersion: 10.14
2022-01-07 13:38:43 omnidisksweeper App requires higher System Version than installed: 10.13
2022-01-07 13:38:43 omnidisksweeper ERROR: Installed macOS is too old for this app.
2022-01-07 13:38:43 omnidisksweeper Deleting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.PXjTfPiA
2022-01-07 13:38:43 omnidisksweeper Unmounting /Volumes/OmniDiskSweeper
"disk4" ejected.
2022-01-07 13:38:43 omnidisksweeper App not closed, so no reopen.
2022-01-07 13:38:43 omnidisksweeper ################## End Installomator, exit code 6
```
2022-01-07 13:44:04 +01:00
Søren Theilgaard
21cee3a1ba signal is universal 2022-01-07 10:35:57 +01:00
Søren Theilgaard
3b6e27f1fa RETURN_LABEL_NAME implemented
When using DEPNotify I would like Installomator to return a nice name for the label to show as status in DEPNotify, instead of only the label name.
This way we can do that.
And maybe in the fute include a description of the software, if people are seeking inspiration to software by looking at Installomator (that contains a lot of preferred solution for many)
2022-01-07 09:51:27 +01:00
AP Orlebeke
d645985184 Update textexpander download URL 2022-01-05 15:26:55 -05:00
Søren Theilgaard
85c8fecc35 Update brave.sh
Brave is now using “CFBundleVersion” for the version check. That can be compared to the sparkle-feed.
2022-01-04 10:52:53 +01:00
Søren Theilgaard
c499327e7d Update brave.sh 2022-01-03 10:18:27 +01:00
Søren Theilgaard
61b05ff31e Update brave.sh
This is a special construction of the `appNewVersion` variable. Not sure this is future proof, but the current one was not working.
2022-01-03 09:09:30 +01:00
Søren Theilgaard
1fdbef74c1 Update logitechoptions.sh 2022-01-02 20:15:42 +01:00
nestyurkin
bd261b1c63 minimize 2021-12-30 23:49:35 +03:00
Søren Theilgaard
1a1ad30b66 mightymike and ottomatic 2021-12-30 20:09:10 +01:00
Søren Theilgaard
2c4bef3524 Update applesfsymbols.sh 2021-12-29 13:37:16 +01:00
Søren Theilgaard
dac472f6d1 Create applesfarabic.sh 2021-12-29 13:28:29 +01:00
nestyurkin
9797da6023 add packageID 2021-12-29 00:36:36 +03:00
nestyurkin
c302cf6376 Create Pritunl
Label for Pritunl
2021-12-28 19:22:11 +03:00
Jeff Finlay
ff621c7916 Create iina
Label for IINA
2021-12-23 13:33:52 -05:00
John Hutchison
d135ca1c4d Updated URL for Box Drive
Box now makes a universal installer for all architectures. Installomator debug output follows;

./assemble.sh boxdrive
2021-12-23 09:16:22 boxdrive ################## Start Installomator v. 9.0dev
2021-12-23 09:16:22 boxdrive ################## boxdrive
2021-12-23 09:16:22 boxdrive DEBUG mode 1 enabled.
2021-12-23 09:16:23 boxdrive BLOCKING_PROCESS_ACTION=tell_user
2021-12-23 09:16:23 boxdrive NOTIFY=success
2021-12-23 09:16:23 boxdrive LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2021-12-23 09:16:23 boxdrive no blocking processes defined, using Box as default
2021-12-23 09:16:23 boxdrive Changing directory to /Users/john/Documents/Source/Installomator/build
2021-12-23 09:16:23 boxdrive App(s) found:
2021-12-23 09:16:23 boxdrive could not find Box.app
2021-12-23 09:16:23 boxdrive appversion:
2021-12-23 09:16:23 boxdrive Latest version not specified.
2021-12-23 09:16:23 boxdrive Downloading https://e3.boxcdn.net/box-installers/desktop/releases/mac/Box.pkg to Box.pkg
2021-12-23 09:16:25 boxdrive DEBUG mode, not checking for blocking processes
2021-12-23 09:16:25 boxdrive Installing Box
2021-12-23 09:16:25 boxdrive Verifying: Box.pkg
2021-12-23 09:16:25 boxdrive Team ID: M683GB7CPW (expected: M683GB7CPW )
2021-12-23 09:16:25 boxdrive DEBUG enabled, skipping installation
2021-12-23 09:16:25 boxdrive Finishing...
2021-12-23 09:16:35 boxdrive App(s) found:
2021-12-23 09:16:35 boxdrive could not find Box.app
2021-12-23 09:16:35 boxdrive Installed Box
2021-12-23 09:16:35 boxdrive notifying
2021-12-23 09:16:35 boxdrive DEBUG mode, not reopening anything
2021-12-23 09:16:35 boxdrive ################## End Installomator, exit code 0
2021-12-23 09:17:37 -05:00
AP Orlebeke
61196b3da6 Add secretive 2021-12-22 14:43:16 -05:00
Adam Codega
9a9d0ca906 Update header.sh
Also clarified `prompt_user_loop`
2021-12-22 10:45:27 -05:00
Adam Codega
c635a05deb Update README.md
Updated verbiage on using `prompt_user` versus `prompt_user_then_kill` for clarification on behavior.
2021-12-22 10:44:04 -05:00
Adam Codega
ce0f23ff16 Update header.sh
Updated verbiage on using `prompt_user` versus `prompt_user_then_kill` for clarification on behavior.
2021-12-22 10:33:35 -05:00
Armin Briegel
6db60dd641 version checking pkgInDMG would attempt to expand the pkg into the read-only dmg, also simplified the xpath call 2021-12-20 14:35:11 +01:00
Armin Briegel
77bee0a88e updated teamID for apple fonts labels 2021-12-20 14:29:31 +01:00
Søren Theilgaard
a4fe0d65ec Create ibarcoder.sh 2021-12-17 14:48:24 +01:00
Søren Theilgaard
9178cf8fe5 Apple fonts 2021-12-16 09:15:43 +01:00
Søren Theilgaard
c7b5f89a4c Update depnotify.sh 2021-12-14 15:42:49 +01:00
dvreijen
acb785bb29 Create itsycal.sh
New label for Itsycal
2021-12-14 13:30:15 +01:00
Adrian Bühler
f57d946410 Added 'tidal' to 'Labels.txt' 2021-12-08 15:00:40 +01:00
Adrian Bühler
f7846c71d2 Added label for 'tidal'
Added 'tidal' to fragment labels.
Unfortunately, I was not able to find a matching URL for `appNewVersion`...
2021-12-08 14:59:15 +01:00
Søren Theilgaard
fd4e00d1fd Merge pull request #344 from dz0ny/patch-1
Add Pareto Security
2021-12-06 15:27:58 +01:00
Janez Troha
304df956b9 Use github label 2021-12-04 10:45:32 +01:00
Søren Theilgaard
76ca386abc README 2021-12-02 08:59:43 +01:00
Adam Codega
259df4aa55 Merge pull request #347 from Installomator/github-labels
GitHub fixes
2021-12-01 22:02:04 -05:00
Søren Theilgaard
b885fdb742 DEBUG mode will overrule running as root
Either DEBUG mode set, and the script will run, no matter it's not running as root.
2021-12-01 22:31:48 +01:00
Austin Leath
5a34a35e86 Plenty of grammar fixes 2021-12-01 15:30:16 -06:00
Søren Theilgaard
5bf24ab7b4 GitHub fixes 2021-12-01 22:25:31 +01:00
Søren Theilgaard
886ab1238a SYSTEMOWNER 2021-12-01 21:36:30 +01:00
Janez Troha
107f39599e Add Pareto Security
Ref: https://github.com/ParetoSecurity/pareto-mac
2021-11-30 16:29:47 +01:00
Søren Theilgaard
2ba53683df Update main.sh
Currently (before this patch) a label like `microsoftonedrive` that was installed from App Store, and that we want to replace with the “ordinary” version, Installomator would use updateTool, even though `IGNORE_APP_STORE_APPS=yes`. So we would have to have `INSTALL=force` in order to have the app replaced, as `updateTool` would be used.

With this patch, if `IGNORE_APP_STORE_APPS=yes` then `updateTool` will be not set, and the App Store app would be replaced. But if the installed software was not from App Store, then `updateTool` would not be used, and it would be a kind of a forced install (except if the version is the same).

I have this output:
```
➜  Downloads sudo Installomator/utils/assemble.sh microsoftonedrive DEBUG=0
2021-11-30 10:12:11 microsoftonedrive setting variable from argument DEBUG=0
2021-11-30 10:12:11 microsoftonedrive ################## Start Installomator v. 9.0dev
2021-11-30 10:12:11 microsoftonedrive ################## microsoftonedrive
2021-11-30 10:12:13 microsoftonedrive Running msupdate --list
Checking for updates...
Update Assistant is available.
Update Assistant is checking for updates.
Update Assistant is available.
No updates available
2021-11-30 10:12:27 microsoftonedrive BLOCKING_PROCESS_ACTION=tell_user
2021-11-30 10:12:27 microsoftonedrive NOTIFY=success
2021-11-30 10:12:27 microsoftonedrive LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2021-11-30 10:12:27 microsoftonedrive no blocking processes defined, using OneDrive as default
2021-11-30 10:12:27 microsoftonedrive Changing directory to /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.5kJ1YWMy
2021-11-30 10:12:27 microsoftonedrive App(s) found: /Applications/OneDrive.app
2021-11-30 10:12:27 microsoftonedrive found app at /Applications/OneDrive.app, version 21.220.1024
2021-11-30 10:12:27 microsoftonedrive Installed OneDrive.app is from App Store, use “IGNORE_APP_STORE_APPS=yes” to replace.
2021-11-30 10:12:27 microsoftonedrive ERROR: App previously installed from App Store, and we respect that
2021-11-30 10:12:27 microsoftonedrive Deleting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.5kJ1YWMy
2021-11-30 10:12:27 microsoftonedrive App not closed, so no reopen.
2021-11-30 10:12:27 microsoftonedrive ################## End Installomator, exit code 1

➜  Downloads sudo Installomator/utils/assemble.sh microsoftonedrive DEBUG=0 IGNORE_APP_STORE_APPS=yes
2021-11-30 10:12:50 microsoftonedrive setting variable from argument DEBUG=0
2021-11-30 10:12:50 microsoftonedrive setting variable from argument IGNORE_APP_STORE_APPS=yes
2021-11-30 10:12:50 microsoftonedrive ################## Start Installomator v. 9.0dev
2021-11-30 10:12:50 microsoftonedrive ################## microsoftonedrive
2021-11-30 10:12:51 microsoftonedrive Running msupdate --list
Checking for updates...
Update Assistant is available.
Update Assistant is checking for updates.
Update Assistant is available.
No updates available
2021-11-30 10:13:06 microsoftonedrive BLOCKING_PROCESS_ACTION=tell_user
2021-11-30 10:13:06 microsoftonedrive NOTIFY=success
2021-11-30 10:13:06 microsoftonedrive LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2021-11-30 10:13:06 microsoftonedrive no blocking processes defined, using OneDrive as default
2021-11-30 10:13:06 microsoftonedrive Changing directory to /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.OXbBLX0y
2021-11-30 10:13:06 microsoftonedrive App(s) found: /Applications/OneDrive.app
2021-11-30 10:13:06 microsoftonedrive found app at /Applications/OneDrive.app, version 21.220.1024
2021-11-30 10:13:06 microsoftonedrive Installed OneDrive.app is from App Store, use “IGNORE_APP_STORE_APPS=yes” to replace.
2021-11-30 10:13:06 microsoftonedrive Replacing App Store apps, no matter the version
2021-11-30 10:13:06 microsoftonedrive appversion: 0
2021-11-30 10:13:06 microsoftonedrive Label is not of type “updateronly”, and it’s set to use force to install or ignoring app store apps, so not using updateTool.
2021-11-30 10:13:06 microsoftonedrive Latest version of OneDrive is 21.205.1003
2021-11-30 10:13:06 microsoftonedrive Downloading https://go.microsoft.com/fwlink/?linkid=823060 to OneDrive.pkg
2021-11-30 10:15:01 microsoftonedrive no more blocking processes, continue with update
2021-11-30 10:15:01 microsoftonedrive Installing OneDrive
2021-11-30 10:15:01 microsoftonedrive Verifying: OneDrive.pkg
2021-11-30 10:15:02 microsoftonedrive Team ID: UBF8T346G9 (expected: UBF8T346G9 )
2021-11-30 10:15:02 microsoftonedrive Installing OneDrive.pkg to /
installer: Package name is Microsoft OneDrive
installer: Upgrading at base path /
installer: The upgrade was successful.
2021-11-30 10:15:08 microsoftonedrive Finishing...
2021-11-30 10:15:18 microsoftonedrive App(s) found: /Applications/OneDrive.app
2021-11-30 10:15:18 microsoftonedrive found app at /Applications/OneDrive.app, version 21.220.1024
2021-11-30 10:15:18 microsoftonedrive Installed OneDrive.app is from App Store, use “IGNORE_APP_STORE_APPS=yes” to replace.
2021-11-30 10:15:18 microsoftonedrive Replacing App Store apps, no matter the version
2021-11-30 10:15:18 microsoftonedrive Installed OneDrive, version 0
2021-11-30 10:15:18 microsoftonedrive notifying
2021-11-30 10:15:18 microsoftonedrive Deleting /var/folders/zz/zyxvpxvq6csfxvn_n0000000000000/T/tmp.OXbBLX0y
2021-11-30 10:15:18 microsoftonedrive App not closed, so no reopen.
2021-11-30 10:15:18 microsoftonedrive ################## End Installomator, exit code 0
```
2021-11-30 10:25:28 +01:00
Søren Theilgaard
49470cdfdd MDM scripts 2021-11-29 13:15:53 +01:00
AP Orlebeke
b80c33320f Add Flux 2021-11-26 12:52:31 -05:00
Søren Theilgaard
fd2ed3aa49 Update README.md 2021-11-26 10:39:29 +01:00
Søren Theilgaard
dd8b9b2b16 Update README.md 2021-11-26 10:06:37 +01:00
Søren Theilgaard
e622c6d434 Update README.md 2021-11-26 09:56:50 +01:00
Søren Theilgaard
f997c702dd Merge pull request #338 from apizz/vimac 2021-11-26 08:07:33 +01:00
Søren Theilgaard
f87540454b Merge pull request #339 from apizz/textexpander 2021-11-26 08:05:06 +01:00
AP Orlebeke
98c56d505b Fix TextExpander 2021-11-26 01:35:58 -05:00
AP Orlebeke
241df209b6 Add Vimac 2021-11-26 00:37:07 -05:00
Søren Theilgaard
dda03ae9d5 Merge branch 'dev' into fullscreen-check 2021-11-25 12:51:42 +01:00
Søren Theilgaard
cf42f1f8b7 Moved change to top of the list 2021-11-25 12:50:36 +01:00
Søren Theilgaard
0b3ab7b382 Merge pull request #278 from samess-flowers/dev
Move root user check forward and add in debug mode 2 to replicate lost functionality
2021-11-25 09:40:50 +01:00
Søren Theilgaard
52f1371042 Merge branch 'dev' into dev 2021-11-25 09:40:38 +01:00
John Hutchison
f73b1af054 New label for Azul Zulu JDK 17
Example output:

Installomator - zulu-jdk-15-urlupdate! ❯ ./assemble.sh zulujdk17
2021-11-24 06:00:42 zulujdk17 ################## Start Installomator v. 9.0dev
2021-11-24 06:00:42 zulujdk17 ################## zulujdk17
2021-11-24 06:00:42 zulujdk17 DEBUG mode 1 enabled.
2021-11-24 06:00:44 zulujdk17 BLOCKING_PROCESS_ACTION=tell_user
2021-11-24 06:00:44 zulujdk17 NOTIFY=success
2021-11-24 06:00:44 zulujdk17 LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2021-11-24 06:00:44 zulujdk17 no blocking processes defined, using Zulu JDK 17 as default
2021-11-24 06:00:44 zulujdk17 Changing directory to /Users/john/Documents/Source/Installomator/build
2021-11-24 06:00:44 zulujdk17 Custom App Version detection is used, found be
2021-11-24 06:00:44 zulujdk17 appversion: be
2021-11-24 06:00:44 zulujdk17 Latest version of Zulu JDK 17 is 17.30.15
2021-11-24 06:00:44 zulujdk17 Downloading https://cdn.azul.com/zulu/bin/zulu17.30.15-ca-jdk17.0.1-macosx_aarch64.dmg to Zulu JDK 17.dmg
2021-11-24 06:00:49 zulujdk17 DEBUG mode, not checking for blocking processes
2021-11-24 06:00:49 zulujdk17 Installing Zulu JDK 17
2021-11-24 06:00:49 zulujdk17 Mounting /Users/john/Documents/Source/Installomator/build/Zulu JDK 17.dmg
2021-11-24 06:00:57 zulujdk17 Mounted: /Volumes/Azul Zulu JDK 17.30+15
2021-11-24 06:00:57 zulujdk17 found pkg: /Volumes/Azul Zulu JDK 17.30+15/Double-Click to Install Azul Zulu JDK 17.pkg
2021-11-24 06:00:57 zulujdk17 Verifying: /Volumes/Azul Zulu JDK 17.30+15/Double-Click to Install Azul Zulu JDK 17.pkg
2021-11-24 06:00:57 zulujdk17 Team ID: TDTHCUPYFR (expected: TDTHCUPYFR )
2021-11-24 06:00:57 zulujdk17 Checking package version.
Error encountered while creating /Volumes/Azul Zulu JDK 17.30+15/Double-Click to Install Azul Zulu JDK 17.pkg_pkg. Error 30: Read-only file system
cat: /Volumes/Azul Zulu JDK 17.30+15/Double-Click to Install Azul Zulu JDK 17.pkg_pkg/Distribution: No such file or directory
rm: /Volumes/Azul Zulu JDK 17.30+15/Double-Click to Install Azul Zulu JDK 17.pkg_pkg: No such file or directory
2021-11-24 06:00:57 zulujdk17 Downloaded package com.azulsystems.zulu.17 version
2021-11-24 06:00:57 zulujdk17 DEBUG enabled, skipping installation
2021-11-24 06:00:57 zulujdk17 Finishing...
2021-11-24 06:01:07 zulujdk17 Custom App Version detection is used, found be
2021-11-24 06:01:07 zulujdk17 Installed Zulu JDK 17, version be
2021-11-24 06:01:07 zulujdk17 notifying
2021-11-24 06:01:07 zulujdk17 Unmounting /Volumes/Azul Zulu JDK 17.30+15
"disk4" ejected.
2021-11-24 06:01:07 zulujdk17 DEBUG mode, not reopening anything
2021-11-24 06:01:07 zulujdk17 ################## End Installomator, exit code 0
2021-11-24 06:01:51 -05:00
John Hutchison
4471169fe4 Updated URL
Updated URL to match Zulu JDK 8 style

Example output:

Installomator - zulu-jdk-15-urlupdate! ❯ ./assemble.sh zulujdk15
2021-11-24 05:54:37 zulujdk15 ################## Start Installomator v. 9.0dev
2021-11-24 05:54:37 zulujdk15 ################## zulujdk15
2021-11-24 05:54:37 zulujdk15 DEBUG mode 1 enabled.
2021-11-24 05:54:37 zulujdk15 BLOCKING_PROCESS_ACTION=tell_user
2021-11-24 05:54:37 zulujdk15 NOTIFY=success
2021-11-24 05:54:37 zulujdk15 LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2021-11-24 05:54:37 zulujdk15 no blocking processes defined, using Zulu JDK 15 as default
2021-11-24 05:54:37 zulujdk15 Changing directory to /Users/john/Documents/Source/Installomator/build
2021-11-24 05:54:37 zulujdk15 Custom App Version detection is used, found be
2021-11-24 05:54:37 zulujdk15 appversion: be
2021-11-24 05:54:37 zulujdk15 Latest version of Zulu JDK 15 is 15.36.13
2021-11-24 05:54:37 zulujdk15 Downloading https://cdn.azul.com/zulu/bin/zulu15.36.13-ca-jdk15.0.5-macosx_aarch64.dmg to Zulu JDK 15.dmg
2021-11-24 05:54:42 zulujdk15 DEBUG mode, not checking for blocking processes
2021-11-24 05:54:42 zulujdk15 Installing Zulu JDK 15
2021-11-24 05:54:42 zulujdk15 Mounting /Users/john/Documents/Source/Installomator/build/Zulu JDK 15.dmg
2021-11-24 05:54:50 zulujdk15 Mounted: /Volumes/Azul Zulu JDK 15.36+13
2021-11-24 05:54:50 zulujdk15 found pkg: /Volumes/Azul Zulu JDK 15.36+13/Double-Click to Install Azul Zulu JDK 15.pkg
2021-11-24 05:54:50 zulujdk15 Verifying: /Volumes/Azul Zulu JDK 15.36+13/Double-Click to Install Azul Zulu JDK 15.pkg
2021-11-24 05:54:50 zulujdk15 Team ID: TDTHCUPYFR (expected: TDTHCUPYFR )
2021-11-24 05:54:50 zulujdk15 Checking package version.
Error encountered while creating /Volumes/Azul Zulu JDK 15.36+13/Double-Click to Install Azul Zulu JDK 15.pkg_pkg. Error 30: Read-only file system
cat: /Volumes/Azul Zulu JDK 15.36+13/Double-Click to Install Azul Zulu JDK 15.pkg_pkg/Distribution: No such file or directory
rm: /Volumes/Azul Zulu JDK 15.36+13/Double-Click to Install Azul Zulu JDK 15.pkg_pkg: No such file or directory
2021-11-24 05:54:50 zulujdk15 Downloaded package com.azulsystems.zulu.15 version
2021-11-24 05:54:50 zulujdk15 DEBUG enabled, skipping installation
2021-11-24 05:54:50 zulujdk15 Finishing...
2021-11-24 05:55:00 zulujdk15 Custom App Version detection is used, found be
2021-11-24 05:55:00 zulujdk15 Installed Zulu JDK 15, version be
2021-11-24 05:55:00 zulujdk15 notifying
2021-11-24 05:55:00 zulujdk15 Unmounting /Volumes/Azul Zulu JDK 15.36+13
"disk4" ejected.
2021-11-24 05:55:00 zulujdk15 DEBUG mode, not reopening anything
2021-11-24 05:55:00 zulujdk15 ################## End Installomator, exit code 0
2021-11-24 05:55:38 -05:00
John Hutchison
72257d21ae Updated URL
Updated URL to match Zulu JDK8 style.

Test output:

Installomator - zulu-jdk-11-urlupdate! ❯ ./assemble.sh zulujdk11
2021-11-24 05:50:02 zulujdk11 ################## Start Installomator v. 9.0dev
2021-11-24 05:50:02 zulujdk11 ################## zulujdk11
2021-11-24 05:50:02 zulujdk11 DEBUG mode 1 enabled.
2021-11-24 05:50:02 zulujdk11 BLOCKING_PROCESS_ACTION=tell_user
2021-11-24 05:50:02 zulujdk11 NOTIFY=success
2021-11-24 05:50:02 zulujdk11 LOGO=/System/Applications/App Store.app/Contents/Resources/AppIcon.icns
2021-11-24 05:50:02 zulujdk11 no blocking processes defined, using Zulu JDK 11 as default
2021-11-24 05:50:02 zulujdk11 Changing directory to /Users/john/Documents/Source/Installomator/build
2021-11-24 05:50:02 zulujdk11 Custom App Version detection is used, found be
2021-11-24 05:50:02 zulujdk11 appversion: be
2021-11-24 05:50:02 zulujdk11 Latest version of Zulu JDK 11 is 11.52.13
2021-11-24 05:50:02 zulujdk11 Downloading https://cdn.azul.com/zulu/bin/zulu11.52.13-ca-jdk11.0.13-macosx_aarch64.dmg to Zulu JDK 11.dmg
2021-11-24 05:50:07 zulujdk11 DEBUG mode, not checking for blocking processes
2021-11-24 05:50:07 zulujdk11 Installing Zulu JDK 11
2021-11-24 05:50:07 zulujdk11 Mounting /Users/john/Documents/Source/Installomator/build/Zulu JDK 11.dmg
2021-11-24 05:50:15 zulujdk11 Mounted: /Volumes/Azul Zulu JDK 11.52+13
2021-11-24 05:50:15 zulujdk11 found pkg: /Volumes/Azul Zulu JDK 11.52+13/Double-Click to Install Azul Zulu JDK 11.pkg
2021-11-24 05:50:15 zulujdk11 Verifying: /Volumes/Azul Zulu JDK 11.52+13/Double-Click to Install Azul Zulu JDK 11.pkg
2021-11-24 05:50:15 zulujdk11 Team ID: TDTHCUPYFR (expected: TDTHCUPYFR )
2021-11-24 05:50:15 zulujdk11 Checking package version.
Error encountered while creating /Volumes/Azul Zulu JDK 11.52+13/Double-Click to Install Azul Zulu JDK 11.pkg_pkg. Error 30: Read-only file system
cat: /Volumes/Azul Zulu JDK 11.52+13/Double-Click to Install Azul Zulu JDK 11.pkg_pkg/Distribution: No such file or directory
rm: /Volumes/Azul Zulu JDK 11.52+13/Double-Click to Install Azul Zulu JDK 11.pkg_pkg: No such file or directory
2021-11-24 05:50:15 zulujdk11 Downloaded package com.azulsystems.zulu.11 version
2021-11-24 05:50:15 zulujdk11 DEBUG enabled, skipping installation
2021-11-24 05:50:15 zulujdk11 Finishing...
2021-11-24 05:50:25 zulujdk11 Custom App Version detection is used, found be
2021-11-24 05:50:25 zulujdk11 Installed Zulu JDK 11, version be
2021-11-24 05:50:25 zulujdk11 notifying
2021-11-24 05:50:26 zulujdk11 Unmounting /Volumes/Azul Zulu JDK 11.52+13
"disk4" ejected.
2021-11-24 05:50:26 zulujdk11 DEBUG mode, not reopening anything
2021-11-24 05:50:26 zulujdk11 ################## End Installomator, exit code 0
2021-11-24 05:51:13 -05:00
Søren Theilgaard
d8dbde032a Update CONTRIBUTING.md 2021-11-24 10:18:09 +01:00
Søren Theilgaard
9af3408da6 Merge pull request #334 from fleish/dev
Create protonvpn.sh
2021-11-24 10:10:42 +01:00
Søren Theilgaard
26b5956894 Update protonvpn.sh 2021-11-24 10:07:59 +01:00
Søren Theilgaard
4adbd1fd2c Update functions.sh 2021-11-24 09:47:35 +01:00
fleish
3dd9818d9a Update protonvpn.sh
appNewVersion
2021-11-23 08:29:05 -08:00
Søren Theilgaard
d7042fce29 A bit cleaning in READMEs 2021-11-23 14:27:31 +01:00
Søren Theilgaard
2178caae0e Update CHANGELOG.md 2021-11-23 13:07:19 +01:00
Armin Briegel
f718e60269 updated version 2021-11-23 11:30:06 +01:00
Søren Theilgaard
5fcb4174f0 Update CHANGELOG.md 2021-11-23 09:06:03 +01:00
Søren Theilgaard
2a15a2142d Moved root check to before case statement
We can have code in the case statement, so no need to run that, if we were supposed to exit.
2021-11-23 08:59:44 +01:00
fleish
ade237079c Create protonvpn.sh 2021-11-22 11:53:17 -08:00
Raptor399
cfdb884818 Setting no default IGNORE_DND_APPS with example in comments.
As per the discussion in the pull request.
2021-10-18 16:12:44 +02:00
Sam Ess
7d59b37bf3 Move root user check forward, add debug mode 2
Moved the root user check to the beginning of the script, but added in debug
mode 2 to allow for the kinds of testing you used to be able to do when running
the program in debug 0 as a non-root user.  Resolves issue 88
2021-10-16 19:21:02 -04:00
Sam Ess
d402f46c3c Fixed printlog issue 2021-10-16 19:17:06 -04:00
Sam Ess
c85a7a1fba Add in missing fi
Close check for root loop -_-
2021-10-16 19:03:29 -04:00
Sam Ess
b6bc0b1269 Add debug mode 2
Restores functionality of running script as a non-root user for testing purposes.
Resolves issue #88
2021-10-16 18:46:36 -04:00
Sam Ess
cbb1e08e26 Move root user check forward
Root user check is now moved from the installation function to main. The new
location is after parsing the label but before printing the log for blocking
process and notify settings.  This prevents a downloading an application
that can't be installed.
Resolves issue #88
2021-10-16 16:42:56 -04:00
Raptor399
9e2fa65670 Added option to not interrupt Do Not Disturb full screen apps like KeyNote or Zoom 2021-10-12 12:14:29 +02:00
167 changed files with 4169 additions and 1090 deletions

View File

@@ -1,3 +1,137 @@
## v9.2
**Note**: Both Google and Mozilla recommend using the pkg installers instead of the dmg downloads for managed deployments. So far, Installomator has provided labels for both. (`googlechrome` and `googlechromepkg` or `firefox` and `firefoxpkg`, respectively) Since there are problems with the dmg downloads, a future release of Installomator will _disable_ the `firefox` and `googlechrome` dmg labels. You should switch to using `googlechromepkg` and `firefoxpkg` labels instead.
- bug fix (#434)
- documentation updates (#485, #494)
- new labels:
- 1password8 (#514)
- ultimakercura
- androidstudio (#547)
- atextlegacy (#464)
- camtasia2019, camtasia2020 (#499)
- clue, cluefull (#481)
- craftmanagerforsketch
- displaylinkmanager (#448)
- drawio (#480)
- duckduckgo
- egnytewebedit (#512)
- filezilla (#522)
- firefoxpkg_intl
- flycut (#501)
- fontexplorer (#523)
- hype (#524)
- idrive (#507), idrivethin (#509)
- imageoptim (#525)
- linear (#519)
- macoslaps (#502)
- mightymike
- mindmanager (#479)
- pika (#526)
- propresenter7 (#394)
- qgis-pr
- shottr (#516)
- slab (#487)
- snagit2019, snagit2020, snagit2021 (#498)
- sonobus (#490)
- talkdeskcxcloud (#452)
- thunderbird_intl (#497)
- unnaturalscrollwheels (#503)
- wechat (#510)
- xeroxworkcentre7800 (#527)
- zohoworkdrivegenie
- updated labels
- adobereaderdc-update, adobereaderdc (#503)
- amazoncorretto8jdk (#461)
- camtasia (#499)
- citrixworkspace (#508)
- dbeaverce (#450)
- dropbox
- firefox, firefox_da, firefox_intl (#495), firefoxesr_intl (#496), firefoxpkg
- googlechrome, googlechromepkg (#484)
- gpgsuite (#465)
- grammarly (#515)
- logitechoptions (#478)
- onlyofficedesktop (#454)
- postman (#458)
- rancherdesktop (#463)
- remotedesktopmanagerenterprise
- remotedesktopmanagerfree
- ringcentralapp (#492)
- sketch
- snagit (#498)
- talkdeskcallbar (#453)
## v9.1
- added option for Microsoft Endpoint Manager (Intune) to `LOGO` (#446)
- minor fixes (#427, #434, #436)
- the `googlechrome` label now always downloads the universal version (#430)
- new labels:
- 1passwordcli (#429)
- amazoncorretto8jdk (#423)
- autodeskfusion360admininstall (#447)
- axurerp10 (#439)
- calcservice (#426)
- clipy (#412)
- dockutil (#432)
- easyfind (#426)
- grammarly (#444)
- houdahspot (#426)
- macadminspython (#431)
- microsoftazuredatastudio (#438)
- nanosaur (#426)
- tembo (#426)
- wordservice (#426)
- xmenu (#426)
- updated labels:
- appcleaner (#428)
- dialog (#435, #437)
- googlechrome (#430)
- microsoftdefender (#440)
- supportapp (#426)
- zoom and zoomgov (#426, #433)
## v9.0.1
- improved logging levels throughout the script #408
- fixed a bug for `pkgindmg` style labels #408
- changed the criteria used to locate an app in the case the it cannot be found in the default locations, this should help with some apps with similar name (Virtual Box and Box Drive, #401) #413
- new label: WhiteBox Packages (`packages`) #415
- modified label: `loom` (added Apple silicon download) #417
## v9
- We have moved the root check to the beginning of the script, and improved DEBUG handling with two different modes. `DEBUG=0` is still for production, and `1` is still for the DEBUG we previously knew downloading to the directory it is running from, but `2` will download to temporary folder, will detect updates, but will not install anything, but it will notify the user (almost as running the script without root before).
- Added option to not interrupt Do Not Disturb full screen apps like Keynote or Zoom with `INTERRUPT_DND="no"`. Default is `"yes"` which is how it has worked until now.
- `pkgName` in a label can now be searched for. An example is logitechoptions, where only the name of the pkg is given, and not the exact file path to it.
- `LSMinimumSystemVersion` will now be honered, if the `Info.plist` in the app is specifying this. That means that an app that has this parameter in that file and it shows that the app requires a newer version of the OS than is currently installed, then we will not install it.
- New variable `RETURN_LABEL_NAME`. If given the value `1`, like `RETURN_LABEL_NAME=1` then Installomator only returns the name of the label. It makes for a better user friendly message for displaying in DEPNotify if that is integrated.
- Changed logic if `IGNORE_APP_STORE_APPS=yes`. Before this version a label like `microsoftonedrive` that was installed from App Store, and that we want to replace with the “ordinary” version, Installomator would still use `updateTool`, even though `IGNORE_APP_STORE_APPS=yes`. So we would have to have `INSTALL=force` in order to have the app replaced, as `updateTool` would be used. But now if `IGNORE_APP_STORE_APPS=yes` then `updateTool` will be not set, and the App Store app will be replaced. BUT if the installed software was not from App Store, then `updateTool` will not be used, and it would be a kind of a forced install (in the example of `microsoftonedrive`), except if the version is the same (where installation is skipped).
- Added variable `SYSTEMOWNER` that is used when copying files when installing. Default `0` is to change owner of the app to the current user on the Mac, like this user was installing this app themselves. When using `1` we will put “root:wheel” on the app, which can be useful for shared machines.
- Added option `curlOptions` to the labels. It can be filled with extra headers need for downloading the specific software. It needs to be an array, like `curlOptions=( )`. See “mocha”-software-labels.
Big changes to logging:
- Introducing variable `LOGGING`, that can be either of the logging levels
- Logging levels:
0: DEBUG Everything is logged
1: INFO Normal logging behavior
2: WARN
3: ERROR
4: REQ
- External logging to Datadog
- A function to shorten duplicate lines in installation logs or output of longer commands
- Ability to extract install.log in the time when Installomator was running, if further investigations needs to be done to logs
Fixes:
- Fixed a problem with pkgs: If they were mounted with .pkg in the name, then we would find the directory and not the pkg file itself.
- Minor fix for a check for a pkgName on a DMG. We used `ls` that would throw an error when not found, so the check was corrected.
## v8.0
- removed leading `0` from the version because it has lost all meaning (thanks to @grahampugh for the inspiration)

View File

@@ -1,26 +1,53 @@
# Contributing to Installomator
__Please note, that if you are contributing to this project with new labels or other suggestions in PRs, please put your changes in the fragmented files, not the full `Installomator.sh` script. The full script is now a build of the fragments, and will be overwritten.__
__Please note, that if you are contributing to this project with new labels or other suggestions in PRs, please put your changes in the files in the `fragments` sub-folder. DO NOT edit the full `Installomator.sh` script. The full script is generated from the fragments, and will be overwritten. More details on [how the script is assembled from the fragments here](https://github.com/Installomator/Installomator/tree/main/utils#how-to-assemble-installomatorsh).__
We try to keep the script as short as possible, and with more than 300 labels, we can save 300 lines in the script, if we do not have credit lines on each of these. So we are thankful for your contribution, but we will be removing these lines in the coming releases.
We try to keep the script as short as possible, and with more than 400 labels, we can save 400 lines in the script, if we do not have credit lines on each of these. So we are thankful for your contribution, but we will be removing these lines in the coming releases.
## Branches
The branch list is as follows:
- `release`: this branch will have the latest released version
- `main`: (default) this branch will be the current build we are working on. It includes new and updated app labels, and critical bug fixes
- `dev`: this will contain new and updated app labels, as well as other code changes that have the risk of significantly changing or breaking behavior
there will be other branches for new features and testing.
This should allow the contributing team to release minor updates for new and updated app labels while also work on new features for the next major release.
With all the new branches, your local repo may get confused. If you dont have local changes, it is easiest to delete your local repo and re-clone it. If you have local changes you want to preserve, then you should commit those to a local branch, pull the latest changes `git pull --all`, then delete the old master branch: `git branch -d master`.
Please make sure you branch off of main for your PRs.
__Thank you for contributing!__
## Labels
If you need a new label, please take a look at the tutorials in the Wiki, if those can be helpful for starting out on the creation of the label.
If you need a new label for a piece of software, please take a look [at the tutorials in the Wiki](https://github.com/Installomator/Installomator/wiki#tutorials), those can be helpful for starting out on the creation of the label.
We really encourage you to try out finding the version of the app online, so that `appNewVersion` can be filled in the label. It helps a lot when the software needs update, and greatly improve user experience.
We expect you to try out finding the __version__ of the software online, so that `appNewVersion` can be filled in the label. It helps a lot when the software needs update, and greatly improve user experience.
When creating a new label, please file a pull request (PR). And feel free to ask questions or make your comments about what else is needed, if we should take a look at the label, or help out in finding the version or isolating URLs or anything else.
Please document what you found out about the __version__ of the software if it's not included. We will not accept a new label if this is not documented, we will ask about this if it was not included. This is very important for the quality and reliability of Installomator.
Please include the log of installing this label in the description.
When creating a new label, please file a pull request (PR). And feel free to ask questions or make your comments about what else is needed, if we should take a look at the label, or help out in finding the version or isolating URLs or anything else. You can find [a tutorial on how to create a PR here](https://github.com/Installomator/Installomator/wiki/GitHub-howto-create-PRs).
Please include the log of installing this label in the description, like this:
```
% /Users/st/Documents/GitHub/Installomator/utils/assemble.sh software
2021-11-24 10:07:19 software ################## Start Installomator v. 0.8.0
2021-11-24 10:07:19 software ################## software
2021-11-24 10:07:19 software DEBUG mode 1 enabled.
```
Please have one label per PR, so we can separate these. Also if you change/fix a label.
Thank you very much!
__Thank you very much for your contribution!__
## Issues
Do not create an issue just when you have a questions, but do file an issue or pull request (PR) for bugs or wrong behavior. Include the full log and include the version of Installomator you're running.
Do not create an issue just when you have a questions, but do file an issue or pull request (PR) for bugs or wrong behavior. Include the full log and include the version of Installomator you're running. When you create a PR to follow-up and solve an issue make sure to [mention the issue using the `#xxx` syntax in a commit message or comment to link the issue](https://docs.github.com/en/issues/tracking-your-work-with-issues/linking-a-pull-request-to-an-issue).
Join [the MacAdmins Slack](https://macadmins.org) and find us in the `#installomator` channel for questions, support and discussions.
When in doubt, use the MacAdmins.org Slack as described in [README.md](https://github.com/Installomator/Installomator/)

File diff suppressed because it is too large Load Diff

View File

@@ -1,4 +1,6 @@
1password7
1password8
1passwordcli
4kvideodownloader
8x8
abstract
@@ -16,12 +18,15 @@ alephone
alfred
alttab
amazonchime
amazoncorretto8jdk
amazonworkspaces
androidfiletransfer
androidstudio
anydesk
apparency
appcleaner
applenyfonts
applesfarabic
applesfcompact
applesfmono
applesfpro
@@ -30,14 +35,18 @@ aquaskk
arq7
asana
atext
atextlegacy
atom
audacity
authydesktop
autodeskfusion360admininstall
autodmg
autopkgr
aviatrix
awscli2
awsvpnclient
axurerp10
azuredatastudio
balenaetcher
balsamiqwireframes
bartender
@@ -54,24 +63,33 @@ brave
bugdom
caffeine
cakebrew
calcservice
calibre
camostudio
camtasia
camtasia2019
camtasia2020
camtasia2021
canva
chatwork
cisdem-documentreader
citrixworkspace
clevershare2
clickshare
clipy
closeio
cloudya
clue
cluefull
code42
coderunner
colourcontrastanalyser
cormorant
craftmanager
craftmanagerforsketch
cryptomator
cyberduck
daisydisk
dangerzone
darktable
dbeaverce
@@ -84,11 +102,18 @@ devonthink
dialog
dialpad
discord
diskspace
displaylinkmanager
docker
dockutil
drawio
drift
dropbox
duckduckgo
easeusdatarecoverywizard
easyfind
egnyte
egnytewebedit
element
eraseinstall
eshareosx
@@ -101,6 +126,7 @@ fastscripts
favro
ferdi
figma
filezilla
findanyfile
firefox
firefox_da
@@ -109,7 +135,11 @@ firefoxesr
firefoxesr_intl
firefoxesrpkg
firefoxpkg
firefoxpkg_intl
flowjo
flux
flycut
fontexplorer
front
fsmonitor
gimp
@@ -126,6 +156,7 @@ googlesoftwareupdate
gotomeeting
gpgsuite
gpgsync
grammarly
grandperspective
grasshopper
gyazo
@@ -133,10 +164,17 @@ gyazogif
hancock
handbrake
hazel
houdahspot
hpeasyadmin
hpeasystart
hype
hyper
ibarcoder
icons
idrive
idrivethin
iina
imageoptim
imazingprofileeditor
inkscape
insomnia
@@ -145,6 +183,7 @@ installomator_theile
intellijideace
istatmenus
iterm2
itsycal
jabradirect
jamfconnect
jamfconnectconfiguration
@@ -174,13 +213,18 @@ lastpass
launchbar
lexarrecoverytool
libreoffice
linear
logioptions
logitechoptions
logseq
loom
lowprofile
lucifer
lulu
macadminspython
maccyapp
macfuse
macoslaps
macports
malwarebytes
marathon
@@ -189,8 +233,10 @@ marathoninfinity
mattermost
menumeters
microsoftautoupdate
microsoftazuredatastudio
microsoftazurestorageexplorer
microsoftcompanyportal
microsoftdefender
microsoftdefenderatp
microsoftedge
microsoftedgeconsumerstable
@@ -210,11 +256,20 @@ microsoftteams
microsoftvisualstudiocode
microsoftword
microsoftyammer
mightymike
mindmanager
miro
mobikinassistantforandroid
mochakeyboard
mochatelnet
mochatn3270
mochatn3812
mochatn5250
montereyblocker
mowgliiitsycal
musescore
muzzle
nanosaur
netnewswire
nextcloud
nomad
@@ -241,26 +296,37 @@ opera
ottomatic
overflow
pacifist
packages
pandoc
paretosecurity
parsec
pdfsam
perimeter81
pika
pitch
plantronicshub
platypus
plisteditpro
postman
prism9
pritunl
privileges
proctortrack
promiseutility
promiseutilityr
propresenter7
protonvpn
proxyman
pycharmce
pymol
qgis-pr
r
ramboxce
rancherdesktop
rectangle
redeye
remotedesktopmanagerenterprise
remotedesktopmanagerfree
remotix
remotixagent
resiliosynchome
@@ -280,9 +346,12 @@ scaleft
screamingfrogseospider
screencloudplayer
screenflick
sdnotary
secretive
sequelpro
sfsymbols
shield
shottr
sidekick
signal
silnite
@@ -291,12 +360,16 @@ sizeup
sketch
sketchupviewer
skype
slab
slack
smartgit
snagit
snagit2019
snagit2020
snagit2021
snagit2022
snapgeneviewer
sonobus
sonos
sonoss1
sonoss2
@@ -311,23 +384,29 @@ sublimetext
superhuman
supportapp
suspiciouspackage
swiftdialog
swiftruntimeforcommandlinetools
sync
tableaudesktop
tableaupublic
tableaureader
tageditor
talkdeskcallbar
talkdeskcxcloud
taskpaper
teamviewer
teamviewerhost
teamviewerqs
techsmithcapture
telegram
tembo
textexpander
textmate
theunarchiver
things
thunderbird
thunderbird_intl
tidal
toggltrack
tom4aconverter
torbrowser
@@ -335,13 +414,16 @@ trex
tunnelbear
tunnelblick
typora
ultimakercura
umbrellaroamingclient
uniconverter
universaltypeclient
unnaturalscrollwheels
utm
vagrant
vanilla
veracrypt
vimac
virtualbox
viscosity
visualstudiocode
@@ -354,19 +436,24 @@ wallyezflash
webex
webexmeetings
webexteams
wechat
whatsapp
wickrme
wickrpro
wireshark
wordservice
wwdc
xeroxphaser7800
xeroxworkcentre7800
xink
xmenu
xquartz
yed
yubikeymanagerqt
zappy
zeplin
zohoworkdrive
zohoworkdrivegenie
zohoworkdrivetruesync
zoom
zoomclient
@@ -375,4 +462,5 @@ zoomrooms
zulujdk11
zulujdk13
zulujdk15
zulujdk17
zulujdk8

View File

@@ -5,28 +5,45 @@ what="brave" # enter the software to install
# To be used as a script sent out from a MDM.
# Fill the variable "what" above with a label.
# Script will run this label.
LOGO="appstore" # or "addigy", "microsoft", "mosyleb", "mosylem"
######################################################################
# Parameters for reinstall/initial install (owner root:wheel):
# "BLOCKING_PROCESS_ACTION=quit_kill INSTALL=force IGNORE_APP_STORE_APPS=yes SYSTEMOWNER=1"
# Parameters for Self Service installed app:
# "BLOCKING_PROCESS_ACTION=prompt_user NOTIFY=all"
# Parameters for security important apps, like browsers (run automaticaly every day):
# "BLOCKING_PROCESS_ACTION=tell_user_then_kill"
# Update of service apps (run automatically):
# "BLOCKING_PROCESS_ACTION=quit_kill NOTIFY=silent"
parameters="BLOCKING_PROCESS_ACTION=tell_user_then_kill NOTIFY=all"
###############################################
# No sleeping
/usr/bin/caffeinate -d -i -m -u &
caffeinatepid=$!
caffexit () {
kill "$caffeinatepid"
exit $1
}
# Verify that Installomator has been installed
destFile="/usr/local/Installomator/Installomator.sh"
if [ ! -e "${destFile}" ]; then
echo "Installomator not found here:"
echo "${destFile}"
echo "Exiting."
caffexit 99
exit 99
fi
${destFile} ${what} LOGO=mosyleb BLOCKING_PROCESS_ACTION=tell_user #NOTIFY=all #INSTALL=force
if [ $? != 0 ]; then
# This is currently not working in Mosyle, that will ignore script errors. Please request support for this from Mosyle!
# No sleeping
/usr/bin/caffeinate -d -i -m -u &
caffeinatepid=$!
caffexit () {
kill "$caffeinatepid"
pkill caffeinate
exit $1
}
cmdOutput="$(${destFile} ${what} LOGO=$LOGO $parameters LOGGING=WARN || true)"
# Check result
exitStatus="$( echo "${cmdOutput}" | grep --binary-files=text -i "exit" | tail -1 | sed -E 's/.*exit code ([0-9]).*/\1/g' || true )"
if [[ ${exitStatus} -ne 0 ]] ; then
echo -e "Error installing ${what}. Exit code ${exitStatus}"
#echo "$cmdOutput"
errorOutput="$( echo "${cmdOutput}" | grep --binary-files=text -i "error" || true )"
echo "$errorOutput"
echo "Error installing ${what}. Exit code $?"
caffexit $?
fi

View File

@@ -1,22 +1,22 @@
#!/bin/zsh
# Installation using Installomator
what="microsoftteams microsoftyammer firefox bravebrowser cyberduck vlc signal" # enter the software to install separated with spaces
whatList="microsoftteams microsoftyammer firefox bravebrowser cyberduck vlc signal" # enter the software to install separated with spaces
# To be used as a script sent out from a MDM.
# Fill the variable "what" above with labels separated by space " ".
# Fill the variable "whatList" above with labels separated by space " ".
# Script will loop through these labels.
LOGO="appstore" # or "addigy", "microsoft", "mosyleb", "mosylem"
######################################################################
# Parameters for reinstall/initial install (owner root:wheel):
# "BLOCKING_PROCESS_ACTION=quit_kill INSTALL=force IGNORE_APP_STORE_APPS=yes SYSTEMOWNER=1"
# Parameters for Self Service installed app:
# "BLOCKING_PROCESS_ACTION=prompt_user NOTIFY=all"
# Parameters for security important apps, like browsers (run automaticaly every day):
# "BLOCKING_PROCESS_ACTION=tell_user_then_kill"
# Update of service apps (run automatically):
# "BLOCKING_PROCESS_ACTION=quit_kill NOTIFY=silent"
parameters="BLOCKING_PROCESS_ACTION=tell_user NOTIFY=all"
######################################################################
# No sleeping
/usr/bin/caffeinate -d -i -m -u &
caffeinatepid=$!
caffexit () {
kill "$caffeinatepid"
exit $1
}
# Count errors
errorCount=0
# Verify that Installomator has been installed
destFile="/usr/local/Installomator/Installomator.sh"
@@ -24,15 +24,32 @@ if [ ! -e "${destFile}" ]; then
echo "Installomator not found here:"
echo "${destFile}"
echo "Exiting."
caffexit 99
exit 99
fi
for item in $what; do
#echo $item
${destFile} ${item} LOGO=mosyleb BLOCKING_PROCESS_ACTION=tell_user #NOTIFY=all #INSTALL=force
if [ $? != 0 ]; then
# This is currently not working in Mosyle, that will ignore script errors. Please request support for this from Mosyle!
echo "[$(DATE)] Error installing ${item}. Exit code $?"
# No sleeping
/usr/bin/caffeinate -d -i -m -u &
caffeinatepid=$!
caffexit () {
kill "$caffeinatepid"
pkill caffeinate
exit $1
}
# Count errors
errorCount=0
for what in $whatList; do
#echo $what
# Install software using Installomator
cmdOutput="$(${destFile} ${what} LOGO=$LOGO $parameters LOGGING=WARN || true)"
# Check result
exitStatus="$( echo "${cmdOutput}" | grep --binary-files=text -i "exit" | tail -1 | sed -E 's/.*exit code ([0-9]).*/\1/g' || true )"
if [[ ${exitStatus} -ne 0 ]] ; then
echo -e "Error installing ${what}. Exit code ${exitStatus}"
#echo "$cmdOutput"
errorOutput="$( echo "${cmdOutput}" | grep --binary-files=text -i "error" || true )"
echo "$errorOutput"
let errorCount++
fi
done

View File

@@ -1,17 +1,9 @@
#!/bin/bash
# Updating Installomator
# Usefull to push out after deployment if earlier version was deployed in DEP profile
# Currently script uses valuesfromarguments as a label is not included before next release, so this can be used to install to version 0.7
what="installomator" # enter the software to install
# No sleeping
/usr/bin/caffeinate -d -i -m -u &
caffeinatepid=$!
caffexit () {
kill "$caffeinatepid"
exit $1
}
LOGO="appstore" # or "addigy", "microsoft", "mosyleb", "mosylem"
# Verify that Installomator has been installed
destFile="/usr/local/Installomator/Installomator.sh"
@@ -19,24 +11,31 @@ if [ ! -e "${destFile}" ]; then
echo "Installomator not found here:"
echo "${destFile}"
echo "Exiting."
caffexit 99
exit 99
fi
${destFile} valuesfromarguments\
name=Installomator \
type=pkg \
packageID=com.scriptingosx.Installomator \
downloadURL=https://github.com/Installomator/Installomator/releases/download/v0.7release/Installomator-0.7.0.pkg \
appNewVersion=0.7 \
expectedTeamID=JME5BW3F3R \
BLOCKING_PROCESS_ACTION=ignore \
NOTIFY=silent
# No sleeping
/usr/bin/caffeinate -d -i -m -u &
caffeinatepid=$!
caffexit () {
kill "$caffeinatepid"
pkill caffeinate
exit $1
}
# ${destFile} ${what} BLOCKING_PROCESS_ACTION=ignore NOTIFY=silent
if [ $? != 0 ]; then
# This is currently not working in Mosyle, that will ignore script errors. Please request support for this from Mosyle!
echo "Error installing ${what}. Exit code $?"
caffexit $?
# Install software using Installomator
cmdOutput="$(${destFile} ${what} LOGO=$LOGO BLOCKING_PROCESS_ACTION=ignore NOTIFY=silent LOGGING=req || true)"
# Check result
exitStatus="$( echo "${cmdOutput}" | grep --binary-files=text -i "exit" | tail -1 | sed -E 's/.*exit code ([0-9]).*/\1/g' || true )"
if [[ ${exitStatus} -eq 0 ]] ; then
echo -e "${what} succesfully installed.\n"
else
echo -e "Error installing ${what}. Exit code ${exitStatus}\n"
#echo "$cmdOutput"
errorOutput="$( echo "${cmdOutput}" | grep --binary-files=text -i "error" || true )"
echo "$errorOutput"
caffexit $exitStatus
fi
echo "[$(DATE)][LOG-END]"

View File

@@ -5,26 +5,25 @@
# Mark: Installation script
# Just click “Add” to autogenerate the installer script line by clicking the “Add”-button next to the Installer PKG, replace with first line below
/usr/sbin/installer -pkg "/Library/Addigy/ansible/packages/Installomator (0.7.0)/Installomator-0.7.0.pkg" -target /
/usr/sbin/installer -pkg "/Library/Addigy/ansible/packages/Installomator (9.1.0)/Installomator-9.1.pkg" -target /
# Installation using Installomator
what="supportapp xink textmate microsoftedge wwdc keka vlc " # enter the software to installed separated with spaces
whatList="supportapp xink textmate microsoftedge wwdc keka vlc " # enter the software to installed separated with spaces
# To be used as a script sent out from a MDM.
# Fill the variable "what" above with labels separated by space " ".
# Fill the variable "whatList" above with labels separated by space " ".
# Script will loop through these labels and exit with number of errors.
######################################################################
# No sleeping
/usr/bin/caffeinate -d -i -m -u &
caffeinatepid=$!
caffexit () {
kill "$caffeinatepid"
exit $1
}
# Count errors
errorCount=0
# Parameters for reinstall/initial install (owner root:wheel):
# "BLOCKING_PROCESS_ACTION=quit_kill INSTALL=force IGNORE_APP_STORE_APPS=yes SYSTEMOWNER=1"
# Parameters for Self Service installed app:
# "BLOCKING_PROCESS_ACTION=prompt_user NOTIFY=all"
# Parameters for security important apps, like browsers (run automaticaly every day):
# "BLOCKING_PROCESS_ACTION=tell_user_then_kill"
# Update of service apps (run automatically):
# "BLOCKING_PROCESS_ACTION=quit_kill NOTIFY=silent"
parameters="BLOCKING_PROCESS_ACTION=quit_kill INSTALL=force IGNORE_APP_STORE_APPS=yes"
######################################################################
# Verify that Installomator has been installed
destFile="/usr/local/Installomator/Installomator.sh"
@@ -32,15 +31,32 @@ if [ ! -e "${destFile}" ]; then
echo "Installomator not found here:"
echo "${destFile}"
echo "Exiting."
caffexit 99
exit 99
fi
for item in $what; do
#echo $item
${destFile} ${item} LOGO=addigy NOTIFY=silent BLOCKING_PROCESS_ACTION=quit_kill #INSTALL=force
if [ $? != 0 ]; then
# Error handling
echo "[$(DATE)] Error installing ${item}. Exit code $?"
# No sleeping
/usr/bin/caffeinate -d -i -m -u &
caffeinatepid=$!
caffexit () {
kill "$caffeinatepid"
pkill caffeinate
exit $1
}
# Count errors
errorCount=0
for what in $whatList; do
#echo $what
# Install software using Installomator
cmdOutput="$(${destFile} ${what} LOGO=addigy $parameters || true)"
# Check result
exitStatus="$( echo "${cmdOutput}" | grep --binary-files=text -i "exit" | tail -1 | sed -E 's/.*exit code ([0-9]).*/\1/g' || true )"
if [[ ${exitStatus} -ne 0 ]] ; then
echo -e "Error installing ${what}. Exit code ${exitStatus}"
#echo "$cmdOutput"
errorOutput="$( echo "${cmdOutput}" | grep --binary-files=text -i "error" || true )"
echo "$errorOutput"
let errorCount++
fi
done
@@ -55,7 +71,7 @@ caffexit $errorCount
# Install on success
# Remember to fill out the correct “TARGET_VERSION” and “PKG_ID”, and click "Install on succes".
PKG_ID="com.scriptingosx.Installomator"
TARGET_VERSION="0.7.0"
TARGET_VERSION="9.1"
vercomp () {
if [[ $1 == $2 ]]; then

View File

@@ -1,10 +1,11 @@
PKG_ID="com.scriptingosx.Installomator"
TARGET_VERSION="0.7.0"
TARGET_VERSION="9.1"
URLDOWNLOAD="%MosyleCDNFile:blah-blah-blah%"
######################################################################
# Installation using Installomator (enter the software to install separated with spaces in the "what"-variable)
what="handbrake theunarchiver microsoftoffice365"
# Installation using Installomator (enter the software to install separated with spaces in the "whatList"-variable)
whatList="handbrake theunarchiver microsoftoffice365"
# Covered by Mosyle Catalog: "brave firefox googlechrome microsoftedge microsoftteams signal sublimetext vlc webex zoom" among others
LOGO="mosyleb" # or "mosylem"
######################################################################
## Mark: Code here
@@ -14,6 +15,7 @@ what="handbrake theunarchiver microsoftoffice365"
caffeinatepid=$!
caffexit () {
kill "$caffeinatepid"
pkill caffeinate
exit $1
}
@@ -55,12 +57,17 @@ if [ ! -e "${destFile}" ]; then
caffexit 99
fi
for item in $what; do
for what in $whatList; do
#echo $item
${destFile} ${item} LOGO=mosyle NOTIFY=all BLOCKING_PROCESS_ACTION=tell_user #NOTIFY=silent BLOCKING_PROCESS_ACTION=quit_kill #INSTALL=force
if [ $? != 0 ]; then
# Error handling
echo "[$(DATE)] Error installing ${item}. Exit code $?"
# Install software using Installomator
cmdOutput="$(${destFile} ${what} LOGO=$LOGO NOTIFY=all BLOCKING_PROCESS_ACTION=tell_user || true)" # NOTIFY=silent BLOCKING_PROCESS_ACTION=quit_kill INSTALL=force
# Check result
exitStatus="$( echo "${cmdOutput}" | grep --binary-files=text -i "exit" | tail -1 | sed -E 's/.*exit code ([0-9]).*/\1/g' || true )"
if [[ ${exitStatus} -ne 0 ]] ; then
echo "Error installing ${what}. Exit code ${exitStatus}"
#echo "$cmdOutput"
errorOutput="$( echo "${cmdOutput}" | grep --binary-files=text -i "error" || true )"
echo "$errorOutput"
let errorCount++
fi
done

View File

@@ -1,16 +1,11 @@
#!/bin/bash
# Software
# Installation using Installomator
# Example of installing software using valuesfromarguments to install a custom software
what="valuesfromarguments" # enter the software to install
# No sleeping
/usr/bin/caffeinate -d -i -m -u &
caffeinatepid=$!
caffexit () {
kill "$caffeinatepid"
exit $1
}
LOGO="appstore" # or "addigy", "microsoft", "mosyleb", "mosylem"
###############################################
# Verify that Installomator has been installed
destFile="/usr/local/Installomator/Installomator.sh"
@@ -18,23 +13,43 @@ if [ ! -e "${destFile}" ]; then
echo "Installomator not found here:"
echo "${destFile}"
echo "Exiting."
caffexit 99
exit 99
fi
${destFile} valuesfromarguments \
name=\"Zoho\ WorkDrive\" \
type=dmg \
downloadURL=https://files-accl.zohopublic.com/public/wdbin/download/46f971e4fc4a32b68ad5d7dade38a7d2 \
appNewVersion=2.6.25 \
expectedTeamID=TZ824L8Y37 \
BLOCKING_PROCESS_ACTION=quit \
NOTIFY=all
# No sleeping
/usr/bin/caffeinate -d -i -m -u &
caffeinatepid=$!
caffexit () {
kill "$caffeinatepid"
pkill caffeinate
exit $1
}
# ${destFile} ${what} BLOCKING_PROCESS_ACTION=ignore NOTIFY=silent
if [ $? != 0 ]; then
# This is currently not working in Mosyle, that will ignore script errors. Please request support for this from Mosyle!
echo "Error installing ${what}. Exit code $?"
caffexit $?
# Variables to calculate
downloadURL="https://craft-assets.invisionapp.com/CraftManager/production/CraftManager.zip"
appNewVersion=$(curl -fs https://craft-assets.invisionapp.com/CraftManager/production/appcast.xml | xpath -e '//rss/channel/item[1]/enclosure/@sparkle:shortVersionString' 2>/dev/null | cut -d '"' -f2)
# Install software using Installomator
cmdOutput="$(${destFile} valuesfromarguments LOGO=$LOGO \
name=CraftManager \
type=zip \
downloadURL=$downloadURL \
appNewVersion=$appNewVersion \
expectedTeamID=VRXQSNCL5W \
BLOCKING_PROCESS_ACTION=prompt_user \
LOGGING=REQ \
NOTIFY=all || true)"
# Check result
exitStatus="$( echo "${cmdOutput}" | grep --binary-files=text -i "exit" | tail -1 | sed -E 's/.*exit code ([0-9]).*/\1/g' || true )"
if [[ ${exitStatus} -eq 0 ]] ; then
echo -e "${what} succesfully installed.\n"
else
echo -e "Error installing ${what}. Exit code ${exitStatus}\n"
#printlog "$cmdOutput"
errorOutput="$( echo "${cmdOutput}" | grep --binary-files=text -i "error" || true )"
echo "$errorOutput"
caffexit $exitStatus
fi
echo "[$(DATE)][LOG-END]"

199
README.md
View File

@@ -2,17 +2,29 @@
_The one installer script to rule them all._
![](https://img.shields.io/github/v/release/scriptingosx/Installomator)&nbsp;![](https://img.shields.io/github/downloads/scriptingosx/Installomator/latest/total)&nbsp;![](https://img.shields.io/badge/macOS-10.14%2B-success)&nbsp;![](https://img.shields.io/github/license/scriptingosx/Installomator)
![](https://img.shields.io/github/v/release/Installomator/Installomator)&nbsp;![](https://img.shields.io/github/downloads/Installomator/Installomator/latest/total)&nbsp;![](https://img.shields.io/badge/macOS-10.14%2B-success)&nbsp;![](https://img.shields.io/github/license/Installomator/Installomator)
This script is in the “we find it useful, it is working for us” stage.
Your production and deployment environment will be different, please test thoroughly before rolling it out to your production.
I have put a lot of work into making it stable and safe, but I cannot - of course - make _any_ promises that it won't break in some not yet encountered edge case.
We have put a lot of work into making it stable and safe, but we cannot - of course - make _any_ promises that it won't break in some not yet encountered edge case.
## Authors
Intallomator was originally inspired by the download scripts from William Smith and Sander Schram, and created by:
- [Armin Briegel - @scriptingosx](https://github.com/scriptingosx)
Later on a few more members came on the project:
- Isaac Ordonez - @issacatmann
- [Søren Theilgaard - @Theile](https://github.com/Theile)
- [Adam Codega - @acodega](https://github.com/acodega)
And with numerous contributions from many others.
## Support and Contributing
__Please note, that if you are contributing to this project with new labels or other suggestions in PRs, please put your changes in the fragmented files, not the full `Installomator.sh` script. The full script is now a build of the fragments, and will be overwritten. See the REAMDME.md file in the `utils` directory for detailed instructions.__
__Please note, that if you are contributing to this project with new labels or other suggestions in PRs, please put your changes in the files below `fragments`-folder. DO NOT edit the full `Installomator.sh` script. The full script is now a build of the fragments, and will be overwritten. See the [README.md](utils/README.md) file in the `utils` directory for detailed instructions.__
Discussion, support and advice around Installomator happens in the `#installomator` channel in the [MacAdmins.org Slack](https://macadmins.org). Go there for support questions.
@@ -22,31 +34,43 @@ Please see [CONTRIBUTING.md](https://github.com/Installomator/Installomator/blob
## More reading
There are a few interesting post on Installomator on my weblog:
Our wiki:
- [Wiki](https://github.com/Installomator/Installomator/wiki)
There are a few interesting post on Installomator on Armins weblog:
- [Introducing Installomator](https://scriptingosx.com/2020/05/introducing-installomator/)
- [Using Installomator with Jamf Pro](https://scriptingosx.com/2020/06/using-installomator-with-jamf-pro/) by Mischa van der Bent
- [Using another MDM than Jamf and you might want a local installation](https://github.com/Theile/Installomator/) By Søren Theilgaard
## Background
As a system engineer at [an Apple Authorized Enterprise Reseller](https://prowarehouse.nl), we manage a lot of Jamf instances.
In the world of managing Apple Macs, organizations can have two different approaches to the management. Either the IT department will tightly manage and verify each piece of software, or they will just want the latest software to be deployed as fast as possible.
Some of these instances are tightly managed, i.e. the versions of the operating system and third party software are controlled and updates will only be pushed with the management system when the administration and security team went through an approval process and then the update is automated. This is an important and valid workflow and the right fit for many deployments.
OK, maybe some software should be tightly managed and others not, but you get the point.
### Tightly managed
If your solution needs to be tightly managed, i.e. the versions of the operating system and third party software are controlled and updates will only be pushed with the management system when the administration and security team went through an approval process and then the update is automated. This is an important and valid workflow and the right fit for many deployments.
Installomator was _not_ written for these kinds of deployment.
If you are running this kind of deployment, you want to use [AutoPkg](https://github.com/autopkg/autopkg) and you can stop reading here.
There are other kinds of deployments, though. In these deployments the management system is merely used to "get the user ready" as quickly as possible when they set up a new machine, and to offer software from a self service portal. In these deployments, system and software installations are 'latest version available' and updates are user driven (though we do want to nag them).
### Latest version always
These deployments are
There are other kinds of deployments, though. In these deployments the management system is merely used to “get the user ready” as quickly as possible when they set up a new machine, and to offer software from a self service portal. In these deployments, system and software installations are latest version available and updates are user driven (though we do want to nag them and push them).
Installomator can help with this.
These deployments can be
- user driven
- low control
- minimal maintenance effort
- latest version is best
These are mostly 'user controlled' Macs and we (the admins) just want to assist the user in doing the right thing. And the right thing is (often) to install the latest versions and updates when they are available.
These can be 'user controlled' Macs and we (the admins) just want to assist the user in doing the right thing. And the right thing is (often) to install the latest versions and updates when they are available.
The Mac App Store and software pushed through the Mac App Store follow this approach. When you manage and deploy software through the App Store — whether it is on iOS or macOS — neither the MacAdmin nor the user get a choice of the application version. They will get the latest version.
@@ -63,16 +87,25 @@ Some of these disadvantages can be seen as advantages in different setups. When
Because this is an attractive solution for _certain kinds_ of deployment, there are already many scripts out there that will download and install the latest version of a given software. And we have built and used quite a few in-house, as well. Most importantly, [William Smith has this script](https://gist.github.com/talkingmoose/a16ca849416ce5ce89316bacd75fc91a) which can be used to install several different Microsoft applications and bundles, because Microsoft has a nice unified URL scheme.
At some point, earlier this year, I got frustrated at the number of scripts we were maintaining (or failing to). Also, my concern that most of the scripts weren't doing _any_ verification of the download was getting unbearable. So, I set out to write the one install script to rule them all...
At some point, in 2018, Armin got frustrated at the number of scripts he was maintaining (or failing to). Also, his concern that most of the scripts werent doing _any_ verification of the download was getting unbearable. So, he set out to write _the one install script to rule them all_
### Locally installed
So Armin made the version for Jamf Pro but universally for any MDM to adopt.
Søren looked at this, and wanted this approach to work in Mosyle and Addigy, and for these solutions we need Installomator to be locally installed on. the Mac, and then the MDM can call this script from their scripts features. For some time Søren had a version of Installomator that was supplied with a notarized pkg, so it could be deployed as part of DEP or however was needed.
This has now been merged into Installomator, and with contributions of Isaac and Adam, new features and labels have been added more frequently.
## Goals
My goals for Installomator are:
The goals for Installomator are:
- work with various common archive types
- verify the downloaded archive or application
- have a simple 'interface' to the admin
- single script file so it can 'easily' be copied into a management system
- have a simple interface to the admin
- single script file so it can easily be copied into a management system
- signed and notarized pkg-installer for local installation
- extensible without deep scripting knowledge
- work independently of a specific management system
- no dependencies that may be removed from macOS in the future or are not pre-installed
@@ -89,9 +122,9 @@ Installomator can work with the following common archive and installer types:
When the download yields a pkg file, Installomator will run `installer` to install it on the current system.
Applications in dmgs or zips will be copied to `/Applications` and their owner will be set to the current user, so the install works like a standard drag'n drop installation.
Applications in dmgs or zips will be copied to `/Applications` and their owner will be set to the current user, so the install works like a standard drag'n drop installation. Owner can also be set to root/wheel.
(I consider it a disgrace, that Jamf, after nearly 20 years, _still_ cannot deal with 'drag'n drop installation dmgs' natively. It's not _that_ hard.)
(I consider it a disgrace, that Jamf, after nearly 20 years, _still_ cannot deal with dragn drop installation dmgs natively. Its not _that_ hard.)
### Verify the download
@@ -108,11 +141,11 @@ When used to install software, Installomator has a single argument: the label or
./Installomator.sh firefox LOGO=jamf BLOCKING_PROCESS_ACTION=tell_user_then_kill NOTIFY=all
```
There is a debug mode and one other setting that can be controlled with variables in the code. This simplifies the actual use of the script from within a management system.
There is a debug mode and other settings that can be controlled with variables in the code. This simplifies the actual use of the script from within a management system.
### Extensible
As of this writing, Installomator knows how to download and install more than 238 different applications. You can add more by adding a block to the _long_ `case` statement starting on line 758. Some of them are more elaborate, but most of them (just) need this information (not really "just" in this case, as we have to differentiate between arm64 and i386 versions for both `downloadURL` and `appNewVersion`):
As of this writing, Installomator knows how to download and install more than 364 different applications. You can add more by adding new labels to the `fragments`-folder. Below is an example of a label, and most of them (just) needs this information (not really "just" in this case, as we have to differentiate between arm64 and i386 versions for both `downloadURL` and `appNewVersion`):
```
googlechrome)
@@ -121,11 +154,11 @@ googlechrome)
if [[ $(arch) != "i386" ]]; then
printlog "Architecture: arm64 (not i386)"
downloadURL="https://dl.google.com/chrome/mac/universal/stable/GGRO/googlechrome.dmg"
appNewVersion=$(curl -s https://omahaproxy.appspot.com/history | awk -F',' '/mac_arm64,stable/{print $3; exit}') # Credit: William Smith (@meck)
appNewVersion=$(curl -s https://omahaproxy.appspot.com/history | awk -F',' '/mac_arm64,stable/{print $3; exit}')
else
printlog "Architecture: i386"
downloadURL="https://dl.google.com/chrome/mac/stable/GGRO/googlechrome.dmg"
appNewVersion=$(curl -s https://omahaproxy.appspot.com/history | awk -F',' '/mac,stable/{print $3; exit}') # Credit: William Smith (@meck)
appNewVersion=$(curl -s https://omahaproxy.appspot.com/history | awk -F',' '/mac,stable/{print $3; exit}')
fi
expectedTeamID="EQHXZ8M8AV"
;;
@@ -133,19 +166,21 @@ googlechrome)
When you know how to extract these pieces of information from the application and/or download, then you can add an application to Installomator.
The script `buildCaseStatement.sh` can help with the label creation.
The script `buildLabel.sh` can help with the label creation. Just server the URL to the script, and it will try to figure out things and write out a label as output. See [Wiki Tutorials](https://github.com/Installomator/Installomator/wiki#tutorials).
Please note: Labels should be named in small caps, numbers 0-9, “-”, and “_”. No other characters allowed.
Actually labels are part of a case-statement, and must be formatted accordingly.
### Not specific to a management system
I wrote this script mainly for use with Jamf Pro, because that is what we use. For testing, you can run the script interactively from the command line. However, I have tried to keep anything that is specific to Jamf optional, or so flexible that it will work anywhere. Even if it does not work with your management system 'out of the box,' the adaptations should be straightforward.
Armin wrote this script mainly for use with Jamf Pro, because that is what he used. For testing, you can run the script interactively from the command line. However, we have tried to keep anything that is specific to Jamf optional, or so flexible that it will work anywhere. Even if it does not work with your management system out of the box, the adaptations should be straightforward.
Not all MDMs can include the full script, for those MDMs it might be more useful to install it on the client machines, and run it from there. See [Using another MDM than Jamf and you might want a local installation](https://github.com/Theile/Installomator/) By Søren Theilgaard.
Not all MDMs can include the full script, for those MDMs it might be more useful to install it on the client machines, and run it from there. So a PKG to be installed on client Macs is also provided here.
### No dependencies
The script started out as a pure `sh` script, and when I needed arrays I 'switched' to `zsh`, because that is what [we can rely on being in macOS for the foreseeable future](https://scriptingosx.com/zsh). There are quite a few places where using python would have been easier and safer, but with the python 2 run-time being deprecated, that would have added a requirement for a Python 3 run-time to be installed. XML and JSON parsing would have been better with a tool like [scout](https://github.com/ABridoux/scout) or [jq](https://stedolan.github.io/jq/), but those would again require additional installations on the client before the script can run.
The script started out as a pure `sh` script, and when arrays was needed it was switched to `zsh`, because that is what [we can rely on being in macOS for the foreseeable future](https://scriptingosx.com/zsh). There are quite a few places where using python would have been easier and safer, but with the python 2 run-time being deprecated, that would have added a requirement for a Python 3 run-time to be installed. XML and JSON parsing would have been better with a tool like [scout](https://github.com/ABridoux/scout) or [jq](https://stedolan.github.io/jq/), but those would again require additional installations on the client before the script can run.
Keeping the script as a `zsh` allows you to paste it into your management system's interface (and disable the DEBUG mode) and use it without requiring any other installations.
@@ -178,19 +213,19 @@ Other than the version arguments, the argument can be any of the labels listed i
### Debug mode
There is a variable named `DEBUG` which is set in line 21 of the script. When `DEBUG` is set to `1` (default) no actions that would actually modify the current system are taken. This is useful for testing most of the actions in the script, but obviously not all of them.
There is a variable named `DEBUG` which is set in line 21 of the script. When `DEBUG` is set to `1` (default) or `2` for a variation of debug, no actions that would actually modify the current system are taken. This is useful for testing most of the actions in the script, but obviously not all of them.
Also when the `DEBUG` variable is `1`, downloaded archives and extracted files will be written to the script's directory, rather than a temporary directory, which can make debugging easier.
When the `DEBUG` variable is `1`, downloaded archives and extracted files will be written to the script's directory, rather than a temporary directory, which can make debugging easier.
_Always remember_ to change the `DEBUG` variable to `0` when deploying.
When `DEBUG` variable is `2`, the temporary folder is created and downloaded and extracted files goes to that folder, as if not in DEBUG mode, but installation is still not done. On the other hand blocking processes are checked, the app is reopened if closed, and the user is notified.
### Use Installomator with Jamf Pro
Debug mode 1 is useful to test the download and verification process without having to re-download and re-install an application or package on your system. Debug mode 2 is great for checking running processe and notifications.
In Jamf Pro, create a new 'Script' and paste the contents of `Installomator.sh` into the 'Script Contents' area. Under 'Options' you can change the parameter label for argument 4 to 'Application Label.'
_Always remember_ to change the `DEBUG` variable to `0` when deploying. The installer PKG we provide has `DEBUG=0`.
Remember to set `DEBUG` to `0`.
### Use Installomator with various MDM solutions
Then you can use the Installomator script in a policy and choose the application to install by setting the label for argument 4.
In the wiki we have provided documentation on how Installomator is used in various MDM solution, like [Jamf Pro](https://github.com/Installomator/Installomator/wiki/MDM:-Jamf-Pro), [Mosyle](https://github.com/Installomator/Installomator/wiki/MDM:-Mosyle-(Business,-Fuse,-and-Manager)), and [Addigy](https://github.com/Installomator/Installomator/wiki/MDM:-Addigy).
## What it does
@@ -198,7 +233,7 @@ When it runs with a known label, the script will perform the following:
- Check the version installed with the version online. Only continue if it's different
- download the latest version from the vendor
- when the application is running, prompt the user to quit or cancel
- when the application is running, prompt the user to quit or cancel (customizable)
- dmg or zip archives:
- extract the application and copy it to /Applications
- change the owner of the application to the current user
@@ -206,19 +241,11 @@ When it runs with a known label, the script will perform the following:
- when necessary, extract the pkg from the enclosing archive
- install the pkg with the `installer` tool
- clean up the downloaded files
- notify the user
- notify the user (also customizable)
## Configuring the script
As of now there are two settings that are meant to configured when deploying the script.
### Debug mode
The first is the `DEBUG` variable. When this is set to `1` the script will _not_ perform any changes to the current system. In other words, no application will be copied to the target directory and no `installer` command be performed.
In addition, files will be downloaded and extracted to the Installomator project folder instead of a temporary directory and _not_ deleted when the script exits. Also archives will _not_ be re-downloaded when they already exist in the project folder. The repository's `.gitignore` file is set up to ignore the archive file extensions.
Debug mode is useful to test the download and verification process without having to re-download and re-install an application or package on your system.
We have several default settings for certain behavior and notifications inside the script, but these can be customized when calling the script.
### Blocking Process actions
@@ -227,13 +254,13 @@ The `BLOCKING_PROCESS_ACTION` variable controls the behavior of the script when
There are eight options:
- `ignore`: continue even when blocking processes are found.
- `silent_fail`: exit script without prompt or installation.
- `prompt_user`: (default) show a user dialog for each blocking process found abort after three attempts to quit (only if user accepts to quit the apps, otherwise the update is cancelled).
- `prompt_user_then_kill`: show a user dialog for each blocking process found, attempt to quit two times, kill the process finally.
- `silent_fail`: Exit script without prompt or installation.
- `prompt_user`: Show a user dialog for each blocking process found, user can choose "Quit and Update" or "Not Now". When "Quit and Update" is chosen, blocking process will be told to quit. Installomator will wait 30 seconds before checking again in case Save dialogs etc are being responded to. Installomator will abort if quitting after three tries does not succeed. "Not Now" will exit Installomator.
- `prompt_user_then_kill`: show a user dialog for each blocking process found, user can choose "Quit and Update" or "Not Now". When "Quit and Update" is chosen, blocking process will be terminated. Installomator will abort if terminating after two tries does not succeed. "Not Now" will exit Installomator.
- `prompt_user_loop`: Like prompt-user, but clicking "Not Now", will just wait an hour, and then it will ask again.
WARNING! It might block the MDM agent on the machine, as the scripts gets stuct in waiting until the hour has passed, possibly blocking for other management actions in this time.
- `tell_user`: User will be showed a notification about the important update, but user is only allowed to quit and continue, and then we ask the app to quit.
- `tell_user_then_kill`: Show dialog 2 times, and if the quitting fails, the blocking processes will be killed.
WARNING! It might block the MDM agent on the machine, as the script will not exit, it will pause until the hour has passed, possibly blocking for other management actions in this time.
- `tell_user`: (Default) User will be showed a notification about the important update, but user is only allowed to Quit and Continue, and then we ask the app to quit. This is default.
- `tell_user_then_kill`: User will be showed a notification about the important update, but user is only allowed to Quit and Continue. If the quitting fails, the blocking processes will be terminated.
- `kill`: kill process without prompting or giving the user a chance to save.
If any process was closed, Installomator will try to open the app again, after the update process is done.
@@ -263,11 +290,17 @@ __options:__
- `no`: If installed app is from App Store (which include VPP installed apps) it will not be touched, no matter it's version (default)
- `yes`: Replace App Store (and VPP) version of app and handle future updates using Installomator, even if latest version. Shouldnt give any problems for the user in most cases. Known bad example: Slack will loose all settings.
### Owner of copied apps
Default is `SYSTEMOWNER=0`
__options:__
- `0`: Current user will be owner of copied apps, just like if they installed it themselves (default).
- `1`: root:wheel will be set on the copied app. Useful for shared machines.
### Install behavior (force installation)
Since we now make a version checking, and only installs the software if the version is different, an `INSTALL` variable can be used to force the installation:
- ``: When not set, software is only installed if it is newer/different in version (default)
- ` `: When not set, software is only installed if it is newer/different in version (default)
- `force`: Install even if its the same version
### Re-opening of closed app
@@ -277,9 +310,29 @@ The `REOPEN` can be used to prevent the reopening of a closed app
- `yes`: (default) app will be reopened if it was closed
- `no`: app not reopened
### Adding applications/label blocks
### Configuration from Arguments
#### Required Variables
You can provide a configuration variable, such as `DEBUG` or `NOTIFY` as an argument in the form `VAR=value`. For example:
```
./Installomator.sh desktoppr DEBUG=0 NOTIFY=silent
```
Providing variables this way will override any variables set in the script.
You can even provide _all_ the variables necessary for download and installation. Of course, without a label the argument parsing will fail, so I created a special label `valuesfromarguments` which only checks if the four required values are present:
```
./Installomator.sh name=desktoppr type=pkg downloadURL=https://github.com/scriptingosx/desktoppr/releases/download/v0.3/desktoppr-0.3.pkg expectedTeamID=JME5BW3F3R valuesfromarguments
```
The order of the variables and label is not relevant. But, when you provide more than one label, all but the _last_ label will be ignored.
Providing all the variables this way might be useful for certain downloads that have a customized URL for each vendor/customer (like customized TeamView or Watchman Monitoring) or are local downloads.
## Adding applications/label blocks
### Required Variables
The script requires four pieces of information to download and install an application:
@@ -312,6 +365,12 @@ The URL from which to download the archive.
The URL can be generated by a series of commands, for example when you need to parse an xml file for the latest URL. (See `bbedit`, `desktoppr`, or `omnigraffle` for examples.)
Sometimes version differs between Intel and Apple Silicon versions. (See `brave`, `obsidian`, `omnidisksweeper`, or `notion`).
- `curlOptions`: (array, optional)
Options to the `curl` command, needed for `curl` to be able to download the software.
Usually used for adding extra headers that some servers need in order to serve the file.
`curlOptions=( -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" )`
(See “mocha”-labels, for examples on labels, and `buildLabel.sh` for header-examples.)
- `appNewVersion` (optional, but recommended):
Version of the downloaded software.
If given, it will be compared to installed version, to see if download is different.
@@ -332,8 +391,7 @@ The 10-character Developer Team ID with which the application or pkg is signed a
- Installation Packages (pkg)
`spctl -a -vv -t install ~/Downloads/desktoppr-0.2.pkg`
#### Optional Variables
### Optional Variables
Depending on the application or pkg there are a few more variables you can or need to set. Many of these are derived from the required variables, but may need to be set manually if those derived values do not work.
@@ -390,42 +448,17 @@ Depending on the application or pkg there are a few more variables you can or ne
Introduced as part of `CLIInstaller`. If the installer in the DMG or ZIP is named differently than the installed app, then this variable can be used to name the installer that should be located after mounting/expanding the downloaded archive.
See label adobecreativeclouddesktop
### Configuration from Arguments
You can provide a configuration variable, such as `DEBUG` or `NOTIFY` as an argument in the form `VAR=value`. For example:
```
./Installomator.sh desktoppr DEBUG=0 NOTIFY=silent
```
Providing variables this way will override any variables set in the script.
You can even provide _all_ the variables necessary for download and installation. Of course, without a label the argument parsing will fail, so I created a special label `valuesfromarguments` which only checks if the four required values are present:
```
./Installomator.sh name=desktoppr type=pkg downloadURL=https://github.com/scriptingosx/desktoppr/releases/download/v0.3/desktoppr-0.3.pkg expectedTeamID=JME5BW3F3R valuesfromarguments
```
The order of the variables and label is not relevant. But, when you provide more than one label, all but the _last_ label will be ignored.
Providing all the variables this way might be useful for certain downloads that have a customized URL for each vendor/customer (like customized TeamView or Watchman Monitoring) or are local downloads.
## Frequently Asked Questions
### What if the latest version of the app is already installed?
Short answer: Installomator will re-download and re-install the latest over the existing installation.
Short answer: That depends on if labels will know what the latest version will be.
Longer answer:
Installomator will try to find a currently installed app to log the version. When Installomator finds an existing app (any version) and the `updateTool` variable is set, then Installomator will _not_ download and install, but run the `updateTool` instead.
However, there is no simple generic method to actually determine the latest version of an application or installer.
We deploy Installomator usually for user initiated installations from Self Service, so re-installs don't really 'hurt' and may be a useful troubleshooting step.
When you want to have automated installations, you can use smart groups based on the app version to limit excessive re-installations.
- Labels without this will re-download and re-install the latest over the existing installation.
- Labels with this info will only install the app if the version is different than the one installed.
- Labels that can use update tool will use that for the update (if the version is different)
### Why don't you just use `autopkg install`?
@@ -455,7 +488,7 @@ Please don't misunderstand this as me saying that AutoPkg is a bad or poorly des
But it is not suited as a client install automation tool.
### Why don't you just use brew?
### Why don't you just use brew or MacPorts?
Read the explanation for `autopkg`, pretty much the same applies for `brew`, i.e. while it is useful on a single Mac, it is a un-manageable mess when you think about deploying and managing on a fleet of computers.

View File

@@ -1,29 +1,30 @@
# MARK: check minimal macOS requirement
autoload is-at-least
if ! is-at-least 10.14 $(sw_vers -productVersion); then
printlog "Installomator requires at least macOS 10.14 Mojave."
installedOSversion=$(sw_vers -productVersion)
if ! is-at-least 10.14 $installedOSversion; then
printlog "Installomator requires at least macOS 10.14 Mojave." ERROR
exit 98
fi
# MARK: argument parsing
if [[ $# -eq 0 ]]; then
if [[ -z $label ]]; then # check if label is set inside script
printlog "no label provided, printing labels"
printlog "no label provided, printing labels" REQ
grep -E '^[a-z0-9\_-]*(\)|\|\\)$' "$0" | tr -d ')|\' | grep -v -E '^(broken.*|longversion|version|valuesfromarguments)$' | sort
#grep -E '^[a-z0-9\_-]*(\)|\|\\)$' "${labelFile}" | tr -d ')|\' | grep -v -E '^(broken.*|longversion|version|valuesfromarguments)$' | sort
exit 0
fi
elif [[ $1 == "/" ]]; then
# jamf uses sends '/' as the first argument
printlog "shifting arguments for Jamf"
printlog "shifting arguments for Jamf" REQ
shift 3
fi
while [[ -n $1 ]]; do
if [[ $1 =~ ".*\=.*" ]]; then
# if an argument contains an = character, send it to eval
printlog "setting variable from argument $1"
printlog "setting variable from argument $1" WARN
eval $1
else
# assume it's a label
@@ -42,44 +43,84 @@ if [[ $label == "version" ]]; then
exit 0
fi
printlog "################## Start Installomator v. $VERSION"
printlog "################## $label"
# MARK: Logging
log_location="/private/var/log/Installomator.log"
# Check if we're in debug mode, if so then set logging to DEBUG, otherwise default to INFO
# if no log level is specified.
if [[ $DEBUG -ne 0 ]]; then
LOGGING=DEBUG
elif [[ -z $LOGGING ]]; then
LOGGING=INFO
datadogLoggingLevel=INFO
fi
# Associate logging levels with a numerical value so that we are able to identify what
# should be removed. For example if the LOGGING=ERROR only printlog statements with the
# level REQ and ERROR will be displayed. LOGGING=DEBUG will show all printlog statements.
# If a printlog statement has no level set it's automatically assigned INFO.
declare -A levels=(DEBUG 0 INFO 1 WARN 2 ERROR 3 REQ 4)
# If we are able to detect an MDM URL (Jamf Pro) or another identifier for a customer/instance we grab it here, this is useful if we're centrally logging multiple MDM instances.
if [[ -f /Library/Preferences/com.jamfsoftware.jamf.plist ]]; then
mdmURL=$(defaults read /Library/Preferences/com.jamfsoftware.jamf.plist jss_url)
elif [[ -n "$MDMProfileName" ]]; then
mdmURL=$(sudo profiles show | grep -A3 "$MDMProfileName" | sed -n -e 's/^.*organization: //p')
else
mdmURL="Unknown"
fi
# Generate a session key for this run, this is useful to idenify streams when we're centrally logging.
SESSION=$RANDOM
# Mark: START
printlog "################## Start Installomator v. $VERSION, date $VERSIONDATE" REQ
printlog "################## Version: $VERSION" INFO
printlog "################## Date: $VERSIONDATE" INFO
printlog "################## $label" INFO
# Check for DEBUG mode
if [[ $DEBUG -gt 0 ]]; then
printlog "DEBUG mode $DEBUG enabled."
printlog "DEBUG mode $DEBUG enabled." DEBUG
fi
# How we get version number from app
# (alternative is "CFBundleVersion", that can be used in labels)
versionKey="CFBundleShortVersionString"
if [[ -z $versionKey ]]; then
versionKey="CFBundleShortVersionString"
fi
# get current user
currentUser=$(scutil <<< "show State:/Users/ConsoleUser" | awk '/Name :/ { print $3 }')
# MARK: check for root
if [[ "$(whoami)" != "root" && "$DEBUG" -eq 0 ]]; then
# not running as root
cleanupAndExit 6 "not running as root, exiting" ERROR
fi
# MARK: labels in case statement
case $label in
longversion)
# print the script version
printlog "Installomater: version $VERSION ($VERSIONDATE)"
printlog "Installomater: version $VERSION ($VERSIONDATE)" REQ
exit 0
;;
valuesfromarguments)
if [[ -z $name ]]; then
printlog "need to provide 'name'"
printlog "need to provide 'name'" ERROR
exit 1
fi
if [[ -z $type ]]; then
printlog "need to provide 'type'"
printlog "need to provide 'type'" ERROR
exit 1
fi
if [[ -z $downloadURL ]]; then
printlog "need to provide 'downloadURL'"
printlog "need to provide 'downloadURL'" ERROR
exit 1
fi
if [[ -z $expectedTeamID ]]; then
printlog "need to provide 'expectedTeamID'"
printlog "need to provide 'expectedTeamID'" ERROR
exit 1
fi
;;

View File

@@ -1,23 +1,33 @@
# MARK: Functions
cleanupAndExit() { # $1 = exit code, $2 message
if [[ -n $2 && $1 -ne 0 ]]; then
printlog "ERROR: $2"
fi
if [ "$DEBUG" -eq 0 ]; then
# remove the temporary working directory when done
printlog "Deleting $tmpDir"
rm -Rf "$tmpDir"
fi
cleanupAndExit() { # $1 = exit code, $2 message, $3 level
if [ -n "$dmgmount" ]; then
# unmount disk image
printlog "Unmounting $dmgmount"
hdiutil detach "$dmgmount"
printlog "Unmounting $dmgmount" DEBUG
unmountingOut=$(hdiutil detach "$dmgmount" 2>&1)
printlog "Debugging enabled, Unmounting output was:\n$unmountingOut" DEBUG
fi
if [ "$DEBUG" -ne 1 ]; then
# remove the temporary working directory when done (only if DEBUG is not used)
printlog "Deleting $tmpDir" DEBUG
deleteTmpOut=$(rm -Rfv "$tmpDir")
printlog "Debugging enabled, Deleting tmpDir output was:\n$deleteTmpOut" DEBUG
fi
# If we closed any processes, reopen the app again
reopenClosedProcess
printlog "################## End Installomator, exit code $1 \n\n"
if [[ -n $2 && $1 -ne 0 ]]; then
printlog "ERROR: $2" $3
else
printlog "$2" $3
fi
printlog "################## End Installomator, exit code $1 \n" REQ
# if label is wrong and we wanted name of the label, then return ##################
if [[ $RETURN_LABEL_NAME -eq 1 ]]; then
1=0 # If only label name should be returned we exit without any errors
echo "#"
fi
exit "$1"
}
@@ -59,26 +69,84 @@ displaynotification() { # $1: message $2: title
fi
}
# MARK: Logging
log_location="/private/var/log/Installomator.log"
printlog(){
[ -z "$2" ] && 2=INFO
log_message=$1
log_priority=$2
timestamp=$(date +%F\ %T)
if [[ "$(whoami)" == "root" ]]; then
echo "$timestamp" "$label" "$1" | tee -a $log_location
else
echo "$timestamp" "$label" "$1"
# Check to make sure that the log isn't the same as the last, if it is then don't log and increment a timer.
if [[ ${log_message} == ${previous_log_message} ]]; then
let logrepeat=$logrepeat+1
return
fi
previous_log_message=$log_message
# Once we finally stop getting duplicate logs output the number of times we got a duplicate.
if [[ $logrepeat -gt 1 ]];then
echo "$timestamp" : "${log_priority} : $label : Last Log repeated ${logrepeat} times" | tee -a $log_location
if [[ ! -z $datadogAPI ]]; then
curl -s -X POST https://http-intake.logs.datadoghq.com/v1/input -H "Content-Type: text/plain" -H "DD-API-KEY: $datadogAPI" -d "${log_priority} : $mdmURL : $APPLICATION : $VERSION : $SESSION : Last Log repeated ${logrepeat} times" > /dev/null
fi
logrepeat=0
fi
# If the datadogAPI key value is set and our logging level is greater than or equal to our set level
# then post to Datadog's HTTPs endpoint.
if [[ -n $datadogAPI && ${levels[$log_priority]} -ge ${levels[$datadogLoggingLevel]} ]]; then
while IFS= read -r logmessage; do
curl -s -X POST https://http-intake.logs.datadoghq.com/v1/input -H "Content-Type: text/plain" -H "DD-API-KEY: $datadogAPI" -d "${log_priority} : $mdmURL : Installomator-${label} : ${VERSIONDATE//-/} : $SESSION : ${logmessage}" > /dev/null
done <<< "$log_message"
fi
# Extra spaces
space_char=""
if [[ ${#log_priority} -eq 3 ]]; then
space_char=" "
elif [[ ${#log_priority} -eq 4 ]]; then
space_char=" "
fi
# If our logging level is greaterthan or equal to our set level then output locally.
if [[ ${levels[$log_priority]} -ge ${levels[$LOGGING]} ]]; then
while IFS= read -r logmessage; do
if [[ "$(whoami)" == "root" ]]; then
echo "$timestamp" : "${log_priority}${space_char} : $label : ${logmessage}" | tee -a $log_location
else
echo "$timestamp" : "${log_priority}${space_char} : $label : ${logmessage}"
fi
done <<< "$log_message"
fi
}
# Used to remove dupplicate lines in large log output,
# for example from msupdate command after it finishes running.
deduplicatelogs() {
loginput=${1:-"Log"}
logoutput=""
# Read each line of the incoming log individually, match it with the previous.
# If it matches increment logrepeate then skip to the next line.
while read log; do
if [[ $log == $previous_log ]];then
let logrepeat=$logrepeat+1
continue
fi
previous_log="$log"
if [[ $logrepeat -gt 1 ]];then
logoutput+="Last Log repeated ${logrepeat} times\n"
logrepeat=0
fi
logoutput+="$log\n"
done <<< "$loginput"
}
# will get the latest release download from a github repo
downloadURLFromGit() { # $1 git user name, $2 git repo name
gitusername=${1?:"no git user name"}
gitreponame=${2?:"no git repo name"}
if [[ $type == "pkgInDmg" ]]; then
filetype="dmg"
elif [[ $type == "pkgInZip" ]]; then
@@ -86,17 +154,16 @@ downloadURLFromGit() { # $1 git user name, $2 git repo name
else
filetype=$type
fi
if [ -n "$archiveName" ]; then
downloadURL=$(curl --silent --fail "https://api.github.com/repos/$gitusername/$gitreponame/releases/latest" \
downloadURL=$(curl -L --silent --fail "https://api.github.com/repos/$gitusername/$gitreponame/releases/latest" \
| awk -F '"' "/browser_download_url/ && /$archiveName\"/ { print \$4; exit }")
else
downloadURL=$(curl --silent --fail "https://api.github.com/repos/$gitusername/$gitreponame/releases/latest" \
downloadURL=$(curl -L --silent --fail "https://api.github.com/repos/$gitusername/$gitreponame/releases/latest" \
| awk -F '"' "/browser_download_url/ && /$filetype\"/ { print \$4; exit }")
fi
if [ -z "$downloadURL" ]; then
cleanupAndExit 9 "could not retrieve download URL for $gitusername/$gitreponame"
#exit 9
cleanupAndExit 9 "could not retrieve download URL for $gitusername/$gitreponame" ERROR
else
echo "$downloadURL"
return 0
@@ -108,10 +175,10 @@ versionFromGit() {
# $1 git user name, $2 git repo name
gitusername=${1?:"no git user name"}
gitreponame=${2?:"no git repo name"}
appNewVersion=$(curl --silent --fail "https://api.github.com/repos/$gitusername/$gitreponame/releases/latest" | grep tag_name | cut -d '"' -f 4 | sed 's/[^0-9\.]//g')
appNewVersion=$(curl -L --silent --fail "https://api.github.com/repos/$gitusername/$gitreponame/releases/latest" | grep tag_name | cut -d '"' -f 4 | sed 's/[^0-9\.]//g')
if [ -z "$appNewVersion" ]; then
printlog "could not retrieve version number for $gitusername/$gitreponame"
printlog "could not retrieve version number for $gitusername/$gitreponame" WARN
appNewVersion=""
else
echo "$appNewVersion"
@@ -122,7 +189,7 @@ versionFromGit() {
# Handling of differences in xpath between Catalina and Big Sur
xpath() {
# the xpath tool changes in Big Sur and now requires the `-e` option
# the xpath tool changes in Big Sur and now requires the `-e` option
if [[ $(sw_vers -buildVersion) > "20A" ]]; then
/usr/bin/xpath -e $@
# alternative: switch to xmllint (which is not perl)
@@ -142,7 +209,7 @@ getAppVersion() {
printlog "Custom App Version detection is used, found $appversion"
return
fi
# pkgs contains a version number, then we don't have to search for an app
if [[ $packageID != "" ]]; then
appversion="$(pkgutil --pkg-info-plist ${packageID} 2>/dev/null | grep -A 1 pkg-version | tail -1 | sed -E 's/.*>([0-9.]*)<.*/\1/g')"
@@ -154,20 +221,35 @@ getAppVersion() {
printlog "No version found using packageID $packageID"
fi
fi
# get app in /Applications, or /Applications/Utilities, or find using Spotlight
if [[ -d "/Applications/$appName" ]]; then
# get app in targetDir, /Applications, or /Applications/Utilities
if [[ -d "$targetDir/$appName" ]]; then
applist="$targetDir/$appName"
elif [[ -d "/Applications/$appName" ]]; then
applist="/Applications/$appName"
# if [[ $type =~ '^(dmg|zip|tbz|app.*)$' ]]; then
# targetDir="/Applications"
# fi
elif [[ -d "/Applications/Utilities/$appName" ]]; then
applist="/Applications/Utilities/$appName"
# if [[ $type =~ '^(dmg|zip|tbz|app.*)$' ]]; then
# targetDir="/Applications/Utilities"
# fi
else
applist=$(mdfind "kind:application $appName" -0 )
# applist=$(mdfind "kind:application $appName" -0 )
printlog "name: $name, appName: $appName"
applist=$(mdfind "kind:application AND name:$name" -0 )
# printlog "App(s) found: ${applist}" DEBUG
# applist=$(mdfind "kind:application AND name:$appName" -0 )
fi
if [[ -z applist ]]; then
printlog "No previous app found"
if [[ -z $applist ]]; then
printlog "No previous app found" WARN
else
printlog "App(s) found: ${applist}"
printlog "App(s) found: ${applist}" INFO
fi
# if [[ $type =~ '^(dmg|zip|tbz|app.*)$' ]]; then
# printlog "targetDir for installation: $targetDir" INFO
# fi
appPathArray=( ${(0)applist} )
@@ -177,30 +259,30 @@ getAppVersion() {
installedAppPath=$filteredAppPaths[1]
#appversion=$(mdls -name kMDItemVersion -raw $installedAppPath )
appversion=$(defaults read $installedAppPath/Contents/Info.plist $versionKey) #Not dependant on Spotlight indexing
printlog "found app at $installedAppPath, version $appversion"
printlog "found app at $installedAppPath, version $appversion, on versionKey $versionKey"
updateDetected="YES"
# Is current app from App Store
if [[ -d "$installedAppPath"/Contents/_MASReceipt ]];then
printlog "Installed $appName is from App Store, use “IGNORE_APP_STORE_APPS=yes” to replace."
if [[ $IGNORE_APP_STORE_APPS == "yes" ]]; then
printlog "Replacing App Store apps, no matter the version"
printlog "Replacing App Store apps, no matter the version" WARN
appversion=0
else
cleanupAndExit 1 "App previously installed from App Store, and we respect that"
cleanupAndExit 1 "App previously installed from App Store, and we respect that" ERROR
fi
fi
else
printlog "could not determine location of $appName"
printlog "could not determine location of $appName" WARN
fi
else
printlog "could not find $appName"
printlog "could not find $appName" WARN
fi
}
checkRunningProcesses() {
# don't check in DEBUG mode
if [[ $DEBUG -ne 0 ]]; then
printlog "DEBUG mode, not checking for blocking processes"
# don't check in DEBUG mode 1
if [[ $DEBUG -eq 1 ]]; then
printlog "DEBUG mode 1, not checking for blocking processes" DEBUG
return
fi
@@ -211,7 +293,7 @@ checkRunningProcesses() {
if pgrep -xq "$x"; then
printlog "found blocking process $x"
appClosed=1
case $BLOCKING_PROCESS_ACTION in
quit|quit_kill)
printlog "telling app $x to quit"
@@ -233,7 +315,7 @@ checkRunningProcesses() {
prompt_user|prompt_user_then_kill)
button=$(displaydialog "Quit “$x” to continue updating? (Leave this dialogue if you want to activate this update later)." "The application “$x” needs to be updated.")
if [[ $button = "Not Now" ]]; then
cleanupAndExit 10 "user aborted update"
cleanupAndExit 10 "user aborted update" ERROR
else
if [[ $i > 2 && $BLOCKING_PROCESS_ACTION = "prompt_user_then_kill" ]]; then
printlog "Changing BLOCKING_PROCESS_ACTION to kill"
@@ -278,7 +360,7 @@ checkRunningProcesses() {
fi
;;
silent_fail)
cleanupAndExit 12 "blocking process '$x' found, aborting"
cleanupAndExit 12 "blocking process '$x' found, aborting" ERROR
;;
esac
@@ -289,28 +371,28 @@ checkRunningProcesses() {
done
if [[ $countedProcesses -ne 0 ]]; then
cleanupAndExit 11 "could not quit all processes, aborting..."
cleanupAndExit 11 "could not quit all processes, aborting..." ERROR
fi
printlog "no more blocking processes, continue with update"
printlog "no more blocking processes, continue with update" REQ
}
reopenClosedProcess() {
# If Installomator closed any processes, let's get the app opened again
# credit: Søren Theilgaard (@theilgaard)
# don't reopen if REOPEN is not "yes"
if [[ $REOPEN != yes ]]; then
printlog "REOPEN=no, not reopening anything"
return
fi
# don't reopen in DEBUG mode
if [[ $DEBUG -ne 0 ]]; then
printlog "DEBUG mode, not reopening anything"
# don't reopen in DEBUG mode 1
if [[ $DEBUG -eq 1 ]]; then
printlog "DEBUG mode 1, not reopening anything" DEBUG
return
fi
if [[ $appClosed == 1 ]]; then
printlog "Telling app $appName to open"
#runAsUser osascript -e "tell app \"$appName\" to open"
@@ -320,7 +402,7 @@ reopenClosedProcess() {
processuser=$(ps aux | grep -i "${appName}" | grep -vi "grep" | awk '{print $1}')
printlog "Reopened ${appName} as $processuser"
else
printlog "App not closed, so no reopen."
printlog "App not closed, so no reopen." INFO
fi
}
@@ -330,89 +412,123 @@ installAppWithPath() { # $1: path to app to install in $targetDir
# check if app exists
if [ ! -e "$appPath" ]; then
cleanupAndExit 8 "could not find: $appPath"
cleanupAndExit 8 "could not find: $appPath" ERROR
fi
# verify with spctl
printlog "Verifying: $appPath"
if ! teamID=$(spctl -a -vv "$appPath" 2>&1 | awk '/origin=/ {print $NF }' | tr -d '()' ); then
cleanupAndExit 4 "Error verifying $appPath"
fi
printlog "Verifying: $appPath" INFO
printlog "App size: $(du -sh "$appPath")" DEBUG
appVerify=$(spctl -a -vv "$appPath" 2>&1 )
appVerifyStatus=$(echo $?)
teamID=$(echo $appVerify | awk '/origin=/ {print $NF }' | tr -d '()' )
deduplicatelogs "$appVerify"
printlog "Team ID matching: $teamID (expected: $expectedTeamID )"
if [[ $appVerifyStatus -ne 0 ]] ; then
#if ! teamID=$(spctl -a -vv "$appPath" 2>&1 | awk '/origin=/ {print $NF }' | tr -d '()' ); then
cleanupAndExit 4 "Error verifying $appPath error:\n$logoutput" ERROR
fi
printlog "Debugging enabled, App Verification output was:\n$logoutput" DEBUG
printlog "Team ID matching: $teamID (expected: $expectedTeamID )" INFO
if [ "$expectedTeamID" != "$teamID" ]; then
cleanupAndExit 5 "Team IDs do not match"
cleanupAndExit 5 "Team IDs do not match" ERROR
fi
# versioncheck
# credit: Søren Theilgaard (@theilgaard)
# app versioncheck
appNewVersion=$(defaults read $appPath/Contents/Info.plist $versionKey)
if [[ -n $appNewVersion && $appversion == $appNewVersion ]]; then
printlog "Downloaded version of $name is $appNewVersion, same as installed."
printlog "Downloaded version of $name is $appNewVersion on versionKey $versionKey, same as installed."
if [[ $INSTALL != "force" ]]; then
message="$name, version $appNewVersion, is the latest version."
if [[ $currentUser != "loginwindow" && $NOTIFY == "all" ]]; then
printlog "notifying"
displaynotification "$message" "No update for $name!"
fi
cleanupAndExit 0 "No new version to install"
cleanupAndExit 0 "No new version to install" REG
else
printlog "Using force to install anyway."
fi
elif [[ -z $appversion ]]; then
printlog "Installing $name version $appNewVersion on versionKey $versionKey."
else
printlog "Downloaded version of $name is $appNewVersion (replacing version $appversion)."
printlog "Downloaded version of $name is $appNewVersion on versionKey $versionKey (replacing version $appversion)."
fi
# skip install for DEBUG
if [ "$DEBUG" -ne 0 ]; then
printlog "DEBUG enabled, skipping remove, copy and chown steps"
# macOS versioncheck
minimumOSversion=$(defaults read $appPath/Contents/Info.plist LSMinimumSystemVersion 2>/dev/null )
if [[ -n $minimumOSversion && $minimumOSversion =~ '[0-9.]*' ]]; then
printlog "App has LSMinimumSystemVersion: $minimumOSversion"
if ! is-at-least $minimumOSversion $installedOSversion; then
printlog "App requires higher System Version than installed: $installedOSversion"
message="Cannot install $name, version $appNewVersion, as it is not compatible with the running system version."
if [[ $currentUser != "loginwindow" && $NOTIFY == "all" ]]; then
printlog "notifying"
displaynotification "$message" "Error updating $name!"
fi
cleanupAndExit 6 "Installed macOS is too old for this app." ERROR
fi
fi
# skip install for DEBUG 1
if [ "$DEBUG" -eq 1 ]; then
printlog "DEBUG mode 1 enabled, skipping remove, copy and chown steps" DEBUG
return 0
fi
# check for root
if [ "$(whoami)" != "root" ]; then
# not running as root
cleanupAndExit 6 "not running as root, exiting"
# skip install for DEBUG 2
if [ "$DEBUG" -eq 2 ]; then
printlog "DEBUG mode 2 enabled, not installing anything, exiting" DEBUG
cleanupAndExit 0
fi
# Test if variable CLIInstaller is set
if [[ -z $CLIInstaller ]]; then
# remove existing application
if [ -e "$targetDir/$appName" ]; then
printlog "Removing existing $targetDir/$appName"
rm -Rf "$targetDir/$appName"
printlog "Removing existing $targetDir/$appName" WARN
deleteAppOut=$(rm -Rfv "$targetDir/$appName" 2>&1)
tempName="$targetDir/$appName"
tempNameLength=$((${#tempName} + 10))
deleteAppOut=$(echo $deleteAppOut | cut -c 1-$tempNameLength)
deduplicatelogs "$deleteAppOut"
printlog "Debugging enabled, App removing output was:\n$logoutput" DEBUG
fi
# copy app to /Applications
printlog "Copy $appPath to $targetDir"
if ! ditto "$appPath" "$targetDir/$appName"; then
cleanupAndExit 7 "Error while copying"
copyAppOut=$(ditto -v "$appPath" "$targetDir/$appName" 2>&1)
copyAppStatus=$(echo $?)
deduplicatelogs "$copyAppOut"
printlog "Debugging enabled, App copy output was:\n$logoutput" DEBUG
if [[ $copyAppStatus -ne 0 ]] ; then
#if ! ditto "$appPath" "$targetDir/$appName"; then
cleanupAndExit 7 "Error while copying:\n$logoutput" ERROR
fi
# set ownership to current user
if [ "$currentUser" != "loginwindow" ]; then
printlog "Changing owner to $currentUser"
if [[ "$currentUser" != "loginwindow" && $SYSTEMOWNER -ne 1 ]]; then
printlog "Changing owner to $currentUser" WARN
chown -R "$currentUser" "$targetDir/$appName"
else
printlog "No user logged in, not changing user"
printlog "No user logged in or SYSTEMOWNER=1, setting owner to root:wheel" WARN
chown -R root:wheel "$targetDir/$appName"
fi
elif [[ ! -z $CLIInstaller ]]; then
mountname=$(dirname $appPath)
printlog "CLIInstaller exists, running installer command $mountname/$CLIInstaller $CLIArguments" #INFO
printlog "CLIInstaller exists, running installer command $mountname/$CLIInstaller $CLIArguments" INFO
CLIoutput=$("$mountname/$CLIInstaller" "${CLIArguments[@]}" 2>&1)
CLIstatus=$(echo $?)
logoutput="$CLIoutput" # dedupliatelogs "$CLIoutput"
deduplicatelogs "$CLIoutput"
if [ $CLIstatus -ne 0 ] ; then
cleanupAndExit 3 "Error installing $mountname/$CLIInstaller $CLIArguments error:\n$logoutput" #ERROR
cleanupAndExit 3 "Error installing $mountname/$CLIInstaller $CLIArguments error:\n$logoutput" ERROR
else
printlog "Succesfully ran $mountname/$CLIInstaller $CLIArguments"
printlog "Succesfully ran $mountname/$CLIInstaller $CLIArguments" INFO
fi
printlog "Debugging enabled, update tool output was:\n$logoutput" #DEBUG
printlog "Debugging enabled, update tool output was:\n$logoutput" DEBUG
fi
}
@@ -421,16 +537,21 @@ mountDMG() {
# mount the dmg
printlog "Mounting $tmpDir/$archiveName"
# always pipe 'Y\n' in case the dmg requires an agreement
if ! dmgmount=$(echo 'Y'$'\n' | hdiutil attach "$tmpDir/$archiveName" -nobrowse -readonly | tail -n 1 | cut -c 54- ); then
cleanupAndExit 3 "Error mounting $tmpDir/$archiveName"
fi
dmgmountOut=$(echo 'Y'$'\n' | hdiutil attach "$tmpDir/$archiveName" -nobrowse -readonly )
dmgmountStatus=$(echo $?)
dmgmount=$(echo $dmgmountOut | tail -n 1 | cut -c 54- )
deduplicatelogs "$dmgmountOut"
if [[ $dmgmountStatus -ne 0 ]] ; then
#if ! dmgmount=$(echo 'Y'$'\n' | hdiutil attach "$tmpDir/$archiveName" -nobrowse -readonly | tail -n 1 | cut -c 54- ); then
cleanupAndExit 3 "Error mounting $tmpDir/$archiveName error:\n$logoutput" ERROR
fi
if [[ ! -e $dmgmount ]]; then
printlog "Error mounting $tmpDir/$archiveName"
cleanupAndExit 3
cleanupAndExit 3 "Error accessing mountpoint for $tmpDir/$archiveName error:\n$logoutput" ERROR
fi
printlog "Debugging enabled, dmgmount output was:\n$logoutput" DEBUG
printlog "Mounted: $dmgmount"
printlog "Mounted: $dmgmount" INFO
}
installFromDMG() {
@@ -441,34 +562,44 @@ installFromDMG() {
installFromPKG() {
# verify with spctl
printlog "Verifying: $archiveName"
if ! spctlout=$(spctl -a -vv -t install "$archiveName" 2>&1 ); then
printlog "Error verifying $archiveName"
cleanupAndExit 4
printlog "File list: $(ls -lh "$archiveName")" DEBUG
printlog "File type: $(file "$archiveName")" DEBUG
spctlOut=$(spctl -a -vv -t install "$archiveName" 2>&1 )
spctlStatus=$(echo $?)
printlog "spctlOut is $spctlOut" DEBUG
teamID=$(echo $spctlOut | awk -F '(' '/origin=/ {print $2 }' | tr -d '()' )
# Apple signed software has no teamID, grab entire origin instead
if [[ -z $teamID ]]; then
teamID=$(echo $spctlOut | awk -F '=' '/origin=/ {print $NF }')
fi
deduplicatelogs "$spctlOut"
if [[ $spctlStatus -ne 0 ]] ; then
#if ! spctlout=$(spctl -a -vv -t install "$archiveName" 2>&1 ); then
cleanupAndExit 4 "Error verifying $archiveName error:\n$logoutput" ERROR
fi
teamID=$(echo $spctlout | awk -F '(' '/origin=/ {print $2 }' | tr -d '()' )
# Apple signed software has no teamID, grab entire origin instead
if [[ -z $teamID ]]; then
teamID=$(echo $spctlout | awk -F '=' '/origin=/ {print $NF }')
fi
printlog "Team ID: $teamID (expected: $expectedTeamID )"
if [ "$expectedTeamID" != "$teamID" ]; then
printlog "Team IDs do not match!"
cleanupAndExit 5
cleanupAndExit 5 "Team IDs do not match!" ERROR
fi
# Check version of pkg to be installed if packageID is set
if [[ $packageID != "" && $appversion != "" ]]; then
printlog "Checking package version."
pkgutil --expand "$archiveName" "$archiveName"_pkg
#printlog "$(cat "$archiveName"_pkg/Distribution | xpath '//installer-gui-script/pkg-ref[@id][@version]' 2>/dev/null)"
appNewVersion=$(cat "$archiveName"_pkg/Distribution | xpath '//installer-gui-script/pkg-ref[@id][@version]' 2>/dev/null | grep -i "$packageID" | tr ' ' '\n' | grep -i version | cut -d \" -f 2) #sed -E 's/.*\"([0-9.]*)\".*/\1/g'
rm -r "$archiveName"_pkg
baseArchiveName=$(basename $archiveName)
expandedPkg="$tmpDir/${baseArchiveName}_pkg"
pkgutil --expand "$archiveName" "$expandedPkg"
appNewVersion=$(cat "$expandedPkg"/Distribution | xpath 'string(//installer-gui-script/pkg-ref[@id][@version]/@version)' 2>/dev/null )
rm -r "$expandedPkg"
printlog "Downloaded package $packageID version $appNewVersion"
if [[ $appversion == $appNewVersion ]]; then
printlog "Downloaded version of $name is the same as installed."
@@ -478,47 +609,63 @@ installFromPKG() {
printlog "notifying"
displaynotification "$message" "No update for $name!"
fi
cleanupAndExit 0 "No new version to install"
cleanupAndExit 0 "No new version to install" REQ
else
printlog "Using force to install anyway."
fi
fi
fi
# skip install for DEBUG
if [ "$DEBUG" -ne 0 ]; then
printlog "DEBUG enabled, skipping installation"
# skip install for DEBUG 1
if [ "$DEBUG" -eq 1 ]; then
printlog "DEBUG enabled, skipping installation" DEBUG
return 0
fi
# check for root
if [ "$(whoami)" != "root" ]; then
# not running as root
cleanupAndExit 6 "not running as root, exiting"
# skip install for DEBUG 2
if [ "$DEBUG" -eq 2 ]; then
cleanupAndExit 0 "DEBUG mode 2 enabled, exiting" DEBUG
fi
# install pkg
printlog "Installing $archiveName to $targetDir"
if ! installer -pkg "$archiveName" -tgt "$targetDir" ; then
printlog "error installing $archiveName"
cleanupAndExit 9
pkgInstall=$(installer -verbose -dumplog -pkg "$archiveName" -tgt "$targetDir" 2>&1)
pkgInstallStatus=$(echo $?)
sleep 1
pkgEndTime=$(date "+$LogDateFormat")
pkgInstall+=$(echo "\nOutput of /var/log/install.log below this line.\n")
pkgInstall+=$(echo "----------------------------------------------------------\n")
pkgInstall+=$(awk -v "b=$starttime" -v "e=$pkgEndTime" -F ',' '$1 >= b && $1 <= e' /var/log/install.log)
deduplicatelogs "$pkgInstall"
if [[ $pkgInstallStatus -ne 0 ]] && [[ $logoutput == *"requires Rosetta 2"* ]] && [[ $rosetta2 == no ]]; then
printlog "Package requires Rosetta 2, Installing Rosetta 2 and Installing Package" INFO
/usr/sbin/softwareupdate --install-rosetta --agree-to-license
rosetta2=yes
installFromPKG
fi
if [[ $pkginstallstatus -ne 0 ]] ; then
#if ! installer -pkg "$archiveName" -tgt "$targetDir" ; then
cleanupAndExit 9 "Error installing $archiveName error:\n$logoutput" ERROR
fi
printlog "Debugging enabled, installer output was:\n$logoutput" DEBUG
}
installFromZIP() {
# unzip the archive
printlog "Unzipping $archiveName"
# tar -xf "$archiveName"
# note: when you expand a zip using tar in Mojave the expanded
# app will never pass the spctl check
# unzip -o -qq "$archiveName"
# note: githubdesktop fails spctl verification when expanded
# with unzip
ditto -x -k "$archiveName" "$tmpDir"
installAppWithPath "$tmpDir/$appName"
}
@@ -535,17 +682,29 @@ installPkgInDmg() {
# locate pkg in dmg
if [[ -z $pkgName ]]; then
# find first file ending with 'pkg'
findfiles=$(find "$dmgmount" -iname "*.pkg" -maxdepth 1 )
findfiles=$(find "$dmgmount" -iname "*.pkg" -type f -maxdepth 1 )
printlog "Found pkg(s):\n$findfiles" DEBUG
filearray=( ${(f)findfiles} )
if [[ ${#filearray} -eq 0 ]]; then
cleanupAndExit 20 "couldn't find pkg in dmg $archiveName"
cleanupAndExit 20 "couldn't find pkg in dmg $archiveName" ERROR
fi
archiveName="${filearray[1]}"
printlog "found pkg: $archiveName"
else
# it is now safe to overwrite archiveName for installFromPKG
archiveName="$dmgmount/$pkgName"
if [[ -s "$dmgmount/$pkgName" ]] ; then # was: $tmpDir
archiveName="$dmgmount/$pkgName"
else
# try searching for pkg
findfiles=$(find "$dmgmount" -iname "$pkgName") # was: $tmpDir
printlog "Found pkg(s):\n$findfiles" DEBUG
filearray=( ${(f)findfiles} )
if [[ ${#filearray} -eq 0 ]]; then
cleanupAndExit 20 "couldn't find pkg “$pkgName” in dmg $archiveName" ERROR
fi
# it is now safe to overwrite archiveName for installFromPKG
archiveName="${filearray[1]}"
fi
fi
printlog "found pkg: $archiveName"
# installFromPkgs
installFromPKG
@@ -559,17 +718,29 @@ installPkgInZip() {
# locate pkg in zip
if [[ -z $pkgName ]]; then
# find first file ending with 'pkg'
findfiles=$(find "$tmpDir" -iname "*.pkg" -maxdepth 2 )
findfiles=$(find "$tmpDir" -iname "*.pkg" -type f -maxdepth 2 )
printlog "Found pkg(s):\n$findfiles" DEBUG
filearray=( ${(f)findfiles} )
if [[ ${#filearray} -eq 0 ]]; then
cleanupAndExit 20 "couldn't find pkg in zip $archiveName"
cleanupAndExit 20 "couldn't find pkg in zip $archiveName" ERROR
fi
archiveName="${filearray[1]}"
# it is now safe to overwrite archiveName for installFromPKG
archiveName="${filearray[1]}"
printlog "found pkg: $archiveName"
else
# it is now safe to overwrite archiveName for installFromPKG
archiveName="$tmpDir/$pkgName"
if [[ -s "$tmpDir/$pkgName" ]]; then
archiveName="$tmpDir/$pkgName"
else
# try searching for pkg
findfiles=$(find "$tmpDir" -iname "$pkgName")
filearray=( ${(f)findfiles} )
if [[ ${#filearray} -eq 0 ]]; then
cleanupAndExit 20 "couldn't find pkg “$pkgName” in zip $archiveName" ERROR
fi
# it is now safe to overwrite archiveName for installFromPKG
archiveName="${filearray[1]}"
printlog "found pkg: $archiveName"
fi
fi
# installFromPkgs
@@ -587,7 +758,7 @@ installAppInDmgInZip() {
findfiles=$(find "$tmpDir" -iname "*.dmg" -maxdepth 2 )
filearray=( ${(f)findfiles} )
if [[ ${#filearray} -eq 0 ]]; then
cleanupAndExit 20 "couldn't find dmg in zip $archiveName"
cleanupAndExit 20 "couldn't find dmg in zip $archiveName" ERROR
fi
archiveName="$(basename ${filearray[1]})"
# it is now safe to overwrite archiveName for installFromDMG
@@ -606,15 +777,32 @@ runUpdateTool() {
if [[ -x $updateTool ]]; then
printlog "running $updateTool $updateToolArguments"
if [[ -n $updateToolRunAsCurrentUser ]]; then
runAsUser $updateTool ${updateToolArguments}
updateOutput=$(runAsUser $updateTool ${updateToolArguments} 2>&1)
updateStatus=$(echo $?)
else
$updateTool ${updateToolArguments}
updateOutput=$($updateTool ${updateToolArguments} 2>&1)
updateStatus=$(echo $?)
fi
if [[ $? -ne 0 ]]; then
cleanupAndExit 15 "Error running $updateTool"
sleep 1
updateEndTime=$(date "+$updateToolLogDateFormat")
deduplicatelogs $updateOutput
if [[ -n $updateToolLog ]]; then
updateOutput+=$(echo "Output of Installer log of $updateToolLog below this line.\n")
updateOutput+=$(echo "----------------------------------------------------------\n")
updateOutput+=$(awk -v "b=$updatestarttime" -v "e=$updateEndTime" -F ',' '$1 >= b && $1 <= e' $updateToolLog)
fi
if [[ $updateStatus -ne 0 ]]; then
printlog "Error running $updateTool, Procceding with normal installation. Exit Status: $updateStatus Error:\n$logoutput" WARN
return 1
if [[ $type == updateronly ]]; then
cleanupAndExit 77 "No Download URL Set, this is an update only application and the updater failed" ERROR
fi
elif [[ $updateStatus -eq 0 ]]; then
printlog "Debugging enabled, update tool output was:\n$logoutput" DEBUG
fi
else
printlog "couldn't find $updateTool, continuing normally"
printlog "couldn't find $updateTool, continuing normally" WARN
return 1
fi
return 0
@@ -631,7 +819,7 @@ finishing() {
message="Installed $name, version $appversion"
fi
printlog "$message"
printlog "$message" REQ
if [[ $currentUser != "loginwindow" && ( $NOTIFY == "success" || $NOTIFY == "all" ) ]]; then
printlog "notifying"
@@ -643,4 +831,30 @@ finishing() {
fi
}
# Detect if there is an app actively making a display sleep assertion, e.g.
# KeyNote, PowerPoint, Zoom, or Webex.
# See: https://developer.apple.com/documentation/iokit/iopmlib_h/iopmassertiontypes
hasDisplaySleepAssertion() {
# Get the names of all apps with active display sleep assertions
local apps="$(/usr/bin/pmset -g assertions | /usr/bin/awk '/NoDisplaySleepAssertion | PreventUserIdleDisplaySleep/ && match($0,/\(.+\)/) && ! /coreaudiod/ {gsub(/^.*\(/,"",$0); gsub(/\).*$/,"",$0); print};')"
if [[ ! "${apps}" ]]; then
# No display sleep assertions detected
return 1
fi
# Create an array of apps that need to be ignored
local ignore_array=("${(@s/,/)IGNORE_DND_APPS}")
for app in ${(f)apps}; do
if (( ! ${ignore_array[(Ie)${app}]} )); then
# Relevant app with display sleep assertion detected
printlog "Display sleep assertion detected by ${app}."
return 0
fi
done
# No relevant display sleep assertion detected
return 1
}

View File

@@ -20,9 +20,11 @@ export PATH=/usr/bin:/bin:/usr/sbin:/sbin
# NOTE: adjust these variables:
# set to 0 for production, 1 for debugging
# set to 0 for production, 1 or 2 for debugging
# while debugging, items will be downloaded to the parent directory of this script
# also no actual installation will be performed
# debug mode 1 will download to the directory the script is run in, but will not check the version
# debug mode 2 will download to the temp directory, check for blocking processes, check the version, but will not install anything or remove the current version
DEBUG=1
# notify behavior
@@ -37,29 +39,36 @@ NOTIFY=success
BLOCKING_PROCESS_ACTION=tell_user
# options:
# - ignore continue even when blocking processes are found
# - quit app will be told to quit nicely, if running
# - quit app will be told to quit nicely if running
# - quit_kill told to quit twice, then it will be killed
# Could be great for service apps, if they do not respawn
# Could be great for service apps if they do not respawn
# - silent_fail exit script without prompt or installation
# - prompt_user show a user dialog for each blocking process found
# abort after three attempts to quit
# (only if user accepts to quit the apps, otherwise
# the update is cancelled).
# - prompt_user show a user dialog for each blocking process found,
# user can choose "Quit and Update" or "Not Now".
# When "Quit and Update" is chosen, blocking process
# will be told to quit. Installomator will wait 30 seconds
# before checking again in case Save dialogs etc are being responded to.
# Installomator will abort if quitting after three tries does not succeed.
# "Not Now" will exit Installomator.
# - prompt_user_then_kill
# show a user dialog for each blocking process found,
# attempt to quit two times, kill the process finally
# user can choose "Quit and Update" or "Not Now".
# When "Quit and Update" is chosen, blocking process
# will be terminated. Installomator will abort if terminating
# after two tries does not succeed. "Not Now" will exit Installomator.
# - prompt_user_loop
# Like prompt-user, but clicking "Not Now", will just wait an hour,
# and then it will ask again.
# WARNING! It might block the MDM agent on the machine, as
# the scripts gets stuct in waiting until the hour has passed,
# the script will not exit, it will pause until the hour has passed,
# possibly blocking for other management actions in this time.
# - tell_user User will be showed a notification about the important update,
# but user is only allowed to quit and continue, and then we
# ask the app to quit.
# but user is only allowed to Quit and Continue, and then we
# ask the app to quit. This is default.
# - tell_user_then_kill
# Show dialog 2 times, and if the quitting fails, the
# blocking processes will be killed.
# User will be showed a notification about the important update,
# but user is only allowed to Quit and Continue. If the quitting fails,
# the blocking processes will be terminated.
# - kill kill process without prompting or giving the user a chance to save
@@ -71,6 +80,7 @@ LOGO=appstore
# - mosyleb Mosyle Business
# - mosylem Mosyle Manager (Education)
# - addigy Addigy
# - microsoft Microsoft Endpoint Manager (Intune)
# path can also be set in the command call, and if file exists, it will be used.
# Like 'LOGO="/System/Applications/App\ Store.app/Contents/Resources/AppIcon.icns"'
# (spaces have to be escaped).
@@ -79,18 +89,25 @@ LOGO=appstore
# App Store apps handling
IGNORE_APP_STORE_APPS=no
# options:
# - no If installed app is from App Store (which include VPP installed apps)
# it will not be touched, no matter it's version (default)
# - yes Replace App Store (and VPP) version of app and handle future
# - no If the installed app is from App Store (which include VPP installed apps)
# it will not be touched, no matter its version (default)
# - yes Replace App Store (and VPP) version of the app and handle future
# updates using Installomator, even if latest version.
# Shouldnt give any problems for the user in most cases.
# Known bad example: Slack will loose all settings.
# Known bad example: Slack will lose all settings.
# Owner of copied apps
SYSTEMOWNER=0
# options:
# - 0 Current user will be owner of copied apps, just like if they
# installed it themselves (default).
# - 1 root:wheel will be set on the copied app.
# Useful for shared machines.
# install behavior
INSTALL=""
# options:
# - When not set, software will only be installed
# - When not set, the software will only be installed
# if it is newer/different in version
# - force Install even if its the same version
@@ -98,9 +115,29 @@ INSTALL=""
# Re-opening of closed app
REOPEN="yes"
# options:
# - yes App wil be reopened if it was closed
# - yes App will be reopened if it was closed
# - no App not reopened
# Only let Installomator return the name of the label
# RETURN_LABEL_NAME=0
# options:
# - 1 Installomator will return the name of the label and exit, so last line of
# output will be that name. When Installomator is locally installed and we
# use DEPNotify, then DEPNotify can present a more nice name to the user,
# instead of just the label name.
# Interrupt Do Not Disturb (DND) full screen apps
INTERRUPT_DND="yes"
# options:
# - yes Script will run without checking for DND full screen apps.
# - no Script will exit when an active DND full screen app is detected.
# Comma separated list of app names to ignore when evaluating DND
IGNORE_DND_APPS=""
# example that will ignore browsers when evaluating DND:
# IGNORE_DND_APPS="firefox,Google Chrome,Safari,Microsoft Edge,Opera,Amphetamine,caffeinate"
# NOTE: How labels work
@@ -124,7 +161,7 @@ REOPEN="yes"
#
# - packageID: (optional)
# The package ID of a pkg
# If given, will be used to find version of installed software, instead of searching for an app.
# If given, will be used to find the version of installed software, instead of searching for an app.
# Usefull if a pkg does not install an app.
# See label installomator_st
#
@@ -132,9 +169,15 @@ REOPEN="yes"
# URL to download the dmg.
# Can be generated with a series of commands (see BBEdit for an example).
#
# - curlOptions: (array, optional)
# Options to the curl command, needed for curl to be able to download the software.
# Usually used for adding extra headers that some servers need in order to serve the file.
# curlOptions=( -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" )
# (See “mocha”-labels, for examples on labels, and buildLabel.sh for header-examples.)
#
# - appNewVersion: (optional)
# Version of the downloaded software.
# If given, it will be compared to installed version, to see if download is different.
# If given, it will be compared to the installed version, to see if the download is different.
# It does not check for newer or not, only different.
#
# - versionKey: (optional)
@@ -188,14 +231,14 @@ REOPEN="yes"
# blockingProcesses=( NONE )
#
# - pkgName: (optional, only used for pkgInDmg, dmgInZip, and appInDmgInZip)
# File name of the pkg/dmg file _inside_ the dmg or zip
# File name or path to the pkg/dmg file _inside_ the dmg or zip.
# When not given the pkgName is derived from the $name
#
# - updateTool:
# - updateToolArguments:
# When Installomator detects an existing installation of the application,
# and the updateTool variable is set
# $updateTool $updateArguments
# $updateTool $updateArguments
# Will be run instead of of downloading and installing a complete new version.
# Use this when the updateTool does differential and optimized downloads.
# e.g. msupdate on various Microsoft labels
@@ -205,12 +248,12 @@ REOPEN="yes"
#
# - CLIInstaller:
# - CLIArguments:
# If the downloaded dmg is actually an installer that we can call using CLI, we can
# If the downloaded dmg is an installer that we can call using CLI, we can
# use these two variables for what to call.
# We need to define `name` for the installed app (to be version checked), as well as
# `installerTool` for the installer app (if named differently that `name`. Installomator
# `installerTool` for the installer app (if named differently than `name`. Installomator
# will add the path to the folder/disk image with the binary, and it will be called like this:
`$CLIInstaller $CLIArguments`
# $CLIInstaller $CLIArguments
# For most installations `CLIInstaller` should contain the `installerTool` for the CLI call
# (if its the same).
# We can support a whole range of other software titles by implementing this.
@@ -222,3 +265,40 @@ REOPEN="yes"
# installer that should be located after mounting/expanding the downloaded archive.
# See label adobecreativeclouddesktop
#
### Logging
# Logging behavior
LOGGING="INFO"
# options:
# - DEBUG Everything is logged
# - INFO (default) normal logging level
# - WARN only warning
# - ERROR only errors
# - REQ ????
# MDM profile name
MDMProfileName=""
# options:
# - MDM Profile Addigy has this name on the profile
# - Mosyle Corporation MDM Mosyle uses this name on the profile
# From the LOGO variable we can know if Addigy og Mosyle is used, so if that variable
# is either of these, and this variable is empty, then we will auto detect this.
# Datadog logging used
datadogAPI=""
# Simply add your own API key for this in order to have logs sent to Datadog
# See more here: https://www.datadoghq.com/product/log-management/
# Log Date format used when parsing logs for debugging, this is the default used by
# install.log, override this in the case statements if you need something custom per
# application (See adobeillustrator). Using stadard GNU Date formatting.
LogDateFormat="%Y-%m-%d %H:%M:%S"
# Get the start time for parsing install.log if we fail.
starttime=$(date "+$LogDateFormat")
# Check if we have rosetta installed
if [[ $(/usr/bin/arch) == "arm64" ]]; then
if ! arch -x86_64 /usr/bin/true >/dev/null 2>&1; then # pgrep oahd >/dev/null 2>&1
rosetta2=no
fi
fi

View File

@@ -0,0 +1,15 @@
1password8)
name="1Password 8"
appName="1Password.app"
type="zip"
if [[ $(arch) == "arm64" ]]; then
archiveName="1Password-latest-aarch64.zip"
downloadURL="https://downloads.1password.com/mac/1Password-latest-aarch64.zip"
elif [[ $(arch) == "i386" ]]; then
archiveName="1Password-latest-x86_64.zip"
downloadURL="https://downloads.1password.com/mac/1Password-latest-x86_64.zip"
fi
expectedTeamID="2BUA8C4S2C"
blockingProcesses=( "1Password Extension Helper" "1Password 7" "1Password" "1Password (Safari)" "1PasswordNativeMessageHost" "1PasswordSafariAppExtension" )
#forcefulQuit=YES
;;

View File

@@ -0,0 +1,9 @@
1passwordcli)
name="1Password CLI"
type="pkg"
#packageID="com.1password.op"
downloadURL=$(curl -fs https://app-updates.agilebits.com/product_history/CLI | grep -m 1 -i op_apple_universal | cut -d'"' -f 2)
appNewVersion=$(echo $downloadURL | sed -E 's/.*\/[a-zA-Z_]*([0-9.]*)\..*/\1/g')
appCustomVersion(){ /usr/local/bin/op -v }
expectedTeamID="2BUA8C4S2C"
;;

View File

@@ -1,7 +1,7 @@
adobereaderdc-update)
name="Adobe Acrobat Reader DC"
type="pkgInDmg"
downloadURL=$(adobecurrent=`curl --fail --silent https://armmf.adobe.com/arm-manifests/mac/AcrobatDC/reader/current_version.txt | tr -d '.'` && echo http://ardownload.adobe.com/pub/adobe/reader/mac/AcrobatDC/"$adobecurrent"/AcroRdrDCUpd"$adobecurrent"_MUI.dmg)
downloadURL=$(adobecurrent=`curl --fail --silent https://armmf.adobe.com/arm-manifests/mac/AcrobatDC/reader/current_version.txt | tr -d '.'` && echo https://ardownload2.adobe.com/pub/adobe/reader/mac/AcrobatDC/"$adobecurrent"/AcroRdrDC_"$adobecurrent"_MUI.dmg)
appNewVersion=$(curl -s https://armmf.adobe.com/arm-manifests/mac/AcrobatDC/reader/current_version.txt)
#appNewVersion=$(curl -s -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15)" https://get.adobe.com/reader/ | grep ">Version" | sed -E 's/.*Version 20([0-9.]*)<.*/\1/g') # credit: Søren Theilgaard (@theilgaard)
expectedTeamID="JQ525L2MZD"

View File

@@ -3,7 +3,8 @@ adobereaderdc-install)
name="Adobe Acrobat Reader DC"
type="pkgInDmg"
packageID="com.adobe.acrobat.DC.reader.app.pkg.MUI"
downloadURL=$(curl --silent --fail -H "Sec-Fetch-Site: same-origin" -H "Accept-Encoding: gzip, deflate, br" -H "Accept-Language: en-US;q=0.9,en;q=0.8" -H "DNT: 1" -H "Sec-Fetch-Mode: cors" -H "X-Requested-With: XMLHttpRequest" -H "Referer: https://get.adobe.com/reader/enterprise/" -H "Accept: */*" "https://get.adobe.com/reader/webservices/json/standalone/?platform_type=Macintosh&platform_dist=OSX&platform_arch=x86-32&language=English&eventname=readerotherversions" | grep -Eo '"download_url":.*?[^\]",' | head -n 1 | cut -d \" -f 4)
#downloadURL=$(curl --silent --fail -H "Sec-Fetch-Site: same-origin" -H "Accept-Encoding: gzip, deflate, br" -H "Accept-Language: en-US;q=0.9,en;q=0.8" -H "DNT: 1" -H "Sec-Fetch-Mode: cors" -H "X-Requested-With: XMLHttpRequest" -H "Referer: https://get.adobe.com/reader/enterprise/" -H "Accept: */*" "https://get.adobe.com/reader/webservices/json/standalone/?platform_type=Macintosh&platform_dist=OSX&platform_arch=x86-32&language=English&eventname=readerotherversions" | grep -Eo '"download_url":.*?[^\]",' | head -n 1 | cut -d \" -f 4)
downloadURL=$(adobecurrent=`curl --fail --silent https://armmf.adobe.com/arm-manifests/mac/AcrobatDC/reader/current_version.txt | tr -d '.'` && echo https://ardownload2.adobe.com/pub/adobe/reader/mac/AcrobatDC/"$adobecurrent"/AcroRdrDC_"$adobecurrent"_MUI.dmg)
appNewVersion=$(curl -s https://armmf.adobe.com/arm-manifests/mac/AcrobatDC/reader/current_version.txt)
#appNewVersion=$(curl -s -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15)" https://get.adobe.com/reader/ | grep ">Version" | sed -E 's/.*Version 20([0-9.]*)<.*/\1/g') # credit: Søren Theilgaard (@theilgaard)
expectedTeamID="JQ525L2MZD"

View File

@@ -0,0 +1,12 @@
amazoncorretto8jdk)
name="Amazon Corretto 8 JDK"
type="pkg"
if [[ $(arch) == "arm64" ]]; then
downloadURL="https://corretto.aws/downloads/latest/amazon-corretto-8-aarch64-macos-jdk.pkg"
appNewVersion=$(curl -s https://raw.githubusercontent.com/corretto/corretto-8/develop/CHANGELOG.md | grep "## Corretto version" | head -n 1 | awk '{ print $4; exit}')
elif [[ $(arch) == "i386" ]]; then
downloadURL="https://corretto.aws/downloads/latest/amazon-corretto-8-x64-macos-jdk.pkg"
appNewVersion=$(curl -s https://raw.githubusercontent.com/corretto/corretto-8/develop/CHANGELOG.md | grep "## Corretto version" | head -n 1 | awk '{ print $4; exit}')
fi
expectedTeamID="94KV3E626L"
;;

View File

@@ -1,5 +1,4 @@
androidfiletransfer)
#credit: Sam Ess (saess-sep)
name="Android File Transfer"
type="dmg"
downloadURL="https://dl.google.com/dl/androidjumper/mtp/current/AndroidFileTransfer.dmg"

View File

@@ -0,0 +1,13 @@
androidstudio)
name="Android Studio"
type="dmg"
if [[ $(arch) == arm64 ]]; then
downloadURL=$(curl -fsL "https://developer.android.com/studio#downloads" | grep -i arm.dmg | head -2 | grep -o -i -E "https.*" | cut -d '"' -f1)
appNewVersion=$( echo "${downloadURL}" | head -1 | sed 's/^.*[^0-9]\([0-9]*\.[0-9]*\.[0-9]*\.[0-9]*\).*$/\1/' )
elif [[ $(arch) == i386 ]]; then
downloadURL=$(curl -fsL "https://developer.android.com/studio#downloads" | grep -i mac.dmg | head -2 | grep -o -i -E "https.*" | cut -d '"' -f1)
appNewVersion=$( echo "${downloadURL}" | head -1 | sed 's/^.*[^0-9]\([0-9]*\.[0-9]*\.[0-9]*\.[0-9]*\).*$/\1/' )
fi
expectedTeamID="EQHXZ8M8AV"
blockingProcesses=( androidstudio )
;;

View File

@@ -1,7 +1,7 @@
appcleaner)
# credit: Tadayuki Onishi (@kenchan0130)
name="AppCleaner"
type="zip"
downloadURL=$(curl -fs https://freemacsoft.net/appcleaner/Updates.xml | xpath '//rss/channel/*/enclosure/@url' 2>/dev/null | tr " " "\n" | sort | tail -1 | cut -d '"' -f 2)
downloadURL=$(curl -fs https://freemacsoft.net/appcleaner/Updates.xml | xpath '//rss/channel/item[last()]/enclosure/@url' 2>/dev/null | tr " " "\n" | sort | tail -1 | cut -d '"' -f 2)
appNewVersion=$(curl -fsL "https://freemacsoft.net/appcleaner/Updates.xml" | xpath '//rss/channel/item[last()]/enclosure/@sparkle:shortVersionString' 2>/dev/null | cut -d '"' -f 2)
expectedTeamID="X85ZX835W9"
;;

View File

@@ -3,5 +3,5 @@ applenyfonts)
type="pkgInDmg"
downloadURL="https://devimages-cdn.apple.com/design/resources/download/NY.dmg"
packageID="com.apple.pkg.NYFonts"
expectedTeamID="Development Update"
expectedTeamID="Software Update"
;;

View File

@@ -0,0 +1,7 @@
applesfarabic)
name="San Francisco Arabic"
type="pkgInDmg"
downloadURL="https://devimages-cdn.apple.com/design/resources/download/SF-Arabic.dmg"
packageID="com.apple.pkg.SFArabicFonts"
expectedTeamID="Software Update"
;;

View File

@@ -3,5 +3,5 @@ applesfcompact)
type="pkgInDmg"
downloadURL="https://devimages-cdn.apple.com/design/resources/download/SF-Compact.dmg"
packageID="com.apple.pkg.SanFranciscoCompact"
expectedTeamID="Development Update"
expectedTeamID="Software Update"
;;

View File

@@ -3,5 +3,5 @@ applesfpro)
type="pkgInDmg"
downloadURL="https://devimages-cdn.apple.com/design/resources/download/SF-Pro.dmg"
packageID="com.apple.pkg.SanFranciscoPro"
expectedTeamID="Development Update"
expectedTeamID="Software Update"
;;

View File

@@ -2,7 +2,7 @@ applesfsymbols|\
sfsymbols)
name="SF Symbols"
type="pkgInDmg"
downloadURL=$( curl -fs "https://developer.apple.com/sf-symbols/" | grep -oe "https.*\.dmg" | head -1 )
appNewVersion=$( echo "$downloadURL" | head -1 | sed -E 's/.*SF-Symbols-([0-9.]*)\..*/\1/g')
downloadURL=$( curl -fs "https://developer.apple.com/sf-symbols/" | grep -oe "https.*Symbols.*\.dmg" | head -1 )
appNewVersion=$( echo "$downloadURL" | sed -E 's/.*SF-Symbols-([0-9.]*)\..*/\1/g')
expectedTeamID="Software Update"
;;

View File

@@ -0,0 +1,7 @@
atextlegacy)
# credit: Gabe Marchan (gabemarchan.com - @darklink87)
name="aText"
type="dmg"
downloadURL="https://trankynam.com/atext/downloads/aTextLegacy.dmg"
expectedTeamID="KHEMQ2FD9E"
;;

View File

@@ -1,7 +1,7 @@
authydesktop)
name="Authy Desktop"
type="dmg"
downloadURL="https://electron.authy.com/download?channel=stable&arch=x64&platform=darwin&version=latest&product=authy"
downloadURL=$(curl -s -w '%{redirect_url}' -o /dev/null "https://electron.authy.com/download?channel=stable&arch=x64&platform=darwin&version=latest&product=authy" | sed 's/\ /%20/g')
appNewVersion="$(curl -sfL --output /dev/null -r 0-0 "${downloadURL}" --remote-header-name --remote-name -w "%{url_effective}\n" | grep -o -E '([a-zA-Z0-9\_.%-]*)\.(dmg|pkg|zip|tbz)$' | sed -E 's/.*-([0-9.]*)\.dmg/\1/g')"
expectedTeamID="9EVH78F4V4"
;;

View File

@@ -0,0 +1,10 @@
autodeskfusion360admininstall)
name="Autodesk Fusion 360 Admin Install"
type="pkg"
packageID="com.autodesk.edu.fusion360"
downloadURL="https://dl.appstreaming.autodesk.com/production/installers/Autodesk%20Fusion%20360%20Admin%20Install.pkg"
appNewVersion=$(curl -fs "https://dl.appstreaming.autodesk.com/production/97e6dd95735340d6ad6e222a520454db/73e72ada57b7480280f7a6f4a289729f/full.json" | sed -E 's/.*build-version":"([[:digit:]]+\.[[:digit:]]+\.[[:digit:]]+).*/\1/g')
expectedTeamID="XXKJ396S2Y"
appName="Autodesk Fusion 360.app"
blockingProcesses=( "Autodesk Fusion 360" "Fusion 360" )
;;

View File

@@ -1,8 +1,6 @@
autopkgr)
# credit: Søren Theilgaard (@theilgaard)
name="AutoPkgr"
type="dmg"
#downloadURL=$(curl -fs "https://api.github.com/repos/lindegroup/autopkgr/releases/latest" | awk -F '"' "/browser_download_url/ && /dmg/ && ! /sig/ && ! /CLI/ && ! /sha256/ { print \$4 }")
downloadURL=$(downloadURLFromGit lindegroup autopkgr)
appNewVersion=$(versionFromGit lindegroup autopkgr)
expectedTeamID="JVY2ZR6SEF"

View File

@@ -0,0 +1,14 @@
axurerp10)
name="Axure RP 10"
type="dmg"
if [[ $(arch) == "arm64" ]]; then
downloadURL="https://d3uii9pxdigrx1.cloudfront.net/AxureRP-Setup-arm64.dmg"
elif [[ $(arch) == "i386" ]]; then
downloadURL="https://d3uii9pxdigrx1.cloudfront.net/AxureRP-Setup.dmg"
fi
appNewVersion=$( curl -sL https://www.axure.com/release-history | grep -Eo '[0-9]{1,4}\.[0-9]{1,4}\.[0-9]{1,4}\.[0-9]{1,4}' -m 1 )
expectedTeamID="HUMW6UU796"
versionKey="CFBundleVersion"
appName="Axure RP 10.app"
blockingProcesses=( "Axure RP 10" )
;;

View File

@@ -1,12 +1,6 @@
boxdrive)
# credit: Isaac Ordonez, Mann consulting (@mannconsulting)
name="Box"
type="pkg"
if [[ $(arch) == "arm64" ]]; then
#Note: https://support.box.com/hc/en-us/articles/1500004479962-Box-Drive-support-on-devices-with-M1-chips
downloadURL="https://e3.boxcdn.net/desktop/pre-releases/mac/BoxDrive.2.20.140-M1-beta.pkg"
elif [[ $(arch) == "i386" ]]; then
downloadURL="https://e3.boxcdn.net/box-installers/desktop/releases/mac/Box.pkg"
fi
downloadURL="https://e3.boxcdn.net/box-installers/desktop/releases/mac/Box.pkg"
expectedTeamID="M683GB7CPW"
;;

View File

@@ -1,15 +1,18 @@
brave)
# credit: @securitygeneration
name="Brave Browser"
type="dmg"
if [[ $(arch) != "i386" ]]; then
printlog "Architecture: arm64 (not i386)"
downloadURL=$(curl -fsIL https://laptop-updates.brave.com/latest/osxarm64/release | grep -i "^location" | awk '{print $2}' | tr -d '\r\n')
downloadURL=$(curl -fsIL https://laptop-updates.brave.com/latest/osxarm64/release | grep -i "^location" | sed -E 's/.*(https.*\.dmg).*/\1/g')
appNewVersion="$(curl -fsL "https://updates.bravesoftware.com/sparkle/Brave-Browser/stable-arm64/appcast.xml" | xpath '//rss/channel/item[last()]/enclosure/@sparkle:version' 2>/dev/null | cut -d '"' -f 2)"
#appNewVersion="96.$(curl -fsL "https://updates.bravesoftware.com/sparkle/Brave-Browser/stable-arm64/appcast.xml" | xpath '//rss/channel/item[last()]/enclosure/@sparkle:shortVersionString' 2>/dev/null | cut -d '"' -f 2 | cut -d "." -f1-3)"
else
printlog "Architecture: i386"
downloadURL=$(curl -fsIL https://laptop-updates.brave.com/latest/osx/release | grep -i "^location" | awk '{print $2}' | tr -d '\r\n')
downloadURL=$(curl -fsIL https://laptop-updates.brave.com/latest/osx/release | grep -i "^location" | sed -E 's/.*(https.*\.dmg).*/\1/g')
appNewVersion="$(curl -fsL "https://updates.bravesoftware.com/sparkle/Brave-Browser/stable/appcast.xml" | xpath '//rss/channel/item[last()]/enclosure/@sparkle:version' 2>/dev/null | cut -d '"' -f 2)"
#appNewVersion="96.$(curl -fsL "https://updates.bravesoftware.com/sparkle/Brave-Browser/stable/appcast.xml" | xpath '//rss/channel/item[last()]/enclosure/@sparkle:shortVersionString' 2>/dev/null | cut -d '"' -f 2 | cut -d "." -f1-3)"
fi
# downloadURL=$(curl --location --fail --silent "https://updates.bravesoftware.com/sparkle/Brave-Browser/stable/appcast.xml" | xpath '//rss/channel/item[last()]/enclosure/@url' 2>/dev/null | cut -d '"' -f 2)
appNewVersion=$(curl --location --fail --silent "https://updates.bravesoftware.com/sparkle/Brave-Browser/stable/appcast.xml" | xpath '//rss/channel/item[last()]/enclosure/@sparkle:shortVersionString' 2>/dev/null | cut -d '"' -f 2)
versionKey="CFBundleVersion"
# downloadURL=$(curl -fsL "https://updates.bravesoftware.com/sparkle/Brave-Browser/stable/appcast.xml" | xpath '//rss/channel/item[last()]/enclosure/@url' 2>/dev/null | cut -d '"' -f 2)
expectedTeamID="KL8N8XSYF4"
;;

View File

@@ -0,0 +1,7 @@
calcservice)
name="CalcService"
type="zip"
downloadURL="$(curl -fs -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" "https://www.devontechnologies.com/support/download" | tr '"' "\n" | grep -o "http.*download.*.zip" | grep -i calcservice | head -1)"
appNewVersion="$(echo $downloadURL | sed -E 's/.*\/([0-9.]*)\/.*/\1/g')"
expectedTeamID="679S2QUWR8"
;;

View File

@@ -1,6 +1,8 @@
camtasia)
name="Camtasia 2020"
camtasia|\
camtasia2021)
name="Camtasia 2021"
type="dmg"
downloadURL=https://download.techsmith.com/camtasiamac/releases/Camtasia.dmg
downloadURL=$(curl -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" -fs "https://support.techsmith.com/hc/en-us/articles/360004908652-Desktop-Product-Download-Links" | grep -A 3 "Camtasia (Mac) 2021" | sed 's/.*href="//' | sed 's/".*//' | grep .dmg)
appNewVersion=$(curl -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" -fs "https://support.techsmith.com/hc/en-us/articles/360004908652-Desktop-Product-Download-Links" | grep "Camtasia (Mac) 2021" | sed -e 's/.*Camtasia (Mac) //' -e 's/<\/td>.*//')
expectedTeamID="7TQL462TU8"
;;

View File

@@ -0,0 +1,7 @@
camtasia2019)
name="Camtasia 2019"
type="dmg"
downloadURL=$(curl -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" -fs "https://support.techsmith.com/hc/en-us/articles/360004908652-Desktop-Product-Download-Links" | grep -A 3 "Camtasia (Mac) 2019" | sed 's/.*href="//' | sed 's/".*//' | grep .dmg)
appNewVersion=$(curl -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" -fs "https://support.techsmith.com/hc/en-us/articles/360004908652-Desktop-Product-Download-Links" | grep "Camtasia (Mac) 2019" | sed -e 's/.*Camtasia (Mac) //' -e 's/<\/td>.*//')
expectedTeamID="7TQL462TU8"
;;

View File

@@ -0,0 +1,7 @@
camtasia2020)
name="Camtasia 2020"
type="dmg"
downloadURL=$(curl -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" -fs "https://support.techsmith.com/hc/en-us/articles/360004908652-Desktop-Product-Download-Links" | grep -A 3 "Camtasia (Mac) 2020" | sed 's/.*href="//' | sed 's/".*//' | grep .dmg)
appNewVersion=$(curl -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" -fs "https://support.techsmith.com/hc/en-us/articles/360004908652-Desktop-Product-Download-Links" | grep "Camtasia (Mac) 2020" | sed -e 's/.*Camtasia (Mac) //' -e 's/<\/td>.*//')
expectedTeamID="7TQL462TU8"
;;

View File

@@ -2,10 +2,11 @@ canva)
name="Canva"
type="dmg"
if [[ $(arch) == "arm64" ]]; then
downloadURL=$(curl -fsLI -H "accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9" -H "accept-encoding: gzip, deflate, br" -H "accept-language: en-US,en;q=0.9" -H "Referrer Policy: strict-origin-when-cross-origin" -H "upgrade-insecure-requests: 1" -H "sec-fetch-dest: document" -H "sec-gpc: 1" -H "sec-fetch-user: ?1" -H "sec-fetch-mode: navigate" -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" "https://www.canva.com/download/mac/arm/canva-desktop/" | grep -i "^location" | cut -d " " -f2 | tr -d '\r')
downloadURL=https://desktop-release.canva.com/Canva-latest-arm64.dmg
appNewVersion=$( curl -fsLI -H "accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9" -H "accept-encoding: gzip, deflate, br" -H "accept-language: en-US,en;q=0.9" -H "Referrer Policy: strict-origin-when-cross-origin" -H "upgrade-insecure-requests: 1" -H "sec-fetch-dest: document" -H "sec-gpc: 1" -H "sec-fetch-user: ?1" -H "sec-fetch-mode: navigate" -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" "https://www.canva.com/download/mac/arm/canva-desktop/" | grep -i "^location" | cut -d " " -f2 | tr -d '\r' | sed -E 's/.*\/[a-zA-Z]*-([0-9.]*)-*.*\.dmg/\1/g' )
elif [[ $(arch) == "i386" ]]; then
downloadURL=$(curl -fsLI -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" -H "accept-encoding: gzip, deflate, br" -H "Referrer Policy: strict-origin-when-cross-origin" -H "upgrade-insecure-requests: 1" -H "sec-fetch-dest: document" -H "sec-gpc: 1" -H "sec-fetch-user: ?1" -H "accept-language: en-US,en;q=0.9" -H "accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9" -H "sec-fetch-mode: navigate" "https://www.canva.com/download/mac/intel/canva-desktop/" | grep -i "^location" | cut -d " " -f2 | tr -d '\r')
downloadURL=https://desktop-release.canva.com/Canva-latest.dmg
appNewVersion=$( curl -fsLI -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.1 Safari/605.1.15" -H "accept-encoding: gzip, deflate, br" -H "Referrer Policy: strict-origin-when-cross-origin" -H "upgrade-insecure-requests: 1" -H "sec-fetch-dest: document" -H "sec-gpc: 1" -H "sec-fetch-user: ?1" -H "accept-language: en-US,en;q=0.9" -H "accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9" -H "sec-fetch-mode: navigate" "https://www.canva.com/download/mac/intel/canva-desktop/" | grep -i "^location" | cut -d " " -f2 | tr -d '\r' | sed -E 's/.*\/[a-zA-Z]*-([0-9.]*)-*.*\.dmg/\1/g' )
fi
appNewVersion=$( echo "${downloadURL}" | sed -E 's/.*\/[a-zA-Z]*-([0-9.]*)\..*/\1/g' )
expectedTeamID="5HD2ARTBFS"
;;

View File

@@ -3,6 +3,6 @@ citrixworkspace)
name="Citrix Workspace"
type="pkgInDmg"
downloadURL="https:"$(curl -s -L "https://www.citrix.com/downloads/workspace-app/mac/workspace-app-for-mac-latest.html#ctx-dl-eula-external" | grep "dmg?" | sed "s/.*rel=.\(.*\)..id=.*/\1/") # http://downloads.citrix.com/18823/CitrixWorkspaceApp.dmg?__gda__=1605791892_edc6786a90eb5197fb226861a8e27aa8
appNewVersion=$(curl -fs https://www.citrix.com/downloads/workspace-app/mac/workspace-app-for-mac-latest.html | grep "<p>Version" | head -1 | cut -d " " -f1 | cut -d ";" -f2 | cut -d "." -f 1-3)
appNewVersion=$(curl -fs https://www.citrix.com/downloads/workspace-app/mac/workspace-app-for-mac-latest.html | grep "<p>Version" | head -1 | awk '{print $2}' | cut -d "." -f 1-3)
expectedTeamID="S272Y5R93J"
;;

View File

@@ -0,0 +1,7 @@
clipy)
name="Clipy"
type="dmg"
downloadURL=$(downloadURLFromGit Clipy Clipy)
appNewVersion=$(versionFromGit Clipy Clipy)
expectedTeamID="BBCHAJ584H"
;;

9
fragments/labels/clue.sh Normal file
View File

@@ -0,0 +1,9 @@
clue)
#For personal use and students
name="Clue"
type="dmg"
downloadURL=$(curl -fsL https://clue.no/en/download | grep "For personal use and students:" | sed 's/.*href="//' | sed 's/".*//')
appNewVersion="$(echo "${downloadURL}" | sed -E 's/.*Clue*([0-9.]*)\..*/\1/g')"
versionKey="CFBundleVersion"
expectedTeamID="3NX6B9TB2F"
;;

View File

@@ -0,0 +1,9 @@
cluefull)
#For companies and schools
name="Clue"
type="dmg"
downloadURL=$(curl -fsL https://clue.no/en/download | grep "For companies and schools:" | sed 's/.*href="//' | sed 's/".*//')
appNewVersion="$(echo "${downloadURL}" | sed -E 's/.*Clue*([0-9.]*)\F.*/\1/g')"
versionKey="CFBundleVersion"
expectedTeamID="3NX6B9TB2F"
;;

View File

@@ -1,8 +1,11 @@
code42)
# credit: Isaac Ordonez, Mann consulting (@mannconsulting)
name="Code42"
type="pkgInDmg"
downloadURL=https://download.code42.com/installs/agent/latest-mac.dmg
if [[ $(arch) == i386 ]]; then
downloadURL="https://download.code42.com/installs/agent/latest-mac.dmg"
elif [[ $(arch) == arm64 ]]; then
downloadURL="https://download.code42.com/installs/agent/latest-mac-arm64.dmg"
fi
expectedTeamID="9YV9435DHD"
blockingProcesses=( NONE )
;;

View File

@@ -0,0 +1,7 @@
craftmanagerforsketch)
name="CraftManager"
type="zip"
downloadURL="https://craft-assets.invisionapp.com/CraftManager/production/CraftManager.zip"
appNewVersion=$(curl -fs https://craft-assets.invisionapp.com/CraftManager/production/appcast.xml | xpath '//rss/channel/item[1]/enclosure/@sparkle:shortVersionString' 2>/dev/null | cut -d '"' -f2)
expectedTeamID="VRXQSNCL5W"
;;

View File

@@ -0,0 +1,7 @@
daisydisk)
name="DaisyDisk"
type="zip"
downloadURL="https://daisydiskapp.com/downloads/DaisyDisk.zip"
appNewVersion=$( curl -fs 'https://daisydiskapp.com/downloads/appcastReleaseNotes.php?appEdition=Standard' | grep Version | head -1 | sed -E 's/.*Version ([0-9.]*).*/\1/g' )
expectedTeamID="4CBU3JHV97"
;;

View File

@@ -1,7 +1,7 @@
dangerzone)
# credit: Micah Lee (@micahflee)
name="Dangerzone"
type="dmg"
downloadURL=$(curl -s https://dangerzone.rocks/ | grep https://github.com/firstlookmedia/dangerzone/releases/download | grep \.dmg | cut -d'"' -f2)
expectedTeamID="P24U45L8P5"
downloadURL="$(downloadURLFromGit firstlookmedia dangerzone)"
appNewVersion="$(versionFromGit firstlookmedia dangerzone)"
expectedTeamID="N9B95FDWH4"
;;

View File

@@ -1,7 +1,13 @@
dbeaverce)
name="DBeaver"
type="dmg"
downloadURL="https://dbeaver.io/files/dbeaver-ce-latest-macos.dmg"
if [[ $(arch) == "arm64" ]]; then
downloadURL="https://dbeaver.io/files/dbeaver-ce-latest-macos-aarch64.dmg"
appNewVersion="$(curl -fsIL "${downloadURL}" | grep -i ^location | sed 's/^.*[^0-9]\([0-9]*\.[0-9]*\.[0-9]*\).*$/\1/' | head -1)"
elif [[ $(arch) == "i386" ]]; then
downloadURL="https://dbeaver.io/files/dbeaver-ce-latest-macos.dmg"
appNewVersion="$(curl -fsIL "${downloadURL}" | grep -i ^location | sed 's/^.*[^0-9]\([0-9]*\.[0-9]*\.[0-9]*\).*$/\1/' | head -1)"
fi
expectedTeamID="42B6MDKMW8"
blockingProcesses=( dbeaver )
;;

View File

@@ -1,7 +1,8 @@
depnotify)
name="DEPNotify"
type="zip"
downloadURL="https://files.nomad.menu/DEPNotify.zip"
type="pkg"
#packageID="menu.nomad.depnotify"
downloadURL="https://files.nomad.menu/DEPNotify.pkg"
#appNewVersion=$()
expectedTeamID="VRPY9KHGX6"
targetDir="/Applications/Utilities"
;;

View File

@@ -1,8 +1,9 @@
dialog)
dialog|\
swiftdialog)
name="Dialog"
type="pkg"
packageID="au.csiro.dialogcli"
downloadURL="$(downloadURLFromGit bartreardon Dialog)"
appNewVersion="$(versionFromGit bartreardon Dialog)"
downloadURL="$(downloadURLFromGit bartreardon swiftDialog)"
appNewVersion="$(versionFromGit bartreardon swiftDialog)"
expectedTeamID="PWA5E9TQ59"
;;

View File

@@ -0,0 +1,8 @@
diskspace)
name="diskspace"
type="pkg"
packageID="com.scriptingosx.diskspace"
downloadURL="$(downloadURLFromGit scriptingosx diskspace)"
appNewVersion="$(versionFromGit scriptingosx diskspace)"
expectedTeamID="JME5BW3F3R"
;;

View File

@@ -0,0 +1,8 @@
displaylinkmanager)
name="DisplayLink Manager"
type="pkg"
#packageID="com.displaylink.displaylinkmanagerapp"
downloadURL=https://www.synaptics.com$(redirect=$(curl -sfL https://www.synaptics.com/products/displaylink-graphics/downloads/macos | grep 'class="download-link">Download' | head -n 1 | sed 's/.*href="//' | sed 's/".*//') && curl -sfL "https://www.synaptics.com$redirect" | grep Accept | head -n 1 | sed 's/.*href="//' | sed 's/".*//')
appNewVersion=$(curl -sfL https://www.synaptics.com/products/displaylink-graphics/downloads/macos | grep "Release:" | head -n 1 | cut -d ' ' -f2)
expectedTeamID="73YQY62QM3"
;;

View File

@@ -1,13 +1,12 @@
docker)
# credit: @securitygeneration
name="Docker"
type="dmg"
#downloadURL="https://download.docker.com/mac/stable/Docker.dmg"
if [[ $(arch) == arm64 ]]; then
downloadURL="https://desktop.docker.com/mac/stable/arm64/Docker.dmg"
appNewVersion=$( curl -fs "https://desktop.docker.com/mac/main/arm64/appcast.xml" | xpath '(//rss/channel/item/enclosure/@sparkle:shortVersionString)[last()]' 2>/dev/null | cut -d '"' -f2 )
elif [[ $(arch) == i386 ]]; then
downloadURL="https://desktop.docker.com/mac/stable/amd64/Docker.dmg"
appNewVersion=$( curl -fs "https://desktop.docker.com/mac/main/amd64/appcast.xml" | xpath '(//rss/channel/item/enclosure/@sparkle:shortVersionString)[last()]' 2>/dev/null | cut -d '"' -f2 )
fi
appNewVersion=$(curl -ifs https://docs.docker.com/docker-for-mac/release-notes/ | grep ">Docker Desktop Community" | head -1 | sed -n -e 's/^.*Community //p' | cut -d '<' -f1)
expectedTeamID="9BNSXJN65R"
;;

View File

@@ -0,0 +1,9 @@
dockutil)
name="dockutil"
type="pkg"
packageID="dockutil.cli.tool"
downloadURL=$(downloadURLFromGit "kcrawford" "dockutil")
appNewVersion=$(versionFromGit "kcrawford" "dockutil")
expectedTeamID="Z5J8CJBUWC"
blockingProcesses=( NONE )
;;

View File

@@ -0,0 +1,9 @@
drawio)
name="draw.io"
type="dmg"
archiveName="draw.io-universal-[0-9.]*.dmg"
downloadURL="$(downloadURLFromGit jgraph drawio-desktop)"
appNewVersion="$(versionFromGit jgraph drawio-desktop)"
expectedTeamID="UZEUFB4N53"
blockingProcesses=( draw.io )
;;

View File

@@ -2,5 +2,6 @@ dropbox)
name="Dropbox"
type="dmg"
downloadURL="https://www.dropbox.com/download?plat=mac&full=1"
appNewVersion=$(curl -fsIL "$downloadURL" | grep -i "^location" | sed -E 's/.*%20([0-9.]*)\.dmg/\1/g')
expectedTeamID="G7HH3F8CAK"
;;

View File

@@ -0,0 +1,10 @@
duckduckgo)
name="DuckDuckGo"
type="dmg"
#downloadURL="https://staticcdn.duckduckgo.com/macos-desktop-browser/duckduckgo.dmg"
#downloadURL=$(curl -fs https://staticcdn.duckduckgo.com/macos-desktop-browser/appcast.xml | xpath '(//rss/channel/item/enclosure/@url)[last()]' 2>/dev/null | cut -d '"' -f2)
downloadURL=$(curl -fs https://staticcdn.duckduckgo.com/macos-desktop-browser/appcast.xml | xpath '(//rss/channel/item/enclosure/@url)[1]' 2>/dev/null | cut -d '"' -f2)
#appNewVersion=$(curl -fs https://staticcdn.duckduckgo.com/macos-desktop-browser/appcast.xml | xpath '(//rss/channel/item/enclosure/@sparkle:version)[last()]' 2>/dev/null | cut -d '"' -f2)
appNewVersion=$(curl -fs https://staticcdn.duckduckgo.com/macos-desktop-browser/appcast.xml | xpath '(//rss/channel/item/sparkle:shortVersionString)[1]' 2>/dev/null | cut -d ">" -f2 | cut -d "<" -f1)
expectedTeamID="HKE973VLUW"
;;

View File

@@ -0,0 +1,7 @@
easyfind)
name="EasyFind"
type="zip"
downloadURL="$(curl -fs "https://www.devontechnologies.com/apps/freeware" | grep -o "http.*download.*.zip" | grep -i easyfind)"
appNewVersion="$(echo $downloadURL | sed -E 's/.*\/([0-9.]*)\/.*/\1/g')"
expectedTeamID="679S2QUWR8"
;;

View File

@@ -0,0 +1,9 @@
egnytewebedit)
name="EgnyteWebEdit"
type="pkg"
downloadURL="https://egnyte-cdn.egnyte.com/webedit/mac/en-us/latest/EgnyteWebEdit.pkg"
expectedTeamID="FELUD555VC"
appName="Egnyte WebEdit.app"
blockingProcesses=( NONE )
;;

View File

@@ -1,7 +1,7 @@
eshareosx)
name="e-Share"
type="pkg"
packageID="com.ncryptedcloud.e-Share.pkg"
#packageID="com.ncryptedcloud.e-Share.pkg"
downloadURL=https://www.ncryptedcloud.com/static/downloads/osx/$(curl -fs https://www.ncryptedcloud.com/static/downloads/osx/ | grep -o -i "href.*\".*\"" | cut -d '"' -f2)
versionKey="CFBundleVersion"
appNewVersion=$( echo "${downloadURL}" | sed -E 's/.*\/[a-zA-Z\-]*_([0-9.]*)\.pkg/\1/g' )

View File

@@ -1,7 +1,7 @@
evernote)
name="Evernote"
type="dmg"
downloadURL=$(curl -fs -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15)" "https://evernote.com/download" | grep -i ".dmg" | cut -d '"' -f2)
downloadURL=$(curl -fs -H "User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15)" "https://evernote.com/download" | grep -i ".dmg" | grep -ioe "href.*" | cut -d '"' -f2)
appNewVersion=$( echo "${downloadURL}" | sed -E 's/.*\/[a-zA-Z]*-([0-9.]*)-.*/\1/g' )
expectedTeamID="Q79WDW8YH9"
appName="Evernote.app"

View File

@@ -1,13 +1,12 @@
ferdi)
name="Ferdi"
type="zip"
if [[ $(arch) == i386 ]]; then
downloadURL=$(curl --silent --fail "https://api.github.com/repos/getferdi/ferdi/releases/latest" \
| awk -F '"' "/browser_download_url/ && /mac.zip/ && ! /blockmap/ && ! /arm64-mac/ && ! /AppImage/{ print \$4 }")
elif [[ $(arch) == arm64 ]]; then
downloadURL=$(downloadURLFromGit getferdi ferdi )
archiveName="arm64-mac.zip"
fi
if [[ $(arch) == "arm64" ]]; then
archiveName="arm64-mac.zip"
elif [[ $(arch) == "i386" ]]; then
archiveName="Ferdi-[0-9.]*-mac.zip"
fi
downloadURL="$(downloadURLFromGit getferdi ferdi)"
appNewVersion=$(versionFromGit getferdi ferdi )
expectedTeamID="B6J9X9DWFL"
;;

10
fragments/labels/filezilla.sh Executable file
View File

@@ -0,0 +1,10 @@
filezilla)
name="FileZilla"
type="tbz"
packageID="org.filezilla-project.filezilla"
downloadURL=$(curl -fsL https://filezilla-project.org/download.php\?show_all=1 | grep macosx | head -n 1 | awk -F '"' '{print $2}' )
appNewVersion=$( curl -fsL https://filezilla-project.org/download.php\?show_all=1 | grep macosx | head -n 1 | awk -F '_' '{print $2}' )
expectedTeamID="5VPGKXL75N"
blockingProcesses=( NONE )
;;

View File

@@ -5,4 +5,5 @@ firefox)
appNewVersion=$(curl -fs https://www.mozilla.org/en-US/firefox/releases/ | grep '<html' | grep -o -i -e "data-latest-firefox=\"[0-9.]*\"" | cut -d '"' -f2)
expectedTeamID="43AQ936H96"
blockingProcesses=( firefox )
printlog "WARNING for ERROR: Label firefox and firefox_intl should not be used. Instead use firefoxpkg and firefoxpkg_intl as per recommendations from Firefox. It's not fully certain that the app actually gets updated here. firefoxpkg and firefoxpkg_intl will have built in updates and make sure the client is updated in the future." REQ
;;

View File

@@ -5,4 +5,5 @@ firefox_da)
appNewVersion=$(curl -fs https://www.mozilla.org/en-US/firefox/releases/ | grep '<html' | grep -o -i -e "data-latest-firefox=\"[0-9.]*\"" | cut -d '"' -f2)
expectedTeamID="43AQ936H96"
blockingProcesses=( firefox )
printlog "WARNING for ERROR: Label firefox, firefox_da and firefox_intl should not be used. Instead use firefoxpkg and firefoxpkg_intl as per recommendations from Firefox. It's not fully certain that the app actually gets updated here. firefoxpkg and firefoxpkg_intl will have built in updates and make sure the client is updated in the future." REQ
;;

View File

@@ -1,23 +1,26 @@
firefox_intl)
# This label will try to figure out the selected language of the user,
# This label will try to figure out the selected language of the user,
# and install corrosponding version of Firefox
name="Firefox"
type="dmg"
userLanguage=$(runAsUser defaults read .GlobalPreferences AppleLocale)
printlog "Found language $userLanguage to be used for Firefox."
if ! curl -fs "https://ftp.mozilla.org/pub/firefox/releases/latest/README.txt" | grep -o "=$userLanguage"; then
userLanguage=$(echo $userLanguage | cut -c 1-2)
if ! curl -fs "https://ftp.mozilla.org/pub/firefox/releases/latest/README.txt" | grep "=$userLanguage"; then
userLanguage="en_US"
userLanguage=$(runAsUser defaults read .GlobalPreferences AppleLocale | tr '_' '-')
printlog "Found language $userLanguage to be used for $name."
releaseURL="https://ftp.mozilla.org/pub/firefox/releases/latest/README.txt"
until curl -fs $releaseURL | grep -q "=$userLanguage"; do
if [ ${#userLanguage} -eq 2 ]; then
break
fi
printlog "No locale matching '$userLanguage', trying '${userLanguage:0:2}'"
userLanguage=${userLanguage:0:2}
done
printlog "Using language '$userLanguage' for download."
downloadURL="https://download.mozilla.org/?product=firefox-latest-ssl&os=osx&lang=$userLanguage"
if ! curl -sfL --output /dev/null -r 0-0 $downloadURL; then
printlog "Download not found for '$userLanguage', using default ('en-US')."
downloadURL="https://download.mozilla.org/?product=firefox-latest-ssl&os=osx"
fi
printlog "Using language $userLanguage for download."
downloadURL="https://download.mozilla.org/?product=firefox-latest&amp;os=osx&amp;lang=$userLanguage"
if ! curl -sfL --output /dev/null -r 0-0 "$downloadURL" ; then
printlog "Download not found for that language. Using en-US"
downloadURL="https://download.mozilla.org/?product=firefox-latest&os=osx&lang=en-US"
fi
appNewVersion=$(curl -fs https://www.mozilla.org/en-US/firefox/releases/ | grep '<html' | grep -o -i -e "data-latest-firefox=\"[0-9.]*\"" | cut -d '"' -f2)
appNewVersion=$(curl -fsIL $downloadURL | awk -F releases/ '/Location:/ {split($2,a,"/"); print a[1]}')
expectedTeamID="43AQ936H96"
blockingProcesses=( firefox )
printlog "WARNING for ERROR: Label firefox and firefox_intl should not be used. Instead use firefoxpkg and firefoxpkg_intl as per recommendations from Firefox. It's not fully certain that the app actually gets updated here. firefoxpkg and firefoxpkg_intl will have built in updates and make sure the client is updated in the future." REQ
;;

View File

@@ -1,24 +1,26 @@
firefoxesr_intl)
# This label will try to figure out the selected language of the user,
# This label will try to figure out the selected language of the user,
# and install corrosponding version of Firefox ESR
name="Firefox"
type="dmg"
userLanguage=$(runAsUser defaults read .GlobalPreferences AppleLocale)
printlog "Found language $userLanguage to be used for Firefox."
if ! curl -fs "https://ftp.mozilla.org/pub/firefox/releases/latest-esr/README.txt" | grep -o "=$userLanguage"; then
userLanguage=$(echo $userLanguage | cut -c 1-2)
if ! curl -fs "https://ftp.mozilla.org/pub/firefox/releases/latest-esr/README.txt" | grep "=$userLanguage"; then
userLanguage="en_US"
userLanguage=$(runAsUser defaults read .GlobalPreferences AppleLocale | tr '_' '-')
printlog "Found language $userLanguage to be used for $name."
releaseURL="https://ftp.mozilla.org/pub/firefox/releases/latest-esr/README.txt"
until curl -fs $releaseURL | grep -q "=$userLanguage"; do
if [ ${#userLanguage} -eq 2 ]; then
break
fi
fi
printlog "Using language $userLanguage for download."
printlog "No locale matching '$userLanguage', trying '${userLanguage:0:2}'"
userLanguage=${userLanguage:0:2}
done
printlog "Using language '$userLanguage' for download."
downloadURL="https://download.mozilla.org/?product=firefox-esr-latest-ssl&os=osx&lang=$userLanguage"
# https://download.mozilla.org/?product=firefox-esr-latest-ssl&os=osx&lang=en-US
if ! curl -sfL --output /dev/null -r 0-0 "$downloadURL" ; then
printlog "Download not found for that language. Using en-US"
downloadURL="https://download.mozilla.org/?product=firefox-latest&os=osx&lang=en-US"
if ! curl -sfL --output /dev/null -r 0-0 $downloadURL; then
printlog "Download not found for '$userLanguage', using default ('en-US')."
downloadURL="https://download.mozilla.org/?product=firefox-esr-latest-ssl&os=osx"
fi
appNewVersion=$(curl -fsIL "$downloadURL" | grep -i "^location" | awk '{print $2}' | sed -E 's/.*releases\/([0-9.]*)esr.*/\1/g')
appNewVersion=$(curl -fsIL $downloadURL | awk -F releases/ '/Location:/ {split($2,a,"esr/"); print a[1]}')
expectedTeamID="43AQ936H96"
blockingProcesses=( firefox )
printlog "WARNING for ERROR: Label firefox and firefox_intl should not be used. Instead use firefoxpkg and firefoxpkg_intl as per recommendations from Firefox. It's not fully certain that the app actually gets updated here. firefoxpkg and firefoxpkg_intl will have built in updates and make sure the client is updated in the future." REQ
;;

View File

@@ -2,6 +2,7 @@ firefoxpkg)
name="Firefox"
type="pkg"
downloadURL="https://download.mozilla.org/?product=firefox-pkg-latest-ssl&os=osx&lang=en-US"
appNewVersion=$(curl -fs https://www.mozilla.org/en-US/firefox/releases/ | grep '<html' | grep -o -i -e "data-latest-firefox=\"[0-9.]*\"" | cut -d '"' -f2)
expectedTeamID="43AQ936H96"
blockingProcesses=( firefox )
;;

View File

@@ -0,0 +1,24 @@
firefoxpkg_intl)
# This label will try to figure out the selected language of the user,
# and install corrosponding version of Firefox ESR
name="Firefox"
type="pkg"
userLanguage=$(runAsUser defaults read .GlobalPreferences AppleLocale)
printlog "Found language $userLanguage to be used for Firefox." WARN
if ! curl -fs "https://ftp.mozilla.org/pub/firefox/releases/latest/README.txt" | grep -o "=$userLanguage"; then
userLanguage=$(echo $userLanguage | cut -c 1-2)
if ! curl -fs "https://ftp.mozilla.org/pub/firefox/releases/latest/README.txt" | grep "=$userLanguage"; then
userLanguage="en_US"
fi
fi
printlog "Using language $userLanguage for download." WARN
downloadURL="https://download.mozilla.org/?product=firefox-pkg-latest-ssl&os=osx&lang=$userLanguage"
# https://download.mozilla.org/?product=firefox-pkg-latest-ssl&os=osx&lang=en-US
if ! curl -sfL --output /dev/null -r 0-0 "$downloadURL" ; then
printlog "Download not found for that language. Using en-US" WARN
downloadURL="https://download.mozilla.org/?product=firefox-pkg-latest-ssl&os=osx&lang=en-US"
fi
appNewVersion=$(curl -fsIL "$downloadURL" | grep -i location | cut -d "/" -f7)
expectedTeamID="43AQ936H96"
blockingProcesses=( firefox )
;;

7
fragments/labels/flux.sh Normal file
View File

@@ -0,0 +1,7 @@
flux)
name="Flux"
type="zip"
downloadURL="https://justgetflux.com/mac/Flux.zip"
expectedTeamID="VZKSA7H9J9"
;;

View File

@@ -0,0 +1,8 @@
flycut)
name="Flycut"
type="zip"
archiveName="Flycut.[0-9.]*.zip"
downloadURL="$(downloadURLFromGit TermiT Flycut)"
appNewVersion=$(versionFromGit TermiT Flycut )
expectedTeamID="S8JLSG5ES7"
;;

View File

@@ -0,0 +1,9 @@
fontexplorer)
name="FontExplorer X Pro"
type="dmg"
packageID="com.linotype.FontExplorerX"
downloadURL="http://www.fontexplorerx.com/download/free-trial/Mac/"
appNewVersion=$( curl -fsL http://fex.linotype.com/update/client/mac/pro/version.plist | grep string | tail -n 1 | sed 's/[^0-9.]//g' )
expectedTeamID="2V7G2B7WG4"
;;

View File

@@ -1,7 +1,13 @@
front)
name="Front"
type="dmg"
downloadURL="https://dl.frontapp.com/macos/Front.dmg"
if [[ $(arch) == "arm64" ]]; then
downloadURL="https://dl.frontapp.com/macos/Front-arm64.dmg"
appNewVersion=$(curl -fs "https://dl.frontapp.com/desktop/updates/latest/mac-arm64/latest-mac.yml" | grep -i version | cut -d " " -f2)
elif [[ $(arch) == "i386" ]]; then
downloadURL="https://dl.frontapp.com/macos/Front.dmg"
appNewVersion=$(curl -fs "https://dl.frontapp.com/desktop/updates/latest/mac/latest-mac.yml" | grep -i version | cut -d " " -f2)
fi
expectedTeamID="X549L7572J"
Company="FrontApp. Inc."
;;

View File

@@ -1,10 +1,9 @@
golang)
# credit: Søren Theilgaard (@theilgaard)
name="GoLang"
type="pkg"
packageID="org.golang.go"
downloadURL="$(curl -fsIL "https://golang.org$(curl -fs "https://golang.org/dl/" | grep -i "downloadBox" | grep "pkg" | tr '"' '\n' | grep "pkg")" | grep -i "^location" | awk '{print $2}' | tr -d '\r\n')"
appNewVersion="$( echo "${downloadURL}" | sed -E 's/.*\/(go[0-9.]*)\..*/\1/g' )" # Version includes letters "go"
downloadURL="https://go.dev$(curl -fs "https://go.dev/dl/" | grep -i "downloadBox" | grep "pkg" | tr '"' '\n' | grep "pkg")"
appNewVersion="$( echo "${downloadURL}" | sed -E 's/.*\/(go[0-9.]*)\..*/\1/g' )" # Version includes letters "go" in the beginning
expectedTeamID="EQHXZ8M8AV"
blockingProcesses=( NONE )
;;

View File

@@ -1,14 +1,8 @@
googlechrome)
name="Google Chrome"
type="dmg"
if [[ $(arch) != "i386" ]]; then
printlog "Architecture: arm64 (not i386)"
downloadURL="https://dl.google.com/chrome/mac/universal/stable/GGRO/googlechrome.dmg"
appNewVersion=$(curl -s https://omahaproxy.appspot.com/history | awk -F',' '/mac_arm64,stable/{print $3; exit}')
else
printlog "Architecture: i386"
downloadURL="https://dl.google.com/chrome/mac/stable/GGRO/googlechrome.dmg"
appNewVersion=$(curl -s https://omahaproxy.appspot.com/history | awk -F',' '/mac,stable/{print $3; exit}')
fi
downloadURL="https://dl.google.com/chrome/mac/universal/stable/GGRO/googlechrome.dmg"
appNewVersion=$(curl -s https://omahaproxy.appspot.com/history | awk -F',' '/mac_arm64,stable/{print $3; exit}')
expectedTeamID="EQHXZ8M8AV"
printlog "WARNING for ERROR: Label googlechrome should not be used. Instead use googlechromepkg as per recommendations from Google. It's not fully certain that the app actually gets updated here. googlechromepkg will have built in updates and make sure the client is updated in the future." REQ
;;

View File

@@ -6,6 +6,7 @@ googlechromepkg)
# https://support.google.com/chrome/a/answer/9915669
#
downloadURL="https://dl.google.com/chrome/mac/stable/accept_tos%3Dhttps%253A%252F%252Fwww.google.com%252Fintl%252Fen_ph%252Fchrome%252Fterms%252F%26_and_accept_tos%3Dhttps%253A%252F%252Fpolicies.google.com%252Fterms/googlechrome.pkg"
appNewVersion=$(curl -s https://omahaproxy.appspot.com/history | awk -F',' '/mac_arm64,stable/{print $3; exit}')
expectedTeamID="EQHXZ8M8AV"
updateTool="/Library/Google/GoogleSoftwareUpdate/GoogleSoftwareUpdate.bundle/Contents/Resources/GoogleSoftwareUpdateAgent.app/Contents/MacOS/GoogleSoftwareUpdateAgent"
updateToolArguments=( -runMode oneshot -userInitiated YES )

View File

@@ -4,5 +4,7 @@ gpgsuite)
type="pkgInDmg"
pkgName="Install.pkg"
downloadURL=$(curl -s https://gpgtools.org/ | grep https://releases.gpgtools.org/GPG_Suite- | grep Download | cut -d'"' -f4)
appNewVersion=$(echo $downloadURL | cut -d "-" -f 2 | cut -d "." -f 1-2)
expectedTeamID="PKV8ZPD836"
blockingProcesses=( "GPG Keychain" )
;;

View File

@@ -1,7 +1,8 @@
gpgsync)
# credit: Micah Lee (@micahflee)
name="GPG Sync"
type="pkg"
downloadURL="https://github.com$(curl -s -L https://github.com/firstlookmedia/gpgsync/releases/latest | grep /firstlookmedia/gpgsync/releases/download | grep \.pkg | cut -d'"' -f2)"
packageID="org.firstlook.gpgsync"
downloadURL="$(downloadURLFromGit firstlookmedia gpgsync)"
appNewVersion="$(versionFromGit firstlookmedia gpgsync)"
expectedTeamID="P24U45L8P5"
;;

View File

@@ -0,0 +1,11 @@
grammarly)
name="Grammarly Desktop"
type="dmg"
packageID="com.grammarly.ProjectLlama"
downloadURL=$(curl -fsL "https://download-mac.grammarly.com/appcast.xml" | xpath '//rss/channel/item[1]/enclosure/@url' 2>/dev/null | cut -d '"' -f 2)
expectedTeamID="W8F64X92K3"
appNewVersion=$(curl -is "https://download-mac.grammarly.com/appcast.xml" | grep sparkle:version | tr ',' '\n' | grep sparkle:version | cut -d '"' -f 4)
# appName="Grammarly Installer.app"
installerTool="Grammarly Installer.app"
CLIInstaller="Grammarly Installer.app/Contents/MacOS/Grammarly Desktop"
;;

View File

@@ -0,0 +1,7 @@
houdahspot)
name="HoudahSpot"
type="zip"
downloadURL="$(curl -fs https://www.houdah.com/houdahSpot/updates/cast6.php | xpath '(//rss/channel/item/enclosure/@url)[1]' 2>/dev/null | head -1 | cut -d '"' -f 2)"
appNewVersion="$(curl -fs https://www.houdah.com/houdahSpot/updates/cast6.php | xpath '(//rss/channel/item/enclosure/@sparkle:shortVersionString)[1]' 2>/dev/null | head -1 | cut -d '"' -f 2)"
expectedTeamID="DKGQD8H8ZY"
;;

9
fragments/labels/hype.sh Executable file
View File

@@ -0,0 +1,9 @@
hype)
name="Hype4"
type="dmg"
packageID="com.tumult.Hype4"
downloadURL="https://static.tumult.com/hype/download/Hype.dmg"
appNewVersion=$( curl -fsL https://tumult.com/hype/download/all/ | grep Ongoing | awk -F '<' '{print $4}' | sed 's/[^0-9.]//g' )
expectedTeamID="8J356DM772"
blockingProcesses=( NONE )
;;

View File

@@ -0,0 +1,7 @@
ibarcoder)
name="iBarcoder"
type="dmg"
downloadURL="https://cristallight.com/Downloads/mac/ibarcoder.dmg"
appNewVersion="$(curl -fs "https://cristallight.com/iBarcoder/" | grep -i version: | head -1 | awk '{print $2}')"
expectedTeamID="JAXVB9AH9M"
;;

View File

@@ -0,0 +1,9 @@
idrive)
name="IDrive"
type="pkgInDmg"
pkgName="IDrive.pkg"
downloadURL=$(curl -fs https://static.idriveonlinebackup.com/downloads/version_mac.js | sed -E 's/.*(https.*dmg).*/\1/g')
appNewVersion=$(curl -fs https://static.idriveonlinebackup.com/downloads/version_mac.js | sed -E 's/.*mac_vernum\=\"Version\ ([0-9.]*).*/\1/g')
versionKey="CFBundleVersion"
expectedTeamID="JWDCNYZ922"
;;

View File

@@ -0,0 +1,9 @@
idrivethin)
name="IDrive"
type="pkgInDmg"
pkgName="IDriveThin.pkg"
downloadURL=$(curl -fs https://static.idriveonlinebackup.com/downloads/idrivethin/thin_version.js | sed -E 's/.*thinclient-mac([^;]*).*/\1/g' | sed -E 's/.*(https.*dmg).*/\1/g')
appNewVersion=$(curl -fs https://static.idriveonlinebackup.com/downloads/idrivethin/thin_version.js | sed -E 's/.*thin\_mac\_ver\=\"Version\ ([0-9.]*).*/\1/g')
versionKey="CFBundleVersion"
expectedTeamID="JWDCNYZ922"
;;

7
fragments/labels/iina.sh Normal file
View File

@@ -0,0 +1,7 @@
iina)
name="IINA"
type="dmg"
downloadURL=$(downloadURLFromGit iina iina )
appNewVersion=$(versionFromGit iina iina )
expectedTeamID="67CQ77V27R"
;;

9
fragments/labels/imageoptim.sh Executable file
View File

@@ -0,0 +1,9 @@
imageoptim)
name="imageoptim"
type="tbz"
packageID="net.pornel.ImageOptim"
downloadURL="https://imageoptim.com/ImageOptim.tbz2"
appNewVersion=$( curl -fsL https://imageoptim.com/appcast.xml | grep "title" | tail -n 1 | sed 's/[^0-9.]//g' )
expectedTeamID="59KZTZA4XR"
blockingProcesses=( NONE )
;;

View File

@@ -0,0 +1,7 @@
itsycal)
name="Itsycal"
type="zip"
downloadURL=$(curl -fs https://s3.amazonaws.com/itsycal/itsycal-apple-silicon.xml | xpath '(//rss/channel/item/enclosure/@url)[1]' 2>/dev/null | head -1 | cut -d '"' -f 2)
appNewVersion=$(curl -fs https://s3.amazonaws.com/itsycal/itsycal-apple-silicon.xml | xpath '(//rss/channel/item/enclosure/@sparkle:shortVersionString)[1]' 2>/dev/null | head -1 | cut -d '"' -f 2)
expectedTeamID="HFT3T55WND"
;;

View File

@@ -1,8 +1,12 @@
libreoffice)
# credit: Micah Lee (@micahflee)
name="LibreOffice"
type="dmg"
downloadURL="https://download.documentfoundation.org/libreoffice/stable/$(curl -s https://www.libreoffice.org/download/download/ | grep dl_version_number | head -n 1 | cut -d'>' -f3 | cut -d'<' -f1)/mac/x86_64/LibreOffice_$(curl -s https://www.libreoffice.org/download/download/ | grep dl_version_number | head -n 1 | cut -d'>' -f3 | cut -d'<' -f1)_MacOS_x86-64.dmg"
if [[ $(arch) == "arm64" ]]; then
downloadURL="https://download.documentfoundation.org/libreoffice/stable/$(curl -s https://www.libreoffice.org/download/download/ | grep dl_version_number | head -n 1 | cut -d'>' -f3 | cut -d'<' -f1)/mac/aarch64/LibreOffice_$(curl -s https://www.libreoffice.org/download/download/ | grep dl_version_number | head -n 1 | cut -d'>' -f3 | cut -d'<' -f1)_MacOS_aarch64.dmg"
elif [[ $(arch) == "i386" ]]; then
downloadURL="https://download.documentfoundation.org/libreoffice/stable/$(curl -s https://www.libreoffice.org/download/download/ | grep dl_version_number | head -n 1 | cut -d'>' -f3 | cut -d'<' -f1)/mac/x86_64/LibreOffice_$(curl -s https://www.libreoffice.org/download/download/ | grep dl_version_number | head -n 1 | cut -d'>' -f3 | cut -d'<' -f1)_MacOS_x86-64.dmg"
fi
appNewVersion=$( echo "${downloadURL}" | sed -E 's/.*\/[a-zA-Z]*_([0-9.]*)_.*/\1/g' )
expectedTeamID="7P5S3ZLCN7"
blockingProcesses=( soffice )
;;

View File

@@ -0,0 +1,15 @@
linear)
name="Linear"
type="dmg"
if [[ $(arch) == "arm64" ]]; then
downloadURL="https://desktop.linear.app/mac/dmg/arm64"
elif [[ $(arch) == "i386" ]]; then
downloadURL="https://desktop.linear.app/mac/dmg"
fi
appNewVersion=$(curl -sIkL $downloadURL | sed -r '/filename=/!d;s/.*filename=(.*)$/\1/' | awk '{print $2}')
expectedTeamID="7VZ2S3V9RV"
versionKey="CFBundleShortVersionString"
appName="Linear.app"
blockingProcesses=( "Linear" )
;;

View File

@@ -1,9 +1,11 @@
logioptions|\
logitechoptions)
# credit: AP Orlebeke (@apizz)
name="Logitech Options"
name="Logi Options"
type="pkgInZip"
downloadURL=$(curl -fs -L https://www.logitech.com/en-us/product/options | grep -m 1 -o "https.*zip" | sed 's/\"//' | awk '{print $1}')
#appNewVersion=$(curl -fs -L https://www.logitech.com/en-us/product/options | grep -m 1 -o "https.*zip" | sed 's/\"//' | awk '{print $1}' | sed -E 's/.*_([0-9\.]*)[-\.].*/\1/' )
pkgName="LogiMgr Installer ${appNewVersion}.app/Contents/Resources/LogiMgr.pkg"
#downloadURL=$(curl -fs "https://support.logi.com/api/v2/help_center/en-us/articles.json?label_names=webcontent=productdownload,webos=mac-macos-x-11.0" | tr "," "\n" | grep -A 10 "macOS" | grep -oie "https.*/.*/options/.*\.zip" | head -1)
downloadURL="https://download01.logi.com/web/ftp/pub/techsupport/options/options_installer.zip"
appNewVersion=$(curl -fs "https://support.logi.com/api/v2/help_center/en-us/articles.json?label_names=webcontent=productdownload,webos=mac-macos-x-11.0" | tr "," "\n" | grep -A 10 "macOS" | grep -B 5 -ie "https.*/.*/options/.*\.zip" | grep "Software Version" | sed 's/\\u[0-9a-z][0-9a-z][0-9a-z][0-9a-z]//g' | grep -ioe "Software Version.*[0-9.]*" | tr "/" "\n" | grep -oe "[0-9.]*" | head -1)
#pkgName="LogiMgr Installer "*".app/Contents/Resources/LogiMgr.pkg"
pkgName=LogiMgr.pkg
expectedTeamID="QED4VVPZWA"
;;

View File

@@ -2,7 +2,11 @@ loom)
# credit: Lance Stephens (@pythoninthegrass on MacAdmins Slack)
name="Loom"
type="dmg"
downloadURL=https://cdn.loom.com/desktop-packages/$(curl -fs https://s3-us-west-2.amazonaws.com/loom.desktop.packages/loom-inc-production/desktop-packages/latest-mac.yml | awk '/url/ && /dmg/ {print $3}' | head -1)
if [[ $(arch) == "arm64" ]]; then
downloadURL=https://cdn.loom.com/desktop-packages/$(curl -fs https://s3-us-west-2.amazonaws.com/loom.desktop.packages/loom-inc-production/desktop-packages/latest-mac.yml | awk '/url/ && /arm64/ && /dmg/ {print $3}' | head -1)
elif [[ $(arch) == "i386" ]]; then
downloadURL=https://cdn.loom.com/desktop-packages/$(curl -fs https://s3-us-west-2.amazonaws.com/loom.desktop.packages/loom-inc-production/desktop-packages/latest-mac.yml | awk '/url/ && /dmg/ {print $3}' | head -1)
fi
appNewVersion=$(curl -fs https://s3-us-west-2.amazonaws.com/loom.desktop.packages/loom-inc-production/desktop-packages/latest-mac.yml | awk '/version/ {print $2}' )
expectedTeamID="QGD2ZPXZZG"
;;

View File

@@ -0,0 +1,7 @@
lowprofile)
name="Low Profile"
type="dmg"
downloadURL="$(downloadURLFromGit ninxsoft LowProfile)"
appNewVersion="$(versionFromGit ninxsoft LowProfile)"
expectedTeamID="7K3HVCLV7Z"
;;

View File

@@ -0,0 +1,9 @@
macadminspython)
name="MacAdmins Python"
type="pkg"
packageID="org.macadmins.python.recommended"
downloadURL=$(curl --silent --fail "https://api.github.com/repos/macadmins/python/releases/latest" | awk -F '"' "/browser_download_url/ && /python_recommended_signed/ { print \$4; exit }")
appNewVersion=$(grep -o -E '\d+\.\d+\.\d+\.\d+' <<< $downloadURL | head -n 1)
expectedTeamID="9GQZ7KUFR6"
blockingProcesses=( NONE )
;;

View File

@@ -0,0 +1,8 @@
macoslaps)
name="macOSLAPS"
type="pkg"
packageID="edu.psu.macOSLAPS"
downloadURL="$(downloadURLFromGit joshua-d-miller macOSLAPS)"
appNewVersion="$(versionFromGit joshua-d-miller macOSLAPS)"
expectedTeamID="9UYK4F9BSM"
;;

View File

@@ -3,7 +3,7 @@ mattermost)
type="dmg"
archiveName="mac-universal.dmg"
downloadURL=$(downloadURLFromGit mattermost desktop)
appNewVersion=$(versionFromGit mattermost desktop )
appNewVersion=$(versionFromGit mattermost desktop)
expectedTeamID="UQ8HT4Q2XM"
Mattermost Helper (Renderer).app app.asar
blockingProcesses=( "Mattermost Helper.app" "Mattermost Helper (Renderer).app" "Mattermost Helper (GPU).app" "Mattermost Helper (Plugin).app" )
;;

View File

@@ -0,0 +1,10 @@
microsoftazuredatastudio|\
azuredatastudio)
name="Azure Data Studio"
type="zip"
downloadURL=$( curl -sL https://github.com/microsoft/azuredatastudio/releases/latest | grep 'macOS ZIP' | grep -Eo "(http|https)://[a-zA-Z0-9./?=_%:-]*" )
appNewVersion=$(versionFromGit microsoft azuredatastudio )
expectedTeamID="UBF8T346G9"
appName="Azure Data Studio.app"
blockingProcesses=( "Azure Data Studio" )
;;

View File

@@ -1,5 +1,6 @@
microsoftdefender|\
microsoftdefenderatp)
name="Microsoft Defender ATP"
name="Microsoft Defender"
type="pkg"
downloadURL="https://go.microsoft.com/fwlink/?linkid=2097502"
appNewVersion=$(curl -fs https://macadmins.software/latest.xml | xpath '//latest/package[id="com.microsoft.defender.standalone"]/version' 2>/dev/null | sed -E 's/<version>([0-9.]*) .*/\1/')

View File

@@ -1,5 +1,5 @@
mightymike)
name="Nanosaur"
name="Mighty Mike"
type="dmg"
downloadURL=$(downloadURLFromGit jorio MightyMike)
appNewVersion=$(versionFromGit jorio MightyMike)

View File

@@ -0,0 +1,7 @@
mindmanager)
name="MindManager"
type="dmg"
downloadURL="https://www.mindmanager.com/mm-mac-dmg"
appNewVersion="$(curl -fsIL "${downloadURL}" | grep -i "^location" | awk '{print $2}' | sed -E 's/.*_Mac_*([0-9.]*)\..*/\1/g')"
expectedTeamID="ZF6ZZ779N5"
;;

View File

@@ -0,0 +1,8 @@
mobikinassistantforandroid)
name="MobiKin Assistant for Android"
type="dmg"
downloadURL="https://www.mobikin.com/downloads/mobikin-android-assistant.dmg"
versionKey="CFBundleVersion"
appNewVersion=$(curl -fs https://www.mobikin.com/assistant-for-android-mac/ | grep -i "version:" | sed -E 's/.*Version: ([0-9.]*)<.*/\1/g')
expectedTeamID="YNL42PA5C4"
;;

Some files were not shown because too many files have changed in this diff Show More