Class: Jamf::Client
- Includes:
- JamfBinary, JamfHelper, ManagementAction
- Defined in:
- lib/jamf/client.rb,
lib/jamf/client/jamf_binary.rb,
lib/jamf/client/jamf_helper.rb,
lib/jamf/client/management_action.rb
Overview
jamf client computer
Defined Under Namespace
Modules: JamfBinary, JamfHelper, ManagementAction
Constant Summary collapse
- JAMF_PLIST =
The Pathname to the preferences plist used by the jamf binary
Pathname.new '/Library/Preferences/com.jamfsoftware.jamf.plist'
- JAMF_SUPPORT_FOLDER =
The Pathname to the JAMF support folder
Pathname.new '/Library/Application Support/JAMF'
- RECEIPTS_FOLDER =
The JAMF receipts folder, where package installs are tracked.
JAMF_SUPPORT_FOLDER + 'Receipts'
- DOWNLOADS_FOLDER =
The JAMF downloads folder
JAMF_SUPPORT_FOLDER + 'Downloads'
- SUPPORT_BIN_FOLDER =
The bin folder inside the Jamf support folder
JAMF_SUPPORT_FOLDER + 'bin'
- CONSOLE_USERS_SCUTIL_CMD =
This command gives raw info about console users
'echo "show State:/Users/ConsoleUser" | /usr/sbin/scutil'.freeze
- ROOT_USER =
ignore console user = root (loginwindow)
'root'.freeze
- LOGINWINDOW_USER =
ignore primary console user loginwindow
'loginwindow'.freeze
- SELF_SERVICE_EXECUTABLE_END =
The end of the path to the Self Service Executable. Used to figure out who’s running Self Service.app
'/Self Service.app/Contents/MacOS/Self Service'.freeze
- PS_USER_COMM =
the ps command used to figure out who’s running Self Service
'ps -A -o user,comm'.freeze
- USER_PREFS_BYHOST_FOLDER =
the path to a users byhost folder from home
'Library/Preferences/ByHost/'.freeze
Class Method Summary collapse
-
.console_user ⇒ Object
alias for primary_console_user.
-
.console_users ⇒ Array<String>
Who’s currently got an active GUI session? - might be more than one if Fast User Switching is in use.
-
.do_not_disturb?(user = nil) ⇒ Boolean?
Is ‘Do Not Disturb’ enabled for the user? nil if unknown/not-applicable.
-
.hardware_data ⇒ Hash
The parsed HardwareDataType output from system_profiler.
-
.homedir(user) ⇒ Pathname?
The home dir of the specified user, nil if no homedir in local dscl.
-
.installed? ⇒ Boolean
Is the jamf binary installed?.
-
.jamf_plist ⇒ Hash
The contents of the JAMF plist.
-
.jamf_version ⇒ String?
What version of the jamf binary is installed?.
-
.jss_available? ⇒ Boolean
Is the JSS available right now?.
-
.jss_port ⇒ Integer
The port number for JSS connections for this client.
-
.jss_protocol ⇒ String
The protocol for JSS connections for this client.
-
.jss_record ⇒ Jamf::Computer?
The Jamf::Computer object for this computer.
-
.jss_server ⇒ String
The JSS server hostname for this client.
-
.jss_url ⇒ String
the URL to the jss for this client.
-
.my_ip_address ⇒ String
Get the current IP address as a String.
-
.primary_console_user ⇒ String?
Which console user is using the primary GUI console? Returns nil if the primary GUI console is at the login window.
-
.receipts ⇒ Array<Pathname>
All the JAMF receipts on this client.
-
.self_service_users ⇒ Array<String>
Who’s currently running Self Service.app? - might be more than one if Fast User Switching is in use.
-
.serial_number ⇒ String
The serial number for this computer via system_profiler.
-
.udid ⇒ String
The UUID for this computer via system_profiler.
Class Method Details
.console_user ⇒ Object
alias for primary_console_user
244 245 246 |
# File 'lib/jamf/client.rb', line 244 def self.console_user primary_console_user end |
.console_users ⇒ Array<String>
Who’s currently got an active GUI session? - might be more than one if Fast User Switching is in use.
224 225 226 227 228 229 |
# File 'lib/jamf/client.rb', line 224 def self.console_users output = `#{CONSOLE_USERS_SCUTIL_CMD}` userlines = output.lines.select { |l| l =~ /SessionUserNameKey\s*:/ } userlines.map! { |ul| ul.split(':').last.strip } userlines.reject { |un| un == ROOT_USER } end |
.do_not_disturb?(user = nil) ⇒ Boolean?
263 264 265 266 267 268 269 |
# File 'lib/jamf/client.rb', line 263 def self.do_not_disturb?(user = nil) home = user ? homedir(user) : Dir.home myudid = udid nc_prefs_file = Pathname.new "#{home}/#{USER_PREFS_BYHOST_FOLDER}/com.apple.notificationcenterui.#{myudid}.plist" return nil unless nc_prefs_file.readable? JSS.parse_plist(nc_prefs_file)['doNotDisturb'] end |
.hardware_data ⇒ Hash
The parsed HardwareDataType output from system_profiler
214 215 216 217 |
# File 'lib/jamf/client.rb', line 214 def self.hardware_data raw = `/usr/sbin/system_profiler SPHardwareDataType -xml 2>/dev/null` JSS.parse_plist(raw)[0]['_items'][0] end |
.homedir(user) ⇒ Pathname?
The home dir of the specified user, nil if no homedir in local dscl.
278 279 280 281 |
# File 'lib/jamf/client.rb', line 278 def self.homedir(user) dir = `/usr/bin/dscl . -read /Users/#{user} NFSHomeDirectory 2>/dev/null`.chomp.split(': ').last dir ? Pathname.new(dir) : nil end |
.installed? ⇒ Boolean
Is the jamf binary installed?
103 104 105 |
# File 'lib/jamf/client.rb', line 103 def self.installed? JAMF_BINARY.executable? end |
.jamf_plist ⇒ Hash
The contents of the JAMF plist
an empty hash if not
161 162 163 164 |
# File 'lib/jamf/client.rb', line 161 def self.jamf_plist return {} unless JAMF_PLIST.file? JSS.parse_plist JAMF_PLIST end |
.jamf_version ⇒ String?
What version of the jamf binary is installed?
111 112 113 |
# File 'lib/jamf/client.rb', line 111 def self.jamf_version installed? ? run_jamf(:version).chomp.split('=')[1] : nil end |
.jss_available? ⇒ Boolean
Is the JSS available right now?
179 180 181 182 |
# File 'lib/jamf/client.rb', line 179 def self.jss_available? run_jamf :checkJSSConnection, '-retry 1' $CHILD_STATUS.exitstatus.zero? end |
.jss_port ⇒ Integer
The port number for JSS connections for this client
151 152 153 154 |
# File 'lib/jamf/client.rb', line 151 def self.jss_port jss_url @port end |
.jss_protocol ⇒ String
The protocol for JSS connections for this client
142 143 144 145 |
# File 'lib/jamf/client.rb', line 142 def self.jss_protocol jss_url @protocol end |
.jss_record ⇒ Jamf::Computer?
The Jamf::Computer object for this computer
188 189 190 191 192 |
# File 'lib/jamf/client.rb', line 188 def self.jss_record Jamf::Computer.fetch udid: udid rescue Jamf::NoSuchItemError nil end |
.jss_server ⇒ String
The JSS server hostname for this client
133 134 135 136 |
# File 'lib/jamf/client.rb', line 133 def self.jss_server jss_url @server end |
.jss_url ⇒ String
the URL to the jss for this client
119 120 121 122 123 124 125 126 127 |
# File 'lib/jamf/client.rb', line 119 def self.jss_url @url = jamf_plist['jss_url'] return nil if @url.nil? @url =~ %r{(https?)://(.+):(\d+)/} @protocol = Regexp.last_match(1) @server = Regexp.last_match(2) @port = Regexp.last_match(3) @url end |
.my_ip_address ⇒ String
Get the current IP address as a String.
This handy code doesn’t acutally make a UDP connection, it just starts to set up the connection, then uses that to get the local IP.
Lifted gratefully from coderrr.wordpress.com/2008/05/28/get-your-local-ip-address/
85 86 87 88 89 90 91 92 93 94 95 96 97 |
# File 'lib/jamf/client.rb', line 85 def self.my_ip_address # turn off reverse DNS resolution temporarily # @note the 'socket' library has already been required by 'rest-client' orig = Socket.do_not_reverse_lookup Socket.do_not_reverse_lookup = true UDPSocket.open do |s| s.connect '192.168.0.0', 1 s.addr.last end ensure Socket.do_not_reverse_lookup = orig end |
.primary_console_user ⇒ String?
Which console user is using the primary GUI console? Returns nil if the primary GUI console is at the login window.
237 238 239 240 241 |
# File 'lib/jamf/client.rb', line 237 def self.primary_console_user `#{CONSOLE_USERS_SCUTIL_CMD}` =~ /^\s*Name : (\S+)$/ user = Regexp.last_match(1) user == LOGINWINDOW_USER ? nil : user end |
.receipts ⇒ Array<Pathname>
All the JAMF receipts on this client
170 171 172 173 |
# File 'lib/jamf/client.rb', line 170 def self.receipts raise Jamf::NoSuchItemError, "The JAMF Receipts folder doesn't exist on this computer." unless RECEIPTS_FOLDER.exist? RECEIPTS_FOLDER.children.select(&:file?) end |
.self_service_users ⇒ Array<String>
Who’s currently running Self Service.app? - might be more than one if Fast User Switching is in use.
253 254 255 256 |
# File 'lib/jamf/client.rb', line 253 def self.self_service_users ss_userlines = `#{PS_USER_COMM}`.lines.select { |l| l.include? SELF_SERVICE_EXECUTABLE_END } ss_userlines.map { |ssl| ssl.split(' ').first } end |
.serial_number ⇒ String
The serial number for this computer via system_profiler
206 207 208 |
# File 'lib/jamf/client.rb', line 206 def self.serial_number hardware_data['serial_number'] end |
.udid ⇒ String
The UUID for this computer via system_profiler
198 199 200 |
# File 'lib/jamf/client.rb', line 198 def self.udid hardware_data['platform_UUID'] end |