forked from openshift-online/ocm-sdk-go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
transport_wrapper.go
93 lines (78 loc) · 2.67 KB
/
transport_wrapper.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
/*
Copyright (c) 2020 Red Hat, Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
// This example shows how to use a transport wrapper for the connection.
package main
import (
"context"
"fmt"
"net/http"
"os"
sdk "github.com/openshift-online/ocm-sdk-go"
"github.com/openshift-online/ocm-sdk-go/logging"
)
type LoggingTransport struct {
logger logging.Logger
wrapped http.RoundTripper
}
// NewLoggingTransport creates a transport that sends basic details of requests to the
// given logger. The wrapped transport will be used actually send the requests.
func NewLoggingTransport(logger logging.Logger, wrapped http.RoundTripper) http.RoundTripper {
return &LoggingTransport{
logger: logger,
wrapped: wrapped,
}
}
func (t *LoggingTransport) RoundTrip(request *http.Request) (response *http.Response, err error) {
t.logger.Info(request.Context(), "Sending request %s '%s'", request.Method, request.URL.String())
response, err = t.wrapped.RoundTrip(request)
if err != nil {
t.logger.Error(response.Request.Context(), "Got error sending request")
} else {
t.logger.Info(response.Request.Context(), "Got response status code %d", response.StatusCode)
}
return response, err
}
func main() {
// Create a context:
ctx := context.Background()
// Create a logger:
logger, err := logging.NewGoLoggerBuilder().
Debug(false).
Build()
if err != nil {
fmt.Fprintf(os.Stderr, "Failed to build logger: %v\n", err)
os.Exit(1)
}
// Create the connection, and remember to close it:
token := os.Getenv("OCM_TOKEN")
connection, err := sdk.NewConnectionBuilder().
Logger(logger).
Tokens(token).
TransportWrapper(func(wrapped http.RoundTripper) http.RoundTripper {
return NewLoggingTransport(logger, wrapped)
}).
BuildContext(ctx)
if err != nil {
fmt.Fprintf(os.Stderr, "Can't build connection: %v\n", err)
os.Exit(1)
}
defer connection.Close()
// Get the client for the resource that manages the collection of cloud providers:
providersCollection := connection.ClustersMgmt().V1().CloudProviders()
// Retrieve the first page of cloud providers:
_, err = providersCollection.List().SendContext(ctx)
if err != nil {
fmt.Fprintf(os.Stderr, "Failed to retrieve providers: %v\n", err)
os.Exit(1)
}
}