R/Data30.r

# Dkube api server
#
# No description provided (generated by Swagger Codegen https://github.com/swagger-api/swagger-codegen)
#
# OpenAPI spec version: 2.2.1.11
# 
# Generated by: https://github.com/swagger-api/swagger-codegen.git


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

      Data30Object
    },
    fromJSON = function(Data30Json) {
      Data30Object <- jsonlite::fromJSON(Data30Json)
      if (!is.null(Data30Object$`uid`)) {
        self$`uid` <- Data30Object$`uid`
      }
      if (!is.null(Data30Object$`kind`)) {
        self$`kind` <- Data30Object$`kind`
      }
      if (!is.null(Data30Object$`namespace`)) {
        self$`namespace` <- Data30Object$`namespace`
      }
      if (!is.null(Data30Object$`volumes`)) {
        self$`volumes` <- lapply(Data30Object$`volumes`, function(x) {
          volumesObject <- ArtifactVolume$new()
          volumesObject$fromJSON(jsonlite::toJSON(x, auto_unbox = TRUE))
          volumesObject
        })
      }
    },
    toJSONString = function() {
       sprintf(
        '{
           "uid": %s,
           "kind": %s,
           "namespace": %s,
           "volumes": [%s]
        }',
        self$`uid`,
        self$`kind`,
        self$`namespace`,
        lapply(self$`volumes`, function(x) paste(x$toJSON(), sep=","))
      )
    },
    fromJSONString = function(Data30Json) {
      Data30Object <- jsonlite::fromJSON(Data30Json)
      self$`uid` <- Data30Object$`uid`
      self$`kind` <- Data30Object$`kind`
      self$`namespace` <- Data30Object$`namespace`
      self$`volumes` <- lapply(Data30Object$`volumes`, function(x) ArtifactVolume$new()$fromJSON(jsonlite::toJSON(x, auto_unbox = TRUE)))
    }
  )
)
riteshkarvaloc/dkubeR documentation built on Feb. 25, 2021, 9:28 p.m.