# Copyright 2020 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. # # # The Module module Jamf # A collection of methods for validating values. Mostly for # ensuring the validity of data being set as attributes of APIObject # subclass instances. # # Some of these methods can take multiple input types, such as a String # or an Array. All of them will either raise an exception # if the value isn't valid, or will return a standardized form of the input # (e.g. an Array, even if given a String) # module Validate # The regular expression that matches a valid MAC address. MAC_ADDR_RE = /^[a-f0-9]{2}(:[a-f0-9]{2}){5}$/i.freeze # Validate the format and content of a MAC address # # @param val[String] The value to validate # # @param msg[String] A custom error message when the value is invalid # # @return [String] The valid value # def self.mac_address(val, msg = nil) msg ||= "Not a valid MAC address: '#{val}'" raise Jamf::InvalidDataError, msg unless val =~ MAC_ADDR_RE val end # Validate the format and content of an IPv4 address # # @param val[String] The value to validate # # @param msg[String] A custom error message when the value is invalid # # @return [String] The valid value # def self.ip_address(val, msg = nil) msg ||= "Not a valid IPv4 address: '#{val}'" ok = true parts = val.strip.split '.' ok = false unless parts.size == 4 parts.each { |p| ok = false unless p.j_integer? && p.to_i < 256 && p.to_i >= 0 } raise Jamf::InvalidDataError, msg unless ok val end # Does a given JSONObject class have a given JSON attribute? # # @param klass [