R/FeatureSetUsageDef.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


#' FeatureSetUsageDef Class
#'
#' @field name 
#' @field user 
#' @field jobid 
#' @field class 
#' @field state 
#' @field tags 
#' @field pipeline 
#'
#' @importFrom R6 R6Class
#' @importFrom jsonlite fromJSON toJSON
#' @export
FeatureSetUsageDef <- R6::R6Class(
  'FeatureSetUsageDef',
  public = list(
    `name` = NULL,
    `user` = NULL,
    `jobid` = NULL,
    `class` = NULL,
    `state` = NULL,
    `tags` = NULL,
    `pipeline` = NULL,
    initialize = function(`name`, `user`, `jobid`, `class`, `state`, `tags`, `pipeline`){
      if (!missing(`name`)) {
        stopifnot(is.character(`name`), length(`name`) == 1)
        self$`name` <- `name`
      }
      if (!missing(`user`)) {
        stopifnot(is.character(`user`), length(`user`) == 1)
        self$`user` <- `user`
      }
      if (!missing(`jobid`)) {
        stopifnot(is.character(`jobid`), length(`jobid`) == 1)
        self$`jobid` <- `jobid`
      }
      if (!missing(`class`)) {
        stopifnot(is.character(`class`), length(`class`) == 1)
        self$`class` <- `class`
      }
      if (!missing(`state`)) {
        stopifnot(is.character(`state`), length(`state`) == 1)
        self$`state` <- `state`
      }
      if (!missing(`tags`)) {
        stopifnot(is.list(`tags`), length(`tags`) != 0)
        lapply(`tags`, function(x) stopifnot(is.character(x)))
        self$`tags` <- `tags`
      }
      if (!missing(`pipeline`)) {
        stopifnot(R6::is.R6(`pipeline`))
        self$`pipeline` <- `pipeline`
      }
    },
    toJSON = function() {
      FeatureSetUsageDefObject <- list()
      if (!is.null(self$`name`)) {
        FeatureSetUsageDefObject[['name']] <- self$`name`
      }
      if (!is.null(self$`user`)) {
        FeatureSetUsageDefObject[['user']] <- self$`user`
      }
      if (!is.null(self$`jobid`)) {
        FeatureSetUsageDefObject[['jobid']] <- self$`jobid`
      }
      if (!is.null(self$`class`)) {
        FeatureSetUsageDefObject[['class']] <- self$`class`
      }
      if (!is.null(self$`state`)) {
        FeatureSetUsageDefObject[['state']] <- self$`state`
      }
      if (!is.null(self$`tags`)) {
        FeatureSetUsageDefObject[['tags']] <- self$`tags`
      }
      if (!is.null(self$`pipeline`)) {
        FeatureSetUsageDefObject[['pipeline']] <- self$`pipeline`$toJSON()
      }

      FeatureSetUsageDefObject
    },
    fromJSON = function(FeatureSetUsageDefJson) {
      FeatureSetUsageDefObject <- jsonlite::fromJSON(FeatureSetUsageDefJson)
      if (!is.null(FeatureSetUsageDefObject$`name`)) {
        self$`name` <- FeatureSetUsageDefObject$`name`
      }
      if (!is.null(FeatureSetUsageDefObject$`user`)) {
        self$`user` <- FeatureSetUsageDefObject$`user`
      }
      if (!is.null(FeatureSetUsageDefObject$`jobid`)) {
        self$`jobid` <- FeatureSetUsageDefObject$`jobid`
      }
      if (!is.null(FeatureSetUsageDefObject$`class`)) {
        self$`class` <- FeatureSetUsageDefObject$`class`
      }
      if (!is.null(FeatureSetUsageDefObject$`state`)) {
        self$`state` <- FeatureSetUsageDefObject$`state`
      }
      if (!is.null(FeatureSetUsageDefObject$`tags`)) {
        self$`tags` <- FeatureSetUsageDefObject$`tags`
      }
      if (!is.null(FeatureSetUsageDefObject$`pipeline`)) {
        pipelineObject <- DatumJobDetailsPipeline$new()
        pipelineObject$fromJSON(jsonlite::toJSON(FeatureSetUsageDefObject$pipeline, auto_unbox = TRUE))
        self$`pipeline` <- pipelineObject
      }
    },
    toJSONString = function() {
       sprintf(
        '{
           "name": %s,
           "user": %s,
           "jobid": %s,
           "class": %s,
           "state": %s,
           "tags": [%s],
           "pipeline": %s
        }',
        self$`name`,
        self$`user`,
        self$`jobid`,
        self$`class`,
        self$`state`,
        lapply(self$`tags`, function(x) paste(paste0('"', x, '"'), sep=",")),
        self$`pipeline`$toJSON()
      )
    },
    fromJSONString = function(FeatureSetUsageDefJson) {
      FeatureSetUsageDefObject <- jsonlite::fromJSON(FeatureSetUsageDefJson)
      self$`name` <- FeatureSetUsageDefObject$`name`
      self$`user` <- FeatureSetUsageDefObject$`user`
      self$`jobid` <- FeatureSetUsageDefObject$`jobid`
      self$`class` <- FeatureSetUsageDefObject$`class`
      self$`state` <- FeatureSetUsageDefObject$`state`
      self$`tags` <- FeatureSetUsageDefObject$`tags`
      DatumJobDetailsPipelineObject <- DatumJobDetailsPipeline$new()
      self$`pipeline` <- DatumJobDetailsPipelineObject$fromJSON(jsonlite::toJSON(FeatureSetUsageDefObject$pipeline, auto_unbox = TRUE))
    }
  )
)
riteshkarvaloc/dkubeR documentation built on Feb. 25, 2021, 9:28 p.m.