github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6@v6.2.0/fake/peerexpressroutecircuitconnections_server.go (about) 1 //go:build go1.18 2 // +build go1.18 3 4 // Copyright (c) Microsoft Corporation. All rights reserved. 5 // Licensed under the MIT License. See License.txt in the project root for license information. 6 // Code generated by Microsoft (R) AutoRest Code Generator. DO NOT EDIT. 7 // Changes may cause incorrect behavior and will be lost if the code is regenerated. 8 9 package fake 10 11 import ( 12 "context" 13 "errors" 14 "fmt" 15 azfake "github.com/Azure/azure-sdk-for-go/sdk/azcore/fake" 16 "github.com/Azure/azure-sdk-for-go/sdk/azcore/fake/server" 17 "github.com/Azure/azure-sdk-for-go/sdk/azcore/runtime" 18 "github.com/Azure/azure-sdk-for-go/sdk/azcore/to" 19 "github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6" 20 "net/http" 21 "net/url" 22 "regexp" 23 ) 24 25 // PeerExpressRouteCircuitConnectionsServer is a fake server for instances of the armnetwork.PeerExpressRouteCircuitConnectionsClient type. 26 type PeerExpressRouteCircuitConnectionsServer struct { 27 // Get is the fake for method PeerExpressRouteCircuitConnectionsClient.Get 28 // HTTP status codes to indicate success: http.StatusOK 29 Get func(ctx context.Context, resourceGroupName string, circuitName string, peeringName string, connectionName string, options *armnetwork.PeerExpressRouteCircuitConnectionsClientGetOptions) (resp azfake.Responder[armnetwork.PeerExpressRouteCircuitConnectionsClientGetResponse], errResp azfake.ErrorResponder) 30 31 // NewListPager is the fake for method PeerExpressRouteCircuitConnectionsClient.NewListPager 32 // HTTP status codes to indicate success: http.StatusOK 33 NewListPager func(resourceGroupName string, circuitName string, peeringName string, options *armnetwork.PeerExpressRouteCircuitConnectionsClientListOptions) (resp azfake.PagerResponder[armnetwork.PeerExpressRouteCircuitConnectionsClientListResponse]) 34 } 35 36 // NewPeerExpressRouteCircuitConnectionsServerTransport creates a new instance of PeerExpressRouteCircuitConnectionsServerTransport with the provided implementation. 37 // The returned PeerExpressRouteCircuitConnectionsServerTransport instance is connected to an instance of armnetwork.PeerExpressRouteCircuitConnectionsClient via the 38 // azcore.ClientOptions.Transporter field in the client's constructor parameters. 39 func NewPeerExpressRouteCircuitConnectionsServerTransport(srv *PeerExpressRouteCircuitConnectionsServer) *PeerExpressRouteCircuitConnectionsServerTransport { 40 return &PeerExpressRouteCircuitConnectionsServerTransport{ 41 srv: srv, 42 newListPager: newTracker[azfake.PagerResponder[armnetwork.PeerExpressRouteCircuitConnectionsClientListResponse]](), 43 } 44 } 45 46 // PeerExpressRouteCircuitConnectionsServerTransport connects instances of armnetwork.PeerExpressRouteCircuitConnectionsClient to instances of PeerExpressRouteCircuitConnectionsServer. 47 // Don't use this type directly, use NewPeerExpressRouteCircuitConnectionsServerTransport instead. 48 type PeerExpressRouteCircuitConnectionsServerTransport struct { 49 srv *PeerExpressRouteCircuitConnectionsServer 50 newListPager *tracker[azfake.PagerResponder[armnetwork.PeerExpressRouteCircuitConnectionsClientListResponse]] 51 } 52 53 // Do implements the policy.Transporter interface for PeerExpressRouteCircuitConnectionsServerTransport. 54 func (p *PeerExpressRouteCircuitConnectionsServerTransport) Do(req *http.Request) (*http.Response, error) { 55 rawMethod := req.Context().Value(runtime.CtxAPINameKey{}) 56 method, ok := rawMethod.(string) 57 if !ok { 58 return nil, nonRetriableError{errors.New("unable to dispatch request, missing value for CtxAPINameKey")} 59 } 60 61 var resp *http.Response 62 var err error 63 64 switch method { 65 case "PeerExpressRouteCircuitConnectionsClient.Get": 66 resp, err = p.dispatchGet(req) 67 case "PeerExpressRouteCircuitConnectionsClient.NewListPager": 68 resp, err = p.dispatchNewListPager(req) 69 default: 70 err = fmt.Errorf("unhandled API %s", method) 71 } 72 73 if err != nil { 74 return nil, err 75 } 76 77 return resp, nil 78 } 79 80 func (p *PeerExpressRouteCircuitConnectionsServerTransport) dispatchGet(req *http.Request) (*http.Response, error) { 81 if p.srv.Get == nil { 82 return nil, &nonRetriableError{errors.New("fake for method Get not implemented")} 83 } 84 const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.Network/expressRouteCircuits/(?P<circuitName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/peerings/(?P<peeringName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/peerConnections/(?P<connectionName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)` 85 regex := regexp.MustCompile(regexStr) 86 matches := regex.FindStringSubmatch(req.URL.EscapedPath()) 87 if matches == nil || len(matches) < 5 { 88 return nil, fmt.Errorf("failed to parse path %s", req.URL.Path) 89 } 90 resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")]) 91 if err != nil { 92 return nil, err 93 } 94 circuitNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("circuitName")]) 95 if err != nil { 96 return nil, err 97 } 98 peeringNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("peeringName")]) 99 if err != nil { 100 return nil, err 101 } 102 connectionNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("connectionName")]) 103 if err != nil { 104 return nil, err 105 } 106 respr, errRespr := p.srv.Get(req.Context(), resourceGroupNameParam, circuitNameParam, peeringNameParam, connectionNameParam, nil) 107 if respErr := server.GetError(errRespr, req); respErr != nil { 108 return nil, respErr 109 } 110 respContent := server.GetResponseContent(respr) 111 if !contains([]int{http.StatusOK}, respContent.HTTPStatus) { 112 return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", respContent.HTTPStatus)} 113 } 114 resp, err := server.MarshalResponseAsJSON(respContent, server.GetResponse(respr).PeerExpressRouteCircuitConnection, req) 115 if err != nil { 116 return nil, err 117 } 118 return resp, nil 119 } 120 121 func (p *PeerExpressRouteCircuitConnectionsServerTransport) dispatchNewListPager(req *http.Request) (*http.Response, error) { 122 if p.srv.NewListPager == nil { 123 return nil, &nonRetriableError{errors.New("fake for method NewListPager not implemented")} 124 } 125 newListPager := p.newListPager.get(req) 126 if newListPager == nil { 127 const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.Network/expressRouteCircuits/(?P<circuitName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/peerings/(?P<peeringName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/peerConnections` 128 regex := regexp.MustCompile(regexStr) 129 matches := regex.FindStringSubmatch(req.URL.EscapedPath()) 130 if matches == nil || len(matches) < 4 { 131 return nil, fmt.Errorf("failed to parse path %s", req.URL.Path) 132 } 133 resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")]) 134 if err != nil { 135 return nil, err 136 } 137 circuitNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("circuitName")]) 138 if err != nil { 139 return nil, err 140 } 141 peeringNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("peeringName")]) 142 if err != nil { 143 return nil, err 144 } 145 resp := p.srv.NewListPager(resourceGroupNameParam, circuitNameParam, peeringNameParam, nil) 146 newListPager = &resp 147 p.newListPager.add(req, newListPager) 148 server.PagerResponderInjectNextLinks(newListPager, req, func(page *armnetwork.PeerExpressRouteCircuitConnectionsClientListResponse, createLink func() string) { 149 page.NextLink = to.Ptr(createLink()) 150 }) 151 } 152 resp, err := server.PagerResponderNext(newListPager, req) 153 if err != nil { 154 return nil, err 155 } 156 if !contains([]int{http.StatusOK}, resp.StatusCode) { 157 p.newListPager.remove(req) 158 return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", resp.StatusCode)} 159 } 160 if !server.PagerResponderMore(newListPager) { 161 p.newListPager.remove(req) 162 } 163 return resp, nil 164 }