forked from aws/aws-sdk-go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapi.go
131 lines (100 loc) · 4.06 KB
/
api.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT.
// Package mobileanalytics provides a client for Amazon Mobile Analytics.
package mobileanalytics
import (
"sync"
"github.com/aws/aws-sdk-go/aws"
)
var oprw sync.Mutex
// PutEventsRequest generates a request for the PutEvents operation.
func (c *MobileAnalytics) PutEventsRequest(input *PutEventsInput) (req *aws.Request, output *PutEventsOutput) {
oprw.Lock()
defer oprw.Unlock()
if opPutEvents == nil {
opPutEvents = &aws.Operation{
Name: "PutEvents",
HTTPMethod: "POST",
HTTPPath: "/2014-06-05/events",
}
}
if input == nil {
input = &PutEventsInput{}
}
req = c.newRequest(opPutEvents, input, output)
output = &PutEventsOutput{}
req.Data = output
return
}
// The PutEvents operation records one or more events. You can have up to 1,500
// unique custom events per app, any combination of up to 40 attributes and
// metrics per custom event, and any number of attribute or metric values.
func (c *MobileAnalytics) PutEvents(input *PutEventsInput) (*PutEventsOutput, error) {
req, out := c.PutEventsRequest(input)
err := req.Send()
return out, err
}
var opPutEvents *aws.Operation
// A JSON object representing a batch of unique event occurrences in your app.
type Event struct {
// A collection of key-value pairs that give additional context to the event.
// The key-value pairs are specified by the developer.
//
// This collection can be empty or the attribute object can be omitted.
Attributes map[string]*string `locationName:"attributes" type:"map"`
// A name signifying an event that occurred in your app. This is used for grouping
// and aggregating like events together for reporting purposes.
EventType *string `locationName:"eventType" type:"string" required:"true"`
// A collection of key-value pairs that gives additional, measurable context
// to the event. The key-value pairs are specified by the developer.
//
// This collection can be empty or the attribute object can be omitted.
Metrics map[string]*float64 `locationName:"metrics" type:"map"`
// The session the event occured within.
Session *Session `locationName:"session" type:"structure"`
// The time the event occurred in ISO 8601 standard date time format. For example,
// 2014-06-30T19:07:47.885Z
Timestamp *string `locationName:"timestamp" type:"string" required:"true"`
// The version of the event.
Version *string `locationName:"version" type:"string"`
metadataEvent `json:"-" xml:"-"`
}
type metadataEvent struct {
SDKShapeTraits bool `type:"structure"`
}
// A container for the data needed for a PutEvent operation
type PutEventsInput struct {
// The client context including the client ID, app title, app version and package
// name.
ClientContext *string `location:"header" locationName:"x-amz-Client-Context" type:"string" required:"true"`
// The encoding used for the client context.
ClientContextEncoding *string `location:"header" locationName:"x-amz-Client-Context-Encoding" type:"string"`
// An array of Event JSON objects
Events []*Event `locationName:"events" type:"list" required:"true"`
metadataPutEventsInput `json:"-" xml:"-"`
}
type metadataPutEventsInput struct {
SDKShapeTraits bool `type:"structure"`
}
type PutEventsOutput struct {
metadataPutEventsOutput `json:"-" xml:"-"`
}
type metadataPutEventsOutput struct {
SDKShapeTraits bool `type:"structure"`
}
// Describes the session. Session information is required on ALL events.
type Session struct {
// The duration of the session.
Duration *int64 `locationName:"duration" type:"long"`
// A unique identifier for the session
ID *string `locationName:"id" type:"string"`
// The time the event started in ISO 8601 standard date time format. For example,
// 2014-06-30T19:07:47.885Z
StartTimestamp *string `locationName:"startTimestamp" type:"string"`
// The time the event terminated in ISO 8601 standard date time format. For
// example, 2014-06-30T19:07:47.885Z
StopTimestamp *string `locationName:"stopTimestamp" type:"string"`
metadataSession `json:"-" xml:"-"`
}
type metadataSession struct {
SDKShapeTraits bool `type:"structure"`
}