# Copyright 2024 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 Jamf

  # This module is the namespace for all objects defined
  # in the OAPI JSON schema under the components => schemas key
  #
  module OAPISchemas


    # OAPI Object Model and Enums for: ManagedSoftwareUpdatePlan
    #
    #
    #
    # This class was automatically generated from the api/schema
    # URL path on a Jamf Pro server version 11.6.1-t1718634702
    #
    # This class may be used directly, e.g instances of other classes may
    # use instances of this class as one of their own properties/attributes.
    #
    # It may also be used as a superclass when implementing Jamf Pro API
    # Resources in ruby-jss. The subclasses include appropriate mixins, and
    # should expand on the basic functionality provided here.
    #
    #
    # Container Objects:
    # Other object models that use this model as the value in one
    # of their attributes.
    #  - Jamf::OAPISchemas::ManagedSoftwareUpdatePlans
    #
    # Sub Objects:
    # Other object models used by this model's attributes.
    #  - Jamf::OAPISchemas::PlanDevice
    #  - Jamf::OAPISchemas::PlanStatus
    #
    # Endpoints and Privileges:
    # API endpoints and HTTP operations that use this object
    # model, and the Jamf Pro privileges needed to access them.
    #  - '/v1/managed-software-updates/plans/{id}:GET' needs permissions:
    #    - Read Managed Software Updates
    #    - Read Computers
    #    - Read Mobile Devices
    #
    #
    class ManagedSoftwareUpdatePlan < Jamf::OAPIObject

      # Enums used by this class or others

      UPDATE_ACTION_OPTIONS = [
        'DOWNLOAD_ONLY',
        'DOWNLOAD_INSTALL',
        'DOWNLOAD_INSTALL_ALLOW_DEFERRAL',
        'DOWNLOAD_INSTALL_RESTART',
        'DOWNLOAD_INSTALL_SCHEDULE',
        'UNKNOWN'
      ]

      VERSION_TYPE_OPTIONS = [
        'LATEST_MAJOR',
        'LATEST_MINOR',
        'LATEST_ANY',
        'SPECIFIC_VERSION',
        'UNKNOWN'
      ]

      OAPI_PROPERTIES = {

        # @!attribute [r] planUuid
        #   @return [String]
        planUuid: {
          class: :string,
          required: true,
          readonly: true,
          min_length: 1
        },

        # @!attribute device
        #   @return [Jamf::OAPISchemas::PlanDevice]
        device: {
          class: Jamf::OAPISchemas::PlanDevice,
          required: true
        },

        # @!attribute [r] updateAction
        #   @return [String]
        updateAction: {
          class: :string,
          required: true,
          readonly: true,
          enum: UPDATE_ACTION_OPTIONS
        },

        # @!attribute [r] versionType
        #   @return [String]
        versionType: {
          class: :string,
          required: true,
          readonly: true,
          enum: VERSION_TYPE_OPTIONS
        },

        # Optional. Indicates the specific version to update to. Only available when the version type is set to specific version, otherwise defaults to NO_SPECIFIC_VERSION.
        # @!attribute [r] specificVersion
        #   @return [String]
        specificVersion: {
          class: :string,
          readonly: true
        },

        # Not applicable to all managed software update plans
        # @!attribute [r] maxDeferrals
        #   @return [Integer]
        maxDeferrals: {
          class: :integer,
          required: true,
          readonly: true,
          minimum: 0
        },

        # Optional. Indicates the local date and time of the device to force update by.
        # @!attribute forceInstallLocalDateTime
        #   @return [String]
        forceInstallLocalDateTime: {
          class: Jamf::Timestamp,
          nil_ok: true
        },

        # The id of the recipe that was used to generate the plan.
        # @!attribute [r] recipeId
        #   @return [String]
        recipeId: {
          class: :string,
          readonly: true
        },

        # @!attribute status
        #   @return [Jamf::OAPISchemas::PlanStatus]
        status: {
          class: Jamf::OAPISchemas::PlanStatus,
          required: true
        }

      } # end OAPI_PROPERTIES

    end # class ManagedSoftwareUpdatePlan

  end # module OAPISchemas

end # module Jamf