### Copyright 2017 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 Constants
  #####################################

  #####################################
  ### Module Variables
  #####################################

  #####################################
  ### Module Methods
  #####################################

  #####################################
  ### Classes
  #####################################

  ###
  ### A Mobile Device group in the JSS
  ###
  ### See also the parent class JSS::Group
  ###
  ### @see JSS::APIObject
  ###
  ### @see JSS::Group
  ###
  class MobileDeviceGroup < JSS::Group

    #####################################
    ### Mix-Ins
    #####################################
    include JSS::MDM

    #####################################
    ### Class Constants
    #####################################

    ### The base for REST resources of this class
    RSRC_BASE = "mobiledevicegroups"

    ### the hash key used for the JSON list output of all objects in the JSS
    RSRC_LIST_KEY = :mobile_device_groups

    ### The hash key used for the JSON object output.
    ### It's also used in various error messages
    RSRC_OBJECT_KEY = :mobile_device_group

    ### these keys, as well as :id and :name,  are present in valid API JSON data for this class
    VALID_DATA_KEYS = [:is_smart, :mobile_devices ]

    ### this allows the parent Group class to do things right
    MEMBER_CLASS = JSS::MobileDevice

    # the object type for this object in
    # the object history table.
    # See {APIObject#add_object_history_entry}
    OBJECT_HISTORY_OBJECT_TYPE = 25

    # what kind of devices are these WRT MDM
    MDM_COMMAND_TARGET = :mobiledevicegroups

    #####################################
    ### Class Variables
    #####################################

    #####################################
    ### Class Methods
    #####################################

    #####################################
    ### Attributes
    #####################################

    #####################################
    ### Public Instance Methods
    #####################################

    ###
    ### Return an array of the udids of mobile_devices in this group
    ###
    ### @return [Array<String>] the member udids
    ###
    def member_udids
      @members.map{|m| m[:udid]}
    end

    ###
    ### Return an array of the serial numbers of mobile_devices in this group
    ###
    ### @return [Array<String>] the member serial numbers
    ###
    def member_serial_numbers
      @members.map{|m| m[:serial_number]}
    end

    ###
    ### Return an array of the mac_addrs of mobile_devices in this group
    ###
    ### @return [Array<String>] the member mac addresses
    ###
    def member_mac_addresses
      @members.map{|m| m[:mac_address]}
    end

    ###
    ### Return an array of the wifi mac_addrs of mobile_devices in this group
    ###
    ### @return [Array<String>] the member wifi mac addresses
    ###
    def member_wifi_mac_addresses
      @members.map{|m| m[:wifi_mac_address]}
    end

    #####################################
    ### Private Instance Methods
    #####################################


  end # class ComputerGroup

end # module