github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6@v6.2.0/fake/privateendpoints_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  // PrivateEndpointsServer is a fake server for instances of the armnetwork.PrivateEndpointsClient type.
    26  type PrivateEndpointsServer struct {
    27  	// BeginCreateOrUpdate is the fake for method PrivateEndpointsClient.BeginCreateOrUpdate
    28  	// HTTP status codes to indicate success: http.StatusOK, http.StatusCreated
    29  	BeginCreateOrUpdate func(ctx context.Context, resourceGroupName string, privateEndpointName string, parameters armnetwork.PrivateEndpoint, options *armnetwork.PrivateEndpointsClientBeginCreateOrUpdateOptions) (resp azfake.PollerResponder[armnetwork.PrivateEndpointsClientCreateOrUpdateResponse], errResp azfake.ErrorResponder)
    30  
    31  	// BeginDelete is the fake for method PrivateEndpointsClient.BeginDelete
    32  	// HTTP status codes to indicate success: http.StatusOK, http.StatusAccepted, http.StatusNoContent
    33  	BeginDelete func(ctx context.Context, resourceGroupName string, privateEndpointName string, options *armnetwork.PrivateEndpointsClientBeginDeleteOptions) (resp azfake.PollerResponder[armnetwork.PrivateEndpointsClientDeleteResponse], errResp azfake.ErrorResponder)
    34  
    35  	// Get is the fake for method PrivateEndpointsClient.Get
    36  	// HTTP status codes to indicate success: http.StatusOK
    37  	Get func(ctx context.Context, resourceGroupName string, privateEndpointName string, options *armnetwork.PrivateEndpointsClientGetOptions) (resp azfake.Responder[armnetwork.PrivateEndpointsClientGetResponse], errResp azfake.ErrorResponder)
    38  
    39  	// NewListPager is the fake for method PrivateEndpointsClient.NewListPager
    40  	// HTTP status codes to indicate success: http.StatusOK
    41  	NewListPager func(resourceGroupName string, options *armnetwork.PrivateEndpointsClientListOptions) (resp azfake.PagerResponder[armnetwork.PrivateEndpointsClientListResponse])
    42  
    43  	// NewListBySubscriptionPager is the fake for method PrivateEndpointsClient.NewListBySubscriptionPager
    44  	// HTTP status codes to indicate success: http.StatusOK
    45  	NewListBySubscriptionPager func(options *armnetwork.PrivateEndpointsClientListBySubscriptionOptions) (resp azfake.PagerResponder[armnetwork.PrivateEndpointsClientListBySubscriptionResponse])
    46  }
    47  
    48  // NewPrivateEndpointsServerTransport creates a new instance of PrivateEndpointsServerTransport with the provided implementation.
    49  // The returned PrivateEndpointsServerTransport instance is connected to an instance of armnetwork.PrivateEndpointsClient via the
    50  // azcore.ClientOptions.Transporter field in the client's constructor parameters.
    51  func NewPrivateEndpointsServerTransport(srv *PrivateEndpointsServer) *PrivateEndpointsServerTransport {
    52  	return &PrivateEndpointsServerTransport{
    53  		srv:                        srv,
    54  		beginCreateOrUpdate:        newTracker[azfake.PollerResponder[armnetwork.PrivateEndpointsClientCreateOrUpdateResponse]](),
    55  		beginDelete:                newTracker[azfake.PollerResponder[armnetwork.PrivateEndpointsClientDeleteResponse]](),
    56  		newListPager:               newTracker[azfake.PagerResponder[armnetwork.PrivateEndpointsClientListResponse]](),
    57  		newListBySubscriptionPager: newTracker[azfake.PagerResponder[armnetwork.PrivateEndpointsClientListBySubscriptionResponse]](),
    58  	}
    59  }
    60  
    61  // PrivateEndpointsServerTransport connects instances of armnetwork.PrivateEndpointsClient to instances of PrivateEndpointsServer.
    62  // Don't use this type directly, use NewPrivateEndpointsServerTransport instead.
    63  type PrivateEndpointsServerTransport struct {
    64  	srv                        *PrivateEndpointsServer
    65  	beginCreateOrUpdate        *tracker[azfake.PollerResponder[armnetwork.PrivateEndpointsClientCreateOrUpdateResponse]]
    66  	beginDelete                *tracker[azfake.PollerResponder[armnetwork.PrivateEndpointsClientDeleteResponse]]
    67  	newListPager               *tracker[azfake.PagerResponder[armnetwork.PrivateEndpointsClientListResponse]]
    68  	newListBySubscriptionPager *tracker[azfake.PagerResponder[armnetwork.PrivateEndpointsClientListBySubscriptionResponse]]
    69  }
    70  
    71  // Do implements the policy.Transporter interface for PrivateEndpointsServerTransport.
    72  func (p *PrivateEndpointsServerTransport) Do(req *http.Request) (*http.Response, error) {
    73  	rawMethod := req.Context().Value(runtime.CtxAPINameKey{})
    74  	method, ok := rawMethod.(string)
    75  	if !ok {
    76  		return nil, nonRetriableError{errors.New("unable to dispatch request, missing value for CtxAPINameKey")}
    77  	}
    78  
    79  	var resp *http.Response
    80  	var err error
    81  
    82  	switch method {
    83  	case "PrivateEndpointsClient.BeginCreateOrUpdate":
    84  		resp, err = p.dispatchBeginCreateOrUpdate(req)
    85  	case "PrivateEndpointsClient.BeginDelete":
    86  		resp, err = p.dispatchBeginDelete(req)
    87  	case "PrivateEndpointsClient.Get":
    88  		resp, err = p.dispatchGet(req)
    89  	case "PrivateEndpointsClient.NewListPager":
    90  		resp, err = p.dispatchNewListPager(req)
    91  	case "PrivateEndpointsClient.NewListBySubscriptionPager":
    92  		resp, err = p.dispatchNewListBySubscriptionPager(req)
    93  	default:
    94  		err = fmt.Errorf("unhandled API %s", method)
    95  	}
    96  
    97  	if err != nil {
    98  		return nil, err
    99  	}
   100  
   101  	return resp, nil
   102  }
   103  
   104  func (p *PrivateEndpointsServerTransport) dispatchBeginCreateOrUpdate(req *http.Request) (*http.Response, error) {
   105  	if p.srv.BeginCreateOrUpdate == nil {
   106  		return nil, &nonRetriableError{errors.New("fake for method BeginCreateOrUpdate not implemented")}
   107  	}
   108  	beginCreateOrUpdate := p.beginCreateOrUpdate.get(req)
   109  	if beginCreateOrUpdate == nil {
   110  		const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.Network/privateEndpoints/(?P<privateEndpointName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)`
   111  		regex := regexp.MustCompile(regexStr)
   112  		matches := regex.FindStringSubmatch(req.URL.EscapedPath())
   113  		if matches == nil || len(matches) < 3 {
   114  			return nil, fmt.Errorf("failed to parse path %s", req.URL.Path)
   115  		}
   116  		body, err := server.UnmarshalRequestAsJSON[armnetwork.PrivateEndpoint](req)
   117  		if err != nil {
   118  			return nil, err
   119  		}
   120  		resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")])
   121  		if err != nil {
   122  			return nil, err
   123  		}
   124  		privateEndpointNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("privateEndpointName")])
   125  		if err != nil {
   126  			return nil, err
   127  		}
   128  		respr, errRespr := p.srv.BeginCreateOrUpdate(req.Context(), resourceGroupNameParam, privateEndpointNameParam, body, nil)
   129  		if respErr := server.GetError(errRespr, req); respErr != nil {
   130  			return nil, respErr
   131  		}
   132  		beginCreateOrUpdate = &respr
   133  		p.beginCreateOrUpdate.add(req, beginCreateOrUpdate)
   134  	}
   135  
   136  	resp, err := server.PollerResponderNext(beginCreateOrUpdate, req)
   137  	if err != nil {
   138  		return nil, err
   139  	}
   140  
   141  	if !contains([]int{http.StatusOK, http.StatusCreated}, resp.StatusCode) {
   142  		p.beginCreateOrUpdate.remove(req)
   143  		return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK, http.StatusCreated", resp.StatusCode)}
   144  	}
   145  	if !server.PollerResponderMore(beginCreateOrUpdate) {
   146  		p.beginCreateOrUpdate.remove(req)
   147  	}
   148  
   149  	return resp, nil
   150  }
   151  
   152  func (p *PrivateEndpointsServerTransport) dispatchBeginDelete(req *http.Request) (*http.Response, error) {
   153  	if p.srv.BeginDelete == nil {
   154  		return nil, &nonRetriableError{errors.New("fake for method BeginDelete not implemented")}
   155  	}
   156  	beginDelete := p.beginDelete.get(req)
   157  	if beginDelete == nil {
   158  		const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.Network/privateEndpoints/(?P<privateEndpointName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)`
   159  		regex := regexp.MustCompile(regexStr)
   160  		matches := regex.FindStringSubmatch(req.URL.EscapedPath())
   161  		if matches == nil || len(matches) < 3 {
   162  			return nil, fmt.Errorf("failed to parse path %s", req.URL.Path)
   163  		}
   164  		resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")])
   165  		if err != nil {
   166  			return nil, err
   167  		}
   168  		privateEndpointNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("privateEndpointName")])
   169  		if err != nil {
   170  			return nil, err
   171  		}
   172  		respr, errRespr := p.srv.BeginDelete(req.Context(), resourceGroupNameParam, privateEndpointNameParam, nil)
   173  		if respErr := server.GetError(errRespr, req); respErr != nil {
   174  			return nil, respErr
   175  		}
   176  		beginDelete = &respr
   177  		p.beginDelete.add(req, beginDelete)
   178  	}
   179  
   180  	resp, err := server.PollerResponderNext(beginDelete, req)
   181  	if err != nil {
   182  		return nil, err
   183  	}
   184  
   185  	if !contains([]int{http.StatusOK, http.StatusAccepted, http.StatusNoContent}, resp.StatusCode) {
   186  		p.beginDelete.remove(req)
   187  		return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK, http.StatusAccepted, http.StatusNoContent", resp.StatusCode)}
   188  	}
   189  	if !server.PollerResponderMore(beginDelete) {
   190  		p.beginDelete.remove(req)
   191  	}
   192  
   193  	return resp, nil
   194  }
   195  
   196  func (p *PrivateEndpointsServerTransport) dispatchGet(req *http.Request) (*http.Response, error) {
   197  	if p.srv.Get == nil {
   198  		return nil, &nonRetriableError{errors.New("fake for method Get not implemented")}
   199  	}
   200  	const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.Network/privateEndpoints/(?P<privateEndpointName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)`
   201  	regex := regexp.MustCompile(regexStr)
   202  	matches := regex.FindStringSubmatch(req.URL.EscapedPath())
   203  	if matches == nil || len(matches) < 3 {
   204  		return nil, fmt.Errorf("failed to parse path %s", req.URL.Path)
   205  	}
   206  	qp := req.URL.Query()
   207  	resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")])
   208  	if err != nil {
   209  		return nil, err
   210  	}
   211  	privateEndpointNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("privateEndpointName")])
   212  	if err != nil {
   213  		return nil, err
   214  	}
   215  	expandUnescaped, err := url.QueryUnescape(qp.Get("$expand"))
   216  	if err != nil {
   217  		return nil, err
   218  	}
   219  	expandParam := getOptional(expandUnescaped)
   220  	var options *armnetwork.PrivateEndpointsClientGetOptions
   221  	if expandParam != nil {
   222  		options = &armnetwork.PrivateEndpointsClientGetOptions{
   223  			Expand: expandParam,
   224  		}
   225  	}
   226  	respr, errRespr := p.srv.Get(req.Context(), resourceGroupNameParam, privateEndpointNameParam, options)
   227  	if respErr := server.GetError(errRespr, req); respErr != nil {
   228  		return nil, respErr
   229  	}
   230  	respContent := server.GetResponseContent(respr)
   231  	if !contains([]int{http.StatusOK}, respContent.HTTPStatus) {
   232  		return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", respContent.HTTPStatus)}
   233  	}
   234  	resp, err := server.MarshalResponseAsJSON(respContent, server.GetResponse(respr).PrivateEndpoint, req)
   235  	if err != nil {
   236  		return nil, err
   237  	}
   238  	return resp, nil
   239  }
   240  
   241  func (p *PrivateEndpointsServerTransport) dispatchNewListPager(req *http.Request) (*http.Response, error) {
   242  	if p.srv.NewListPager == nil {
   243  		return nil, &nonRetriableError{errors.New("fake for method NewListPager not implemented")}
   244  	}
   245  	newListPager := p.newListPager.get(req)
   246  	if newListPager == nil {
   247  		const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.Network/privateEndpoints`
   248  		regex := regexp.MustCompile(regexStr)
   249  		matches := regex.FindStringSubmatch(req.URL.EscapedPath())
   250  		if matches == nil || len(matches) < 2 {
   251  			return nil, fmt.Errorf("failed to parse path %s", req.URL.Path)
   252  		}
   253  		resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")])
   254  		if err != nil {
   255  			return nil, err
   256  		}
   257  		resp := p.srv.NewListPager(resourceGroupNameParam, nil)
   258  		newListPager = &resp
   259  		p.newListPager.add(req, newListPager)
   260  		server.PagerResponderInjectNextLinks(newListPager, req, func(page *armnetwork.PrivateEndpointsClientListResponse, createLink func() string) {
   261  			page.NextLink = to.Ptr(createLink())
   262  		})
   263  	}
   264  	resp, err := server.PagerResponderNext(newListPager, req)
   265  	if err != nil {
   266  		return nil, err
   267  	}
   268  	if !contains([]int{http.StatusOK}, resp.StatusCode) {
   269  		p.newListPager.remove(req)
   270  		return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", resp.StatusCode)}
   271  	}
   272  	if !server.PagerResponderMore(newListPager) {
   273  		p.newListPager.remove(req)
   274  	}
   275  	return resp, nil
   276  }
   277  
   278  func (p *PrivateEndpointsServerTransport) dispatchNewListBySubscriptionPager(req *http.Request) (*http.Response, error) {
   279  	if p.srv.NewListBySubscriptionPager == nil {
   280  		return nil, &nonRetriableError{errors.New("fake for method NewListBySubscriptionPager not implemented")}
   281  	}
   282  	newListBySubscriptionPager := p.newListBySubscriptionPager.get(req)
   283  	if newListBySubscriptionPager == nil {
   284  		const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.Network/privateEndpoints`
   285  		regex := regexp.MustCompile(regexStr)
   286  		matches := regex.FindStringSubmatch(req.URL.EscapedPath())
   287  		if matches == nil || len(matches) < 1 {
   288  			return nil, fmt.Errorf("failed to parse path %s", req.URL.Path)
   289  		}
   290  		resp := p.srv.NewListBySubscriptionPager(nil)
   291  		newListBySubscriptionPager = &resp
   292  		p.newListBySubscriptionPager.add(req, newListBySubscriptionPager)
   293  		server.PagerResponderInjectNextLinks(newListBySubscriptionPager, req, func(page *armnetwork.PrivateEndpointsClientListBySubscriptionResponse, createLink func() string) {
   294  			page.NextLink = to.Ptr(createLink())
   295  		})
   296  	}
   297  	resp, err := server.PagerResponderNext(newListBySubscriptionPager, req)
   298  	if err != nil {
   299  		return nil, err
   300  	}
   301  	if !contains([]int{http.StatusOK}, resp.StatusCode) {
   302  		p.newListBySubscriptionPager.remove(req)
   303  		return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", resp.StatusCode)}
   304  	}
   305  	if !server.PagerResponderMore(newListBySubscriptionPager) {
   306  		p.newListBySubscriptionPager.remove(req)
   307  	}
   308  	return resp, nil
   309  }