# Copyright 2023 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 # Classes ##################################### # An API Role in the Jamf Pro API # # API Roles are predefined sets of privileges that can be assigned to API Clients, aka API Integrations. # class APIClient < Jamf::OAPISchemas::ApiIntegrationResponse include Jamf::CollectionResource extend Jamf::Filterable ########### RELATED OAPI OBJECTS # These objects should be OAPIObjects, NOT subclasses of them and # not Collection or Singleton resources. # # TODO: See if these constants can be auto-generated from the # OAPI schema and baked into the parent class # The OAPI object class we get back from a 'list' query to get the # whole collection, or a subset of it. It contains a :results key # which is an array of data for objects of the parent class. SEARCH_RESULT_OBJECT = Jamf::OAPISchemas::ApiIntegrationSearchResult # The OAPI object class we send with a POST request to make a new member of # the collection in Jamf. This is usually the same as the parent class. POST_OBJECT = Jamf::OAPISchemas::ApiIntegrationRequest # The OAPI object class we send with a PUT request to change an object in # Jamf by specifying all its values. Most updates happen this way, # and this is usually the same as the parent class PUT_OBJECT = Jamf::OAPISchemas::ApiIntegrationRequest # The OAPI object we send with a PATCH request to change an object in # Jamf by replacing only some of its values. This is never the same as the # parent class, and is usually used when many or most of the data about an # object cannot be changed via the API. # PATCH_OBJECT = Jamf::OAPISchemas::Building ############# API PATHS # The path for GETting the list of all objects in the collection, possibly # filtered, sorted, and/or paged # REQUIRED for all collection resources # # GET_PATH, POST_PATH, PUT_PATH, PATCH_PATH, and DELETE_PATH are automatically # assumed from the LIST_PATH if they follow the standards: # - GET_PATH = "#{LIST_PATH}/id" # - fetch an object from the collection # - POST_PATH = LIST_PATH # - create a new object in the collection # - PUT_PATH = "#{LIST_PATH}/id" # - update an object passing all its values back. # Most objects use this or PATCH but not both # - PATCH_PATH = "#{LIST_PATH}/id" # - update an object passing some of its values back # Most objects use this or PUT but not both # - DELETE_PATH = "#{LIST_PATH}/id" # - delete an object from the collection # # If those paths differ from the standards, the constants must be defined # here # LIST_PATH = 'v1/api-integrations'.freeze # The path that returns a list of all available privs NEW_CREDENTIALS_PATH_SUFFIX = 'client-credentials' # When creating new credentials, an instance of this is returned NEW_CREDENTIALS_OBJECT = Jamf::OAPISchemas::OAuthClientCredentials # Identifiers not marked in the superclass's OAPI_PROPERTIES constant # which usually only identifies ':id' ALT_IDENTIFIERS = %i[displayName].freeze # Must define this when extending Filterable FILTER_KEYS = %i[ id displayName ].freeze # Class Methods ############################### # For the given API Client, replace the existing clientSecret with a new one, to be # used with the clientID for generating a connection token. # # IMPORTANT: When you do this, the previous secret becomes immediately invalid and # can no longer be used for generating connection tokens. # BE SURE to capture the output in a variable, or display it somewhere immediately, # as it will not be available ever again. # See the Jamf Pro docs at # https://learn.jamf.com/bundle/jamf-pro-documentation-current/page/API_Roles_and_Clients.html # # @param client_ident [String, Integer] The displayName or id of the APIClient # for which to generate a new secret. # # @param cnx [Jamf::APIConnection] The API connection through which to perform # the operation # # @return [String] The new valid secret for use with the clientId # def self.rotate_secret(client_ident, cnx: Jamf.cnx) valid_id = valid_id(client_ident, cnx: cnx) raise Jamf::NoSuchItemError, "No APIClient matching '#{client_ident}'" unless valid_id creds = NEW_CREDENTIALS_OBJECT.new cnx.jp_post("#{LIST_PATH}/#{valid_id}/#{NEW_CREDENTIALS_PATH_SUFFIX}", nil) creds.clientSecret end # Instance Attributes and Methods ########################### # For this API Client, replace the existing clientSecret with a new one, to be # used with the clientID for generating a connection token. # # IMPORTANT: When you do this, the previous secret becomes immediately invalid and # can no longer be used for generating connection tokens. # BE SURE to capture the output in a variable, or display it somewhere immediately, # as it will not be available ever again. # See the Jamf Pro docs at # https://learn.jamf.com/bundle/jamf-pro-documentation-current/page/API_Roles_and_Clients.html # # @return [String] The new valid secret for use with the clientId # def rotate_secret self.class.rotate_secret(id, cnx: cnx) end # In the UI these are the 'API Roles', not 'authorization scopes' alias roles authorizationScopes alias roles= authorizationScopes= alias roles_append authorizationScopes_append alias roles_delete authorizationScopes_delete alias roles_delete_at authorizationScopes_delete_at alias roles_delete_if authorizationScopes_delete_if alias roles_insert authorizationScopes_insert alias roles_prepend authorizationScopes_prepend end # class end # module