lib/jss/api_object/self_servable.rb in ruby-jss-0.6.3 vs lib/jss/api_object/self_servable.rb in ruby-jss-0.6.4
- old
+ new
@@ -1,28 +1,28 @@
### Copyright 2016 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
#####################################
@@ -39,23 +39,23 @@
### A mix-in module for handling Self Service data for objects in the JSS.
###
### The JSS objects that have Self Service data return it in a :self_service subset,
### which all have similar data, a hash with at least these keys:
- ### - :self_service_description
- ### - :self_service_icon
+ ### - :self_service_description
+ ### - :self_service_icon
###
### Most also have:
### - :feature_on_main_page
### - :self_service_categories
###
- ### iOS Profiles in self service have this key:
- ### - :security
+ ### iOS Profiles in self service have this key:
+ ### - :security
###
### Additionally, items that apper in OS X SlfSvc have these keys:
### - :install_button_text
- ### - :force_users_to_view_description
+ ### - :force_users_to_view_description
###
### See the attribute definitions for details of these values and structures.
###
### Including this module in an {APIObject} subclass and calling {#parse_self_service} in the
### subclass's constructor will give it matching attributes with 'self_service_'
@@ -69,18 +69,18 @@
###
### - Define the constant SELF_SERVICE_TARGET which contains either :osx or :ios
### - Define the constant SELF_SERVICE_PAYLOAD which contains one of :policy, :profile, or :app
### - Call {#parse_self_service} in the subclass's constructor after calling super
### - Include the result of {#self_service_xml} in their #rest_xml output
- ### - Define the method #in_self_service? which returns a Boolean indicating that the item is
+ ### - Define the method #in_self_service? which returns a Boolean indicating that the item is
### available in self service. Different API objects indicate this in different ways.
### - Define the method #user_removable? which returns Boolean indicating that the item (a profile)
### can be removed by the user in SSvc. OS X profiles store this in the :user_removable key of the
### :general subset as a boolean, whereas iOS profiles stor it in :security as one of 3 strings
###
###
- ### Notes:
+ ### Notes:
### - Self service icons cannot be modified via this code. Use the Web UI.
### - There an API bug in handling categories, and all but the last one are ommitted. Until this is fixed, categories
### cannot be saved via this code since that would cause data-loss when more than one category is applied.
###
module SelfServable
@@ -88,23 +88,23 @@
#####################################
### Constants
#####################################
SELF_SERVABLE = true
-
+
IOS_PROFILE_REMOVAL_OPTIONS = ["Always", "With Authorization", "Never"]
-
+
#####################################
### Variables
#####################################
-
-
+
+
#####################################
### Attribtues
#####################################
-
+
### @return [String] The verbage that appears in SelfSvc for this item
attr_reader :self_service_description
### @return [Hash] The icon that appears in SelfSvc for this item
###
@@ -125,11 +125,11 @@
### - :id => [Integer] the JSS id of the category
### - :name => [String] the name of the category
### - :display_in => [Boolean] should the item be displayed in this category in SSvc? (OSX SSvc only)
### - :feature_in => [Boolean] should the item be featured in this category in SSVC? (OSX SSvc only)
###
- ### NOTE: as of Casper 9.61 there's a bug in the JSON output from the API, and only the last
+ ### NOTE: as of Casper 9.61 there's a bug in the JSON output from the API, and only the last
### category is returned, if more than one are set.
###
attr_reader :self_service_categories
### @return [Hash] The security settings for iOS profiles in SSvc
@@ -143,11 +143,11 @@
###
attr_reader :self_service_security
### @return [String] The text label on the install button in SSvc (OSX SSvc only)
attr_reader :self_service_install_button_text
-
+
### @return [Boolean] Should an extra window appear before the user can install the item? (OSX SSvc only)
attr_reader :self_service_force_users_to_view_description
#####################################
@@ -163,36 +163,36 @@
### @return [void]
###
def parse_self_service
@init_data[:self_service] ||= {}
ss_data = @init_data[:self_service]
-
+
@self_service_description = ss_data[:self_service_description]
@self_service_icon = ss_data[:self_service_icon]
-
+
@self_service_feature_on_main_page = ss_data[:feature_on_main_page]
-
+
# TEMPORARY - until JAMF fixes the category data in JSON
@self_service_categories = [
ss_data[:self_service_categories][:category]
]
-
+
# make this an empty hash if needed
@self_service_security = ss_data[:security] || {}
-
- # if this is an osx profile, set @self_service_security[:removal_disallowed] to "Always" or "Never"
+
+ # if this is an osx profile, set @self_service_security[:removal_disallowed] to "Always" or "Never"
# to indicate the boolean :user_removable
if @init_data[:general].keys.include? :user_removable
@self_service_security[:removal_disallowed] = @init_data[:general][:user_removable] ? "Always" : "Never"
end
-
+
@self_service_install_button_text = ss_data[:install_button_text]
@self_service_force_users_to_view_description = ss_data[:force_users_to_view_description]
end
-
+
###
###
### Setters
###
@@ -216,36 +216,36 @@
return nil if @self_service_install_button_text == new_val
raise JSS::InvalidDataError, "Only OS X Self Service Items can have custom button text" unless self.class::SELF_SERVICE_TARGET == :osx
@self_service_install_button_text = new_val.strip
@need_to_update = true
end
-
+
###
- ### @param new_val[Boolean] should this appear on the main SelfSvc page?
+ ### @param new_val[Boolean] should this appear on the main SelfSvc page?
###
### @return [void]
###
def self_service_feature_on_main_page= (new_val)
return nil if @self_service_feature_on_main_page == new_val
raise JSS::InvalidDataError, "New value must be true or false" unless JSS::TRUE_FALSE.include? new_val
@self_service_feature_on_main_page = new_val
@need_to_update = true
end
-
+
###
- ### @param new_val[Boolean] should this appear on the main SelfSvc page?
+ ### @param new_val[Boolean] should this appear on the main SelfSvc page?
###
### @return [void]
###
def self_service_force_users_to_view_description= (new_val)
return nil if @self_service_force_users_to_view_description == new_val
raise JSS::InvalidDataError, "Only OS X Self Service Items can force users to view description" unless self.class::SELF_SERVICE_TARGET == :osx
raise JSS::InvalidDataError, "New value must be true or false" unless JSS::TRUE_FALSE.include? new_val
@self_service_force_users_to_view_description = new_val
@need_to_update = true
end
-
+
###
### Add or change one of the categories for this item in SSvc.
###
### @param new_cat[String] the name of a category for this item in SelfSvc
###
@@ -258,25 +258,25 @@
def add_self_service_category (new_cat, display_in = true, feature_in = false)
new_cat.strip!
raise JSS::NoSuchItemError, "No category '#{new_cat}' in the JSS" unless JSS::Category.all_names(:refresh).include? new_cat
raise JSS::InvalidDataError, "display_in must be true or false" unless JSS::TRUE_FALSE.include? display_in
raise JSS::InvalidDataError, "feature_in must be true or false" unless JSS::TRUE_FALSE.include? feature_in
-
+
new_data = {:name => new_cat, :display_in => display_in, :feature_in => feature_in }
-
+
# see if this category is already among our categories.
idx = @self_service_categories.index{|c| c[new_cat]}
-
- if idx
+
+ if idx
@self_service_categories[idx] = new_data
else
@self_service_categories << new_data
end
-
+
@need_to_update = true
end
-
+
###
### Remove a category from those for this item in SSvc
###
### @param cat[String] the name of the category to remove
###
@@ -294,63 +294,62 @@
### @param new_val[String] one of the values in PROFILE_REMOVAL_OPTIONS, or true or false
###
### @return [void]
###
def profile_can_be_removed (new_val)
-
- new_val = "Always" if new_val === true
+
+ new_val = "Always" if new_val === true
new_val = "Never" if new_val === false
-
+
return nil if new_val == @self_service_security[:removal_disallowed]
raise JSS::InvalidDataError, "" unless IOS_PROFILE_REMOVAL_OPTIONS.include? new_val
-
+
@self_service_security[:removal_disallowed] = new_val
end
-
-
-
+
+
###
### @api private
###
### Return a REXML <location> element to be
### included in the rest_xml of
### objects that have a Location subset
###
### @return [REXML::Element]
###
def self_service_xml
-
+
ssvc = REXML::Element.new('self_service')
-
+
return ssvc unless self.in_self_service?
-
+
ssvc.add_element('self_service_description').text = @self_service_description
ssvc.add_element('feature_on_main_page').text = @self_service_feature_on_main_page
-
+
### TEMPORARY - re-enable this when the category bug is fixed.
-
+
# cats = ssvc.add_element('self_service_categories')
# @self_service_categories.each do |cat|
# catelem = cats.add_element('category')
# catelem.add_element('name').text = cat[:name]
# catelem.add_element('display_in').text = cat[:display_in] if cat.keys.include? :display_in
# catelem.add_element('feature_in').text = cat[:feature_in] if cat.keys.include? :feature_in
# end
-
+
unless @self_service_security.empty?
sec = ssvc.add_element('security')
sec.add_element('removal_disallowed').text = @self_service_security[:removal_disallowed] if @self_service_security[:removal_disallowed]
sec.add_element('password').text = @self_service_security[:password] if @self_service_security[:password]
end
-
+
ssvc.add_element('install_button_text').text = @self_service_install_button_text if @self_service_install_button_text
ssvc.add_element('force_users_to_view_description').text = @self_service_force_users_to_view_description unless @self_service_force_users_to_view_description.nil?
return ssvc
end
-
+
### aliases
alias change_self_service_category add_self_service_category
-
+
end # module SelfServable
end # module JSS