Module: Jamf::Scopable
- Included in:
- ConfigurationProfile, MacApplication, MobileDeviceApplication, PatchPolicy, Policy, RestrictedSoftware
- Defined in:
- lib/jamf/api/classic/api_objects/scopable.rb,
lib/jamf/api/classic/api_objects/scopable/scope.rb
Overview
A mix-in module for handling scoping data for objects in the JSS.
The JSS objects that can be scoped use similar data to represent that scoping. This module provides a consistant way to deal with scoping data via some instance methods and the Scope class.
When this module is mixed in to a APIObject subclass, instances of the subclass will have a @scope attribute containing a Scope instance
Classes that mix in this module must:
Defined Under Namespace
Classes: Scope
Constant Summary collapse
- SCOPABLE =
Constants
true
Instance Attribute Summary collapse
-
#scope ⇒ Object
Attribtues.
Instance Method Summary collapse
-
#parse_scope ⇒ void
private
Call this during initialization of objects that have a scope and the scope instance will be created from @init_data.
-
#should_update ⇒ void
When the scope changes, it calls this to tell us that an update is needed.
-
#update ⇒ Object
A wrapper around the update method, to try catching 409 conflict errors when we couldn’t verify all ldap users/groups due to lack of ldap connections.
Instance Attribute Details
#scope ⇒ Object
Attribtues
65 66 67 |
# File 'lib/jamf/api/classic/api_objects/scopable.rb', line 65 def scope @scope end |
Instance Method Details
#parse_scope ⇒ void
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
This method returns an undefined value.
Call this during initialization of objects that have a scope and the scope instance will be created from @init_data
77 78 79 80 |
# File 'lib/jamf/api/classic/api_objects/scopable.rb', line 77 def parse_scope @scope = Jamf::Scopable::Scope.new self.class::SCOPE_TARGET_KEY, @init_data[:scope] @scope.container = self end |
#should_update ⇒ void
This method returns an undefined value.
When the scope changes, it calls this to tell us that an update is needed.
99 100 101 |
# File 'lib/jamf/api/classic/api_objects/scopable.rb', line 99 def should_update @need_to_update = true if @in_jss end |
#update ⇒ Object
A wrapper around the update method, to try catching 409 conflict errors when we couldn’t verify all ldap users/groups due to lack of ldap connections
106 107 108 109 110 111 112 113 114 |
# File 'lib/jamf/api/classic/api_objects/scopable.rb', line 106 def update super rescue Jamf::ConflictError => conflict if scope.unable_to_verify_ldap_entries == true raise Jamf::InvalidDataError, "Potentially non-existant LDAP user or group in new scope values." else raise conflict end end |