diff options
Diffstat (limited to 'vendor/github.com/yaegashi/msgraph.go/beta/CalendarAction.go')
-rw-r--r-- | vendor/github.com/yaegashi/msgraph.go/beta/CalendarAction.go | 106 |
1 files changed, 106 insertions, 0 deletions
diff --git a/vendor/github.com/yaegashi/msgraph.go/beta/CalendarAction.go b/vendor/github.com/yaegashi/msgraph.go/beta/CalendarAction.go new file mode 100644 index 00000000..a2cdbbba --- /dev/null +++ b/vendor/github.com/yaegashi/msgraph.go/beta/CalendarAction.go @@ -0,0 +1,106 @@ +// Code generated by msgraph-generate.go DO NOT EDIT. + +package msgraph + +import ( + "context" + "fmt" + "io/ioutil" + "net/http" + + "github.com/yaegashi/msgraph.go/jsonx" +) + +// CalendarGetScheduleRequestParameter undocumented +type CalendarGetScheduleRequestParameter struct { + // Schedules undocumented + Schedules []string `json:"Schedules,omitempty"` + // EndTime undocumented + EndTime *DateTimeTimeZone `json:"EndTime,omitempty"` + // StartTime undocumented + StartTime *DateTimeTimeZone `json:"StartTime,omitempty"` + // AvailabilityViewInterval undocumented + AvailabilityViewInterval *int `json:"AvailabilityViewInterval,omitempty"` +} + +// +type CalendarGetScheduleRequestBuilder struct{ BaseRequestBuilder } + +// GetSchedule action undocumented +func (b *CalendarRequestBuilder) GetSchedule(reqObj *CalendarGetScheduleRequestParameter) *CalendarGetScheduleRequestBuilder { + bb := &CalendarGetScheduleRequestBuilder{BaseRequestBuilder: b.BaseRequestBuilder} + bb.BaseRequestBuilder.baseURL += "/getSchedule" + bb.BaseRequestBuilder.requestObject = reqObj + return bb +} + +// +type CalendarGetScheduleRequest struct{ BaseRequest } + +// +func (b *CalendarGetScheduleRequestBuilder) Request() *CalendarGetScheduleRequest { + return &CalendarGetScheduleRequest{ + BaseRequest: BaseRequest{baseURL: b.baseURL, client: b.client, requestObject: b.requestObject}, + } +} + +// +func (r *CalendarGetScheduleRequest) Paging(ctx context.Context, method, path string, obj interface{}) ([][]ScheduleInformation, error) { + req, err := r.NewJSONRequest(method, path, obj) + if err != nil { + return nil, err + } + if ctx != nil { + req = req.WithContext(ctx) + } + res, err := r.client.Do(req) + if err != nil { + return nil, err + } + var values [][]ScheduleInformation + for { + defer res.Body.Close() + if res.StatusCode != http.StatusOK { + b, _ := ioutil.ReadAll(res.Body) + errRes := &ErrorResponse{Response: res} + err := jsonx.Unmarshal(b, errRes) + if err != nil { + return nil, fmt.Errorf("%s: %s", res.Status, string(b)) + } + return nil, errRes + } + var ( + paging Paging + value [][]ScheduleInformation + ) + err := jsonx.NewDecoder(res.Body).Decode(&paging) + if err != nil { + return nil, err + } + err = jsonx.Unmarshal(paging.Value, &value) + if err != nil { + return nil, err + } + values = append(values, value...) + if len(paging.NextLink) == 0 { + return values, nil + } + req, err = http.NewRequest("GET", paging.NextLink, nil) + if ctx != nil { + req = req.WithContext(ctx) + } + res, err = r.client.Do(req) + if err != nil { + return nil, err + } + } +} + +// +func (r *CalendarGetScheduleRequest) Get(ctx context.Context) ([][]ScheduleInformation, error) { + var query string + if r.query != nil { + query = "?" + r.query.Encode() + } + return r.Paging(ctx, "GET", query, nil) +} |