forked from airheartdev/duffel
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathofferrequests.go
107 lines (93 loc) · 4.5 KB
/
offerrequests.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
// Copyright 2021-present Airheart, Inc. All rights reserved.
// This source code is licensed under the Apache 2.0 license found
// in the LICENSE file in the root directory of this source tree.
package duffel
import (
"context"
"fmt"
"net/url"
"strconv"
"strings"
"time"
)
const offerRequestIDPrefix = "orq_"
type (
OfferRequestClient interface {
CreateOfferRequest(ctx context.Context, requestInput OfferRequestInput, requestOptions ...RequestOption) (*OfferRequest, error)
GetOfferRequest(ctx context.Context, offerRequestID string, requestOptions ...RequestOption) (*OfferRequest, error)
ListOfferRequests(ctx context.Context, requestOptions ...RequestOption) *Iter[OfferRequest]
}
OfferRequestInput struct {
// The passengers who want to travel. If you specify an age for a passenger, the type may differ for the same passenger in different offers due to airline's different rules. e.g. one airline may treat a 14 year old as an adult, and another as a young adult. You may only specify an age or a type – not both.
Passengers []OfferRequestPassenger `json:"passengers" url:"-"`
// The slices that make up this offer request. One-way journeys can be expressed using one slice, whereas return trips will need two.
Slices []OfferRequestSlice `json:"slices" url:"-"`
// The cabin that the passengers want to travel in
CabinClass CabinClass `json:"cabin_class" url:"-"`
// The maximum number of connections within any slice of the offer. For example 0 means a direct flight which will have a single segment within each slice and 1 means a maximum of two segments within each slice of the offer.
MaxConnections *int `json:"max_connections,omitempty" url:"-"`
// When set to true, the offer request resource returned will include all the offers returned by the airlines
ReturnOffers bool `json:"-" url:"return_offers"`
// The maximum amount of time in milliseconds to wait for each airline to respond
SupplierTimeout int `json:"-" url:"supplier_timeout,omitempty"`
}
OfferRequestSlice struct {
DepartureDate Date `json:"departure_date"`
Destination string `json:"destination"`
Origin string `json:"origin"`
}
OfferRequestPassenger struct {
ID string `json:"id,omitempty"`
FamilyName string `json:"family_name,omitempty"`
GivenName string `json:"given_name,omitempty"`
Age int `json:"age,omitempty"`
LoyaltyProgrammeAccounts []LoyaltyProgrammeAccount `json:"loyalty_programme_accounts,omitempty"`
// deprecated
Type PassengerType `json:"type,omitempty"`
}
// OfferRequest is the response from the OfferRequest endpoint, created using the OfferRequestInput.
OfferRequest struct {
ID string `json:"id"`
LiveMode bool `json:"live_mode"`
ClientKey string `json:"client_key"`
CreatedAt time.Time `json:"created_at"`
Slices []BaseSlice `json:"slices"`
Passengers []OfferRequestPassenger `json:"passengers"`
CabinClass CabinClass `json:"cabin_class"`
Offers []Offer `json:"offers"`
}
)
func (a *API) CreateOfferRequest(ctx context.Context, requestInput OfferRequestInput, requestOptions ...RequestOption) (*OfferRequest, error) {
return newRequestWithAPI[OfferRequestInput, OfferRequest](a).
Post("/air/offer_requests", &requestInput).
WithOptions(requestOptions...).
Single(ctx)
}
func (a *API) GetOfferRequest(ctx context.Context, offerRequestID string, requestOptions ...RequestOption) (*OfferRequest, error) {
if err := validateID(offerRequestID, offerRequestIDPrefix); err != nil {
return nil, err
}
return newRequestWithAPI[EmptyPayload, OfferRequest](a).
Getf("/air/offer_requests/%s", offerRequestID).
WithOptions(requestOptions...).
Single(ctx)
}
func (a *API) ListOfferRequests(ctx context.Context, requestOptions ...RequestOption) *Iter[OfferRequest] {
return newRequestWithAPI[EmptyPayload, OfferRequest](a).
Get("/air/offer_requests").
WithOptions(requestOptions...).
Iter(ctx)
}
// Encode implements the ParamEncoder interface.
func (o OfferRequestInput) Encode(q url.Values) error {
q.Set("return_offers", strconv.FormatBool(o.ReturnOffers))
return nil
}
func validateID(id, prefix string) error {
if id == "" {
return fmt.Errorf("id param is required")
} else if !strings.HasPrefix(id, prefix) {
return fmt.Errorf("id should begin with %s, but got %s", prefix, id)
}
return nil
}