### Copyright 2019 Pixar ### ### Licensed under the Apache License, Version 2.0 (the "Apache License") ### with the following modification; you may not use this file except in ### compliance with the Apache License and the following modification to it: ### Section 6. Trademarks. is deleted and replaced with: ### ### 6. Trademarks. This License does not grant permission to use the trade ### names, trademarks, service marks, or product names of the Licensor ### and its affiliates, except as required to comply with Section 4(c) of ### the License and to reproduce the content of the NOTICE file. ### ### You may obtain a copy of the Apache License at ### ### http://www.apache.org/licenses/LICENSE-2.0 ### ### Unless required by applicable law or agreed to in writing, software ### distributed under the Apache License with the above modification is ### distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY ### KIND, either express or implied. See the Apache License for the specific ### language governing permissions and limitations under the Apache License. ### ### ### module JSS ##################################### ### Module Variables ##################################### ##################################### ### Module Methods ##################################### ##################################### ### Classes ##################################### ### ### A User in the JSS. ### ### @see JSS::APIObject ### class User < JSS::APIObject ##################################### ### Mix-Ins ##################################### include JSS::Creatable include JSS::Updatable include JSS::Extendable ##################################### ### Class Methods ##################################### ##################################### ### Class Constants ##################################### ### The base for REST resources of this class RSRC_BASE = "users" ### the hash key used for the JSON list output of all objects in the JSS RSRC_LIST_KEY = :users ### The hash key used for the JSON object output. ### It's also used in various error messages RSRC_OBJECT_KEY = :user ### This class lets us seach for users SEARCH_CLASS = JSS::AdvancedUserSearch ### This is the class for relevant Extension Attributes EXT_ATTRIB_CLASS = JSS::UserExtensionAttribute # the object type for this object in # the object history table. # See {APIObject#add_object_history_entry} OBJECT_HISTORY_OBJECT_TYPE = 53 ##################################### ### Attributes ##################################### ### @return [String] The user's full name attr_reader :full_name ### @return [String] The user's email address attr_reader :email ### @return [String] The user's phone number attr_reader :phone_number ### @return [String] The user's position / job title attr_reader :position ### @return [String] The name of the user's LDAP server attr_reader :ldap_server attr_reader :ldap_sever_id ### @return [Array] ### ### Unlike every other Sitable object, Users ### can be in multiple sites, so we don't use ### the Sitable mixin module. Instead we'll ### we'll store them in this Array, as they come ### from the API. ### ### Each Hash has the :id and :name for one site ### attr_reader :sites ### @return [Array] ### ### The computers associated with this user ### ### Each Hash has then :id and :name for one computer ### attr_reader :computers ### @return [Array] ### ### The peripherals associated with this user ### ### Each Hash has then :id and :name for one peripheral ### attr_reader :peripherals ### @return [Array] ### ### The mobile devices associated with this user ### ### Each Hash has then :id and :name for one device ### ### @note This data is currently broken - the JSON output of the API only ### returns one mobile device, and it isn't formatted in a standard way. ### attr_reader :mobile_devices ### @return [Array] ### ### The vpp assignments associated with this user ### ### Each Hash has then :id and :name for one assignment ### attr_reader :vpp_assignments ### @return [Integer] the total number of vpp codes assigned to this user attr_reader :total_vpp_code_count ##################################### ### Constructor ##################################### ### ### See JSS::APIObject#initialize ### def initialize (args = {}) super @full_name = @init_data[:full_name] @email = @init_data[:email] @phone_number = @init_data[:phone_number] @position = @init_data[:position] @ldap_server = JSS::APIObject.get_name @init_data[:ldap_server] @ldap_server_id = @init_data[:ldap_server][:id] @sites = @init_data[:sites] ? @init_data[:sites] : [] if @init_data[:links] @computers = @init_data[:links][:computers] @peripherals = @init_data[:links][:peripherals] @mobile_devices = @init_data[:links][:mobile_devices] @vpp_assignments = @init_data[:links][:vpp_assignments] @total_vpp_code_count = @init_data[:links][:total_vpp_code_count] end end ##################################### ### Public Instance Methods ##################################### ### ### Simple Setters ### ### def full_name= (new_val) @full_name = new_val @need_to_update = true end ### def email= (new_val) @email = new_val @need_to_update = true end ### def phone_number= (new_val) @phone_number = new_val @need_to_update = true end ### def position= (new_val) @position = new_val @need_to_update = true end ### def ldap_server= (new_val) raise JSS::InvalidDataError, "No LDAP server in the JSS named #{new_val}" unless JSS::LDAPServer.all_names(api: @api).include? new_val @ldap_server = new_val @ldap_server_id = JSS::LDAPServer.valid_id @ldap_server @need_to_update = true end ### ### Add this user to a site ### ### @param site[String] the name of the site ### ### @return [void] ### def add_site (site) return nil if @sites.map{|s| s[:name]}.include? site raise JSS::InvalidDataError, "No site in the JSS named #{site}" unless JSS::Site.all_names(api: @api).include? site @sites << {:name => site} @need_to_update = true end ### ### Remove this user from a site ### ### @param site[String] the name of the site ### ### @return [void] ### def remove_site (site) return nil unless @sites.map{|s| s[:name]}.include? site @sites.reject!{|s| s[:name] == site} @need_to_update = true end ##################################### ### Private Instance Methods ##################################### private def rest_xml doc = REXML::Document.new APIConnection::XML_HEADER user = doc.add_element self.class::RSRC_OBJECT_KEY.to_s user.add_element('name').text = @name user.add_element('full_name').text = @full_name user.add_element('email').text = @email user.add_element('phone_number').text = @phone_number user.add_element('position').text = @position ldap = user.add_element('ldap_server') ldap.add_element('id').text = @ldap_server_id user << JSS::Site.xml_list(@sites) user << ext_attr_xml if unsaved_eas? return doc.to_s end end # class user end # module