本文整理汇总了Golang中encoding/json.RawMessage.UnmarshalJSON方法的典型用法代码示例。如果您正苦于以下问题:Golang RawMessage.UnmarshalJSON方法的具体用法?Golang RawMessage.UnmarshalJSON怎么用?Golang RawMessage.UnmarshalJSON使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类encoding/json.RawMessage
的用法示例。
在下文中一共展示了RawMessage.UnmarshalJSON方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: Update
func (c RecentCacheUpdater) Update(db *DB) *json.RawMessage {
users, err := db.RecentlyUpdatedUsers(12)
if err != nil {
return nil
}
items := make([]recentItem, len(users))
for index, user := range users {
logs, err := db.ClimbingLogs(user.ID)
if err != nil {
continue
}
routeIDs := make([]bson.ObjectId, 0)
for _, log := range logs {
if !log.Pending {
routeIDs = append(routeIDs, log.Route)
}
}
items[index] = recentItem{UserID: user.ID, RouteIDs: routeIDs}
}
ret, err := json.Marshal(items)
if err != nil {
fmt.Println(err)
return nil
}
j := new(json.RawMessage)
j.UnmarshalJSON(ret)
return j
}
示例2: MockSession
// MockSession creates a new mocked API session returning the JSON message stored in message.
func MockSession(message []byte) (*Session, error) {
rm := json.RawMessage{}
err := rm.UnmarshalJSON(message)
if err != nil {
return nil, err
}
return &Session{
requester: &mockRequester{message: &rm},
}, nil
}
示例3: ToSigned
func (ts SignedTimestamp) ToSigned() (*Signed, error) {
s, err := cjson.Marshal(ts.Signed)
if err != nil {
return nil, err
}
signed := json.RawMessage{}
err = signed.UnmarshalJSON(s)
if err != nil {
return nil, err
}
sigs := make([]Signature, len(ts.Signatures))
copy(sigs, ts.Signatures)
return &Signed{
Signatures: sigs,
Signed: signed,
}, nil
}
示例4: ToSigned
func (sp SignedSnapshot) ToSigned() (*Signed, error) {
s, err := cjson.Marshal(sp.Signed)
if err != nil {
return nil, err
}
signed := json.RawMessage{}
err = signed.UnmarshalJSON(s)
if err != nil {
return nil, err
}
sigs := make([]Signature, len(sp.Signatures))
copy(sigs, sp.Signatures)
return &Signed{
Signatures: sigs,
Signed: signed,
}, nil
}
示例5: PostData
func (esi *MockIndex) PostData(typeName string, id string, obj interface{}) (*IndexResponse, error) {
ok, err := esi.IndexExists()
if err != nil {
return nil, err
}
if !ok {
return nil, fmt.Errorf("Index does not exist")
}
ok, err = esi.TypeExists(typeName)
if err != nil {
return nil, err
}
var typ *MockIndexType
if !ok {
typ = &MockIndexType{}
typ.items = make(map[string]*json.RawMessage)
esi.types[typeName] = typ
} else {
typ = esi.types[typeName]
}
byts, err := json.Marshal(obj)
if err != nil {
return nil, err
}
var raw json.RawMessage
err = raw.UnmarshalJSON(byts)
if err != nil {
return nil, err
}
typ.items[id] = &raw
r := &IndexResponse{Created: true, ID: id, Index: esi.name, Type: typeName}
return r, nil
}
示例6: processOverview
//.........这里部分代码省略.........
for _, region := range regions.Regions {
fmt.Println("-", *region.RegionName)
}
ec2client = ec2.New(session.New(), &aws.Config{Region: aws.String(config.General.DefaultRegion)})
instances, err := ec2client.DescribeInstances(nil)
if err != nil {
panic(err)
}
fmt.Println("Instances:")
instanceCount := 0
instanceMap := make(map[string]ec2.Instance)
for _, reservation := range instances.Reservations {
for _, instance := range reservation.Instances {
fmt.Println("-", *instance.InstanceId)
instanceMap[*instance.InstanceId] = *instance
if *instance.State.Name == "running" {
instanceCount++
}
}
}
attachment.Fields = append(attachment.Fields, Field{Title: "Running instances", Value: fmt.Sprintf("%d", instanceCount), Short: true})
volumes, err := ec2client.DescribeVolumes(nil)
if err != nil {
panic(err)
}
attachment.Fields = append(attachment.Fields, Field{Title: "Volumes", Value: fmt.Sprintf("%d", len(volumes.Volumes)), Short: true})
securityGroups, err := ec2client.DescribeSecurityGroups(nil)
if err != nil {
panic(err)
}
securityGroupMap := make(map[string]ec2.SecurityGroup)
for _, securityGroup := range securityGroups.SecurityGroups {
securityGroupMap[*securityGroup.GroupId] = *securityGroup
}
vpcs, err := ec2client.DescribeVpcs(nil)
if err != nil {
panic(err)
}
subnets, err := ec2client.DescribeSubnets(nil)
if err != nil {
panic(err)
}
routeTables, err := ec2client.DescribeRouteTables(nil)
if err != nil {
panic(err)
}
vpcPeeringConnections, err := ec2client.DescribeVpcPeeringConnections(nil)
if err != nil {
panic(err)
}
s3client := s3.New(session.New(), &aws.Config{Region: aws.String(config.General.DefaultRegion)})
buckets, err := s3client.ListBuckets(nil)
if err != nil {
panic(err)
}
attachment.Fields = append(attachment.Fields, Field{Title: "S3 buckets", Value: fmt.Sprintf("%d", len(buckets.Buckets)), Short: true})
rdsclient := rds.New(session.New(), &aws.Config{Region: aws.String(config.General.DefaultRegion)})
dbInstances, err := rdsclient.DescribeDBInstances(nil)
if err != nil {
panic(err)
}
attachment.Fields = append(attachment.Fields, Field{Title: "DB instances", Value: fmt.Sprintf("%d", len(dbInstances.DBInstances)), Short: true})
overview := Overview{Instances: instances, SecurityGroups: securityGroups, Vpcs: vpcs, Subnets: subnets, RouteTables: routeTables, VpcPeeringConnections: vpcPeeringConnections, Buckets: buckets, DBInstances: dbInstances}
jsonData, err := json.MarshalIndent(overview, "", " ")
if err != nil {
panic(err)
}
const outputDir = "/tmp"
err = os.MkdirAll(outputDir, os.ModeDir)
if err != nil {
panic(err)
}
err = ioutil.WriteFile(outputDir+"/aws.json", jsonData, 0777)
if err != nil {
panic(err)
}
var m json.RawMessage
err = m.UnmarshalJSON(jsonData)
if err != nil {
panic(err)
}
}