sdk/resourcemanager/apimanagement/armapimanagement/fake/workspacesubscription_server.go (565 lines of code) (raw):

// Copyright (c) Microsoft Corporation. All rights reserved. // Licensed under the MIT License. See License.txt in the project root for license information. // Code generated by Microsoft (R) AutoRest Code Generator. DO NOT EDIT. // Changes may cause incorrect behavior and will be lost if the code is regenerated. package fake import ( "context" "errors" "fmt" azfake "github.com/Azure/azure-sdk-for-go/sdk/azcore/fake" "github.com/Azure/azure-sdk-for-go/sdk/azcore/fake/server" "github.com/Azure/azure-sdk-for-go/sdk/azcore/runtime" "github.com/Azure/azure-sdk-for-go/sdk/azcore/to" "github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/apimanagement/armapimanagement/v3" "net/http" "net/url" "regexp" "strconv" ) // WorkspaceSubscriptionServer is a fake server for instances of the armapimanagement.WorkspaceSubscriptionClient type. type WorkspaceSubscriptionServer struct { // CreateOrUpdate is the fake for method WorkspaceSubscriptionClient.CreateOrUpdate // HTTP status codes to indicate success: http.StatusOK, http.StatusCreated CreateOrUpdate func(ctx context.Context, resourceGroupName string, serviceName string, workspaceID string, sid string, parameters armapimanagement.SubscriptionCreateParameters, options *armapimanagement.WorkspaceSubscriptionClientCreateOrUpdateOptions) (resp azfake.Responder[armapimanagement.WorkspaceSubscriptionClientCreateOrUpdateResponse], errResp azfake.ErrorResponder) // Delete is the fake for method WorkspaceSubscriptionClient.Delete // HTTP status codes to indicate success: http.StatusOK, http.StatusNoContent Delete func(ctx context.Context, resourceGroupName string, serviceName string, workspaceID string, sid string, ifMatch string, options *armapimanagement.WorkspaceSubscriptionClientDeleteOptions) (resp azfake.Responder[armapimanagement.WorkspaceSubscriptionClientDeleteResponse], errResp azfake.ErrorResponder) // Get is the fake for method WorkspaceSubscriptionClient.Get // HTTP status codes to indicate success: http.StatusOK Get func(ctx context.Context, resourceGroupName string, serviceName string, workspaceID string, sid string, options *armapimanagement.WorkspaceSubscriptionClientGetOptions) (resp azfake.Responder[armapimanagement.WorkspaceSubscriptionClientGetResponse], errResp azfake.ErrorResponder) // GetEntityTag is the fake for method WorkspaceSubscriptionClient.GetEntityTag // HTTP status codes to indicate success: http.StatusOK GetEntityTag func(ctx context.Context, resourceGroupName string, serviceName string, workspaceID string, sid string, options *armapimanagement.WorkspaceSubscriptionClientGetEntityTagOptions) (resp azfake.Responder[armapimanagement.WorkspaceSubscriptionClientGetEntityTagResponse], errResp azfake.ErrorResponder) // NewListPager is the fake for method WorkspaceSubscriptionClient.NewListPager // HTTP status codes to indicate success: http.StatusOK NewListPager func(resourceGroupName string, serviceName string, workspaceID string, options *armapimanagement.WorkspaceSubscriptionClientListOptions) (resp azfake.PagerResponder[armapimanagement.WorkspaceSubscriptionClientListResponse]) // ListSecrets is the fake for method WorkspaceSubscriptionClient.ListSecrets // HTTP status codes to indicate success: http.StatusOK ListSecrets func(ctx context.Context, resourceGroupName string, serviceName string, workspaceID string, sid string, options *armapimanagement.WorkspaceSubscriptionClientListSecretsOptions) (resp azfake.Responder[armapimanagement.WorkspaceSubscriptionClientListSecretsResponse], errResp azfake.ErrorResponder) // RegeneratePrimaryKey is the fake for method WorkspaceSubscriptionClient.RegeneratePrimaryKey // HTTP status codes to indicate success: http.StatusNoContent RegeneratePrimaryKey func(ctx context.Context, resourceGroupName string, serviceName string, workspaceID string, sid string, options *armapimanagement.WorkspaceSubscriptionClientRegeneratePrimaryKeyOptions) (resp azfake.Responder[armapimanagement.WorkspaceSubscriptionClientRegeneratePrimaryKeyResponse], errResp azfake.ErrorResponder) // RegenerateSecondaryKey is the fake for method WorkspaceSubscriptionClient.RegenerateSecondaryKey // HTTP status codes to indicate success: http.StatusNoContent RegenerateSecondaryKey func(ctx context.Context, resourceGroupName string, serviceName string, workspaceID string, sid string, options *armapimanagement.WorkspaceSubscriptionClientRegenerateSecondaryKeyOptions) (resp azfake.Responder[armapimanagement.WorkspaceSubscriptionClientRegenerateSecondaryKeyResponse], errResp azfake.ErrorResponder) // Update is the fake for method WorkspaceSubscriptionClient.Update // HTTP status codes to indicate success: http.StatusOK Update func(ctx context.Context, resourceGroupName string, serviceName string, workspaceID string, sid string, ifMatch string, parameters armapimanagement.SubscriptionUpdateParameters, options *armapimanagement.WorkspaceSubscriptionClientUpdateOptions) (resp azfake.Responder[armapimanagement.WorkspaceSubscriptionClientUpdateResponse], errResp azfake.ErrorResponder) } // NewWorkspaceSubscriptionServerTransport creates a new instance of WorkspaceSubscriptionServerTransport with the provided implementation. // The returned WorkspaceSubscriptionServerTransport instance is connected to an instance of armapimanagement.WorkspaceSubscriptionClient via the // azcore.ClientOptions.Transporter field in the client's constructor parameters. func NewWorkspaceSubscriptionServerTransport(srv *WorkspaceSubscriptionServer) *WorkspaceSubscriptionServerTransport { return &WorkspaceSubscriptionServerTransport{ srv: srv, newListPager: newTracker[azfake.PagerResponder[armapimanagement.WorkspaceSubscriptionClientListResponse]](), } } // WorkspaceSubscriptionServerTransport connects instances of armapimanagement.WorkspaceSubscriptionClient to instances of WorkspaceSubscriptionServer. // Don't use this type directly, use NewWorkspaceSubscriptionServerTransport instead. type WorkspaceSubscriptionServerTransport struct { srv *WorkspaceSubscriptionServer newListPager *tracker[azfake.PagerResponder[armapimanagement.WorkspaceSubscriptionClientListResponse]] } // Do implements the policy.Transporter interface for WorkspaceSubscriptionServerTransport. func (w *WorkspaceSubscriptionServerTransport) Do(req *http.Request) (*http.Response, error) { rawMethod := req.Context().Value(runtime.CtxAPINameKey{}) method, ok := rawMethod.(string) if !ok { return nil, nonRetriableError{errors.New("unable to dispatch request, missing value for CtxAPINameKey")} } return w.dispatchToMethodFake(req, method) } func (w *WorkspaceSubscriptionServerTransport) dispatchToMethodFake(req *http.Request, method string) (*http.Response, error) { resultChan := make(chan result) defer close(resultChan) go func() { var intercepted bool var res result if workspaceSubscriptionServerTransportInterceptor != nil { res.resp, res.err, intercepted = workspaceSubscriptionServerTransportInterceptor.Do(req) } if !intercepted { switch method { case "WorkspaceSubscriptionClient.CreateOrUpdate": res.resp, res.err = w.dispatchCreateOrUpdate(req) case "WorkspaceSubscriptionClient.Delete": res.resp, res.err = w.dispatchDelete(req) case "WorkspaceSubscriptionClient.Get": res.resp, res.err = w.dispatchGet(req) case "WorkspaceSubscriptionClient.GetEntityTag": res.resp, res.err = w.dispatchGetEntityTag(req) case "WorkspaceSubscriptionClient.NewListPager": res.resp, res.err = w.dispatchNewListPager(req) case "WorkspaceSubscriptionClient.ListSecrets": res.resp, res.err = w.dispatchListSecrets(req) case "WorkspaceSubscriptionClient.RegeneratePrimaryKey": res.resp, res.err = w.dispatchRegeneratePrimaryKey(req) case "WorkspaceSubscriptionClient.RegenerateSecondaryKey": res.resp, res.err = w.dispatchRegenerateSecondaryKey(req) case "WorkspaceSubscriptionClient.Update": res.resp, res.err = w.dispatchUpdate(req) default: res.err = fmt.Errorf("unhandled API %s", method) } } select { case resultChan <- res: case <-req.Context().Done(): } }() select { case <-req.Context().Done(): return nil, req.Context().Err() case res := <-resultChan: return res.resp, res.err } } func (w *WorkspaceSubscriptionServerTransport) dispatchCreateOrUpdate(req *http.Request) (*http.Response, error) { if w.srv.CreateOrUpdate == nil { return nil, &nonRetriableError{errors.New("fake for method CreateOrUpdate not implemented")} } const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.ApiManagement/service/(?P<serviceName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/workspaces/(?P<workspaceId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/subscriptions/(?P<sid>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)` regex := regexp.MustCompile(regexStr) matches := regex.FindStringSubmatch(req.URL.EscapedPath()) if matches == nil || len(matches) < 5 { return nil, fmt.Errorf("failed to parse path %s", req.URL.Path) } qp := req.URL.Query() body, err := server.UnmarshalRequestAsJSON[armapimanagement.SubscriptionCreateParameters](req) if err != nil { return nil, err } resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")]) if err != nil { return nil, err } serviceNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("serviceName")]) if err != nil { return nil, err } workspaceIDParam, err := url.PathUnescape(matches[regex.SubexpIndex("workspaceId")]) if err != nil { return nil, err } sidParam, err := url.PathUnescape(matches[regex.SubexpIndex("sid")]) if err != nil { return nil, err } notifyUnescaped, err := url.QueryUnescape(qp.Get("notify")) if err != nil { return nil, err } notifyParam, err := parseOptional(notifyUnescaped, strconv.ParseBool) if err != nil { return nil, err } ifMatchParam := getOptional(getHeaderValue(req.Header, "If-Match")) appTypeUnescaped, err := url.QueryUnescape(qp.Get("appType")) if err != nil { return nil, err } appTypeParam := getOptional(armapimanagement.AppType(appTypeUnescaped)) var options *armapimanagement.WorkspaceSubscriptionClientCreateOrUpdateOptions if notifyParam != nil || ifMatchParam != nil || appTypeParam != nil { options = &armapimanagement.WorkspaceSubscriptionClientCreateOrUpdateOptions{ Notify: notifyParam, IfMatch: ifMatchParam, AppType: appTypeParam, } } respr, errRespr := w.srv.CreateOrUpdate(req.Context(), resourceGroupNameParam, serviceNameParam, workspaceIDParam, sidParam, body, options) if respErr := server.GetError(errRespr, req); respErr != nil { return nil, respErr } respContent := server.GetResponseContent(respr) if !contains([]int{http.StatusOK, http.StatusCreated}, respContent.HTTPStatus) { return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK, http.StatusCreated", respContent.HTTPStatus)} } resp, err := server.MarshalResponseAsJSON(respContent, server.GetResponse(respr).SubscriptionContract, req) if err != nil { return nil, err } if val := server.GetResponse(respr).ETag; val != nil { resp.Header.Set("ETag", *val) } return resp, nil } func (w *WorkspaceSubscriptionServerTransport) dispatchDelete(req *http.Request) (*http.Response, error) { if w.srv.Delete == nil { return nil, &nonRetriableError{errors.New("fake for method Delete not implemented")} } const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.ApiManagement/service/(?P<serviceName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/workspaces/(?P<workspaceId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/subscriptions/(?P<sid>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)` regex := regexp.MustCompile(regexStr) matches := regex.FindStringSubmatch(req.URL.EscapedPath()) if matches == nil || len(matches) < 5 { return nil, fmt.Errorf("failed to parse path %s", req.URL.Path) } resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")]) if err != nil { return nil, err } serviceNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("serviceName")]) if err != nil { return nil, err } workspaceIDParam, err := url.PathUnescape(matches[regex.SubexpIndex("workspaceId")]) if err != nil { return nil, err } sidParam, err := url.PathUnescape(matches[regex.SubexpIndex("sid")]) if err != nil { return nil, err } respr, errRespr := w.srv.Delete(req.Context(), resourceGroupNameParam, serviceNameParam, workspaceIDParam, sidParam, getHeaderValue(req.Header, "If-Match"), nil) if respErr := server.GetError(errRespr, req); respErr != nil { return nil, respErr } respContent := server.GetResponseContent(respr) if !contains([]int{http.StatusOK, http.StatusNoContent}, respContent.HTTPStatus) { return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK, http.StatusNoContent", respContent.HTTPStatus)} } resp, err := server.NewResponse(respContent, req, nil) if err != nil { return nil, err } return resp, nil } func (w *WorkspaceSubscriptionServerTransport) dispatchGet(req *http.Request) (*http.Response, error) { if w.srv.Get == nil { return nil, &nonRetriableError{errors.New("fake for method Get not implemented")} } const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.ApiManagement/service/(?P<serviceName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/workspaces/(?P<workspaceId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/subscriptions/(?P<sid>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)` regex := regexp.MustCompile(regexStr) matches := regex.FindStringSubmatch(req.URL.EscapedPath()) if matches == nil || len(matches) < 5 { return nil, fmt.Errorf("failed to parse path %s", req.URL.Path) } resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")]) if err != nil { return nil, err } serviceNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("serviceName")]) if err != nil { return nil, err } workspaceIDParam, err := url.PathUnescape(matches[regex.SubexpIndex("workspaceId")]) if err != nil { return nil, err } sidParam, err := url.PathUnescape(matches[regex.SubexpIndex("sid")]) if err != nil { return nil, err } respr, errRespr := w.srv.Get(req.Context(), resourceGroupNameParam, serviceNameParam, workspaceIDParam, sidParam, nil) if respErr := server.GetError(errRespr, req); respErr != nil { return nil, respErr } respContent := server.GetResponseContent(respr) if !contains([]int{http.StatusOK}, respContent.HTTPStatus) { return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", respContent.HTTPStatus)} } resp, err := server.MarshalResponseAsJSON(respContent, server.GetResponse(respr).SubscriptionContract, req) if err != nil { return nil, err } if val := server.GetResponse(respr).ETag; val != nil { resp.Header.Set("ETag", *val) } return resp, nil } func (w *WorkspaceSubscriptionServerTransport) dispatchGetEntityTag(req *http.Request) (*http.Response, error) { if w.srv.GetEntityTag == nil { return nil, &nonRetriableError{errors.New("fake for method GetEntityTag not implemented")} } const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.ApiManagement/service/(?P<serviceName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/workspaces/(?P<workspaceId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/subscriptions/(?P<sid>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)` regex := regexp.MustCompile(regexStr) matches := regex.FindStringSubmatch(req.URL.EscapedPath()) if matches == nil || len(matches) < 5 { return nil, fmt.Errorf("failed to parse path %s", req.URL.Path) } resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")]) if err != nil { return nil, err } serviceNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("serviceName")]) if err != nil { return nil, err } workspaceIDParam, err := url.PathUnescape(matches[regex.SubexpIndex("workspaceId")]) if err != nil { return nil, err } sidParam, err := url.PathUnescape(matches[regex.SubexpIndex("sid")]) if err != nil { return nil, err } respr, errRespr := w.srv.GetEntityTag(req.Context(), resourceGroupNameParam, serviceNameParam, workspaceIDParam, sidParam, nil) if respErr := server.GetError(errRespr, req); respErr != nil { return nil, respErr } respContent := server.GetResponseContent(respr) if !contains([]int{http.StatusOK}, respContent.HTTPStatus) { return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", respContent.HTTPStatus)} } resp, err := server.NewResponse(respContent, req, nil) if err != nil { return nil, err } if val := server.GetResponse(respr).ETag; val != nil { resp.Header.Set("ETag", *val) } return resp, nil } func (w *WorkspaceSubscriptionServerTransport) dispatchNewListPager(req *http.Request) (*http.Response, error) { if w.srv.NewListPager == nil { return nil, &nonRetriableError{errors.New("fake for method NewListPager not implemented")} } newListPager := w.newListPager.get(req) if newListPager == nil { const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.ApiManagement/service/(?P<serviceName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/workspaces/(?P<workspaceId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/subscriptions` regex := regexp.MustCompile(regexStr) matches := regex.FindStringSubmatch(req.URL.EscapedPath()) if matches == nil || len(matches) < 4 { return nil, fmt.Errorf("failed to parse path %s", req.URL.Path) } qp := req.URL.Query() resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")]) if err != nil { return nil, err } serviceNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("serviceName")]) if err != nil { return nil, err } workspaceIDParam, err := url.PathUnescape(matches[regex.SubexpIndex("workspaceId")]) if err != nil { return nil, err } filterUnescaped, err := url.QueryUnescape(qp.Get("$filter")) if err != nil { return nil, err } filterParam := getOptional(filterUnescaped) topUnescaped, err := url.QueryUnescape(qp.Get("$top")) if err != nil { return nil, err } topParam, err := parseOptional(topUnescaped, func(v string) (int32, error) { p, parseErr := strconv.ParseInt(v, 10, 32) if parseErr != nil { return 0, parseErr } return int32(p), nil }) if err != nil { return nil, err } skipUnescaped, err := url.QueryUnescape(qp.Get("$skip")) if err != nil { return nil, err } skipParam, err := parseOptional(skipUnescaped, func(v string) (int32, error) { p, parseErr := strconv.ParseInt(v, 10, 32) if parseErr != nil { return 0, parseErr } return int32(p), nil }) if err != nil { return nil, err } var options *armapimanagement.WorkspaceSubscriptionClientListOptions if filterParam != nil || topParam != nil || skipParam != nil { options = &armapimanagement.WorkspaceSubscriptionClientListOptions{ Filter: filterParam, Top: topParam, Skip: skipParam, } } resp := w.srv.NewListPager(resourceGroupNameParam, serviceNameParam, workspaceIDParam, options) newListPager = &resp w.newListPager.add(req, newListPager) server.PagerResponderInjectNextLinks(newListPager, req, func(page *armapimanagement.WorkspaceSubscriptionClientListResponse, createLink func() string) { page.NextLink = to.Ptr(createLink()) }) } resp, err := server.PagerResponderNext(newListPager, req) if err != nil { return nil, err } if !contains([]int{http.StatusOK}, resp.StatusCode) { w.newListPager.remove(req) return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", resp.StatusCode)} } if !server.PagerResponderMore(newListPager) { w.newListPager.remove(req) } return resp, nil } func (w *WorkspaceSubscriptionServerTransport) dispatchListSecrets(req *http.Request) (*http.Response, error) { if w.srv.ListSecrets == nil { return nil, &nonRetriableError{errors.New("fake for method ListSecrets not implemented")} } const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.ApiManagement/service/(?P<serviceName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/workspaces/(?P<workspaceId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/subscriptions/(?P<sid>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/listSecrets` regex := regexp.MustCompile(regexStr) matches := regex.FindStringSubmatch(req.URL.EscapedPath()) if matches == nil || len(matches) < 5 { return nil, fmt.Errorf("failed to parse path %s", req.URL.Path) } resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")]) if err != nil { return nil, err } serviceNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("serviceName")]) if err != nil { return nil, err } workspaceIDParam, err := url.PathUnescape(matches[regex.SubexpIndex("workspaceId")]) if err != nil { return nil, err } sidParam, err := url.PathUnescape(matches[regex.SubexpIndex("sid")]) if err != nil { return nil, err } respr, errRespr := w.srv.ListSecrets(req.Context(), resourceGroupNameParam, serviceNameParam, workspaceIDParam, sidParam, nil) if respErr := server.GetError(errRespr, req); respErr != nil { return nil, respErr } respContent := server.GetResponseContent(respr) if !contains([]int{http.StatusOK}, respContent.HTTPStatus) { return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", respContent.HTTPStatus)} } resp, err := server.MarshalResponseAsJSON(respContent, server.GetResponse(respr).SubscriptionKeysContract, req) if err != nil { return nil, err } if val := server.GetResponse(respr).ETag; val != nil { resp.Header.Set("ETag", *val) } return resp, nil } func (w *WorkspaceSubscriptionServerTransport) dispatchRegeneratePrimaryKey(req *http.Request) (*http.Response, error) { if w.srv.RegeneratePrimaryKey == nil { return nil, &nonRetriableError{errors.New("fake for method RegeneratePrimaryKey not implemented")} } const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.ApiManagement/service/(?P<serviceName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/workspaces/(?P<workspaceId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/subscriptions/(?P<sid>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/regeneratePrimaryKey` regex := regexp.MustCompile(regexStr) matches := regex.FindStringSubmatch(req.URL.EscapedPath()) if matches == nil || len(matches) < 5 { return nil, fmt.Errorf("failed to parse path %s", req.URL.Path) } resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")]) if err != nil { return nil, err } serviceNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("serviceName")]) if err != nil { return nil, err } workspaceIDParam, err := url.PathUnescape(matches[regex.SubexpIndex("workspaceId")]) if err != nil { return nil, err } sidParam, err := url.PathUnescape(matches[regex.SubexpIndex("sid")]) if err != nil { return nil, err } respr, errRespr := w.srv.RegeneratePrimaryKey(req.Context(), resourceGroupNameParam, serviceNameParam, workspaceIDParam, sidParam, nil) if respErr := server.GetError(errRespr, req); respErr != nil { return nil, respErr } respContent := server.GetResponseContent(respr) if !contains([]int{http.StatusNoContent}, respContent.HTTPStatus) { return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusNoContent", respContent.HTTPStatus)} } resp, err := server.NewResponse(respContent, req, nil) if err != nil { return nil, err } return resp, nil } func (w *WorkspaceSubscriptionServerTransport) dispatchRegenerateSecondaryKey(req *http.Request) (*http.Response, error) { if w.srv.RegenerateSecondaryKey == nil { return nil, &nonRetriableError{errors.New("fake for method RegenerateSecondaryKey not implemented")} } const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.ApiManagement/service/(?P<serviceName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/workspaces/(?P<workspaceId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/subscriptions/(?P<sid>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/regenerateSecondaryKey` regex := regexp.MustCompile(regexStr) matches := regex.FindStringSubmatch(req.URL.EscapedPath()) if matches == nil || len(matches) < 5 { return nil, fmt.Errorf("failed to parse path %s", req.URL.Path) } resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")]) if err != nil { return nil, err } serviceNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("serviceName")]) if err != nil { return nil, err } workspaceIDParam, err := url.PathUnescape(matches[regex.SubexpIndex("workspaceId")]) if err != nil { return nil, err } sidParam, err := url.PathUnescape(matches[regex.SubexpIndex("sid")]) if err != nil { return nil, err } respr, errRespr := w.srv.RegenerateSecondaryKey(req.Context(), resourceGroupNameParam, serviceNameParam, workspaceIDParam, sidParam, nil) if respErr := server.GetError(errRespr, req); respErr != nil { return nil, respErr } respContent := server.GetResponseContent(respr) if !contains([]int{http.StatusNoContent}, respContent.HTTPStatus) { return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusNoContent", respContent.HTTPStatus)} } resp, err := server.NewResponse(respContent, req, nil) if err != nil { return nil, err } return resp, nil } func (w *WorkspaceSubscriptionServerTransport) dispatchUpdate(req *http.Request) (*http.Response, error) { if w.srv.Update == nil { return nil, &nonRetriableError{errors.New("fake for method Update not implemented")} } const regexStr = `/subscriptions/(?P<subscriptionId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/resourceGroups/(?P<resourceGroupName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/providers/Microsoft\.ApiManagement/service/(?P<serviceName>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/workspaces/(?P<workspaceId>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)/subscriptions/(?P<sid>[!#&$-;=?-\[\]_a-zA-Z0-9~%@]+)` regex := regexp.MustCompile(regexStr) matches := regex.FindStringSubmatch(req.URL.EscapedPath()) if matches == nil || len(matches) < 5 { return nil, fmt.Errorf("failed to parse path %s", req.URL.Path) } qp := req.URL.Query() body, err := server.UnmarshalRequestAsJSON[armapimanagement.SubscriptionUpdateParameters](req) if err != nil { return nil, err } resourceGroupNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("resourceGroupName")]) if err != nil { return nil, err } serviceNameParam, err := url.PathUnescape(matches[regex.SubexpIndex("serviceName")]) if err != nil { return nil, err } workspaceIDParam, err := url.PathUnescape(matches[regex.SubexpIndex("workspaceId")]) if err != nil { return nil, err } sidParam, err := url.PathUnescape(matches[regex.SubexpIndex("sid")]) if err != nil { return nil, err } notifyUnescaped, err := url.QueryUnescape(qp.Get("notify")) if err != nil { return nil, err } notifyParam, err := parseOptional(notifyUnescaped, strconv.ParseBool) if err != nil { return nil, err } appTypeUnescaped, err := url.QueryUnescape(qp.Get("appType")) if err != nil { return nil, err } appTypeParam := getOptional(armapimanagement.AppType(appTypeUnescaped)) var options *armapimanagement.WorkspaceSubscriptionClientUpdateOptions if notifyParam != nil || appTypeParam != nil { options = &armapimanagement.WorkspaceSubscriptionClientUpdateOptions{ Notify: notifyParam, AppType: appTypeParam, } } respr, errRespr := w.srv.Update(req.Context(), resourceGroupNameParam, serviceNameParam, workspaceIDParam, sidParam, getHeaderValue(req.Header, "If-Match"), body, options) if respErr := server.GetError(errRespr, req); respErr != nil { return nil, respErr } respContent := server.GetResponseContent(respr) if !contains([]int{http.StatusOK}, respContent.HTTPStatus) { return nil, &nonRetriableError{fmt.Errorf("unexpected status code %d. acceptable values are http.StatusOK", respContent.HTTPStatus)} } resp, err := server.MarshalResponseAsJSON(respContent, server.GetResponse(respr).SubscriptionContract, req) if err != nil { return nil, err } if val := server.GetResponse(respr).ETag; val != nil { resp.Header.Set("ETag", *val) } return resp, nil } // set this to conditionally intercept incoming requests to WorkspaceSubscriptionServerTransport var workspaceSubscriptionServerTransportInterceptor interface { // Do returns true if the server transport should use the returned response/error Do(*http.Request) (*http.Response, error, bool) }