Test case updates
[nonrtric.git] / auth-token-fetch / HTTPClient.go
1 // -
2 //   ========================LICENSE_START=================================
3 //   O-RAN-SC
4 //   %%
5 //   Copyright (C) 2022: Nordix Foundation
6 //   %%
7 //   Licensed under the Apache License, Version 2.0 (the "License");
8 //   you may not use this file except in compliance with the License.
9 //   You may obtain a copy of the License at
10 //
11 //        http://www.apache.org/licenses/LICENSE-2.0
12 //
13 //   Unless required by applicable law or agreed to in writing, software
14 //   distributed under the License is distributed on an "AS IS" BASIS,
15 //   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 //   See the License for the specific language governing permissions and
17 //   limitations under the License.
18 //   ========================LICENSE_END===================================
19 //
20
21 package main
22
23 import (
24         "crypto/tls"
25         "crypto/x509"
26
27         "net/http"
28         "time"
29 )
30
31 func CreateHttpClient(cert tls.Certificate, caCerts *x509.CertPool, timeout time.Duration) *http.Client {
32         return &http.Client{
33                 Timeout:   timeout,
34                 Transport: createTransport(cert, caCerts),
35         }
36 }
37
38 func createTransport(cert tls.Certificate, caCerts *x509.CertPool) *http.Transport {
39         return &http.Transport{
40                 TLSClientConfig: &tls.Config{
41                         ClientCAs: caCerts,
42                         RootCAs:   caCerts,
43                         Certificates: []tls.Certificate{
44                                 cert,
45                         },
46                         InsecureSkipVerify: true,
47                 },
48         }
49 }