R/updateEntity.R

#' updateEntity - Updates an instance of a entity.
#'
#' \code{updateEntity}  Updates an instance of a entity.
#' @param coreApi coreApi object with valid jsessionid
#' @param entityType entity type to get as character string
#' @param barcode User provided barcode as a character string
#' @param attributeValues attributes as a list of key-values pairs
#' @param locationId location ID for initial location as character string
#' @param projectIds project comma separated list of project IDs as character string
#' @param associations association as a list of dataframes (see details)
#' @param useVerbose Use verbose communication for debugging
#' @export
#' @return RETURN returns a list $entity contains entity information, $response contains the
#'        entire http response
#' @examples
#'\dontrun{
#' api<-CoreAPI("PATH TO JSON FILE")
#' login<- CoreAPI::authBasic(api)
#' newitem<-CoreAPI::updateEntity(login$coreApi,entityType,barcode)
#' logOut(login$coreApi ) response<- CoreAPI::authBasic(coreApi)
#' }
#'@author Craig Parman
#'@description \code{updateEntity} Updates an instance of a entity.




updateEntity<-function (coreApi,entityType,barcode,attributeValues=NULL,
                        locationId=NULL,projectIds=NULL,associations=NULL,useVerbose=FALSE)

{


  #todo asscociations,xxx-locations, xxxx- project, xxxx-barcode

  sdkCmd<-jsonlite::unbox("update")
  data<-list()
  #data<-list(entityTypeName= jsonlite::unbox(entityType))

  if(!is.null(attributeValues))
  {

    values<-list()


    for(i in 1:length(attributeValues))
    {
      values[[names(attributeValues)[i]]] <- list(stringData= jsonlite::unbox(as.character( attributeValues[[i]] ) ))
    }

    data[["values"]]<-values
  }






  if(!is.null(locationId))
  {
    data[["locationId"]]<- jsonlite::unbox(locationId)
  }


  if(!is.null(projectIds))
  {
    data[["projectIds"]]<- jsonlite::unbox(projectIds)
  }

  if(!is.null(barcode))
  {
    data[["barcode"]]<- jsonlite::unbox(barcode)
  }


  if(!is.null(associations))
  {
    data[["associations"]]<- associations
  }




  responseOptions<-c("CONTEXT_GET","MESSAGE_LEVEL_WARN")
  logicOptions<-jsonlite::unbox("EXECUTE_TRIGGERS")
  typeParam <- jsonlite::unbox(entityType)




  request<-list(request=list(sdkCmd=sdkCmd,data=data,typeParam =typeParam,
                             responseOptions=responseOptions,
                             logicOptions=logicOptions))



  response<- CoreAPI::apiCall(coreApi,request,"json",useVerbose=useVerbose)


  list(entity=httr::content(response)$response$data,response=response)

}
ceparman/CoreAPI documentation built on May 13, 2019, 2:59 p.m.