github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6@v6.2.0/fake/applicationgatewaywafdynamicmanifests_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  	"errors"
    13  	"fmt"
    14  	azfake "github.com/Azure/azure-sdk-for-go/sdk/azcore/fake"
    15  	"github.com/Azure/azure-sdk-for-go/sdk/azcore/fake/server"
    16  	"github.com/Azure/azure-sdk-for-go/sdk/azcore/runtime"
    17  	"github.com/Azure/azure-sdk-for-go/sdk/azcore/to"
    18  	"github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6"
    19  	"net/http"
    20  	"net/url"
    21  	"regexp"
    22  )
    23  
    24  // ApplicationGatewayWafDynamicManifestsServer is a fake server for instances of the armnetwork.ApplicationGatewayWafDynamicManifestsClient type.
    25  type ApplicationGatewayWafDynamicManifestsServer struct {
    26  	// NewGetPager is the fake for method ApplicationGatewayWafDynamicManifestsClient.NewGetPager
    27  	// HTTP status codes to indicate success: http.StatusOK
    28  	NewGetPager func(location string, options *armnetwork.ApplicationGatewayWafDynamicManifestsClientGetOptions) (resp azfake.PagerResponder[armnetwork.ApplicationGatewayWafDynamicManifestsClientGetResponse])
    29  }
    30  
    31  // NewApplicationGatewayWafDynamicManifestsServerTransport creates a new instance of ApplicationGatewayWafDynamicManifestsServerTransport with the provided implementation.
    32  // The returned ApplicationGatewayWafDynamicManifestsServerTransport instance is connected to an instance of armnetwork.ApplicationGatewayWafDynamicManifestsClient via the
    33  // azcore.ClientOptions.Transporter field in the client's constructor parameters.
    34  func NewApplicationGatewayWafDynamicManifestsServerTransport(srv *ApplicationGatewayWafDynamicManifestsServer) *ApplicationGatewayWafDynamicManifestsServerTransport {
    35  	return &ApplicationGatewayWafDynamicManifestsServerTransport{
    36  		srv:         srv,
    37  		newGetPager: newTracker[azfake.PagerResponder[armnetwork.ApplicationGatewayWafDynamicManifestsClientGetResponse]](),
    38  	}
    39  }
    40  
    41  // ApplicationGatewayWafDynamicManifestsServerTransport connects instances of armnetwork.ApplicationGatewayWafDynamicManifestsClient to instances of ApplicationGatewayWafDynamicManifestsServer.
    42  // Don't use this type directly, use NewApplicationGatewayWafDynamicManifestsServerTransport instead.
    43  type ApplicationGatewayWafDynamicManifestsServerTransport struct {
    44  	srv         *ApplicationGatewayWafDynamicManifestsServer
    45  	newGetPager *tracker[azfake.PagerResponder[armnetwork.ApplicationGatewayWafDynamicManifestsClientGetResponse]]
    46  }
    47  
    48  // Do implements the policy.Transporter interface for ApplicationGatewayWafDynamicManifestsServerTransport.
    49  func (a *ApplicationGatewayWafDynamicManifestsServerTransport) Do(req *http.Request) (*http.Response, error) {
    50  	rawMethod := req.Context().Value(runtime.CtxAPINameKey{})
    51  	method, ok := rawMethod.(string)
    52  	if !ok {
    53  		return nil, nonRetriableError{errors.New("unable to dispatch request, missing value for CtxAPINameKey")}
    54  	}
    55  
    56  	var resp *http.Response
    57  	var err error
    58  
    59  	switch method {
    60  	case "ApplicationGatewayWafDynamicManifestsClient.NewGetPager":
    61  		resp, err = a.dispatchNewGetPager(req)
    62  	default:
    63  		err = fmt.Errorf("unhandled API %s", method)
    64  	}
    65  
    66  	if err != nil {
    67  		return nil, err
    68  	}
    69  
    70  	return resp, nil
    71  }
    72  
    73  func (a *ApplicationGatewayWafDynamicManifestsServerTransport) dispatchNewGetPager(req *http.Request) (*http.Response, error) {
    74  	if a.srv.NewGetPager == nil {
    75  		return nil, &nonRetriableError{errors.New("fake for method NewGetPager not implemented")}
    76  	}
    77  	newGetPager := a.newGetPager.get(req)
    78  	if newGetPager == nil {
    79  		const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.Network/locations/(?P<location>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/applicationGatewayWafDynamicManifests`
    80  		regex := regexp.MustCompile(regexStr)
    81  		matches := regex.FindStringSubmatch(req.URL.EscapedPath())
    82  		if matches == nil || len(matches) < 2 {
    83  			return nil, fmt.Errorf("failed to parse path %s", req.URL.Path)
    84  		}
    85  		locationParam, err := url.PathUnescape(matches[regex.SubexpIndex("location")])
    86  		if err != nil {
    87  			return nil, err
    88  		}
    89  		resp := a.srv.NewGetPager(locationParam, nil)
    90  		newGetPager = &resp
    91  		a.newGetPager.add(req, newGetPager)
    92  		server.PagerResponderInjectNextLinks(newGetPager, req, func(page *armnetwork.ApplicationGatewayWafDynamicManifestsClientGetResponse, createLink func() string) {
    93  			page.NextLink = to.Ptr(createLink())
    94  		})
    95  	}
    96  	resp, err := server.PagerResponderNext(newGetPager, req)
    97  	if err != nil {
    98  		return nil, err
    99  	}
   100  	if !contains([]int{http.StatusOK}, resp.StatusCode) {
   101  		a.newGetPager.remove(req)
   102  		return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", resp.StatusCode)}
   103  	}
   104  	if !server.PagerResponderMore(newGetPager) {
   105  		a.newGetPager.remove(req)
   106  	}
   107  	return resp, nil
   108  }