NAME
Config::Apple::Profile::Payload::Common - Base class for almost all payload types, with common payload keys.
DESCRIPTION
This module serves two purposes.
First, this module contains code to store payload data, to validate client-provided data, and to export payload data as a plist.
Second, this module defines the payload keys that are common to almost all payload types. Specific payload types (classes) will include these common payload types in their own payload type-specific list.
Ideally, each payload type will be implemented as a class that subclasses this one, using this class to do all of the work, leaving the subclass to define the payload keys specific to that subclass.
CLASS METHODS
new()
Returns a new object.
INSTANCE METHODS
keys()
Returns a hashref that contains the list of payload keys recognized by this instance.
NOTE: The hashref points to a hash that is read-only. Any attempts to modify will cause your code to die. You probably want to look at payload()
.
payload()
Returns a hashref that can be used to access the contents of the payload. This is a reference to a tied hash, so you can not use it as liberally as a normal hash. The only keys that will be accepted are those listed under "PAYLOAD KEYS".
The following exception may be thrown when accessing a hash key:
- Config::Apple::Profile::Payload::Common::KeyInvalid
-
Thrown when attempting to access a payload key that is not valid for this payload.
If a payload key is valid, but has not been set, then undef
is returned.
The following exceptions may be thrown when setting a hash key:
- Config::Apple::Profile::Payload::Common::KeyInvalid
-
Thrown when attempting to access a payload key that is not valid for this payload.
- Config::Apple::Profile::Payload::Common::ValueInvalid
-
Thrown when attempting to set an invalid value for this payload key.
You can use exists
to test if a particular key is valid for this payload, and you can use defined
to test if a particular key actually has a value defined. Take note that calling defined
with an invalid key name will always return false.
You can use delete
to delete a key.
plist([option1_name
=> option1_value
, ...])
Return a copy of this payload, represented as a Mac::Propertylist object. All strings will be in UTF-8, and all Data entries will be Base64-encoded. This method is used when assembling payloads into a profile.
There are two ways to get string output from the plist object:
# First, get your plist object from the payload
my $plist = $payload->plist();
# If you just want the <dict> XML element and its contents, do this...
my $dict_element = $plist->write;
# If you want the complete XML plist, with headers, do this...
use Mac::PropertyList;
my $complete_plist = Mac::PropertyList::plist_as_string($plist);
Several parameters can be provided, which will influence how this method runs.
- target
-
If
target
(a value from Config::Apple::Profile::Targets) is provided, then this will be taken into account when exporting. Only payload keys that are used on the specified target will be included in the output.The
completeness
option controls what happens if keys are excluded. - version
-
If
version
(a version string) is provided, then only payload keys that work on the specified version will be included in the output.If
version
is provided, thentarget
must also be set, buttarget
can be set without settingversion
.The
completeness
option controls what happens if keys are excluded. - completeness
-
If
completeness
is set to a true value, and keys are excluded because oftarget
orversion
, thenplist
will throw an exception. If set to a false value, or if not set at all, then no exceptions will be thrown, and a less-than-complete (but still valid) plist will be returned.
The following exceptions may be thrown:
- Config::Apple::Profile::Exception::KeyRequired
-
Thrown if a required key has not been set.
- Config::Apple::Profile::Exception::Incomplete
-
Thrown if payload keys are being excluded from the output because of
target
orversion
.
populate_id()
Populates the PayloadIdentifier
and PayloadUUID
fields, if they are not already set. In addition, if the payload has any keys of type $PayloadClass
, then populate_id
will also be called on them.
Sub-classes may decide to override this, so as to add extra functionality.
exportable([target
])
Returns true if the payload is complete enough to be exported. In other words, all required keys must have values provided.
exportable()
will return false if all UUID and Identifier fields are not filled in, so it is suggested that you call populate_id()
before calling exportable()
.
validate_key($key, $value)
Confirm the value provided is valid for the given payload key, and return a de-tained copy of $value
, or undef
if the provided value is invalid.
$key
is the name of the payload key being set, and $value
is the proposed new value. This class will perform checking for all payload types except for Data payloads. The checks performed will be very basic.
Subclasses should override this method to check their keys, and then call SUPER::validate_key($self, $key, $value) to check the remaining keys.
The following exceptions may be thrown:
- Config::Apple::Profile::Payload::Common::KeyUnknown
-
Thrown if the payload key referenced is unknown.
NOTE: An exception will not be thrown if the value is found to be invalid. This is intentional!
NOTE: To test the result of this method, you should use defined
, because it's possible for a valid value to be false (for example, 0)!
PAYLOAD KEYS
Every payload type has a certain number of common keys. Those common keys are defined (not stored) in %payloadKeys
.
For general information on payload types, see Config::Apple::Profile::Payload::Types.
PayloadIdentifier
A Identifier
for this specific payload. It must be unique.
PayloadUUID
A UUID
for this specific payload. It must be unique.
PayloadDisplayName
Optional
A String
that the user will be able to see when looking at the details of the profile that is about to be installed.
PayloadDescription
Optional
A String
that the user will be able to see when looking at the details of the profile that is about to be installed.
PayloadOrganization
Optional
A String
that the user will be able to see when looking at the details of the profile that is about to be installed.
PayloadType
A Identifier
that identifies which type of payload this is. This value may not be set by the client. Instead, the value is automatically determined based on which Config::Apple::Profile::Payload::Types::
class is being used.
PayloadVersion
A Number
that identifies the version of the payload type. This specifies the version of the standard, not the client's own revision number. Right now, all payload types have a version number of 1
.
DEVELOPER NOTES
The following sections have information that will be useful to people working on the code that makes up this release.
%payloadKeys
contents
The %payloadKeys
hash is critical, so it is important to know how it is constructed. To start, each key in the hash is a key that appears in a payload. The value corresponding to the key is a hashref, which can contain the following keys:
type
-
This key's value is a value from Config::Apple::Profile::Payload::Types. It is used to specify the type of data the profile key contains.
The type is used when creating Mac::PropertyList objects, and when doing value-checking.
If a payload class uses <$ProfileClass> as a type, then the payload class is responsible for providing an instance method named
construct
, which takes the payload key name as its only parameter, and returns a new object.This key must be present.
subtype
-
This key is required when
type
is set to$ProfileDict
or$ProfileArray
.If
type
is set to$ProfileDict
, thensubtype
contains the type of data stored as values. That data type will be used for validation, when entries are added to the Perl hash representing the dictionary.If
type
is set to$ProfileArray
, thensubtype
contains the type of data stored in the array. That data type will be used for validation, when entries are added to the Perl array.If a payload class uses <$ProfileClass> as a subtype, then the payload class is responsible for providing an instance method named
construct
, which takes the payload key name as its only parameter, and returns a new object.For other values of the
type
key, this key must not be present. description
-
This key's value contains a human-readable description of the profile key. The purpose of this is so that client software can easily enumerate profile keys, such as when making a web application.
This key must be present.
targets
-
This key's value is a hashref. Within the hashref, the keys are platform identifiers, scalars taken from
Config::Apple::Profile::Targets
. The value for each key is a version object representing the earliest version of the named platform's OS which supports this payload key.If a platform does not support a particular key at all, that platform should not be included in the hashref.
This key must be present, and the hashref must contain at least one entry.
optional
-
If this key is present, then this payload key does not have to be present. This might mean that a key is completely optional (like
PayloadDescription
), or it might mean that the value will be auto-generated (likePayloadUUID
).It doesn't matter what this key is set to, its presence is what's important.
Optional checks are done when exportable is run, at the very least.
unique
-
If this key is present, then this payload key's value needs to be unique across all payloads in the profile. This is normally used for things like the UUID and the payload identifier, which need to be unique.
It doesn't matter what this key is set to, its presence is what's important.
Uniqueness checks are done during profile creation time only.
private
-
If this key is present, then this payload key's value is something that should only be transmitted when the profile is encrypted. This is meant for things like passwords, which should not be sent in the clear.
Right now, none of the code in this release does anything with this key. It is provided solely for future use.
value
-
If this key is present, then the corresponding value will be used as the value for the payload key. Any attempts by the user to change the payload key's value will throw an exception.
This is used for things like PayloadVersion and PayloadType, which are fixed.
ACKNOWLEDGEMENTS
Refer to the Config::Apple::Profile for acknowledgements.
AUTHOR
A. Karl Kornel, <karl at kornel.us>
COPYRIGHT AND LICENSE
Copyright © 2014 A. Karl Kornel.
This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.
See http://dev.perl.org/licenses/ for more information.