How To Make A Bash Script For Mac
Well, what are you waiting for? Let’s get to work at answering that question! The Bitter Truth As you know, a login script is a script file that contains a sequence of commands to automate our users’ environments. Naturally, the “logon” part of the login script means that the script file is applied during, well, user domain logon. In Active Directory, we can create login scripts by using either a standard “DOS” shell scripts, or we can employ a Windows Script Host (WSH) compatible scripting language such as VBScript or Jscript. Other programming language options are available, but these are by far the most common.
We deploy login scripts by using either Group Policy or the user’s domain account properties sheet. The logon script files themselves need to be stored in the NETLOGON share of one of your domain controllers; Active Directory replication ensures that all domain controllers possess a copy of the login script file. The preceding information is all well and good, but where does that help us with respect to applying logon scripts to Mac OS X clients?
While Apple has given us rudimentary integration with Active Directory, a Mac system cannot process a DOS shell script or VBScript file—Macs simply do not have the appropriate command interpreters available to them out of the box. In point of fact, Group Policy is utterly irrelevant to the Mac OS X operating system.
NOTE: Third-party products exist that do allow for Group Policy processing on Mac OS X systems. Two notable examples are. Thus, unless we turn to third-party tools, we have to face the unavoidable conclusion that we must maintain a separate login scripts for Mac OX clients.
This brings up the important questions, “Okay, but how do I accomplish this goal?” To let the proverbial cat out of the bag, in this article series we shall investigate the following options:. Defining a login item or login hook. Leveraging Open Directory in Mac OS X Server.
Using a third-party utility In future installments of this series, we will discuss the second and third bullet points. The focus of this article is to learn how we can create usable login scripts for our Macs with the least amount of effort, at least for the smallest of Mac/Windows environments. Creating a login item Login items in Mac OS X are directly analogous to Startup Items in Windows. In other words, these are applications that start up automatically after user login and are executed in the context of the current user. To see a user’s login items, open the Accounts Preference pane, select the desired user account, and navigate to the Login Items tab. The simplest way to add a Windows share to a Mac user’s login items list is simply to in another 4sysops.com blog post) and drag the mounted volume to the user’s Login Items list. Adding a Login Item If you are looking for more robustness in how the SMB mount is performed, then allow me to suggest AppleScript.
AppleScript is an interpreted scripting language that is almost as old as the Mac OS itself. Following is an extremely basic AppleScript that mounts the aforementioned SMB share: try mount volume “smb://user@server/share” end try You can search online to find that include error checking, conditional logic, and so forth. The key to using an AppleScript file as a login script is that you first need to save the script as an application (these have the.app extension by default). From the Apple Script Editor, click File Save As and select Application from the File Format popup menu.
Saving an AppleScript as an application You can then drag the AppleScript.app file to the user’s Login Items preference pane, as usual. The finished configuration Creating a login hook Whereas a login item runs in the context of the currently logged on user, a login hook runs with root (superuser) privilege. Thus, login hooks tend to be much more powerful and have more capability than login items. To define a login hook, you’ll first need to compose a UNIX shell script that performs the actions you desire. For instance, the following code creates a folder on the user’s Desktop and mounts a Server Message Block (SMB) Windows share named winshare from a Windows server named server01: #!/bin/sh mkdir /Users/tim/Desktop/winshare mountsmbfs //username:password@server01/winshare /Users/tim/Desktop/winshare KillAll Terminal exit UNIX shell scripts typically have the.sh file extension.
However, in this case we need to change the extension to.command as well as make the shell script executable. To perform this latter action, issue the following command from Terminal: chmod +x filename.command The final step is to create the login hook proper. From Terminal, issue the following statement: sudo defaults write com.apple.loginwindow LoginHook /path/to/filename.command where /path/to represents the path that leads to the.command shell script. If for any reason you need to remove a previously created login hook, issue the following statement from Terminal: sudo defaults delete com.apple.loginwindow LoginHook Conclusion While the techniques discussed in this blog post will work just fine for very small Mac/Windows environments with, say, 10 or fewer Macs, they are obviously unworkable for larger-scale implementations. To this end, in the following installments of this series we will examine some methods for deploying login scripts to several Mac OS X clients in a more centralized manner. Advance warning: the next procedure we will examine involves, and will include almost no reference to Windows at all. The horrors, the horrors!
🙂 Thanks for reading! For further study.
I discovered that the hook running as root causes problems also. Primarily it changes the permisions and the user can’t see the folder on the desktop any longer because it is only available to root. And of course I don’t want to log into the server as root. According to this page the short username is in $1 (you have to click more near the top to see it though) So I tried a script like #!/bin/sh su - $1 txtUSER=$(whoami) mkdir /Users/$txtUSER/Desktop/Fdrive mountsmbfs //MYSERVER/sys /Users/$txtUSER/Desktop/Fdrive mkdir /Users/$txtUSER/Desktop/Hdrive mountsmbfs //MYSERVER/home/$txtUSER /Users/$txtUSER/Desktop/Hdrive KillAll Terminal exit This script will run (without the su -$1) fine when placed in the users login items. Note: To get the shortcuts to show on the desktop the user will need to go to finder - preferences and check connected servers. Hope this helps someone else.
Wished I could figure out how to switch users to run this command from the hook. This is great, but Im having an issue setting up an login item for domain users. I used Script Editor to create an alert message that will pop up when user login. I am using Profile manager to deploy it and run it. I save the script as an app and placed it in the Applications folder. The message I want come up but only for local accounts, domain accounts fail to open it and when i check the apps folder, the application states that it is damaged or not complete.
Unsure why when it runs under any local account just fine. I am beginning to use VS Code (in conjunction with Powershell 1.9.0 extension).
I also installed Powershell Core 6.1 - on the understanding (please correct if this is wrong!) that VS Code will use Powershell Core 6.1 by default. In Powershell ISE, I had a simple 'Login script' file named: Microsoft.PowershellISEprofile.ps1 which automatically runs a few lines of PS code such as Set-Location, Set-RemoteExecutonPolicy, Get-content env:Psmodulepath, etc. For my 'environment'. My question is: Where would I put such a Login script in the VS Code/Powershell 1.9.0? I notice that Vs Code created two separate folders in my Documents folder:.VS Code Powershell and.VS Code Javascript.
And what file name should I use? Would be grateful for any advice, tips or references.
Thanks in advance.
. First in terminal make the script executable by typing: chmod a+x (yourscriptname).
Then, in Finder, right-click your file and select 'Open with' and then 'Other.' . Here you select the application you want the file to execute into, in this case it would be Terminal. To be able to select terminal you need to switch from 'Recommended Applications' to 'All Applications'. (The Terminal.app application can be found in the Utilities folder). NOTE that unless you don't want to associate all files with this extension to be run in terminal you should not have 'Always Open With' checked.
How To Make Shell Scripts
After clicking OK you should be able to execute you script by simply double-clicking it. As of OSX 10.10 (Yosemite) and since at least OS X 10.8 (Mountain Lion), the behavior is as follows when you open (double-click) executable scripts from Finder:. Executable scripts 1 with either NO suffix or suffix.command:. are executed by default - no setup required:. a new Terminal window opens in which the script runs. by default, the window will remain open after the script terminates so you can inspect the output (though at that point the shell that ran the script has exited and you cannot interact with it any longer). However, via Terminal's Preferences.
Profiles you can opt to automatically close the window when the script exits. Caveat: the working folder is invariably the current user's home folder, NOT the folder in which the script is located. To make a shell script change to the folder in which it is located, place. cd - '$(dirname '$BASHSOURCE')' right after the shebang line. or, if you must remain POSIX-compliant, cd - '$(dirname '$0')'.
For edge cases, such as finding a symlinked script's true source directory, see of mine. If the script is unexpectedly not executable:. Make it executable by running chmod +x.