R/CredentialsGroupDTO.r

# OpenSilex API
#
# No description provided (generated by Swagger Codegen https://github.com/swagger-api/swagger-codegen)
#
# OpenAPI spec version: 1.0.0-rc+2
# 
# Generated by: https://github.com/swagger-api/swagger-codegen.git


#' CredentialsGroupDTO Class
#'
#' @field group_id 
#' @field group_key_name 
#' @field credentials 
#'
#' @importFrom R6 R6Class
#' @importFrom jsonlite fromJSON toJSON
#' @export
CredentialsGroupDTO <- R6::R6Class(
  'CredentialsGroupDTO',
  public = list(
    `group_id` = NULL,
    `group_key_name` = NULL,
    `credentials` = NULL,
    initialize = function(`group_id`, `group_key_name`, `credentials`){
      if (!missing(`group_id`)) {
        stopifnot(is.character(`group_id`), length(`group_id`) == 1)
        self$`group_id` <- `group_id`
      }
      if (!missing(`group_key_name`)) {
        stopifnot(is.character(`group_key_name`), length(`group_key_name`) == 1)
        self$`group_key_name` <- `group_key_name`
      }
      if (!missing(`credentials`)) {
        stopifnot(is.list(`credentials`), length(`credentials`) != 0)
        lapply(`credentials`, function(x) stopifnot(R6::is.R6(x)))
        self$`credentials` <- `credentials`
      }
    },
    toJSON = function() {
      CredentialsGroupDTOObject <- list()
      if (!is.null(self$`group_id`)) {
        CredentialsGroupDTOObject[['group_id']] <- self$`group_id`
      }
      if (!is.null(self$`group_key_name`)) {
        CredentialsGroupDTOObject[['group_key_name']] <- self$`group_key_name`
      }
      if (!is.null(self$`credentials`)) {
        CredentialsGroupDTOObject[['credentials']] <- lapply(self$`credentials`, function(x) x$toJSON())
      }

      CredentialsGroupDTOObject
    },
    fromJSON = function(CredentialsGroupDTOJson) {
      CredentialsGroupDTOObject <- jsonlite::fromJSON(CredentialsGroupDTOJson)
      if (!is.null(CredentialsGroupDTOObject$`group_id`)) {
        self$`group_id` <- CredentialsGroupDTOObject$`group_id`
      }
      if (!is.null(CredentialsGroupDTOObject$`group_key_name`)) {
        self$`group_key_name` <- CredentialsGroupDTOObject$`group_key_name`
      }
      if (!is.null(CredentialsGroupDTOObject$`credentials`)) {
        self$`credentials` <- lapply(CredentialsGroupDTOObject$`credentials`, function(x) {
          credentialsObject <- CredentialDTO$new()
          credentialsObject$fromJSON(jsonlite::toJSON(x, auto_unbox = TRUE, null = "null"))
          credentialsObject
        })
      }
    },
    fromJSONObject = function(CredentialsGroupDTOObject) {
      if (!is.null(CredentialsGroupDTOObject$`group_id`)) {
        self$`group_id` <- CredentialsGroupDTOObject$`group_id`
      }
      if (!is.null(CredentialsGroupDTOObject$`group_key_name`)) {
        self$`group_key_name` <- CredentialsGroupDTOObject$`group_key_name`
      }
      if (!is.null(CredentialsGroupDTOObject$`credentials`)) {
        self$`credentials` <- lapply(CredentialsGroupDTOObject$`credentials`, function(x) {
          credentialsObject <- CredentialDTO$new()
          credentialsObject$fromJSON(jsonlite::toJSON(x, auto_unbox = TRUE, null = "null"))
          credentialsObject
        })
      }
    },
    toJSONString = function() {
      credentialsList = paste(lapply(self$`credentials`, function(x) x$toJSONString()),collapse = ",")
       sprintf(
        '{
           "group_id": %s,
           "group_key_name": %s,
           "credentials": [%s]
        }',
        ifelse(is.null(self$`group_id`), "null",jsonlite::toJSON(self$`group_id`,auto_unbox=TRUE, null = "null")),
        ifelse(is.null(self$`group_key_name`), "null",jsonlite::toJSON(self$`group_key_name`,auto_unbox=TRUE, null = "null")),
        credentialsList
      )
    },
    fromJSONString = function(CredentialsGroupDTOJson) {
      CredentialsGroupDTOObject <- jsonlite::fromJSON(CredentialsGroupDTOJson)
      self$`group_id` <- CredentialsGroupDTOObject$`group_id`
      self$`group_key_name` <- CredentialsGroupDTOObject$`group_key_name`
      self$`credentials` <- lapply(CredentialsGroupDTOObject$`credentials`, function(x) CredentialDTO$new()$fromJSON(jsonlite::toJSON(x, auto_unbox = TRUE)))
    }
  )
)
OpenSILEX/opensilexClientToolsR documentation built on Jan. 28, 2022, 5:03 a.m.