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


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

      ModelDetailsTensorpbSignaturesObject
    },
    fromJSON = function(ModelDetailsTensorpbSignaturesJson) {
      ModelDetailsTensorpbSignaturesObject <- jsonlite::fromJSON(ModelDetailsTensorpbSignaturesJson)
      if (!is.null(ModelDetailsTensorpbSignaturesObject$`name`)) {
        self$`name` <- ModelDetailsTensorpbSignaturesObject$`name`
      }
      if (!is.null(ModelDetailsTensorpbSignaturesObject$`method`)) {
        self$`method` <- ModelDetailsTensorpbSignaturesObject$`method`
      }
      if (!is.null(ModelDetailsTensorpbSignaturesObject$`inputs`)) {
        self$`inputs` <- lapply(ModelDetailsTensorpbSignaturesObject$`inputs`, function(x) {
          inputsObject <- Tensor$new()
          inputsObject$fromJSON(jsonlite::toJSON(x, auto_unbox = TRUE))
          inputsObject
        })
      }
      if (!is.null(ModelDetailsTensorpbSignaturesObject$`outputs`)) {
        self$`outputs` <- lapply(ModelDetailsTensorpbSignaturesObject$`outputs`, function(x) {
          outputsObject <- Tensor$new()
          outputsObject$fromJSON(jsonlite::toJSON(x, auto_unbox = TRUE))
          outputsObject
        })
      }
    },
    toJSONString = function() {
       sprintf(
        '{
           "name": %s,
           "method": %s,
           "inputs": [%s],
           "outputs": [%s]
        }',
        self$`name`,
        self$`method`,
        lapply(self$`inputs`, function(x) paste(x$toJSON(), sep=",")),
        lapply(self$`outputs`, function(x) paste(x$toJSON(), sep=","))
      )
    },
    fromJSONString = function(ModelDetailsTensorpbSignaturesJson) {
      ModelDetailsTensorpbSignaturesObject <- jsonlite::fromJSON(ModelDetailsTensorpbSignaturesJson)
      self$`name` <- ModelDetailsTensorpbSignaturesObject$`name`
      self$`method` <- ModelDetailsTensorpbSignaturesObject$`method`
      self$`inputs` <- lapply(ModelDetailsTensorpbSignaturesObject$`inputs`, function(x) Tensor$new()$fromJSON(jsonlite::toJSON(x, auto_unbox = TRUE)))
      self$`outputs` <- lapply(ModelDetailsTensorpbSignaturesObject$`outputs`, function(x) Tensor$new()$fromJSON(jsonlite::toJSON(x, auto_unbox = TRUE)))
    }
  )
)
riteshkarvaloc/dkubeR documentation built on Feb. 25, 2021, 9:28 p.m.