本文整理汇总了Golang中duov6/com/objectstore/messaging.ObjectRequest.Controls方法的典型用法代码示例。如果您正苦于以下问题:Golang ObjectRequest.Controls方法的具体用法?Golang ObjectRequest.Controls怎么用?Golang ObjectRequest.Controls使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类duov6/com/objectstore/messaging.ObjectRequest
的用法示例。
在下文中一共展示了ObjectRequest.Controls方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: getObjectRequest
//.........这里部分代码省略.........
//isTokenValid, _ := validateSecurityToken(headerToken, headerNamespace)
isTokenValid := true
if isTokenValid {
if r.Method != "GET" {
rb, rerr := ioutil.ReadAll(r.Body)
if rerr != nil {
message = "Error converting request : " + rerr.Error()
isSuccess = false
} else {
err := json.Unmarshal(rb, &requestBody)
if err != nil {
message = "JSON Parse error in Request : " + err.Error()
isSuccess = false
} else {
objectRequest.Body = requestBody
}
}
}
if isSuccess {
canAddHeader := true
switch r.Method {
case "GET": //read keyword, and unique key
if len(headerId) != 0 {
headerOperation = "read-key"
} else if len(headerKeyword) != 0 {
objectRequest.Body = messaging.RequestBody{}
objectRequest.Body.Query = messaging.Query{Parameters: headerKeyword}
headerOperation = "read-keyword"
} else if len(headerNamespace) != 0 && len(headerClass) != 0 {
headerOperation = "read-all"
}
canAddHeader = false
case "POST": //read query, read special, insert
if len(requestBody.Object) != 0 || len(requestBody.Objects) != 0 {
fmt.Println("Insert by POST : " + objectRequest.Body.Parameters.KeyProperty)
headerOperation = "insert"
if len(objectRequest.Body.Object) != 0 {
headerId = objectRequest.Body.Object[objectRequest.Body.Parameters.KeyProperty].(string)
}
} else if requestBody.Query.Type != "" && requestBody.Query.Type != " " {
fmt.Println("Query Function Identified!")
headerOperation = "read-filter"
canAddHeader = false
} else if requestBody.Special.Type != "" && requestBody.Special.Type != " " {
fmt.Println("Special Function Identified!")
headerOperation = "special"
canAddHeader = false
}
case "PUT": //update
if len(objectRequest.Body.Objects) != 0 {
headerOperation = "update"
} else {
headerId = objectRequest.Body.Object[objectRequest.Body.Parameters.KeyProperty].(string)
headerOperation = "update"
}
case "DELETE": //delete
if len(objectRequest.Body.Objects) != 0 {
headerOperation = "delete"
} else {
headerId = objectRequest.Body.Object[objectRequest.Body.Parameters.KeyProperty].(string)
headerOperation = "delete"
}
}
if len(objectRequest.Body.Objects) != 0 {
headerMultipliciry = "multiple"
} else if len(objectRequest.Body.Object) != 0 {
headerMultipliciry = "single"
}
objectRequest.Controls = messaging.RequestControls{SecurityToken: headerToken, SendMetaData: sendMetaData, Namespace: headerNamespace, Class: headerClass, Multiplicity: headerMultipliciry, Id: headerId, Operation: headerOperation}
configObject := configuration.ConfigurationManager{}.Get(headerToken, headerNamespace, headerClass)
objectRequest.Configuration = configObject
if canAddHeader {
//This was changed on 2015-08-04
//From now on headers will be added in repositories.RepositoryExecutor.go
//Why this wasn't removed then? Without this note you could have deleted this.
//SAVING IT FOR A RAINY DAY! Stop questioning the dev!
repositories.FillControlHeaders(objectRequest)
}
}
} else {
isSuccess = false
message = "Access token not validated." + missingFields
}
} else {
message = "Missing attributes in request header : " + missingFields
}
return
}