We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/shibaleo/mcpist'
If you have feedback or need assistance with the MCP directory API, please join our Discord server
// Code generated by ogen, DO NOT EDIT.
package gen
import (
"net/http"
"net/url"
"strings"
"github.com/ogen-go/ogen/uri"
)
var (
rn28AllowedHeaders = map[string]string{
"GET": "X-Gateway-Token",
}
rn8AllowedHeaders = map[string]string{
"DELETE": "X-Gateway-Token",
"PUT": "Content-Type,X-Gateway-Token",
}
rn24AllowedHeaders = map[string]string{
"GET": "X-Gateway-Token",
}
rn14AllowedHeaders = map[string]string{
"GET": "X-Gateway-Token",
}
rn11AllowedHeaders = map[string]string{
"GET": "X-Gateway-Token",
"POST": "Content-Type,X-Gateway-Token",
}
rn34AllowedHeaders = map[string]string{
"DELETE": "X-Gateway-Token",
}
rn25AllowedHeaders = map[string]string{
"GET": "X-Gateway-Token",
}
rn5AllowedHeaders = map[string]string{
"DELETE": "X-Gateway-Token",
"PUT": "Content-Type,X-Gateway-Token",
}
rn15AllowedHeaders = map[string]string{
"GET": "X-Gateway-Token",
}
rn41AllowedHeaders = map[string]string{
"PUT": "Content-Type,X-Gateway-Token",
}
rn43AllowedHeaders = map[string]string{
"PUT": "Content-Type,X-Gateway-Token",
}
rn30AllowedHeaders = map[string]string{
"GET": "X-Gateway-Token",
}
rn36AllowedHeaders = map[string]string{
"DELETE": "X-Gateway-Token",
}
rn1AllowedHeaders = map[string]string{
"POST": "Content-Type,X-Gateway-Token",
}
rn17AllowedHeaders = map[string]string{
"GET": "X-Gateway-Token",
}
rn3AllowedHeaders = map[string]string{
"GET": "X-Gateway-Token",
"POST": "Content-Type,X-Gateway-Token",
}
rn10AllowedHeaders = map[string]string{
"DELETE": "X-Gateway-Token",
"GET": "X-Gateway-Token",
"PUT": "Content-Type,X-Gateway-Token",
}
rn32AllowedHeaders = map[string]string{
"POST": "X-Gateway-Token",
}
rn38AllowedHeaders = map[string]string{
"PUT": "Content-Type,X-Gateway-Token",
}
rn21AllowedHeaders = map[string]string{
"GET": "X-Gateway-Token",
"PUT": "Content-Type,X-Gateway-Token",
}
rn22AllowedHeaders = map[string]string{
"GET": "X-Gateway-Token",
}
rn20AllowedHeaders = map[string]string{
"GET": "X-Gateway-Token",
}
)
func (s *Server) cutPrefix(path string) (string, bool) {
prefix := s.cfg.Prefix
if prefix == "" {
return path, true
}
if !strings.HasPrefix(path, prefix) {
// Prefix doesn't match.
return "", false
}
// Cut prefix from the path.
return strings.TrimPrefix(path, prefix), true
}
// ServeHTTP serves http request as defined by OpenAPI v3 specification,
// calling handler that matches the path or returning not found error.
func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request) {
elem := r.URL.Path
elemIsEscaped := false
if rawPath := r.URL.RawPath; rawPath != "" {
if normalized, ok := uri.NormalizeEscapedPath(rawPath); ok {
elem = normalized
elemIsEscaped = strings.ContainsRune(elem, '%')
}
}
elem, ok := s.cutPrefix(elem)
if !ok || len(elem) == 0 {
s.notFound(w, r)
return
}
args := [1]string{}
// Static code generated router with unwrapped path search.
switch {
default:
if len(elem) == 0 {
break
}
switch elem[0] {
case '/': // Prefix: "/v1/"
if l := len("/v1/"); len(elem) >= l && elem[0:l] == "/v1/" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'a': // Prefix: "admin/oauth/"
if l := len("admin/oauth/"); len(elem) >= l && elem[0:l] == "admin/oauth/" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'a': // Prefix: "apps"
if l := len("apps"); len(elem) >= l && elem[0:l] == "apps" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
switch r.Method {
case "GET":
s.handleListOAuthAppsRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET",
allowedHeaders: rn28AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
switch elem[0] {
case '/': // Prefix: "/"
if l := len("/"); len(elem) >= l && elem[0:l] == "/" {
elem = elem[l:]
} else {
break
}
// Param: "provider"
// Leaf parameter, slashes are prohibited
idx := strings.IndexByte(elem, '/')
if idx >= 0 {
break
}
args[0] = elem
elem = ""
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "DELETE":
s.handleDeleteOAuthAppRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
case "PUT":
s.handleUpsertOAuthAppRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "DELETE,PUT",
allowedHeaders: rn8AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
case 'c': // Prefix: "consents"
if l := len("consents"); len(elem) >= l && elem[0:l] == "consents" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "GET":
s.handleListAllOAuthConsentsRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET",
allowedHeaders: rn24AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
case 'i': // Prefix: "internal/apikeys/"
if l := len("internal/apikeys/"); len(elem) >= l && elem[0:l] == "internal/apikeys/" {
elem = elem[l:]
} else {
break
}
// Param: "id"
// Match until "/"
idx := strings.IndexByte(elem, '/')
if idx < 0 {
idx = len(elem)
}
args[0] = elem[:idx]
elem = elem[idx:]
if len(elem) == 0 {
break
}
switch elem[0] {
case '/': // Prefix: "/status"
if l := len("/status"); len(elem) >= l && elem[0:l] == "/status" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "GET":
s.handleGetApiKeyStatusRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET",
allowedHeaders: rn14AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
case 'm': // Prefix: "m"
if l := len("m"); len(elem) >= l && elem[0:l] == "m" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'e': // Prefix: "e/"
if l := len("e/"); len(elem) >= l && elem[0:l] == "e/" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'a': // Prefix: "apikeys"
if l := len("apikeys"); len(elem) >= l && elem[0:l] == "apikeys" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
switch r.Method {
case "GET":
s.handleListApiKeysRequest([0]string{}, elemIsEscaped, w, r)
case "POST":
s.handleGenerateApiKeyRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET,POST",
allowedHeaders: rn11AllowedHeaders,
acceptPost: "application/json",
acceptPatch: "",
})
}
return
}
switch elem[0] {
case '/': // Prefix: "/"
if l := len("/"); len(elem) >= l && elem[0:l] == "/" {
elem = elem[l:]
} else {
break
}
// Param: "id"
// Leaf parameter, slashes are prohibited
idx := strings.IndexByte(elem, '/')
if idx >= 0 {
break
}
args[0] = elem
elem = ""
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "DELETE":
s.handleRevokeApiKeyRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "DELETE",
allowedHeaders: rn34AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
case 'c': // Prefix: "credentials"
if l := len("credentials"); len(elem) >= l && elem[0:l] == "credentials" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
switch r.Method {
case "GET":
s.handleListCredentialsRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET",
allowedHeaders: rn25AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
switch elem[0] {
case '/': // Prefix: "/"
if l := len("/"); len(elem) >= l && elem[0:l] == "/" {
elem = elem[l:]
} else {
break
}
// Param: "module"
// Leaf parameter, slashes are prohibited
idx := strings.IndexByte(elem, '/')
if idx >= 0 {
break
}
args[0] = elem
elem = ""
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "DELETE":
s.handleDeleteCredentialRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
case "PUT":
s.handleUpsertCredentialRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "DELETE,PUT",
allowedHeaders: rn5AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
case 'm': // Prefix: "modules/"
if l := len("modules/"); len(elem) >= l && elem[0:l] == "modules/" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'c': // Prefix: "config"
origElem := elem
if l := len("config"); len(elem) >= l && elem[0:l] == "config" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "GET":
s.handleGetModuleConfigRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET",
allowedHeaders: rn15AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
elem = origElem
}
// Param: "name"
// Match until "/"
idx := strings.IndexByte(elem, '/')
if idx < 0 {
idx = len(elem)
}
args[0] = elem[:idx]
elem = elem[idx:]
if len(elem) == 0 {
break
}
switch elem[0] {
case '/': // Prefix: "/"
if l := len("/"); len(elem) >= l && elem[0:l] == "/" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'd': // Prefix: "description"
if l := len("description"); len(elem) >= l && elem[0:l] == "description" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "PUT":
s.handleUpsertModuleDescriptionRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "PUT",
allowedHeaders: rn41AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
case 't': // Prefix: "tools"
if l := len("tools"); len(elem) >= l && elem[0:l] == "tools" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "PUT":
s.handleUpsertToolSettingsRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "PUT",
allowedHeaders: rn43AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
}
case 'o': // Prefix: "o"
if l := len("o"); len(elem) >= l && elem[0:l] == "o" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'a': // Prefix: "auth/consents"
if l := len("auth/consents"); len(elem) >= l && elem[0:l] == "auth/consents" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
switch r.Method {
case "GET":
s.handleListOAuthConsentsRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET",
allowedHeaders: rn30AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
switch elem[0] {
case '/': // Prefix: "/"
if l := len("/"); len(elem) >= l && elem[0:l] == "/" {
elem = elem[l:]
} else {
break
}
// Param: "id"
// Leaf parameter, slashes are prohibited
idx := strings.IndexByte(elem, '/')
if idx >= 0 {
break
}
args[0] = elem
elem = ""
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "DELETE":
s.handleRevokeOAuthConsentRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "DELETE",
allowedHeaders: rn36AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
case 'n': // Prefix: "nboarding"
if l := len("nboarding"); len(elem) >= l && elem[0:l] == "nboarding" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "POST":
s.handleCompleteUserOnboardingRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "POST",
allowedHeaders: rn1AllowedHeaders,
acceptPost: "application/json",
acceptPatch: "",
})
}
return
}
}
case 'p': // Prefix: "pro"
if l := len("pro"); len(elem) >= l && elem[0:l] == "pro" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'f': // Prefix: "file"
if l := len("file"); len(elem) >= l && elem[0:l] == "file" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "GET":
s.handleGetMyProfileRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET",
allowedHeaders: rn17AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
case 'm': // Prefix: "mpts"
if l := len("mpts"); len(elem) >= l && elem[0:l] == "mpts" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
switch r.Method {
case "GET":
s.handleListPromptsRequest([0]string{}, elemIsEscaped, w, r)
case "POST":
s.handleCreatePromptRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET,POST",
allowedHeaders: rn3AllowedHeaders,
acceptPost: "application/json",
acceptPatch: "",
})
}
return
}
switch elem[0] {
case '/': // Prefix: "/"
if l := len("/"); len(elem) >= l && elem[0:l] == "/" {
elem = elem[l:]
} else {
break
}
// Param: "id"
// Leaf parameter, slashes are prohibited
idx := strings.IndexByte(elem, '/')
if idx >= 0 {
break
}
args[0] = elem
elem = ""
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "DELETE":
s.handleDeletePromptRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
case "GET":
s.handleGetPromptRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
case "PUT":
s.handleUpdatePromptRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "DELETE,GET,PUT",
allowedHeaders: rn10AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
}
case 'r': // Prefix: "register"
if l := len("register"); len(elem) >= l && elem[0:l] == "register" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "POST":
s.handleRegisterUserRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "POST",
allowedHeaders: rn32AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
case 's': // Prefix: "s"
if l := len("s"); len(elem) >= l && elem[0:l] == "s" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'e': // Prefix: "ettings"
if l := len("ettings"); len(elem) >= l && elem[0:l] == "ettings" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "PUT":
s.handleUpdateSettingsRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "PUT",
allowedHeaders: rn38AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
case 't': // Prefix: "tripe"
if l := len("tripe"); len(elem) >= l && elem[0:l] == "tripe" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "GET":
s.handleGetStripeCustomerIdRequest([0]string{}, elemIsEscaped, w, r)
case "PUT":
s.handleLinkStripeCustomerRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET,PUT",
allowedHeaders: rn21AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
case 'u': // Prefix: "usage"
if l := len("usage"); len(elem) >= l && elem[0:l] == "usage" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "GET":
s.handleGetUsageRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET",
allowedHeaders: rn22AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
case 'o': // Prefix: "odules"
if l := len("odules"); len(elem) >= l && elem[0:l] == "odules" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "GET":
s.handleListModulesRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET",
allowedHeaders: nil,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
case 'o': // Prefix: "oauth/apps/"
if l := len("oauth/apps/"); len(elem) >= l && elem[0:l] == "oauth/apps/" {
elem = elem[l:]
} else {
break
}
// Param: "provider"
// Match until "/"
idx := strings.IndexByte(elem, '/')
if idx < 0 {
idx = len(elem)
}
args[0] = elem[:idx]
elem = elem[idx:]
if len(elem) == 0 {
break
}
switch elem[0] {
case '/': // Prefix: "/credentials"
if l := len("/credentials"); len(elem) >= l && elem[0:l] == "/credentials" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "GET":
s.handleGetOAuthAppCredentialsRequest([1]string{
args[0],
}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET",
allowedHeaders: rn20AllowedHeaders,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
case 'p': // Prefix: "plans"
if l := len("plans"); len(elem) >= l && elem[0:l] == "plans" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch r.Method {
case "GET":
s.handleListPlansRequest([0]string{}, elemIsEscaped, w, r)
default:
s.notAllowed(w, r, notAllowedParams{
allowedMethods: "GET",
allowedHeaders: nil,
acceptPost: "",
acceptPatch: "",
})
}
return
}
}
}
}
s.notFound(w, r)
}
// Route is route object.
type Route struct {
name string
summary string
operationID string
operationGroup string
pathPattern string
count int
args [1]string
}
// Name returns ogen operation name.
//
// It is guaranteed to be unique and not empty.
func (r Route) Name() string {
return r.name
}
// Summary returns OpenAPI summary.
func (r Route) Summary() string {
return r.summary
}
// OperationID returns OpenAPI operationId.
func (r Route) OperationID() string {
return r.operationID
}
// OperationGroup returns the x-ogen-operation-group value.
func (r Route) OperationGroup() string {
return r.operationGroup
}
// PathPattern returns OpenAPI path.
func (r Route) PathPattern() string {
return r.pathPattern
}
// Args returns parsed arguments.
func (r Route) Args() []string {
return r.args[:r.count]
}
// FindRoute finds Route for given method and path.
//
// Note: this method does not unescape path or handle reserved characters in path properly. Use FindPath instead.
func (s *Server) FindRoute(method, path string) (Route, bool) {
return s.FindPath(method, &url.URL{Path: path})
}
// FindPath finds Route for given method and URL.
func (s *Server) FindPath(method string, u *url.URL) (r Route, _ bool) {
var (
elem = u.Path
args = r.args
)
if rawPath := u.RawPath; rawPath != "" {
if normalized, ok := uri.NormalizeEscapedPath(rawPath); ok {
elem = normalized
}
defer func() {
for i, arg := range r.args[:r.count] {
if unescaped, err := url.PathUnescape(arg); err == nil {
r.args[i] = unescaped
}
}
}()
}
elem, ok := s.cutPrefix(elem)
if !ok {
return r, false
}
// Static code generated router with unwrapped path search.
switch {
default:
if len(elem) == 0 {
break
}
switch elem[0] {
case '/': // Prefix: "/v1/"
if l := len("/v1/"); len(elem) >= l && elem[0:l] == "/v1/" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'a': // Prefix: "admin/oauth/"
if l := len("admin/oauth/"); len(elem) >= l && elem[0:l] == "admin/oauth/" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'a': // Prefix: "apps"
if l := len("apps"); len(elem) >= l && elem[0:l] == "apps" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
switch method {
case "GET":
r.name = ListOAuthAppsOperation
r.summary = "List all OAuth apps (admin only)"
r.operationID = "listOAuthApps"
r.operationGroup = ""
r.pathPattern = "/v1/admin/oauth/apps"
r.args = args
r.count = 0
return r, true
default:
return
}
}
switch elem[0] {
case '/': // Prefix: "/"
if l := len("/"); len(elem) >= l && elem[0:l] == "/" {
elem = elem[l:]
} else {
break
}
// Param: "provider"
// Leaf parameter, slashes are prohibited
idx := strings.IndexByte(elem, '/')
if idx >= 0 {
break
}
args[0] = elem
elem = ""
if len(elem) == 0 {
// Leaf node.
switch method {
case "DELETE":
r.name = DeleteOAuthAppOperation
r.summary = "Delete an OAuth app (admin only)"
r.operationID = "deleteOAuthApp"
r.operationGroup = ""
r.pathPattern = "/v1/admin/oauth/apps/{provider}"
r.args = args
r.count = 1
return r, true
case "PUT":
r.name = UpsertOAuthAppOperation
r.summary = "Create or update an OAuth app (admin only)"
r.operationID = "upsertOAuthApp"
r.operationGroup = ""
r.pathPattern = "/v1/admin/oauth/apps/{provider}"
r.args = args
r.count = 1
return r, true
default:
return
}
}
}
case 'c': // Prefix: "consents"
if l := len("consents"); len(elem) >= l && elem[0:l] == "consents" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "GET":
r.name = ListAllOAuthConsentsOperation
r.summary = "List all OAuth consents across users (admin only)"
r.operationID = "listAllOAuthConsents"
r.operationGroup = ""
r.pathPattern = "/v1/admin/oauth/consents"
r.args = args
r.count = 0
return r, true
default:
return
}
}
}
case 'i': // Prefix: "internal/apikeys/"
if l := len("internal/apikeys/"); len(elem) >= l && elem[0:l] == "internal/apikeys/" {
elem = elem[l:]
} else {
break
}
// Param: "id"
// Match until "/"
idx := strings.IndexByte(elem, '/')
if idx < 0 {
idx = len(elem)
}
args[0] = elem[:idx]
elem = elem[idx:]
if len(elem) == 0 {
break
}
switch elem[0] {
case '/': // Prefix: "/status"
if l := len("/status"); len(elem) >= l && elem[0:l] == "/status" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "GET":
r.name = GetApiKeyStatusOperation
r.summary = "Check if an API key is active (internal, called by Worker)"
r.operationID = "getApiKeyStatus"
r.operationGroup = ""
r.pathPattern = "/v1/internal/apikeys/{id}/status"
r.args = args
r.count = 1
return r, true
default:
return
}
}
}
case 'm': // Prefix: "m"
if l := len("m"); len(elem) >= l && elem[0:l] == "m" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'e': // Prefix: "e/"
if l := len("e/"); len(elem) >= l && elem[0:l] == "e/" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'a': // Prefix: "apikeys"
if l := len("apikeys"); len(elem) >= l && elem[0:l] == "apikeys" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
switch method {
case "GET":
r.name = ListApiKeysOperation
r.summary = "List API keys"
r.operationID = "listApiKeys"
r.operationGroup = ""
r.pathPattern = "/v1/me/apikeys"
r.args = args
r.count = 0
return r, true
case "POST":
r.name = GenerateApiKeyOperation
r.summary = "Generate a new API key"
r.operationID = "generateApiKey"
r.operationGroup = ""
r.pathPattern = "/v1/me/apikeys"
r.args = args
r.count = 0
return r, true
default:
return
}
}
switch elem[0] {
case '/': // Prefix: "/"
if l := len("/"); len(elem) >= l && elem[0:l] == "/" {
elem = elem[l:]
} else {
break
}
// Param: "id"
// Leaf parameter, slashes are prohibited
idx := strings.IndexByte(elem, '/')
if idx >= 0 {
break
}
args[0] = elem
elem = ""
if len(elem) == 0 {
// Leaf node.
switch method {
case "DELETE":
r.name = RevokeApiKeyOperation
r.summary = "Revoke an API key"
r.operationID = "revokeApiKey"
r.operationGroup = ""
r.pathPattern = "/v1/me/apikeys/{id}"
r.args = args
r.count = 1
return r, true
default:
return
}
}
}
case 'c': // Prefix: "credentials"
if l := len("credentials"); len(elem) >= l && elem[0:l] == "credentials" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
switch method {
case "GET":
r.name = ListCredentialsOperation
r.summary = "List stored credentials"
r.operationID = "listCredentials"
r.operationGroup = ""
r.pathPattern = "/v1/me/credentials"
r.args = args
r.count = 0
return r, true
default:
return
}
}
switch elem[0] {
case '/': // Prefix: "/"
if l := len("/"); len(elem) >= l && elem[0:l] == "/" {
elem = elem[l:]
} else {
break
}
// Param: "module"
// Leaf parameter, slashes are prohibited
idx := strings.IndexByte(elem, '/')
if idx >= 0 {
break
}
args[0] = elem
elem = ""
if len(elem) == 0 {
// Leaf node.
switch method {
case "DELETE":
r.name = DeleteCredentialOperation
r.summary = "Delete credentials for a module"
r.operationID = "deleteCredential"
r.operationGroup = ""
r.pathPattern = "/v1/me/credentials/{module}"
r.args = args
r.count = 1
return r, true
case "PUT":
r.name = UpsertCredentialOperation
r.summary = "Create or update credentials for a module"
r.operationID = "upsertCredential"
r.operationGroup = ""
r.pathPattern = "/v1/me/credentials/{module}"
r.args = args
r.count = 1
return r, true
default:
return
}
}
}
case 'm': // Prefix: "modules/"
if l := len("modules/"); len(elem) >= l && elem[0:l] == "modules/" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'c': // Prefix: "config"
origElem := elem
if l := len("config"); len(elem) >= l && elem[0:l] == "config" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "GET":
r.name = GetModuleConfigOperation
r.summary = "Get module configuration"
r.operationID = "getModuleConfig"
r.operationGroup = ""
r.pathPattern = "/v1/me/modules/config"
r.args = args
r.count = 0
return r, true
default:
return
}
}
elem = origElem
}
// Param: "name"
// Match until "/"
idx := strings.IndexByte(elem, '/')
if idx < 0 {
idx = len(elem)
}
args[0] = elem[:idx]
elem = elem[idx:]
if len(elem) == 0 {
break
}
switch elem[0] {
case '/': // Prefix: "/"
if l := len("/"); len(elem) >= l && elem[0:l] == "/" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'd': // Prefix: "description"
if l := len("description"); len(elem) >= l && elem[0:l] == "description" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "PUT":
r.name = UpsertModuleDescriptionOperation
r.summary = "Update module description"
r.operationID = "upsertModuleDescription"
r.operationGroup = ""
r.pathPattern = "/v1/me/modules/{name}/description"
r.args = args
r.count = 1
return r, true
default:
return
}
}
case 't': // Prefix: "tools"
if l := len("tools"); len(elem) >= l && elem[0:l] == "tools" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "PUT":
r.name = UpsertToolSettingsOperation
r.summary = "Update tool enable/disable settings for a module"
r.operationID = "upsertToolSettings"
r.operationGroup = ""
r.pathPattern = "/v1/me/modules/{name}/tools"
r.args = args
r.count = 1
return r, true
default:
return
}
}
}
}
case 'o': // Prefix: "o"
if l := len("o"); len(elem) >= l && elem[0:l] == "o" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'a': // Prefix: "auth/consents"
if l := len("auth/consents"); len(elem) >= l && elem[0:l] == "auth/consents" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
switch method {
case "GET":
r.name = ListOAuthConsentsOperation
r.summary = "List OAuth consents"
r.operationID = "listOAuthConsents"
r.operationGroup = ""
r.pathPattern = "/v1/me/oauth/consents"
r.args = args
r.count = 0
return r, true
default:
return
}
}
switch elem[0] {
case '/': // Prefix: "/"
if l := len("/"); len(elem) >= l && elem[0:l] == "/" {
elem = elem[l:]
} else {
break
}
// Param: "id"
// Leaf parameter, slashes are prohibited
idx := strings.IndexByte(elem, '/')
if idx >= 0 {
break
}
args[0] = elem
elem = ""
if len(elem) == 0 {
// Leaf node.
switch method {
case "DELETE":
r.name = RevokeOAuthConsentOperation
r.summary = "Revoke an OAuth consent"
r.operationID = "revokeOAuthConsent"
r.operationGroup = ""
r.pathPattern = "/v1/me/oauth/consents/{id}"
r.args = args
r.count = 1
return r, true
default:
return
}
}
}
case 'n': // Prefix: "nboarding"
if l := len("nboarding"); len(elem) >= l && elem[0:l] == "nboarding" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "POST":
r.name = CompleteUserOnboardingOperation
r.summary = "Complete a user onboarding step"
r.operationID = "completeUserOnboarding"
r.operationGroup = ""
r.pathPattern = "/v1/me/onboarding"
r.args = args
r.count = 0
return r, true
default:
return
}
}
}
case 'p': // Prefix: "pro"
if l := len("pro"); len(elem) >= l && elem[0:l] == "pro" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'f': // Prefix: "file"
if l := len("file"); len(elem) >= l && elem[0:l] == "file" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "GET":
r.name = GetMyProfileOperation
r.summary = "Get current user profile"
r.operationID = "getMyProfile"
r.operationGroup = ""
r.pathPattern = "/v1/me/profile"
r.args = args
r.count = 0
return r, true
default:
return
}
}
case 'm': // Prefix: "mpts"
if l := len("mpts"); len(elem) >= l && elem[0:l] == "mpts" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
switch method {
case "GET":
r.name = ListPromptsOperation
r.summary = "List prompts"
r.operationID = "listPrompts"
r.operationGroup = ""
r.pathPattern = "/v1/me/prompts"
r.args = args
r.count = 0
return r, true
case "POST":
r.name = CreatePromptOperation
r.summary = "Create a prompt"
r.operationID = "createPrompt"
r.operationGroup = ""
r.pathPattern = "/v1/me/prompts"
r.args = args
r.count = 0
return r, true
default:
return
}
}
switch elem[0] {
case '/': // Prefix: "/"
if l := len("/"); len(elem) >= l && elem[0:l] == "/" {
elem = elem[l:]
} else {
break
}
// Param: "id"
// Leaf parameter, slashes are prohibited
idx := strings.IndexByte(elem, '/')
if idx >= 0 {
break
}
args[0] = elem
elem = ""
if len(elem) == 0 {
// Leaf node.
switch method {
case "DELETE":
r.name = DeletePromptOperation
r.summary = "Delete a prompt"
r.operationID = "deletePrompt"
r.operationGroup = ""
r.pathPattern = "/v1/me/prompts/{id}"
r.args = args
r.count = 1
return r, true
case "GET":
r.name = GetPromptOperation
r.summary = "Get a prompt by ID"
r.operationID = "getPrompt"
r.operationGroup = ""
r.pathPattern = "/v1/me/prompts/{id}"
r.args = args
r.count = 1
return r, true
case "PUT":
r.name = UpdatePromptOperation
r.summary = "Update a prompt"
r.operationID = "updatePrompt"
r.operationGroup = ""
r.pathPattern = "/v1/me/prompts/{id}"
r.args = args
r.count = 1
return r, true
default:
return
}
}
}
}
case 'r': // Prefix: "register"
if l := len("register"); len(elem) >= l && elem[0:l] == "register" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "POST":
r.name = RegisterUserOperation
r.summary = "Register or find existing user from Clerk ID"
r.operationID = "registerUser"
r.operationGroup = ""
r.pathPattern = "/v1/me/register"
r.args = args
r.count = 0
return r, true
default:
return
}
}
case 's': // Prefix: "s"
if l := len("s"); len(elem) >= l && elem[0:l] == "s" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
break
}
switch elem[0] {
case 'e': // Prefix: "ettings"
if l := len("ettings"); len(elem) >= l && elem[0:l] == "ettings" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "PUT":
r.name = UpdateSettingsOperation
r.summary = "Update user settings"
r.operationID = "updateSettings"
r.operationGroup = ""
r.pathPattern = "/v1/me/settings"
r.args = args
r.count = 0
return r, true
default:
return
}
}
case 't': // Prefix: "tripe"
if l := len("tripe"); len(elem) >= l && elem[0:l] == "tripe" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "GET":
r.name = GetStripeCustomerIdOperation
r.summary = "Get linked Stripe customer ID"
r.operationID = "getStripeCustomerId"
r.operationGroup = ""
r.pathPattern = "/v1/me/stripe"
r.args = args
r.count = 0
return r, true
case "PUT":
r.name = LinkStripeCustomerOperation
r.summary = "Link a Stripe customer ID"
r.operationID = "linkStripeCustomer"
r.operationGroup = ""
r.pathPattern = "/v1/me/stripe"
r.args = args
r.count = 0
return r, true
default:
return
}
}
}
case 'u': // Prefix: "usage"
if l := len("usage"); len(elem) >= l && elem[0:l] == "usage" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "GET":
r.name = GetUsageOperation
r.summary = "Get usage statistics"
r.operationID = "getUsage"
r.operationGroup = ""
r.pathPattern = "/v1/me/usage"
r.args = args
r.count = 0
return r, true
default:
return
}
}
}
case 'o': // Prefix: "odules"
if l := len("odules"); len(elem) >= l && elem[0:l] == "odules" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "GET":
r.name = ListModulesOperation
r.summary = "List available modules with their tools"
r.operationID = "listModules"
r.operationGroup = ""
r.pathPattern = "/v1/modules"
r.args = args
r.count = 0
return r, true
default:
return
}
}
}
case 'o': // Prefix: "oauth/apps/"
if l := len("oauth/apps/"); len(elem) >= l && elem[0:l] == "oauth/apps/" {
elem = elem[l:]
} else {
break
}
// Param: "provider"
// Match until "/"
idx := strings.IndexByte(elem, '/')
if idx < 0 {
idx = len(elem)
}
args[0] = elem[:idx]
elem = elem[idx:]
if len(elem) == 0 {
break
}
switch elem[0] {
case '/': // Prefix: "/credentials"
if l := len("/credentials"); len(elem) >= l && elem[0:l] == "/credentials" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "GET":
r.name = GetOAuthAppCredentialsOperation
r.summary = "Get OAuth app credentials for a provider"
r.operationID = "getOAuthAppCredentials"
r.operationGroup = ""
r.pathPattern = "/v1/oauth/apps/{provider}/credentials"
r.args = args
r.count = 1
return r, true
default:
return
}
}
}
case 'p': // Prefix: "plans"
if l := len("plans"); len(elem) >= l && elem[0:l] == "plans" {
elem = elem[l:]
} else {
break
}
if len(elem) == 0 {
// Leaf node.
switch method {
case "GET":
r.name = ListPlansOperation
r.summary = "List available plans"
r.operationID = "listPlans"
r.operationGroup = ""
r.pathPattern = "/v1/plans"
r.args = args
r.count = 0
return r, true
default:
return
}
}
}
}
}
return r, false
}