diff --git a/README.md b/README.md index c7a19eb..6cc0e60 100644 --- a/README.md +++ b/README.md @@ -28,69 +28,72 @@ the [![Use Template](https://img.shields.io/badge/use%20-template-blue?TODO?logo In production all configuration is sourced from environment variables. For localhost development the [`local-config.yaml`][config] can be used to set the variables. -| Variable | Default | Description | -|------------------------------------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| -| `APPLICATION_NAME` | `metadata` | The name of the application, lowercase, numbers and - only. | -| `SERVER_ADDRESS` | `0.0.0.0` | Address to bind to, one of IP, Hostname, ipv6_ip, ipv6ip%interface | -| `SERVER_PORT` | `8080` | Port to listen on, cannot be a privileged port. Must be in range of 1024 - 65535. | -| `METRICS_PORT` | `9090` | Port to provide prometheus metrics on, cannot be a privileged port. Must be in range of 1024 - 65535. | -| | | | -| `METADATA_REPO_URL` | | The HTTP url to the repository containing the metadata. e.g.: `https://github.com/Interhyp/metadata-service-template.git` | -| `METADATA_REPO_MAINLINE` | `refs/heads/main` | The ref of the service metadata used as mainline | -| `OWNER_REGEX` | `.*` | The regex used to limt owner aliases to load. Mostly useful for local development to minimize startup time. Default loads all owners. | -| | | | -| `LOGSTYLE` | `ecs` | The logstyle to use (defaults to [elastic common schema][ecs]) and can be changed to `plain` for localhost debugging. | -| | | | -| `VAULT_ENABLED` | `true` | Enables vault. supports all values supported by [ParseBool][https://pkg.go.dev/strconv#ParseBool]. | -| `VAULT_SERVER` | | FQDN of the [Vault][vault] server - do not add any other part of the URL. | -| `VAULT_AUTH_TOKEN` | | Authentication token used to fetch secrets. Setting this implicitly switches from [Kubernetes authentication][vault-k8-auth] to [token mode][vault-token-auth]. | -| `VAULT_AUTH_KUBERNETES_ROLE` | | Role binding to use for vault kubernetes authentication, usually _microservice_role__ | -| `VAULT_AUTH_KUBERNETES_TOKEN_PATH` | `/var/run/secrets/kubernetes.io/serviceaccount/token` | File path to the service-account token. | -| `VAULT_AUTH_KUBERNETES_BACKEND` | | Authentication path for the kubernetes cluster. | -| `VAULT_SECRETS_CONFIG` | | Configuration consisting of vault paths and keys to fetch from the corresponding path. Values will be written to the global configuration object. | -| | | | -| `BASIC_AUTH_USERNAME` | | Name of the user used for basic authentication to this service. User will be granted admin privileges. | -| `BASIC_AUTH_PASSWORD` | | Password of the user used for basic authentication to this service. User will be granted admin privileges. | -| | | | -| `BITBUCKET_USERNAME` | | Name of the user used for basic git authentication to pull and update the metadata repository. | -| `BITBUCKET_PASSWORD` | | Password of the user used for basic git authentication to pull and update the metadata repository. | -| `PULL_REQUEST_BUILD_URL` | | Url to link to on pull request builds. Should probably be the public URL of this service. | -| `PULL_REQUEST_BUILD_KEY` | `metadata-service` | Key for pull request builds on pull requests in the underlying git repository. Changed files are syntactically validated. | -| | | | -| `GIT_COMMITTER_NAME` | | Name of the user used to create the Git commits. | -| `GIT_COMMITTER_EMAIL` | | E-Mail of the user used to create the Git commits. | -| | | | -| `KAFKA_TOPICS_CONFIG` | | A Json configuration for a Kafka Topic to publish updates to. Leave empty to skip the Kafka integration. See below for details and an example. | -| `KAFKA_GROUP_ID_OVERRIDE` | | Override the kafka group id for local development to avoid creating lots of consumer groups. If unset, derived from local IP address so each k8s pod gets their own group. | -| | | | -| `AUTH_OIDC_KEY_SET_URL` | | URL to the [OpenID Connect Keyset][openid] for validating JWTs. See [authentication](#authentication) for more details. | -| `AUTH_OIDC_TOKEN_AUDIENCE` | | Expected audience of the JWT. Tokens not created for this audience will be rejected. | -| `AUTH_GROUP_WRITE` | | Id or name of the group that is allowed to perform write actions. Needs to be part of the 'groups' claim to perform successful requests. If left blank, anyone with a valid JWT is allowed to perform write actions. | -| | | | -| `UPDATE_JOB_INTERVAL_MINUTES` | `15` | Interval in minutes for refreshing the metadata repository cache. | -| `UPDATE_JOB_TIMEOUT_SECONDS` | `30` | Timeout in seconds when fetching the Git repository. | -| | | | -| `ALERT_TARGET_REGEX` | | Validates the alert target to match the regular expression. | -| | | | -| `OWNER_ALIAS_PERMITTED_REGEX` | `^[a-z](-?[a-z0-9]+)*$` | Regular expression to control the owner aliases that are permitted to be be created. | -| `OWNER_ALIAS_PROHIBITED_REGEX` | `^$` | Regular expression to control the owner aliases that are prohibited to be be created. | -| `OWNER_ALIAS_MAX_LENGTH` | `28` | Maximum length of a valid owner alias. | -| `OWNER_ALIAS_FILTER_REGEX` | | Regular expression to filter owners based on their alias. Useful on localhost or for test instances to speed up service startup. | -| | | | -| `SERVICE_NAME_PERMITTED_REGEX` | `^[a-z](-?[a-z0-9]+)*$` | Regular expression to control the service names that are permitted to be be created. | -| `SERVICE_NAME_PROHIBITED_REGEX` | `^$` | Regular expression to control the service names that are prohibited to be be created. | -| `SERVICE_NAME_MAX_LENGTH` | `28` | Maximum length of a valid service name. | -| | | | -| `REPOSITORY_NAME_PERMITTED_REGEX` | `^[a-z](-?[a-z0-9]+)*$` | Regular expression to control the repository names that are permitted to be be created. | -| `REPOSITORY_NAME_PROHIBITED_REGEX` | `^$` | Regular expression to control the repository names that are prohibited to be be created. | -| `REPOSITORY_NAME_MAX_LENGTH` | `64` | Maximum length of a valid repository name. | -| `REPOSITORY_TYPES` | | Comma separated list of supported repository types. | -| `REPOSITORY_KEY_SEPARATOR` | `.` | Single character used to separate repository name from repository type. repository name and repository type must not contain separator. | -| | | | -| `ALLOWED_FILE_CATEGORIES` | | List of allowed keys for the filecategory field in repositories. Parsed as a json array, example value: `["key1","key2"]`. All keys not in this list are rejected on writes, and silently dropped when reading. | -| | | | -| `REDIS_URL` | | Url to an optional Redis instance to use as a shared cache. Will use in-memory cache if left blank | -| `REDIS_PASSWORD` | | Password for the Redis instance. Can be read from Vault via `VAULT_SECRETS_CONFIG` | +| Variable | Default | Description | +|------------------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| +| `APPLICATION_NAME` | `metadata` | The name of the application, lowercase, numbers and - only. | +| `SERVER_ADDRESS` | `0.0.0.0` | Address to bind to, one of IP, Hostname, ipv6_ip, ipv6ip%interface | +| `SERVER_PORT` | `8080` | Port to listen on, cannot be a privileged port. Must be in range of 1024 - 65535. | +| `METRICS_PORT` | `9090` | Port to provide prometheus metrics on, cannot be a privileged port. Must be in range of 1024 - 65535. | +| | | | +| `METADATA_REPO_URL` | | The HTTP url to the repository containing the metadata. e.g.: `https://github.com/Interhyp/metadata-service-template.git` | +| `METADATA_REPO_MAINLINE` | `refs/heads/main` | The ref of the service metadata used as mainline | +| `OWNER_REGEX` | `.*` | The regex used to limt owner aliases to load. Mostly useful for local development to minimize startup time. Default loads all owners. | +| | | | +| `LOGSTYLE` | `ecs` | The logstyle to use (defaults to [elastic common schema][ecs]) and can be changed to `plain` for localhost debugging. | +| | | | +| `VAULT_ENABLED` | `true` | Enables vault. supports all values supported by [ParseBool][https://pkg.go.dev/strconv#ParseBool]. | +| `VAULT_SERVER` | | FQDN of the [Vault][vault] server - do not add any other part of the URL. | +| `VAULT_AUTH_TOKEN` | | Authentication token used to fetch secrets. Setting this implicitly switches from [Kubernetes authentication][vault-k8-auth] to [token mode][vault-token-auth]. | +| `VAULT_AUTH_KUBERNETES_ROLE` | | Role binding to use for vault kubernetes authentication, usually _microservice_role__ | +| `VAULT_AUTH_KUBERNETES_TOKEN_PATH` | `/var/run/secrets/kubernetes.io/serviceaccount/token` | File path to the service-account token. | +| `VAULT_AUTH_KUBERNETES_BACKEND` | | Authentication path for the kubernetes cluster. | +| `VAULT_SECRETS_CONFIG` | | Configuration consisting of vault paths and keys to fetch from the corresponding path. Values will be written to the global configuration object. | +| | | | +| `BASIC_AUTH_USERNAME` | | Name of the user used for basic authentication to this service. User will be granted admin privileges. | +| `BASIC_AUTH_PASSWORD` | | Password of the user used for basic authentication to this service. User will be granted admin privileges. | +| | | | +| `BITBUCKET_USERNAME` | | Name of the user used for basic git authentication to pull and update the metadata repository. | +| `BITBUCKET_PASSWORD` | | Password of the user used for basic git authentication to pull and update the metadata repository. | +| `PULL_REQUEST_BUILD_URL` | | Url to link to on pull request builds. Should probably be the public URL of this service. | +| `PULL_REQUEST_BUILD_KEY` | `metadata-service` | Key for pull request builds on pull requests in the underlying git repository. Changed files are syntactically validated. | +| | | | +| `GIT_COMMITTER_NAME` | | Name of the user used to create the Git commits. | +| `GIT_COMMITTER_EMAIL` | | E-Mail of the user used to create the Git commits. | +| | | | +| `KAFKA_TOPICS_CONFIG` | | A Json configuration for a Kafka Topic to publish updates to. Leave empty to skip the Kafka integration. See below for details and an example. | +| `KAFKA_GROUP_ID_OVERRIDE` | | Override the kafka group id for local development to avoid creating lots of consumer groups. If unset, derived from local IP address so each k8s pod gets their own group. | +| | | | +| `AUTH_OIDC_KEY_SET_URL` | | URL to the [OpenID Connect Keyset][openid] for validating JWTs. See [authentication](#authentication) for more details. | +| `AUTH_OIDC_TOKEN_AUDIENCE` | | Expected audience of the JWT. Tokens not created for this audience will be rejected. | +| `AUTH_GROUP_WRITE` | | Id or name of the group that is allowed to perform write actions. Needs to be part of the 'groups' claim to perform successful requests. If left blank, anyone with a valid JWT is allowed to perform write actions. | +| | | | +| `UPDATE_JOB_INTERVAL_MINUTES` | `15` | Interval in minutes for refreshing the metadata repository cache. | +| `UPDATE_JOB_TIMEOUT_SECONDS` | `30` | Timeout in seconds when fetching the Git repository. | +| | | | +| `ALERT_TARGET_REGEX` | | Validates the alert target to match the regular expression. | +| | | | +| `OWNER_ALIAS_PERMITTED_REGEX` | `^[a-z](-?[a-z0-9]+)*$` | Regular expression to control the owner aliases that are permitted to be be created. | +| `OWNER_ALIAS_PROHIBITED_REGEX` | `^$` | Regular expression to control the owner aliases that are prohibited to be be created. | +| `OWNER_ALIAS_MAX_LENGTH` | `28` | Maximum length of a valid owner alias. | +| `OWNER_ALIAS_FILTER_REGEX` | | Regular expression to filter owners based on their alias. Useful on localhost or for test instances to speed up service startup. | +| | | | +| `SERVICE_NAME_PERMITTED_REGEX` | `^[a-z](-?[a-z0-9]+)*$` | Regular expression to control the service names that are permitted to be be created. | +| `SERVICE_NAME_PROHIBITED_REGEX` | `^$` | Regular expression to control the service names that are prohibited to be be created. | +| `SERVICE_NAME_MAX_LENGTH` | `28` | Maximum length of a valid service name. | +| | | | +| `REPOSITORY_NAME_PERMITTED_REGEX` | `^[a-z](-?[a-z0-9]+)*$` | Regular expression to control the repository names that are permitted to be be created. | +| `REPOSITORY_NAME_PROHIBITED_REGEX` | `^$` | Regular expression to control the repository names that are prohibited to be be created. | +| `REPOSITORY_NAME_MAX_LENGTH` | `64` | Maximum length of a valid repository name. | +| `REPOSITORY_TYPES` | | Comma separated list of supported repository types. | +| `REPOSITORY_KEY_SEPARATOR` | `.` | Single character used to separate repository name from repository type. repository name and repository type must not contain separator. | +| | | | +| `ALLOWED_FILE_CATEGORIES` | | List of allowed keys for the filecategory field in repositories. Parsed as a json array, example value: `["key1","key2"]`. All keys not in this list are rejected on writes, and silently dropped when reading. | +| | | | +| `REDIS_URL` | | Url to an optional Redis instance to use as a shared cache. Will use in-memory cache if left blank | +| `REDIS_PASSWORD` | | Password for the Redis instance. Can be read from Vault via `VAULT_SECRETS_CONFIG` | +| `VCS_CONFIGS` | | A Json configuration for a VCS to add pull request validation build status and comment to. Leave empty to skip the VCS integration. Supportet VCS GitHub and Bitbucket Datacenter. See below for details and an example. | +| `WEBHOOKS_PROCESS_ASYNC` | | Webhooks handler is working asynchronously/synchronously. | +| `USER_PREFIX` | | Prefix for usernames, in case usernames in the VCS has a prefix that is not part of usernames in yaml files. | ## Datastore @@ -123,15 +126,19 @@ service. ### Datastore Authentication The service currently only supports Basic Authentication for fetching and updating the git repository used as -the [datastore](#datastore). The credentials are configured via `BITBUCKET_USERNAME` and `BITBUCKET_PASSWORD` which are either -provided as environment variable or via [Vault][vault] using the same keys at the destination defined in `VAULT_SERVICE_SECRETS_PATH`. +the [datastore](#datastore). The credentials are configured via `BITBUCKET_USERNAME` and `BITBUCKET_PASSWORD` which are +either +provided as environment variable or via [Vault][vault] using the same keys at the destination defined in +`VAULT_SERVICE_SECRETS_PATH`. ### API Authentication Authentication against the API of the metadata-service can be done using a JWT and configuring the `KEY_SET_URL` -with a valid [OpenID][openid] backend. As an alternative Basic Authentication can be enabled to authorise requests to your API. +with a valid [OpenID][openid] backend. As an alternative Basic Authentication can be enabled to authorise requests to +your API. The credentials are configured via `BASIC_AUTH_USERNAME` and `BASIC_AUTH_PASSWORD` which are either -provided as environment variable or via [Vault][vault] using the same keys at the destination defined in `VAULT_SERVICE_SECRETS_PATH`. +provided as environment variable or via [Vault][vault] using the same keys at the destination defined in +`VAULT_SERVICE_SECRETS_PATH`. > **WARNING** > Leaving `BASIC_AUTH_USERNAME` and `BASIC_AUTH_PASSWORD` empty will currently expose your protected API to anonymous @@ -190,7 +197,7 @@ correct version. If not, wait a bit and try again, you landed on an instance tha ### Kafka configuration -If you wish to use a Kafka topic, set the environment variable `KAFKA_TOPICS_CONFIG` to a JSON document +If you wish to use a Kafka topic, set the environment variable `KAFKA_TOPICS_CONFIG` to a JSON document as follows (displayed in prettyprinted form for readability): ``` @@ -223,6 +230,35 @@ Note: You can use the Vault integration configuration to read the password from ], ``` +## VCS configuration + +If you wish to use pull request validation with your VCS (Bitbucket Datacenter, GitHub), set the environment variable +`VCS_CONFIGS` to a JSON document +as follows (displayed in prettyprinted form for readability): + +``` + { + "github": { + "platform": "GITHUB", + "apiBaseURL": "https://api.github.com", + "accessTokenEnvVar": "GITHUB_ACCESS_TOKEN" + } + } +``` + +This assumes of course that the password is provided in the specified environment variable. On Localhost, you +can simply set "password" in the JSON. + +Note: You can use the Vault integration configuration to read the password from Vault by including it in +`VAULT_SECRETS_CONFIG`, similar to: + +``` + [...] + "some/vault/path": [ + {"vaultKey": "GITHUB_ACCESS_TOKEN"} + ], +``` + ## architecture ![software architecture](docs/architecture-export.png) @@ -313,6 +349,12 @@ Open http://localhost:8080/swagger-ui/index.html in your browser. The api docs URL is /v3/api-docs (in case the swagger ui does not automatically open it). +### working with GitHub webhooks + +[GitHub webhooks forwarding documentation](https://docs.github.com/en/webhooks/testing-and-troubleshooting-webhooks/using-the-github-cli-to-forward-webhooks-for-testing) + +e.g: `gh webhook foward --repo=interhyp-intern-test/service-metadata-test --url=http://localhost:8080/webhooks/vcs/github --events=pull_request,push` + ### List dependency tree `go mod graph > deps.txt` diff --git a/api-generator/generate.sh b/api-generator/generate.sh index a499cf4..63ae190 100644 --- a/api-generator/generate.sh +++ b/api-generator/generate.sh @@ -25,6 +25,8 @@ function generate_apimodel { -g go-autumrest } +DOWNSTREAM_API_DIRECTORY=../internal/client + function generate_downstream { P_DOWNSTREAM_NAME=$1 P_SPEC_FILE_NAME=$2 @@ -42,6 +44,7 @@ function generate_downstream { } generate_apimodel +generate_downstream bitbucket bitbucket-v8.19.json BuildsAndDeployments:PullRequests:Repository:User # -------------------------------------- customization ----------------------------------------- # omit certain fields from yaml representations, which we use internally to save to files in git diff --git a/api/openapi-v3-spec.yaml b/api/openapi-v3-spec.yaml index 53da354..26e9d04 100644 --- a/api/openapi-v3-spec.yaml +++ b/api/openapi-v3-spec.yaml @@ -1143,6 +1143,38 @@ paths: description: Internal Server Error tags: - webhook + /webhooks/vcs/{vcsKey}: + post: + tags: + - webhooks + operationId: postWebhook + parameters: + - name: vcsKey + in: path + required: true + schema: + type: string + requestBody: + required: true + content: + application/json: + schema: + type: object + responses: + '204': + description: Success + '400': + description: Bad Request + '404': + description: Deployment Repository or Git Reference Not found + '422': + description: Bad Deployment Repository + '500': + description: Internal Server Error + content: + "*/*": + schema: + "$ref": "#/components/schemas/ErrorDto" components: schemas: OwnerDto: diff --git a/go.mod b/go.mod index bdc8ab1..7eb1a41 100644 --- a/go.mod +++ b/go.mod @@ -21,6 +21,8 @@ require ( github.com/go-git/go-git/v5 v5.12.0 github.com/go-http-utils/headers v0.0.0-20181008091004-fed159eddc2a github.com/go-playground/webhooks/v6 v6.4.0 + github.com/google/go-github/v66 v66.0.0 + github.com/google/uuid v1.6.0 github.com/lestrrat-go/jwx/v2 v2.1.1 github.com/pkg/errors v0.9.1 github.com/prometheus/client_golang v1.20.4 @@ -55,6 +57,7 @@ require ( github.com/golang-jwt/jwt/v4 v4.5.0 // indirect github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect github.com/golang/snappy v0.0.4 // indirect + github.com/google/go-querystring v1.1.0 // indirect github.com/hashicorp/errwrap v1.1.0 // indirect github.com/hashicorp/go-multierror v1.1.1 // indirect github.com/hashicorp/go-uuid v1.0.3 // indirect diff --git a/go.sum b/go.sum index 46fa9c2..3a0130d 100644 --- a/go.sum +++ b/go.sum @@ -99,8 +99,15 @@ github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da h1:oI5xCqsCo564l github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= github.com/golang/snappy v0.0.4 h1:yAGX7huGHXlcLOEtBnF4w7FQwA26wojNCwOYAEhLjQM= github.com/golang/snappy v0.0.4/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= +github.com/google/go-cmp v0.5.2/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= +github.com/google/go-github/v66 v66.0.0 h1:ADJsaXj9UotwdgK8/iFZtv7MLc8E8WBl62WLd/D/9+M= +github.com/google/go-github/v66 v66.0.0/go.mod h1:+4SO9Zkuyf8ytMj0csN1NR/5OTR+MfqPp8P8dVlcvY4= +github.com/google/go-querystring v1.1.0 h1:AnCroh3fv4ZBgVIf1Iwtovgjaw/GiKJo8M8yD/fhyJ8= +github.com/google/go-querystring v1.1.0/go.mod h1:Kcdr2DB4koayq7X8pmAG4sNG59So17icRSOU623lUBU= +github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0= +github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/gorilla/securecookie v1.1.1/go.mod h1:ra0sb63/xPlUeL+yeDciTfxMRAA+MP+HVt/4epWDjd4= github.com/gorilla/sessions v1.2.1/go.mod h1:dk2InVEVJ0sfLlnXv9EAgkf6ecYs/i80K/zI+bUmuGM= github.com/hashicorp/errwrap v1.0.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4= diff --git a/internal/acorn/config/customconfigint.go b/internal/acorn/config/customconfigint.go index f4e9dd5..18544c2 100644 --- a/internal/acorn/config/customconfigint.go +++ b/internal/acorn/config/customconfigint.go @@ -9,6 +9,20 @@ import ( librepo "github.com/Interhyp/go-backend-service-common/acorns/repository" ) +type VCSPlatform int64 + +const ( + VCSPlatformBitbucketDatacenter VCSPlatform = iota + VCSPlatformGitHub + VCSPlatformUnknown +) + +type VCSConfig struct { + Platform VCSPlatform + APIBaseURL string + AccessToken string +} + type CustomConfiguration interface { BasicAuthUsername() string BasicAuthPassword() string @@ -63,6 +77,10 @@ type CustomConfiguration interface { AllowedFileCategories() []string + VCSConfigs() map[string]VCSConfig + WebhooksProcessAsync() bool + UserPrefix() string + Kafka() *kafka.Config KafkaGroupIdOverride() string @@ -125,4 +143,7 @@ const ( KeyRedisPassword = "REDIS_PASSWORD" KeyPullRequestBuildUrl = "PULL_REQUEST_BUILD_URL" KeyPullRequestBuildKey = "PULL_REQUEST_BUILD_KEY" + KeyVCSConfigs = "VCS_CONFIGS" + KeyWebhooksProcessAsync = "WEBHOOKS_PROCESS_ASYNC" + KeyUserPrefix = "USER_PREFIX" ) diff --git a/internal/acorn/errors/inputvalidationerror/error.go b/internal/acorn/errors/inputvalidationerror/error.go new file mode 100644 index 0000000..dc7f5cd --- /dev/null +++ b/internal/acorn/errors/inputvalidationerror/error.go @@ -0,0 +1,44 @@ +package inputvalidationerror + +import ( + "context" + "errors" + "fmt" +) + +type ErrorInt interface { + Ctx() context.Context + IsInputValidationError() bool +} + +// this also implements the error interface + +type Error struct { + ctx context.Context + err error +} + +func New(ctx context.Context, reason string) error { + return &Error{ + ctx: ctx, + err: fmt.Errorf("input validation failed: %s", reason), + } +} + +func (e *Error) Error() string { + return e.err.Error() +} + +func (e *Error) Ctx() context.Context { + return e.ctx +} + +// the presence of this method makes the interface unique and thus recognizable by a simple type check + +func (e *Error) IsInputValidationError() bool { + return true +} + +func Is(err error) bool { + return errors.As(err, new(*Error)) +} diff --git a/internal/acorn/repository/bitbucketint.go b/internal/acorn/repository/bitbucketint.go deleted file mode 100644 index 655f086..0000000 --- a/internal/acorn/repository/bitbucketint.go +++ /dev/null @@ -1,36 +0,0 @@ -package repository - -import ( - "context" -) - -type Bitbucket interface { - IsBitbucket() bool - - Setup() error - - SetupClient(ctx context.Context) error - - GetBitbucketUser(ctx context.Context, username string) (BitbucketUser, error) - GetBitbucketUsers(ctx context.Context, usernames []string) ([]BitbucketUser, error) - FilterExistingUsernames(ctx context.Context, usernames []string) ([]string, error) - - // GetChangedFilesOnPullRequest returns the file paths and contents list of changed files, and the - // head commit hash of the pull request source for which the files were obtained. - GetChangedFilesOnPullRequest(ctx context.Context, pullRequestId int) ([]File, string, error) - - AddCommitBuildStatus(ctx context.Context, commitHash string, url string, key string, success bool) error - - CreatePullRequestComment(ctx context.Context, pullRequestId int, comment string) error -} - -type BitbucketUser struct { - Id int `json:"id"` - Name string `json:"name"` - Active bool `json:"active"` -} - -type File struct { - Path string - Contents string -} diff --git a/internal/acorn/repository/vcsint.go b/internal/acorn/repository/vcsint.go new file mode 100644 index 0000000..40408cb --- /dev/null +++ b/internal/acorn/repository/vcsint.go @@ -0,0 +1,30 @@ +package repository + +import "context" + +type VcsPlugin interface { + SetCommitStatusInProgress(ctx context.Context, repoPath, repoName, commitID, url string, statusKey string) error + + SetCommitStatusSucceeded(ctx context.Context, repoPath, repoName, commitID, url string, statusKey string) error + + SetCommitStatusFailed(ctx context.Context, repoPath, repoName, commitID, url string, statusKey string) error + + CreatePullRequestComment(ctx context.Context, repoPath, repoName, pullRequestID, text string) error + + GetChangedFilesOnPullRequest(ctx context.Context, repoPath, repoName, pullRequestID, toRef string) ([]File, string, error) + + GetUser(ctx context.Context, username string) (string, error) +} + +type CommitBuildStatus string + +const ( + CommitBuildStatusSuccess CommitBuildStatus = "SUCCESSFUL" + CommitBuildStatusInProgress CommitBuildStatus = "INPROGRESS" + CommitBuildStatusFailed CommitBuildStatus = "FAILED" +) + +type File struct { + Path string + Contents string +} diff --git a/internal/acorn/service/prvalidatorint.go b/internal/acorn/service/prvalidatorint.go deleted file mode 100644 index 5343940..0000000 --- a/internal/acorn/service/prvalidatorint.go +++ /dev/null @@ -1,15 +0,0 @@ -package service - -import "context" - -// PRValidator validates pull requests in the underlying repository to prevent bringing invalid content to the mainline. -type PRValidator interface { - IsPRValidator() bool - - // ValidatePullRequest validates the pull request, commenting on it and setting a build result. - // - // Failures to validate a pull request are not considered errors. Errors are only returned if - // the process of validation could not be completed (failure to respond by git server, - // could not obtain file list, etc.) - ValidatePullRequest(ctx context.Context, id uint64, toRef string, fromRef string) error -} diff --git a/internal/acorn/service/vcswebhookshandlerint.go b/internal/acorn/service/vcswebhookshandlerint.go new file mode 100644 index 0000000..9c82901 --- /dev/null +++ b/internal/acorn/service/vcswebhookshandlerint.go @@ -0,0 +1,10 @@ +package service + +import ( + "context" + "net/http" +) + +type VCSWebhooksHandler interface { + HandleEvent(ctx context.Context, vcsKey string, r *http.Request) error +} diff --git a/internal/client/bitbucket-v8.19.json b/internal/client/bitbucket-v8.19.json new file mode 100644 index 0000000..81aab8e --- /dev/null +++ b/internal/client/bitbucket-v8.19.json @@ -0,0 +1,63228 @@ +{ + "openapi": "3.0.1", + "info": { + "title": "Bitbucket Data Center", + "description": "This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: \n\n - integrate Bitbucket with other applications;\n\n - create scripts that interact with Bitbucket; or\n\n - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. \n\n You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/).", + "termsOfService": "https://www.atlassian.com/legal/software-license-agreement", + "contact": { + "name": "Bitbucket Data Center Jira Project", + "url": "https://jira.atlassian.com/projects/BSERV/summary" + }, + "version": "8.19" + }, + "servers": [ + { + "url": "http://{baseurl}/rest", + "variables": { + "baseurl": { + "default": "example.com:7990", + "description": "Address of your Bitbucket instance" + } + } + } + ], + "components": { + "securitySchemes": { + "basic": { + "type": "http", + "description": "In order to use basic authorization, provide username:password Base64 encoded in the 'Authorization' header.", + "scheme": "basic" + } + }, + "schemas": { + "RestErrorMessage": { + "properties": { + "message": { + "type": "string" + }, + "context": { + "type": "string" + }, + "exceptionName": { + "type": "string" + } + } + }, + "RestAccessToken": { + "properties": { + "id": { + "type": "string", + "example": "252973515069" + }, + "name": { + "type": "string", + "example": "My access token" + }, + "createdDate": { + "type": "string", + "format": "date-time" + } + } + }, + "RestAccessTokenRequest": { + "type": "object", + "properties": { + "expiryDays": { + "type": "integer", + "format": "int32" + }, + "name": { + "type": "string", + "example": "My access token" + }, + "permissions": { + "uniqueItems": true, + "type": "array", + "example": [ + "REPO_ADMIN", + "PROJECT_READ" + ], + "items": { + "type": "string", + "example": "[\"REPO_ADMIN\",\"PROJECT_READ\"]" + } + } + } + }, + "RestRawAccessToken": { + "properties": { + "token": { + "type": "string" + }, + "id": { + "type": "string", + "example": "252973515069" + }, + "name": { + "type": "string", + "example": "My access token" + }, + "createdDate": { + "type": "string", + "format": "date-time" + } + } + }, + "RestBuildStats": { + "properties": { + "successful": { + "type": "integer", + "format": "int32" + }, + "cancelled": { + "type": "integer", + "format": "int32" + }, + "inProgress": { + "type": "integer", + "format": "int32" + }, + "failed": { + "type": "integer", + "format": "int32" + }, + "unknown": { + "type": "integer", + "format": "int32" + } + } + }, + "RestBuildStatus": { + "properties": { + "name": { + "type": "string", + "example": "Database Matrix Tests" + }, + "key": { + "type": "string", + "example": "TEST-REP3" + }, + "parent": { + "type": "string", + "example": "TEST-REP" + }, + "state": { + "type": "string", + "enum": [ + "CANCELLED", + "FAILED", + "INPROGRESS", + "SUCCESSFUL", + "UNKNOWN" + ] + }, + "ref": { + "type": "string", + "example": "refs/heads/master" + }, + "duration": { + "type": "integer", + "format": "int64" + }, + "testResults": { + "type": "object", + "properties": { + "successful": { + "type": "integer", + "format": "int32", + "example": 134 + }, + "skipped": { + "type": "integer", + "format": "int32", + "example": 5 + }, + "failed": { + "type": "integer", + "format": "int32", + "example": 1 + } + } + }, + "createdDate": { + "type": "integer", + "format": "int64", + "example": 1587533099278 + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "example": 1587533699278 + }, + "description": { + "type": "string", + "example": "A description of the build goes here" + }, + "buildNumber": { + "type": "string", + "example": "3" + }, + "url": { + "type": "string", + "example": "https://bamboo.example.com/browse/TEST-REP3" + } + } + }, + "RestMultipleBuildStats": { + "properties": {} + }, + "RestRefMatcher": { + "properties": { + "id": { + "type": "string", + "example": "refs/heads/main" + }, + "type": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Branch" + }, + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + } + } + }, + "displayId": { + "type": "string", + "example": "main" + } + } + }, + "RestRefMatcherType": { + "properties": { + "name": { + "type": "string", + "example": "Branch" + }, + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + } + } + }, + "RestRequiredBuildCondition": { + "properties": { + "id": { + "type": "integer", + "format": "int64", + "example": 15 + }, + "buildParentKeys": { + "type": "array", + "description": "A non-empty list of build parent keys that require green builds for this merge check to pass", + "example": [ + "build-key-1", + "build-key-2" + ], + "items": { + "type": "string" + } + }, + "refMatcher": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/main" + }, + "type": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Branch" + }, + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + } + } + }, + "displayId": { + "type": "string", + "example": "main" + } + } + }, + "exemptRefMatcher": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/main" + }, + "type": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Branch" + }, + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + } + } + }, + "displayId": { + "type": "string", + "example": "main" + } + } + } + } + }, + "RestRequiredBuildConditionSetRequest": { + "required": [ + "buildParentKeys", + "refMatcher" + ], + "type": "object", + "properties": { + "buildParentKeys": { + "maxItems": 100, + "minItems": 0, + "type": "array", + "description": "A non-empty list of build parent keys that require green builds for this merge check to pass", + "example": [ + "build-key-1", + "build-key-2" + ], + "items": { + "type": "string" + } + }, + "exemptRefMatcher": { + "$ref": "#/components/schemas/RestRefMatcher" + }, + "refMatcher": { + "type": "object", + "properties": { + "displayId": { + "type": "string", + "example": "main" + }, + "id": { + "type": "string", + "example": "refs/heads/main" + }, + "type": { + "type": "object", + "properties": { + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + }, + "name": { + "type": "string", + "example": "Branch" + } + } + } + } + } + } + }, + "RefType": {}, + "RestBranch": { + "properties": { + "type": { + "$ref": "#/components/schemas/RefType" + }, + "default": { + "type": "boolean", + "readOnly": true + }, + "displayId": { + "type": "string", + "readOnly": true + }, + "latestCommit": { + "type": "string", + "readOnly": true, + "example": "8d51122def5632836d1cb1026e879069e10a1e13" + }, + "latestChangeset": { + "type": "string", + "readOnly": true, + "example": "8d51122def5632836d1cb1026e879069e10a1e13" + }, + "id": { + "type": "string", + "example": "refs/heads/master" + } + } + }, + "RestBranchCreateRequest": { + "type": "object", + "properties": { + "name": { + "type": "string", + "description": "Name of the branch to be created" + }, + "startPoint": { + "maxLength": 40, + "type": "string", + "description": "Commit ID from which the branch is created" + } + } + }, + "RestBranchDeleteRequest": { + "type": "object", + "properties": { + "dryRun": { + "type": "boolean", + "description": "Don't actually delete the ref name, just do a dry run" + }, + "endPoint": { + "maxLength": 40, + "type": "string", + "description": "Commit ID that the provided ref name is expected to point to" + }, + "name": { + "type": "string", + "description": "Name of the ref to be deleted" + } + } + }, + "RestMinimalRef": { + "properties": { + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + } + }, + "RestBulkAddInsightAnnotationRequest": { + "type": "object", + "properties": { + "annotations": { + "maxItems": 2147483647, + "minItems": 1, + "type": "array", + "items": { + "$ref": "#/components/schemas/RestSingleAddInsightAnnotationRequest" + } + } + } + }, + "RestInsightAnnotation": { + "properties": { + "message": { + "type": "string", + "example": "This is an annotation message" + }, + "type": { + "type": "string", + "example": "BUG" + }, + "path": { + "type": "string", + "example": "src/some/structure/file.ext" + }, + "severity": { + "type": "string", + "example": "HIGH" + }, + "externalId": { + "type": "string", + "example": "external.id" + }, + "reportKey": { + "type": "string", + "example": "report.key" + }, + "line": { + "type": "integer", + "format": "int32", + "example": 5 + }, + "link": { + "type": "string", + "example": "http://example.com/my/file/analysis?line=5" + } + } + }, + "RestInsightAnnotationsResponse": { + "properties": { + "annotations": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestInsightAnnotation" + } + } + } + }, + "RestInsightReport": { + "properties": { + "result": { + "type": "string", + "example": "PASS", + "enum": [ + "FAIL", + "PASS" + ] + }, + "key": { + "type": "string", + "example": "report.key" + }, + "createdDate": { + "type": "number", + "example": 1630041546433 + }, + "reporter": { + "type": "string", + "example": "Reporter/tool that produced this report" + }, + "data": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestInsightReportData" + } + }, + "title": { + "type": "string", + "example": "report.title" + }, + "details": { + "type": "string", + "example": "This is the details of the report, it can be a longer string describing the report" + }, + "link": { + "type": "string", + "format": "uri", + "example": "http://integration.example.com" + }, + "logoUrl": { + "type": "string", + "format": "uri", + "example": "http://integration.example.com/logo" + } + } + }, + "RestInsightReportData": { + "properties": { + "value": { + "type": "object", + "example": 9 + }, + "type": { + "pattern": "BOOLEAN|DATE|DURATION|LINK|NUMBER|PERCENTAGE|TEXT", + "type": "string", + "example": "NUMBER" + }, + "title": { + "type": "string", + "example": "data.title" + } + } + }, + "RestSetInsightReportRequest": { + "required": [ + "data", + "title" + ], + "type": "object", + "properties": { + "coverageProviderKey": { + "type": "string" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "example": 1630041546433 + }, + "data": { + "maxItems": 6, + "minItems": 0, + "type": "array", + "items": { + "$ref": "#/components/schemas/RestInsightReportData" + } + }, + "details": { + "type": "string", + "example": "This is the details of the report, it can be a longer string describing the report." + }, + "link": { + "type": "string", + "example": "http://insight.example.com" + }, + "logoUrl": { + "type": "string", + "example": "http://insight.example.com/logo" + }, + "reporter": { + "maxLength": 450, + "minLength": 0, + "type": "string", + "example": "Reporter/tool that produced this report" + }, + "result": { + "pattern": "FAIL|PASS", + "type": "string", + "example": "PASS" + }, + "title": { + "maxLength": 450, + "minLength": 0, + "type": "string", + "example": "report.title" + } + } + }, + "RestSingleAddInsightAnnotationRequest": { + "required": [ + "message", + "severity" + ], + "type": "object", + "properties": { + "externalId": { + "maxLength": 450, + "minLength": 0, + "type": "string", + "example": "message-1" + }, + "line": { + "minimum": 0, + "type": "integer", + "format": "int32", + "example": 4 + }, + "link": { + "type": "string", + "example": "https://link.to.tool/that/produced/annotation/message-1" + }, + "message": { + "maxLength": 2000, + "minLength": 0, + "type": "string", + "example": "This is a bug here because reasons" + }, + "path": { + "maxLength": 50000, + "minLength": 0, + "type": "string", + "example": "path/to/file/in/repo" + }, + "severity": { + "pattern": "LOW|MEDIUM|HIGH", + "type": "string", + "example": "MEDIUM" + }, + "type": { + "pattern": "VULNERABILITY|CODE_SMELL|BUG", + "type": "string", + "example": "CODE_SMELL" + } + } + }, + "RestApplicationUser": { + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "RestDefaultReviewersRequest": { + "type": "object", + "properties": { + "requiredApprovals": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "reviewers": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestApplicationUser" + } + }, + "sourceMatcher": { + "type": "object", + "properties": { + "displayId": { + "type": "string", + "example": "main" + }, + "id": { + "type": "string", + "example": "refs/heads/main" + }, + "type": { + "type": "object", + "properties": { + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + }, + "name": { + "type": "string", + "example": "Branch" + } + } + } + } + }, + "targetMatcher": { + "type": "object", + "properties": { + "displayId": { + "type": "string", + "example": "main" + }, + "id": { + "type": "string", + "example": "refs/heads/main" + }, + "type": { + "type": "object", + "properties": { + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + }, + "name": { + "type": "string", + "example": "Branch" + } + } + } + } + } + } + }, + "RestErrors": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + }, + "RestPullRequestCondition": { + "properties": { + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 1 + }, + "sourceRefMatcher": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/main" + }, + "type": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Branch" + }, + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + } + } + }, + "displayId": { + "type": "string", + "example": "main" + } + } + }, + "targetRefMatcher": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/main" + }, + "type": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Branch" + }, + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + } + } + }, + "displayId": { + "type": "string", + "example": "main" + } + } + }, + "reviewers": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestApplicationUser" + } + }, + "requiredApprovals": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "scope": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "GLOBAL", + "PROJECT", + "REPOSITORY" + ] + }, + "resourceId": { + "type": "integer", + "format": "int32", + "example": 2 + } + }, + "readOnly": true + } + } + }, + "RestRelatedLinks": { + "properties": {} + }, + "RestScope": { + "properties": { + "type": { + "type": "string", + "enum": [ + "GLOBAL", + "PROJECT", + "REPOSITORY" + ] + }, + "resourceId": { + "type": "integer", + "format": "int32", + "example": 2 + } + } + }, + "RestPath": { + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "RestPullRequestParticipant": { + "properties": { + "lastReviewedCommit": { + "type": "string", + "example": "7549846524f8aed2bd1c0249993ae1bf9d3c9998" + }, + "status": { + "type": "string", + "enum": [ + "UNAPPROVED", + "NEEDS_WORK", + "APPROVED" + ] + }, + "role": { + "type": "string", + "enum": [ + "AUTHOR", + "REVIEWER", + "PARTICIPANT" + ] + }, + "user": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "approved": { + "type": "boolean" + } + } + }, + "RestPullRequest": { + "properties": { + "version": { + "type": "integer", + "format": "int32" + }, + "open": { + "type": "boolean" + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "state": { + "type": "string", + "enum": [ + "DECLINED", + "MERGED", + "OPEN" + ] + }, + "locked": { + "type": "boolean" + }, + "closed": { + "type": "boolean" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "example": 13590759200 + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "example": 14490759200 + }, + "htmlDescription": { + "type": "string", + "writeOnly": true + }, + "closedDate": { + "type": "integer", + "format": "int64", + "example": 19990759200 + }, + "participants": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "reviewers": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "description": { + "type": "string", + "example": "It is a kludge, but put the tuple from the database in the cache." + }, + "title": { + "type": "string", + "example": "Talking Nerdy" + }, + "fromRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "toRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "draft": { + "type": "boolean" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "RestCommentThreadDiffAnchor": { + "properties": { + "path": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "diffType": { + "type": "string", + "enum": [ + "COMMIT", + "EFFECTIVE", + "RANGE" + ] + }, + "fileType": { + "type": "string", + "enum": [ + "FROM", + "TO" + ] + }, + "fromHash": { + "type": "string", + "example": "62a0505e8204115b8b9c8a95bfa264a8c0896a93" + }, + "lineType": { + "type": "string", + "enum": [ + "ADDED", + "CONTEXT", + "REMOVED" + ] + }, + "pullRequest": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32" + }, + "open": { + "type": "boolean" + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "state": { + "type": "string", + "enum": [ + "DECLINED", + "MERGED", + "OPEN" + ] + }, + "locked": { + "type": "boolean" + }, + "closed": { + "type": "boolean" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "example": 13590759200 + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "example": 14490759200 + }, + "htmlDescription": { + "type": "string", + "writeOnly": true + }, + "closedDate": { + "type": "integer", + "format": "int64", + "example": 19990759200 + }, + "participants": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "reviewers": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "description": { + "type": "string", + "example": "It is a kludge, but put the tuple from the database in the cache." + }, + "title": { + "type": "string", + "example": "Talking Nerdy" + }, + "fromRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "toRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "draft": { + "type": "boolean" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "lineComment": { + "type": "boolean", + "readOnly": true + }, + "line": { + "type": "integer", + "format": "int32", + "example": 98 + }, + "srcPath": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "toHash": { + "type": "string", + "example": "3cdd5d19178a54d2e51b5098d43b57571241d0ab" + } + } + }, + "RestPullRequestRef": { + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "RestProject": { + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "RestEmoticon": { + "properties": { + "value": { + "type": "string" + }, + "shortcut": { + "type": "string" + }, + "url": { + "type": "string" + } + } + }, + "RestUserReaction": { + "properties": { + "comment": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "parent": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "state": { + "type": "string", + "example": "OPEN" + }, + "severity": { + "type": "string", + "example": "NORMAL" + }, + "threadResolvedDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1569075920 + }, + "threadResolver": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + }, + "readOnly": true + }, + "threadResolved": { + "type": "boolean", + "description": "Indicates if this comment thread has been marked as resolved or not" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1359075920 + }, + "resolvedDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1239075920 + }, + "resolver": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + }, + "readOnly": true + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1449075920 + }, + "comments": { + "type": "array", + "readOnly": true, + "items": { + "$ref": "#/components/schemas/RestComment" + } + }, + "text": { + "type": "string", + "example": "An insightful comment." + }, + "anchor": { + "type": "object", + "properties": { + "path": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "diffType": { + "type": "string", + "enum": [ + "COMMIT", + "EFFECTIVE", + "RANGE" + ] + }, + "fileType": { + "type": "string", + "enum": [ + "FROM", + "TO" + ] + }, + "fromHash": { + "type": "string", + "example": "62a0505e8204115b8b9c8a95bfa264a8c0896a93" + }, + "lineType": { + "type": "string", + "enum": [ + "ADDED", + "CONTEXT", + "REMOVED" + ] + }, + "pullRequest": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32" + }, + "open": { + "type": "boolean" + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "state": { + "type": "string", + "enum": [ + "DECLINED", + "MERGED", + "OPEN" + ] + }, + "locked": { + "type": "boolean" + }, + "closed": { + "type": "boolean" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "example": 13590759200 + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "example": 14490759200 + }, + "htmlDescription": { + "type": "string", + "writeOnly": true + }, + "closedDate": { + "type": "integer", + "format": "int64", + "example": 19990759200 + }, + "participants": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "reviewers": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "description": { + "type": "string", + "example": "It is a kludge, but put the tuple from the database in the cache." + }, + "title": { + "type": "string", + "example": "Talking Nerdy" + }, + "fromRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "toRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "draft": { + "type": "boolean" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "lineComment": { + "type": "boolean", + "readOnly": true + }, + "line": { + "type": "integer", + "format": "int32", + "example": 98 + }, + "srcPath": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "toHash": { + "type": "string", + "example": "3cdd5d19178a54d2e51b5098d43b57571241d0ab" + } + }, + "readOnly": true + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + }, + "readOnly": true + }, + "html": { + "type": "string", + "readOnly": true + }, + "anchored": { + "type": "boolean", + "readOnly": true + }, + "pending": { + "type": "boolean", + "readOnly": true + }, + "reply": { + "type": "boolean", + "readOnly": true + }, + "properties": { + "type": "object" + } + }, + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "state": { + "type": "string", + "example": "OPEN" + }, + "severity": { + "type": "string", + "example": "NORMAL" + }, + "threadResolvedDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1569075920 + }, + "threadResolver": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + }, + "readOnly": true + }, + "threadResolved": { + "type": "boolean", + "description": "Indicates if this comment thread has been marked as resolved or not" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1359075920 + }, + "resolvedDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1239075920 + }, + "resolver": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + }, + "readOnly": true + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1449075920 + }, + "comments": { + "type": "array", + "readOnly": true, + "items": { + "$ref": "#/components/schemas/RestComment" + } + }, + "text": { + "type": "string", + "example": "An insightful comment." + }, + "anchor": { + "type": "object", + "properties": { + "path": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "diffType": { + "type": "string", + "enum": [ + "COMMIT", + "EFFECTIVE", + "RANGE" + ] + }, + "fileType": { + "type": "string", + "enum": [ + "FROM", + "TO" + ] + }, + "fromHash": { + "type": "string", + "example": "62a0505e8204115b8b9c8a95bfa264a8c0896a93" + }, + "lineType": { + "type": "string", + "enum": [ + "ADDED", + "CONTEXT", + "REMOVED" + ] + }, + "pullRequest": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32" + }, + "open": { + "type": "boolean" + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "state": { + "type": "string", + "enum": [ + "DECLINED", + "MERGED", + "OPEN" + ] + }, + "locked": { + "type": "boolean" + }, + "closed": { + "type": "boolean" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "example": 13590759200 + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "example": 14490759200 + }, + "htmlDescription": { + "type": "string", + "writeOnly": true + }, + "closedDate": { + "type": "integer", + "format": "int64", + "example": 19990759200 + }, + "participants": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "reviewers": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "description": { + "type": "string", + "example": "It is a kludge, but put the tuple from the database in the cache." + }, + "title": { + "type": "string", + "example": "Talking Nerdy" + }, + "fromRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "toRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "draft": { + "type": "boolean" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "lineComment": { + "type": "boolean", + "readOnly": true + }, + "line": { + "type": "integer", + "format": "int32", + "example": 98 + }, + "srcPath": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "toHash": { + "type": "string", + "example": "3cdd5d19178a54d2e51b5098d43b57571241d0ab" + } + }, + "readOnly": true + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + }, + "readOnly": true + }, + "html": { + "type": "string", + "readOnly": true + }, + "anchored": { + "type": "boolean", + "readOnly": true + }, + "pending": { + "type": "boolean", + "readOnly": true + }, + "reply": { + "type": "boolean", + "readOnly": true + }, + "properties": { + "type": "object" + } + } + }, + "emoticon": { + "type": "object", + "properties": { + "value": { + "type": "string" + }, + "shortcut": { + "type": "string" + }, + "url": { + "type": "string" + } + } + }, + "user": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + } + } + }, + "RestComment": { + "properties": { + "version": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "parent": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "state": { + "type": "string", + "example": "OPEN" + }, + "severity": { + "type": "string", + "example": "NORMAL" + }, + "threadResolvedDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1569075920 + }, + "threadResolver": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + }, + "readOnly": true + }, + "threadResolved": { + "type": "boolean", + "description": "Indicates if this comment thread has been marked as resolved or not" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1359075920 + }, + "resolvedDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1239075920 + }, + "resolver": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + }, + "readOnly": true + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1449075920 + }, + "comments": { + "type": "array", + "readOnly": true, + "items": { + "$ref": "#/components/schemas/RestComment" + } + }, + "text": { + "type": "string", + "example": "An insightful comment." + }, + "anchor": { + "type": "object", + "properties": { + "path": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "diffType": { + "type": "string", + "enum": [ + "COMMIT", + "EFFECTIVE", + "RANGE" + ] + }, + "fileType": { + "type": "string", + "enum": [ + "FROM", + "TO" + ] + }, + "fromHash": { + "type": "string", + "example": "62a0505e8204115b8b9c8a95bfa264a8c0896a93" + }, + "lineType": { + "type": "string", + "enum": [ + "ADDED", + "CONTEXT", + "REMOVED" + ] + }, + "pullRequest": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32" + }, + "open": { + "type": "boolean" + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "state": { + "type": "string", + "enum": [ + "DECLINED", + "MERGED", + "OPEN" + ] + }, + "locked": { + "type": "boolean" + }, + "closed": { + "type": "boolean" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "example": 13590759200 + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "example": 14490759200 + }, + "htmlDescription": { + "type": "string", + "writeOnly": true + }, + "closedDate": { + "type": "integer", + "format": "int64", + "example": 19990759200 + }, + "participants": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "reviewers": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "description": { + "type": "string", + "example": "It is a kludge, but put the tuple from the database in the cache." + }, + "title": { + "type": "string", + "example": "Talking Nerdy" + }, + "fromRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "toRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "draft": { + "type": "boolean" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "lineComment": { + "type": "boolean", + "readOnly": true + }, + "line": { + "type": "integer", + "format": "int32", + "example": 98 + }, + "srcPath": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "toHash": { + "type": "string", + "example": "3cdd5d19178a54d2e51b5098d43b57571241d0ab" + } + }, + "readOnly": true + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + }, + "readOnly": true + }, + "html": { + "type": "string", + "readOnly": true + }, + "anchored": { + "type": "boolean", + "readOnly": true + }, + "pending": { + "type": "boolean", + "readOnly": true + }, + "reply": { + "type": "boolean", + "readOnly": true + }, + "properties": { + "type": "object" + } + }, + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "state": { + "type": "string", + "example": "OPEN" + }, + "severity": { + "type": "string", + "example": "NORMAL" + }, + "threadResolvedDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1569075920 + }, + "threadResolver": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + }, + "readOnly": true + }, + "threadResolved": { + "type": "boolean", + "description": "Indicates if this comment thread has been marked as resolved or not" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1359075920 + }, + "resolvedDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1239075920 + }, + "resolver": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + }, + "readOnly": true + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1449075920 + }, + "comments": { + "type": "array", + "readOnly": true, + "items": { + "$ref": "#/components/schemas/RestComment" + } + }, + "text": { + "type": "string", + "example": "An insightful comment." + }, + "anchor": { + "type": "object", + "properties": { + "path": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "diffType": { + "type": "string", + "enum": [ + "COMMIT", + "EFFECTIVE", + "RANGE" + ] + }, + "fileType": { + "type": "string", + "enum": [ + "FROM", + "TO" + ] + }, + "fromHash": { + "type": "string", + "example": "62a0505e8204115b8b9c8a95bfa264a8c0896a93" + }, + "lineType": { + "type": "string", + "enum": [ + "ADDED", + "CONTEXT", + "REMOVED" + ] + }, + "pullRequest": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32" + }, + "open": { + "type": "boolean" + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "state": { + "type": "string", + "enum": [ + "DECLINED", + "MERGED", + "OPEN" + ] + }, + "locked": { + "type": "boolean" + }, + "closed": { + "type": "boolean" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "example": 13590759200 + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "example": 14490759200 + }, + "htmlDescription": { + "type": "string", + "writeOnly": true + }, + "closedDate": { + "type": "integer", + "format": "int64", + "example": 19990759200 + }, + "participants": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "reviewers": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "description": { + "type": "string", + "example": "It is a kludge, but put the tuple from the database in the cache." + }, + "title": { + "type": "string", + "example": "Talking Nerdy" + }, + "fromRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "toRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "draft": { + "type": "boolean" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "lineComment": { + "type": "boolean", + "readOnly": true + }, + "line": { + "type": "integer", + "format": "int32", + "example": 98 + }, + "srcPath": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "toHash": { + "type": "string", + "example": "3cdd5d19178a54d2e51b5098d43b57571241d0ab" + } + }, + "readOnly": true + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + }, + "readOnly": true + }, + "html": { + "type": "string", + "readOnly": true + }, + "anchored": { + "type": "boolean", + "readOnly": true + }, + "pending": { + "type": "boolean", + "readOnly": true + }, + "reply": { + "type": "boolean", + "readOnly": true + }, + "properties": { + "type": "object" + } + } + }, + "RestRepository": { + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "RestGitTagCreateRequest": { + "type": "object", + "properties": { + "force": { + "type": "boolean" + }, + "message": { + "type": "string", + "example": "A new release tag" + }, + "name": { + "type": "string", + "example": "release-tag" + }, + "startPoint": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "ANNOTATED", + "LIGHTWEIGHT" + ] + } + } + }, + "RestPullRequestRebaseRequest": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32", + "example": 1 + } + } + }, + "RestPullRequestRebaseResult": { + "properties": { + "refChange": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "ADD", + "DELETE", + "UPDATE" + ] + }, + "ref": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + } + }, + "fromHash": { + "type": "string", + "example": "6053a1eaa1c009dd11092d09a72f3c41af1b59ad" + }, + "refId": { + "type": "string", + "example": "refs/heads/master" + }, + "toHash": { + "type": "string", + "example": "d6edcbf924697ab811a867421dab60d954ccad99" + } + } + } + } + }, + "RestPullRequestRebaseability": { + "properties": { + "vetoes": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepositoryHookVeto" + } + } + } + }, + "RestRefChange": { + "properties": { + "type": { + "type": "string", + "enum": [ + "ADD", + "DELETE", + "UPDATE" + ] + }, + "ref": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + } + }, + "fromHash": { + "type": "string", + "example": "6053a1eaa1c009dd11092d09a72f3c41af1b59ad" + }, + "refId": { + "type": "string", + "example": "refs/heads/master" + }, + "toHash": { + "type": "string", + "example": "d6edcbf924697ab811a867421dab60d954ccad99" + } + } + }, + "RestRepositoryHookVeto": { + "properties": { + "summaryMessage": { + "type": "string", + "example": "Insufficient branch permissions" + }, + "detailedMessage": { + "type": "string", + "example": "You have insufficient permissions to rebase 'refs/heads/feature-branch'." + } + } + }, + "RestTag": { + "properties": { + "hash": { + "type": "string", + "example": "8d51122def5632836d1cb1026e879069e10a1e13" + }, + "latestCommit": { + "type": "string", + "readOnly": true, + "example": "8d51122def5632836d1cb1026e879069e10a1e13" + }, + "latestChangeset": { + "type": "string", + "readOnly": true, + "example": "8d51122def5632836d1cb1026e879069e10a1e13" + }, + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + } + }, + "RestGpgKey": { + "properties": { + "id": { + "type": "string", + "readOnly": true, + "example": "00000000000004d2" + }, + "emailAddress": { + "type": "string", + "readOnly": true, + "example": "bitbucket@example.com" + }, + "expiryDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 61550496000000 + }, + "fingerprint": { + "type": "string", + "readOnly": true, + "example": "43:51:43:a1:b5:fc:8b:b7:0a:3a:a9:b1:0f:66:73:a8" + }, + "text": { + "type": "string", + "writeOnly": true, + "example": "-----BEGIN PGP SIGNATURE-----\n\niQEzBAABCAAdFiEEM8MrWnoxlp3K1lFY5BMGiWNefn4FAlkqKE4ACgkQ5BMGiWNe\nfn6/kggAyzKhDDqdVb3Rq02hiSqeqKa1JuKRqDmzIpa6Pxa+1CpCnxwaIVrGgIii\nvj0ZNJzL1Bm2xm0JasotJDiZq5pFKi0FfQ0WmskuhsW1VY/f08TltHpHvK2kHVRr\nGEMVDUb0nj0I7Duc8XTipiYoDGS1GvydNR/bu3SsFTcZyapXirQcTCRT6/Sn0/IP\npUeIwQo1qK4e8gTOhWhfWEiVig39lQhiZFtm5S/vfAY72/Rgp68zMYmwasMSnBgF\n/LLFW6lXAqZIoAP8AnmsMRjCH6mS98+/lxKq2+K71+2YUUIAnNEeO09Lufo3B3Da\nPbs7BpD28w4lKlzb2EQ0n0C9rrxdPA==\n=VZpm\n-----END PGP SIGNATURE-----\n" + }, + "subKeys": { + "type": "array", + "readOnly": true, + "example": [], + "items": { + "$ref": "#/components/schemas/RestGpgSubKey" + } + } + } + }, + "RestGpgSubKey": { + "properties": { + "expiryDate": { + "type": "string", + "format": "date-time" + }, + "fingerprint": { + "type": "string" + } + } + }, + "ApplicationId": { + "type": "object" + }, + "RestChangeset": { + "properties": { + "fromCommit": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "abcdef0123abcdef4567abcdef8987abcdef6543" + }, + "displayId": { + "type": "string", + "example": "abcdef0" + } + } + }, + "toCommit": { + "type": "object", + "properties": { + "message": { + "type": "string", + "example": "More work on feature 1" + }, + "committerTimestamp": { + "type": "integer", + "format": "int64", + "example": 1449075830 + }, + "committer": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Charlie" + }, + "emailAddress": { + "type": "string", + "example": "charlie@example.com" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "authorTimestamp": { + "type": "integer", + "format": "int64", + "example": 1359075920 + }, + "parents": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestMinimalCommit" + } + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Charlie" + }, + "emailAddress": { + "type": "string", + "example": "charlie@example.com" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "id": { + "type": "string", + "example": "abcdef0123abcdef4567abcdef8987abcdef6543" + }, + "displayId": { + "type": "string", + "example": "abcdef0" + } + } + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "changes": { + "type": "object", + "properties": { + "values": { + "type": "object" + }, + "size": { + "type": "integer", + "format": "int32" + }, + "limit": { + "type": "integer", + "format": "int32" + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "RestCommentJiraIssue": { + "properties": { + "commentId": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "issueKey": { + "type": "string", + "example": "TEST-123" + } + } + }, + "RestCommit": { + "properties": { + "message": { + "type": "string", + "example": "More work on feature 1" + }, + "committerTimestamp": { + "type": "integer", + "format": "int64", + "example": 1449075830 + }, + "committer": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Charlie" + }, + "emailAddress": { + "type": "string", + "example": "charlie@example.com" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "authorTimestamp": { + "type": "integer", + "format": "int64", + "example": 1359075920 + }, + "parents": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestMinimalCommit" + } + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Charlie" + }, + "emailAddress": { + "type": "string", + "example": "charlie@example.com" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "id": { + "type": "string", + "example": "abcdef0123abcdef4567abcdef8987abcdef6543" + }, + "displayId": { + "type": "string", + "example": "abcdef0" + } + } + }, + "RestEnhancedEntityLink": { + "properties": { + "displayUrl": { + "type": "string", + "example": "example.com/jira" + }, + "projectName": { + "type": "string", + "example": "My Project" + }, + "applicationLinkId": { + "type": "string", + "example": "a1b54cs4wsd45" + }, + "projectKey": { + "type": "string", + "example": "MPROJ" + }, + "projectId": { + "type": "integer", + "format": "int64", + "example": 10000 + } + } + }, + "RestJiraIssue": { + "type": "object", + "properties": { + "key": { + "type": "string", + "example": "JRA-9" + }, + "url": { + "type": "string", + "example": "https://jira.atlassian.com/browse/JRA-9" + } + } + }, + "RestMinimalCommit": { + "properties": { + "id": { + "type": "string", + "example": "abcdef0123abcdef4567abcdef8987abcdef6543" + }, + "displayId": { + "type": "string", + "example": "abcdef0" + } + } + }, + "RestPageRestChange": { + "properties": { + "values": { + "type": "object" + }, + "size": { + "type": "integer", + "format": "int32" + }, + "limit": { + "type": "integer", + "format": "int32" + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + }, + "RestPerson": { + "properties": { + "name": { + "type": "string", + "example": "Charlie" + }, + "emailAddress": { + "type": "string", + "example": "charlie@example.com" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "RestClusterNode": { + "properties": { + "name": { + "type": "string", + "example": "foo" + }, + "id": { + "type": "string", + "example": "d4fde8b1-2504-4998-a0ba-14fbe98edd4d" + }, + "address": { + "type": "object", + "properties": { + "address": { + "type": "string", + "example": "node.example.com" + }, + "port": { + "type": "integer", + "format": "int32", + "example": 8230 + } + } + }, + "buildVersion": { + "type": "string", + "example": "7.0.0" + }, + "local": { + "type": "boolean" + } + } + }, + "RestFarmSynchronizationRequest": { + "type": "object", + "properties": { + "attempt": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "createdAt": { + "type": "string", + "example": "2022-08-18T02:04:46.435Z" + }, + "externalRepoId": { + "type": "string", + "example": "1" + }, + "type": { + "type": "string", + "example": "INCREMENTAL", + "enum": [ + "incremental", + "snapshot" + ] + } + } + }, + "RestMirrorHashes": { + "properties": { + "content": { + "type": "string", + "example": "677513e1f2a93ff50e7b709e3c96454c23a3fcd40046ab385c4093e30809500a" + }, + "metadata": { + "type": "string", + "example": "677513e1f2a93ff50e7b709e3c96454c23a3fcd40046ab385c4093e30809500a" + } + } + }, + "RestMirrorRepositorySynchronizationStatus": { + "properties": { + "localProjectId": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "lastSyncDate": { + "type": "string", + "format": "date-time" + }, + "failedSyncCount": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "externalRepoId": { + "type": "string", + "example": "1" + }, + "localRepoId": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "upstreamId": { + "type": "string", + "example": "148728f5-df0f-3f3e-af11-5ca16be3725f" + }, + "initialSyncDate": { + "type": "string", + "format": "date-time" + }, + "hashes": { + "type": "object", + "properties": { + "content": { + "type": "string", + "example": "677513e1f2a93ff50e7b709e3c96454c23a3fcd40046ab385c4093e30809500a" + }, + "metadata": { + "type": "string", + "example": "677513e1f2a93ff50e7b709e3c96454c23a3fcd40046ab385c4093e30809500a" + } + } + } + } + }, + "RestMirroredRepository": { + "properties": { + "available": { + "type": "boolean" + }, + "mirrorName": { + "type": "string", + "example": "Saigon Mirror" + }, + "pushUrls": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestNamedLink" + } + }, + "cloneUrls": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestNamedLink" + } + }, + "lastUpdated": { + "type": "string", + "format": "date-time" + }, + "repositoryId": { + "type": "string", + "example": "1" + }, + "status": { + "type": "string", + "enum": [ + "NOT_MIRRORED", + "INITIALIZING", + "AVAILABLE", + "ERROR_INITIALIZING", + "ERROR_AVAILABLE" + ] + } + } + }, + "RestNamedLink": { + "properties": { + "name": { + "type": "string", + "example": "http" + }, + "href": { + "type": "string", + "example": "https://bitbucket.example.com/scm/awesomeproject/awesomerepo.git" + } + } + }, + "RestRefSyncQueue": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestFarmSynchronizationRequest" + } + } + } + }, + "RestSyncProgress": { + "properties": { + "discovering": { + "type": "boolean" + }, + "syncedRepos": { + "type": "integer", + "format": "int32" + }, + "totalRepos": { + "type": "integer", + "format": "int32" + } + } + }, + "RestUpstreamServer": { + "properties": { + "id": { + "type": "string", + "example": "f76a35c5-4592-425d-bf85-b4d9db68e809" + }, + "state": { + "type": "string", + "example": "INSTALLED", + "enum": [ + "INITIALIZING", + "PENDING", + "INSTALLED", + "UNKNOWN", + "REMOVED" + ] + }, + "type": { + "type": "string", + "example": "server", + "enum": [ + "BITBUCKET_SERVER", + "BITBUCKET_CLOUD" + ] + }, + "apiBaseUrl": { + "type": "string", + "example": "https://bitbucket.example.com" + }, + "baseUrl": { + "type": "string", + "example": "https://bitbucket.example.com" + } + } + }, + "RestUpstreamSettings": { + "properties": { + "mode": { + "type": "string", + "enum": [ + "ALL_PROJECTS", + "SELECTED_PROJECTS" + ] + }, + "projectIds": { + "uniqueItems": true, + "type": "array", + "items": { + "type": "string" + } + } + } + }, + "RestRepositoryPolicy": { + "properties": { + "permission": { + "type": "string", + "description": "The permission required to delete repositories. Must be one of: \"SYS_ADMIN\", \"ADMIN\", \"PROJECT_ADMIN\", \"REPO_ADMIN\".", + "example": "ADMIN", + "enum": [ + "SYS_ADMIN", + "ADMIN", + "PROJECT_ADMIN", + "REPO_ADMIN" + ] + } + } + }, + "Credentials": { + "type": "object", + "oneOf": [ + { + "$ref": "#/components/schemas/RestUsernamePasswordCredentials" + }, + { + "$ref": "#/components/schemas/RestBearerTokenCredentials" + }, + { + "$ref": "#/components/schemas/RestSshCredentials" + } + ] + }, + "EnrichedRepository": { + "properties": { + "properties": { + "type": "object", + "properties": { + "contentHash": { + "type": "string", + "example": "457389a0b871fb61012a7351d09aefc0cf1c57c306449d4b5df4d2f381df8433" + }, + "defaultBranchId": { + "type": "string", + "example": "refs/heads/master" + }, + "metadataHash": { + "type": "string", + "example": "11e5cd17e8d74d84a11f2c8a6bbc6ae0a2b69059e54030f49214c94d980364c1" + } + } + }, + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "RestAnalyticsSettings": { + "properties": { + "canCollectAnalytics": { + "type": "boolean" + }, + "serverTime": { + "type": "integer", + "format": "int64", + "example": 1640390400000 + }, + "supportEntitlementNumber": { + "type": "string", + "example": "SEN-500" + } + } + }, + "RestApplicationUserWithPermissions": { + "properties": { + "effectivePermissions": { + "type": "object" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "name": { + "type": "string", + "example": "jcitizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "RestAuthenticationRequest": { + "required": [ + "credentials" + ], + "type": "object", + "properties": { + "credentials": { + "$ref": "#/components/schemas/Credentials" + }, + "repositoryId": { + "type": "integer", + "format": "int32" + }, + "requiredPermissionsOnly": { + "type": "boolean" + } + } + }, + "RestBearerTokenCredentials": { + "required": [ + "token" + ], + "type": "object", + "properties": { + "token": { + "type": "string" + } + } + }, + "RestMirrorAuthToken": { + "properties": {} + }, + "RestMirrorServer": { + "properties": { + "name": { + "type": "string", + "example": "Mirror" + }, + "id": { + "type": "string", + "example": "B0F5-CS21-45C2-CCK3" + }, + "productType": { + "type": "string", + "example": "Bitbucket" + }, + "productVersion": { + "type": "string", + "example": "8.0.0" + }, + "mirrorType": { + "type": "string", + "enum": [ + "SINGLE", + "FARM" + ] + }, + "lastSeenDate": { + "type": "string", + "format": "date-time" + }, + "enabled": { + "type": "boolean" + }, + "baseUrl": { + "type": "string", + "example": "http://vietnam.example.com" + } + } + }, + "RestMirrorUpgradeRequest": { + "type": "object", + "properties": { + "addonDescriptorUri": { + "type": "string", + "format": "uri", + "example": "https://bitbucket-eu.example.com:7990/bitbucket/rest/mirroring/1.0/descriptor" + }, + "baseUrl": { + "type": "string", + "example": "https://bitbucket-eu.example.com:7990/bitbucket" + }, + "productType": { + "type": "string", + "example": "Bitbucket" + }, + "productVersion": { + "type": "string", + "example": "8.0.0" + } + } + }, + "RestMirroredRepositoryDescriptor": { + "properties": { + "mirrorServer": { + "required": [ + "lastSeenDate" + ], + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Mirror" + }, + "id": { + "type": "string", + "example": "B0F5-CS21-45C2-CCK3" + }, + "productType": { + "type": "string", + "example": "Bitbucket" + }, + "productVersion": { + "type": "string", + "example": "8.0.0" + }, + "mirrorType": { + "type": "string", + "enum": [ + "SINGLE", + "FARM" + ] + }, + "lastSeenDate": { + "type": "string", + "format": "date-time" + }, + "enabled": { + "type": "boolean" + }, + "baseUrl": { + "type": "string", + "example": "http://vietnam.example.com" + } + } + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "RestMirroringRequest": { + "properties": { + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "enum": [ + "PENDING", + "ACCEPTED", + "REJECTED" + ] + }, + "productType": { + "type": "string", + "example": "Bitbucket" + }, + "productVersion": { + "type": "string", + "example": "8.0.0" + }, + "mirrorType": { + "type": "string", + "enum": [ + "SINGLE", + "FARM" + ] + }, + "mirrorId": { + "type": "string", + "example": "4f0eb5fc-67fc-48f8-b4a7-87981f026c6a" + }, + "mirrorName": { + "type": "string", + "example": "Bitbucket Mirror" + }, + "addonDescriptorUri": { + "type": "string", + "example": "https://bitbucket-eu.example.com:7990/bitbucket/rest/mirroring/1.0/descriptor" + }, + "mirrorBaseUrl": { + "type": "string", + "example": "https://bitbucket-eu.example.com:7990/bitbucket" + } + } + }, + "RestProperties": { + "properties": { + "contentHash": { + "type": "string", + "example": "457389a0b871fb61012a7351d09aefc0cf1c57c306449d4b5df4d2f381df8433" + }, + "defaultBranchId": { + "type": "string", + "example": "refs/heads/master" + }, + "metadataHash": { + "type": "string", + "example": "11e5cd17e8d74d84a11f2c8a6bbc6ae0a2b69059e54030f49214c94d980364c1" + } + } + }, + "RestRepositoryMirrorEvent": { + "type": "object", + "properties": { + "mirrorRepoId": { + "type": "integer", + "format": "int32", + "example": 42 + }, + "type": { + "type": "string", + "enum": [ + "SYNCHRONIZED", + "SYNCHRONIZATION_FAILED" + ] + }, + "upstreamRepoId": { + "type": "string", + "example": "24" + } + } + }, + "RestSshCredentials": { + "required": [ + "publicKey" + ], + "type": "object", + "properties": { + "algorithm": { + "type": "string", + "description": "The key algorithm, if passing in a legacy X.509 encoded key. Do not specify for OpenSSH encoded keys", + "example": "RSA" + }, + "publicKey": { + "type": "string", + "description": "The public key text in the OpenSSH format. The algorithm must be specified in case of the legacy X.509 keys", + "example": "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKjFjYCLJjrIY/jCXPbJ9wd3drcGospvPkKFNZ1ZcacA test@test.local" + }, + "username": { + "type": "string", + "example": "git" + } + } + }, + "RestUsernamePasswordCredentials": { + "required": [ + "password", + "username" + ], + "type": "object", + "properties": { + "password": { + "type": "string", + "example": "secr3t" + }, + "username": { + "type": "string", + "example": "user1" + } + } + }, + "RestRefRestriction": { + "properties": { + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 1 + }, + "type": { + "type": "string", + "example": "pull-request-only" + }, + "accessKeys": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestSshAccessKey" + } + }, + "scope": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "GLOBAL", + "PROJECT", + "REPOSITORY" + ] + }, + "resourceId": { + "type": "integer", + "format": "int32", + "example": 2 + } + }, + "readOnly": true + }, + "groups": { + "type": "array", + "example": [ + "group_a", + "group_b" + ], + "items": { + "type": "string", + "example": "[\"group_a\",\"group_b\"]" + } + }, + "matcher": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/main" + }, + "type": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Branch" + }, + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + } + } + }, + "displayId": { + "type": "string", + "example": "main" + } + } + }, + "users": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestApplicationUser" + } + } + } + }, + "RestRestrictionRequest": { + "type": "object", + "properties": { + "accessKeyIds": { + "type": "array", + "example": [ + 1, + 2, + 3 + ], + "items": { + "type": "integer", + "format": "int32" + } + }, + "accessKeys": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestSshAccessKey" + } + }, + "groupNames": { + "type": "array", + "example": [ + "bitbucket-developers" + ], + "items": { + "type": "string", + "example": "[\"bitbucket-developers\"]" + } + }, + "groups": { + "type": "array", + "example": [ + "group_a", + "group_b" + ], + "items": { + "type": "string", + "example": "[\"group_a\",\"group_b\"]" + } + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 1 + }, + "matcher": { + "type": "object", + "properties": { + "displayId": { + "type": "string", + "example": "main" + }, + "id": { + "type": "string", + "example": "refs/heads/main" + }, + "type": { + "type": "object", + "properties": { + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + }, + "name": { + "type": "string", + "example": "Branch" + } + } + } + } + }, + "scope": { + "type": "object", + "properties": { + "resourceId": { + "type": "integer", + "format": "int32", + "example": 2 + }, + "type": { + "type": "string", + "enum": [ + "GLOBAL", + "PROJECT", + "REPOSITORY" + ] + } + }, + "readOnly": true + }, + "type": { + "type": "string", + "example": "pull-request-only" + }, + "userSlugs": { + "type": "array", + "example": [ + "bman", + "tstark", + "hulk" + ], + "items": { + "type": "string", + "example": "[\"bman\",\"tstark\",\"hulk\"]" + } + }, + "users": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestApplicationUser" + } + } + } + }, + "RestSshAccessKey": { + "properties": { + "permission": { + "type": "string", + "enum": [ + "USER_ADMIN", + "PROJECT_VIEW", + "REPO_READ", + "REPO_WRITE", + "REPO_ADMIN", + "PROJECT_READ", + "PROJECT_WRITE", + "REPO_CREATE", + "PROJECT_ADMIN", + "LICENSED_USER", + "PROJECT_CREATE", + "ADMIN", + "SYS_ADMIN" + ] + }, + "key": { + "type": "object", + "properties": { + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 1 + }, + "createdDate": { + "type": "string", + "format": "date-time", + "readOnly": true + }, + "expiryDays": { + "type": "integer", + "format": "int32", + "example": 30 + }, + "lastAuthenticated": { + "type": "string", + "readOnly": true, + "example": "1630041546434" + }, + "fingerprint": { + "type": "string", + "readOnly": true, + "example": "Cbg38r+gDCiNHqBk6Y1BKO+EvufFBqhFWIEXh8oq9MI" + }, + "bitLength": { + "type": "integer", + "format": "int32" + }, + "algorithmType": { + "type": "string" + }, + "text": { + "type": "string", + "example": "ssh-rsa AAAAB3... me@127.0.0.1" + }, + "label": { + "type": "string", + "example": "me@127.0.0.1" + } + } + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "RestSshKey": { + "properties": { + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 1 + }, + "createdDate": { + "type": "string", + "format": "date-time", + "readOnly": true + }, + "expiryDays": { + "type": "integer", + "format": "int32", + "example": 30 + }, + "lastAuthenticated": { + "type": "string", + "readOnly": true, + "example": "1630041546434" + }, + "fingerprint": { + "type": "string", + "readOnly": true, + "example": "Cbg38r+gDCiNHqBk6Y1BKO+EvufFBqhFWIEXh8oq9MI" + }, + "bitLength": { + "type": "integer", + "format": "int32" + }, + "algorithmType": { + "type": "string" + }, + "text": { + "type": "string", + "example": "ssh-rsa AAAAB3... me@127.0.0.1" + }, + "label": { + "type": "string", + "example": "me@127.0.0.1" + } + } + }, + "Context": { + "type": "object", + "properties": { + "commitMessage": { + "type": "string", + "example": "Merging in latest from upstream." + } + } + }, + "RestRefSyncRequest": { + "type": "object", + "properties": { + "action": { + "type": "string", + "example": "MERGE", + "enum": [ + "DISCARD", + "MERGE", + "REBASE" + ] + }, + "context": { + "$ref": "#/components/schemas/Context" + }, + "refId": { + "type": "string", + "example": "refs/heads/master" + } + } + }, + "RestRefSyncStatus": { + "properties": { + "available": { + "type": "boolean", + "readOnly": true + }, + "aheadRefs": { + "type": "object", + "properties": { + "tag": { + "type": "boolean" + }, + "state": { + "type": "string", + "enum": [ + "AHEAD", + "DIVERGED", + "ORPHANED" + ] + }, + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + }, + "readOnly": true + }, + "orphanedRefs": { + "type": "object", + "properties": { + "tag": { + "type": "boolean" + }, + "state": { + "type": "string", + "enum": [ + "AHEAD", + "DIVERGED", + "ORPHANED" + ] + }, + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + }, + "readOnly": true + }, + "lastSync": { + "type": "number", + "readOnly": true, + "example": 1331038800000 + }, + "divergedRefs": { + "type": "object", + "properties": { + "tag": { + "type": "boolean" + }, + "state": { + "type": "string", + "enum": [ + "AHEAD", + "DIVERGED", + "ORPHANED" + ] + }, + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + }, + "readOnly": true + }, + "enabled": { + "type": "boolean" + } + } + }, + "RestRejectedRef": { + "properties": { + "tag": { + "type": "boolean" + }, + "state": { + "type": "string", + "enum": [ + "AHEAD", + "DIVERGED", + "ORPHANED" + ] + }, + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + } + }, + "RestSshAccessKeyLocations": { + "type": "object", + "properties": { + "projects": { + "$ref": "#/components/schemas/RestProject" + }, + "repositories": { + "$ref": "#/components/schemas/RestRepository" + } + } + }, + "RestSshKeySettings": { + "properties": { + "maxExpiryDays": { + "type": "object", + "properties": { + "asInt": { + "type": "integer", + "format": "int32" + }, + "present": { + "type": "boolean" + } + } + }, + "keyTypeRestrictions": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestSshKeyTypeRestriction" + } + } + } + }, + "RestSshKeyTypeRestriction": { + "properties": { + "algorithm": { + "type": "string", + "example": "RSA" + }, + "minKeyLength": { + "type": "object", + "properties": { + "asInt": { + "type": "integer", + "format": "int32" + }, + "present": { + "type": "boolean" + } + }, + "example": 2048 + }, + "allowed": { + "type": "boolean", + "example": true + } + } + }, + "RestSshSettings": { + "properties": { + "port": { + "type": "integer", + "format": "int32", + "example": 7999 + }, + "fingerprint": { + "$ref": "#/components/schemas/SimpleSshKeyFingerprint" + }, + "accessKeysEnabled": { + "type": "boolean" + }, + "enabled": { + "type": "boolean", + "example": true + }, + "baseUrl": { + "type": "string", + "example": "ssh://example.com" + } + } + }, + "SimpleSshKeyFingerprint": { + "properties": { + "algorithm": { + "type": "string" + }, + "value": { + "type": "string" + } + } + }, + "AdminPasswordUpdate": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "password": { + "type": "string", + "writeOnly": true, + "example": "my-secret-password" + }, + "passwordConfirm": { + "type": "string", + "writeOnly": true, + "example": "my-secret-password" + } + } + }, + "ApplicationUser": { + "properties": { + "id": { + "type": "integer", + "format": "int32" + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string" + }, + "slug": { + "type": "string" + }, + "name": { + "type": "string" + }, + "emailAddress": { + "type": "string" + } + } + }, + "EntityHolderRestPullRequestDeclineRequest": { + "type": "object", + "properties": { + "entity": { + "type": "object", + "properties": { + "comment": { + "type": "string", + "example": "An optional comment explaining why the pull request is being declined" + }, + "version": { + "type": "integer", + "format": "int32" + } + } + } + } + }, + "EntityHolderRestPullRequestMergeRequest": { + "type": "object", + "properties": { + "entity": { + "type": "object", + "properties": { + "autoMerge": { + "type": "boolean", + "example": false + }, + "autoSubject": { + "type": "string", + "example": "(Optional, 5.7+) true to prepend an auto-generated subject to the message (default), or false to use the message as-is" + }, + "message": { + "type": "string", + "example": "(Optional) A descriptive message for the merge commit" + }, + "strategyId": { + "type": "string", + "example": "(Optional) squash" + }, + "version": { + "type": "integer", + "format": "int32" + } + } + } + } + }, + "EntityHolderRestPullRequestReopenRequest": { + "type": "object", + "properties": { + "entity": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32" + } + } + } + } + }, + "ExampleAvatarMultipartFormData": { + "type": "object", + "properties": { + "avatar": { + "type": "string", + "description": "The avatar file to upload.", + "format": "binary" + } + } + }, + "ExampleCertificateMultipartFormData": { + "type": "object", + "properties": { + "certificate": { + "type": "string", + "description": "The X.509 certificate file to upload.", + "format": "binary" + } + } + }, + "ExampleFiles": { + "properties": { + "files": { + "$ref": "#/components/schemas/ExampleJsonLastModifiedCallback" + } + } + }, + "ExampleJsonLastModifiedCallback": { + "properties": { + "latestCommit": { + "type": "object", + "properties": { + "message": { + "type": "string", + "example": "More work on feature 1" + }, + "committerTimestamp": { + "type": "integer", + "format": "int64", + "example": 1449075830 + }, + "committer": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Charlie" + }, + "emailAddress": { + "type": "string", + "example": "charlie@example.com" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "authorTimestamp": { + "type": "integer", + "format": "int64", + "example": 1359075920 + }, + "parents": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestMinimalCommit" + } + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Charlie" + }, + "emailAddress": { + "type": "string", + "example": "charlie@example.com" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "id": { + "type": "string", + "example": "abcdef0123abcdef4567abcdef8987abcdef6543" + }, + "displayId": { + "type": "string", + "example": "abcdef0" + } + } + }, + "readmeMd": { + "type": "object", + "properties": { + "message": { + "type": "string", + "example": "More work on feature 1" + }, + "committerTimestamp": { + "type": "integer", + "format": "int64", + "example": 1449075830 + }, + "committer": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Charlie" + }, + "emailAddress": { + "type": "string", + "example": "charlie@example.com" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "authorTimestamp": { + "type": "integer", + "format": "int64", + "example": 1359075920 + }, + "parents": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestMinimalCommit" + } + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Charlie" + }, + "emailAddress": { + "type": "string", + "example": "charlie@example.com" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "id": { + "type": "string", + "example": "abcdef0123abcdef4567abcdef8987abcdef6543" + }, + "displayId": { + "type": "string", + "example": "abcdef0" + } + } + }, + "pomXml": { + "type": "object", + "properties": { + "message": { + "type": "string", + "example": "More work on feature 1" + }, + "committerTimestamp": { + "type": "integer", + "format": "int64", + "example": 1449075830 + }, + "committer": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Charlie" + }, + "emailAddress": { + "type": "string", + "example": "charlie@example.com" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "authorTimestamp": { + "type": "integer", + "format": "int64", + "example": 1359075920 + }, + "parents": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestMinimalCommit" + } + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "Charlie" + }, + "emailAddress": { + "type": "string", + "example": "charlie@example.com" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "id": { + "type": "string", + "example": "abcdef0123abcdef4567abcdef8987abcdef6543" + }, + "displayId": { + "type": "string", + "example": "abcdef0" + } + } + } + } + }, + "ExampleMultipartFormData": { + "type": "object", + "properties": { + "branch": { + "type": "string", + "description": "The branch on which the path should be modified or created." + }, + "content": { + "type": "string", + "description": "The full content of the file at path." + }, + "message": { + "type": "string", + "description": "The message associated with this change, to be used as the commit message. Or null if the default message should be used." + }, + "sourceBranch": { + "type": "string", + "description": "The starting point for branch. If provided and different from branch, branch will be created as a new branch, branching off from sourceBranch." + }, + "sourceCommitId": { + "type": "string", + "description": "The commit ID of the file before it was edited, used to identify if content has changed. Or null if this is a new file" + } + } + }, + "ExamplePostMultipartFormData": { + "type": "object", + "properties": { + "content": { + "type": "string", + "description": "The hook script contents." + }, + "description": { + "type": "string", + "description": "A description of the hook script (useful when querying registered hook scripts)." + }, + "name": { + "type": "string", + "description": "The name of the hook script (useful when querying registered hook scripts)." + }, + "type": { + "type": "string", + "description": "The type of hook script; supported values are \"PRE\" for pre-receive hooks and \"POST\" for post-receive hooks." + } + } + }, + "ExamplePreviewMigration": { + "properties": { + "repositories": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepository" + } + } + } + }, + "ExamplePutMultipartFormData": { + "type": "object", + "properties": { + "content": { + "type": "string", + "description": "The hook script contents." + }, + "description": { + "type": "string", + "description": "A description of the hook script (useful when querying registered hook scripts)." + }, + "name": { + "type": "string", + "description": "The name of the hook script (useful when querying registered hook scripts)." + } + } + }, + "ExampleRequirements": { + "properties": { + "count": { + "type": "string", + "example": "3" + }, + "enabled": { + "type": "boolean", + "example": true + } + } + }, + "ExampleSettings": { + "properties": { + "stringValue": { + "type": "string", + "example": "This is an arbitrary string" + }, + "booleanValue": { + "type": "boolean", + "example": true + }, + "doubleValue": { + "type": "number", + "format": "double", + "example": 1.1 + }, + "integerValue": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "longValue": { + "type": "integer", + "format": "int64", + "example": -2147483648 + } + } + }, + "ExampleSettingsMap": { + "properties": { + "boolean key": { + "type": "boolean", + "example": true + }, + "string key": { + "type": "string", + "example": "string value" + }, + "long key": { + "type": "number", + "example": 10 + } + } + }, + "ExampleSocketAddress": { + "properties": { + "address": { + "type": "string", + "example": "node.example.com" + }, + "port": { + "type": "integer", + "format": "int32", + "example": 8230 + } + } + }, + "ExampleStatus": { + "properties": { + "serverId": { + "type": "string", + "example": "" + }, + "currentNumberOfUsers": { + "type": "integer", + "format": "int32", + "example": 2 + } + } + }, + "FileListResource": {}, + "FilePart": { + "type": "object", + "properties": { + "contentType": { + "type": "string" + }, + "formField": { + "type": "boolean" + }, + "inputStream": { + "type": "object" + }, + "name": { + "type": "string" + }, + "size": { + "type": "integer", + "format": "int64" + }, + "value": { + "type": "string" + } + } + }, + "Group": { + "properties": { + "name": { + "type": "string", + "example": "group_a" + } + } + }, + "GroupAndUsers": { + "required": [ + "users" + ], + "type": "object", + "properties": { + "group": { + "type": "string", + "example": "group" + }, + "users": { + "uniqueItems": true, + "type": "array", + "example": [ + "user1", + "user2" + ], + "items": { + "type": "string" + } + } + } + }, + "GroupPickerContext": { + "type": "object", + "properties": { + "context": { + "type": "string", + "example": "user_a" + }, + "itemName": { + "type": "string", + "example": "group_a" + } + } + }, + "RepositoryHookDetails": { + "properties": { + "version": { + "type": "string" + }, + "name": { + "type": "string" + }, + "key": { + "type": "string" + }, + "type": { + "type": "string", + "enum": [ + "PRE_RECEIVE", + "PRE_PULL_REQUEST_MERGE", + "POST_RECEIVE" + ] + }, + "configFormKey": { + "type": "string" + }, + "supportedScopes": { + "uniqueItems": true, + "type": "array", + "items": { + "type": "string", + "enum": [ + "GLOBAL", + "PROJECT", + "REPOSITORY" + ] + } + }, + "description": { + "type": "string" + } + } + }, + "RestAggregateRejectCounter": { + "properties": { + "lastRejectTime": { + "type": "number", + "example": 1630041546433 + }, + "rejectCount": { + "type": "integer", + "format": "int64", + "example": 5 + }, + "user": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + } + } + }, + "RestAnnouncementBanner": { + "properties": { + "message": { + "type": "string" + }, + "audience": { + "type": "string", + "enum": [ + "AUTHENTICATED", + "ALL" + ] + }, + "enabled": { + "type": "boolean" + } + } + }, + "RestApplicationProperties": { + "properties": { + "version": { + "type": "string", + "example": "2.1.0" + }, + "displayName": { + "type": "string", + "example": "Example.com Bitbucket" + }, + "buildDate": { + "type": "string", + "example": "1358897885952000" + }, + "buildNumber": { + "type": "string", + "example": "20220123103656677" + } + } + }, + "RestApplySuggestionRequest": { + "type": "object", + "properties": { + "commentVersion": { + "type": "object", + "properties": { + "asInt": { + "type": "integer", + "format": "int32" + }, + "present": { + "type": "boolean" + } + }, + "example": 0 + }, + "commitMessage": { + "type": "string", + "example": "A commit message" + }, + "pullRequestVersion": { + "type": "object", + "properties": { + "asInt": { + "type": "integer", + "format": "int32" + }, + "present": { + "type": "boolean" + } + }, + "example": 1 + }, + "suggestionIndex": { + "type": "object", + "properties": { + "asInt": { + "type": "integer", + "format": "int32" + }, + "present": { + "type": "boolean" + } + }, + "example": 2 + } + } + }, + "RestAttachmentMetadata": { + "properties": { + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "metadata": { + "type": "string", + "example": "{\\\"A\\\":\\\"B\\\"}" + }, + "url": { + "type": "string", + "example": "test.com/test" + } + } + }, + "RestAutoDeclineSettings": { + "properties": { + "inactivityWeeks": { + "type": "integer", + "format": "int32", + "example": 4 + }, + "scope": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "GLOBAL", + "PROJECT", + "REPOSITORY" + ] + }, + "resourceId": { + "type": "integer", + "format": "int32", + "example": 2 + } + } + }, + "enabled": { + "type": "boolean", + "example": true + } + } + }, + "RestAutoDeclineSettingsRequest": { + "type": "object", + "properties": { + "enabled": { + "type": "boolean", + "example": true + }, + "inactivityWeeks": { + "type": "integer", + "format": "int32", + "example": 4 + } + } + }, + "RestAutoMergeProcessingResult": { + "properties": { + "pullRequest": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32" + }, + "open": { + "type": "boolean" + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "state": { + "type": "string", + "enum": [ + "DECLINED", + "MERGED", + "OPEN" + ] + }, + "locked": { + "type": "boolean" + }, + "closed": { + "type": "boolean" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "example": 13590759200 + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "example": 14490759200 + }, + "htmlDescription": { + "type": "string", + "writeOnly": true + }, + "closedDate": { + "type": "integer", + "format": "int64", + "example": 19990759200 + }, + "participants": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "reviewers": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "description": { + "type": "string", + "example": "It is a kludge, but put the tuple from the database in the cache." + }, + "title": { + "type": "string", + "example": "Talking Nerdy" + }, + "fromRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "toRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "feature-ABC-1233" + }, + "latestCommit": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "draft": { + "type": "boolean" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "autoMergeProcessingStatus": { + "type": "string", + "example": "CANCELLED", + "enum": [ + "CANCELLED", + "VETOED", + "STALE", + "MERGED", + "LOCK_FAILURE", + "UNKNOWN" + ] + } + } + }, + "RestAutoMergeProjectSettingsRequest": { + "type": "object", + "properties": { + "enabled": { + "type": "boolean", + "example": false + }, + "restrictionAction": { + "type": "string", + "example": "CREATE", + "enum": [ + "CREATE", + "DELETE", + "NONE" + ] + } + } + }, + "RestAutoMergeRequest": { + "properties": { + "message": { + "type": "string", + "example": "(Optional) A descriptive message for the merge commit" + }, + "autoSubject": { + "type": "boolean", + "example": true + }, + "strategyId": { + "type": "string", + "example": "(Optional) squash" + }, + "createdDate": { + "type": "integer", + "format": "int64", + "example": 13590759200 + }, + "fromHash": { + "type": "string", + "example": "babecafebabecafebabecafebabecafebabecafe" + }, + "toRefId": { + "type": "string", + "example": "refs/heads/feature-ABC-123" + } + } + }, + "RestAutoMergeRestrictedSettings": { + "properties": { + "restrictionState": { + "type": "string", + "description": "The restriction state of this scope's project.", + "enum": [ + "NONE", + "RESTRICTED_UNMODIFIABLE", + "RESTRICTED_MODIFIABLE" + ] + }, + "scope": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "GLOBAL", + "PROJECT", + "REPOSITORY" + ] + }, + "resourceId": { + "type": "integer", + "format": "int32", + "example": 2 + } + }, + "description": "The scope that these settings apply to." + }, + "enabled": { + "type": "boolean", + "example": false + } + } + }, + "RestAutoMergeSettingsRequest": { + "type": "object", + "properties": { + "enabled": { + "type": "boolean", + "example": false + } + } + }, + "RestBitbucketLicense": { + "properties": { + "serverId": { + "type": "string", + "readOnly": true, + "example": "" + }, + "creationDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1331038800000 + }, + "daysBeforeExpiry": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "expiryDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1372493732817 + }, + "gracePeriodEndDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1372493732817 + }, + "maintenanceExpiryDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1372493732817 + }, + "maximumNumberOfUsers": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 12 + }, + "purchaseDate": { + "type": "integer", + "format": "int64", + "readOnly": true, + "example": 1331038800000 + }, + "unlimitedNumberOfUsers": { + "type": "boolean", + "readOnly": true + }, + "status": { + "type": "object", + "properties": { + "serverId": { + "type": "string", + "example": "" + }, + "currentNumberOfUsers": { + "type": "integer", + "format": "int32", + "example": 2 + } + }, + "readOnly": true + }, + "license": { + "type": "string", + "example": "" + }, + "numberOfDaysBeforeExpiry": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "numberOfDaysBeforeGracePeriodExpiry": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "numberOfDaysBeforeMaintenanceExpiry": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "supportEntitlementNumber": { + "type": "string", + "readOnly": true, + "example": "" + } + } + }, + "RestBuildCapabilities": { + "properties": { + "buildStatus": { + "type": "array", + "items": { + "type": "string", + "example": "richBuildStatus" + } + } + } + }, + "RestBuildStatusSetRequest": { + "required": [ + "key", + "state", + "url" + ], + "type": "object", + "properties": { + "buildNumber": { + "maxLength": 255, + "minLength": 0, + "type": "string", + "example": "3" + }, + "description": { + "type": "string", + "example": "Unit test build" + }, + "duration": { + "type": "integer", + "format": "int64", + "example": 1500000 + }, + "key": { + "maxLength": 255, + "minLength": 0, + "type": "string", + "example": "TEST-REP123" + }, + "lastUpdated": { + "type": "integer", + "format": "int64", + "example": 1359075920 + }, + "name": { + "maxLength": 255, + "minLength": 0, + "type": "string", + "example": "Database Matrix Tests" + }, + "parent": { + "maxLength": 1024, + "minLength": 0, + "type": "string", + "example": "TEST-REP" + }, + "ref": { + "maxLength": 1024, + "minLength": 0, + "pattern": "^refs\\/.*", + "type": "string", + "example": "refs/heads/master" + }, + "state": { + "type": "string", + "enum": [ + "CANCELLED", + "FAILED", + "INPROGRESS", + "SUCCESSFUL", + "UNKNOWN" + ] + }, + "testResults": { + "type": "object", + "properties": { + "failed": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "skipped": { + "type": "integer", + "format": "int32", + "example": 5 + }, + "successful": { + "type": "integer", + "format": "int32", + "example": 134 + } + } + }, + "url": { + "maxLength": 450, + "minLength": 0, + "type": "string", + "example": "https://bamboo.example.com/browse/TEST-REP1-3" + } + } + }, + "RestBulkUserRateLimitSettingsUpdateRequest": { + "type": "object", + "properties": { + "settings": { + "type": "object", + "properties": { + "capacity": { + "type": "integer", + "format": "int32", + "example": 60 + }, + "fillRate": { + "type": "integer", + "format": "int32", + "example": 5 + } + } + }, + "usernames": { + "uniqueItems": true, + "type": "array", + "items": { + "type": "string" + } + }, + "whitelisted": { + "type": "boolean" + } + } + }, + "RestChange": { + "properties": { + "type": { + "type": "string", + "enum": [ + "ADD", + "COPY", + "DELETE", + "MODIFY", + "MOVE", + "UNKNOWN" + ] + }, + "path": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "srcExecutable": { + "type": "boolean" + }, + "percentUnchanged": { + "type": "integer", + "format": "int32", + "example": 98 + }, + "conflict": { + "type": "object", + "properties": { + "ourChange": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "ADD", + "COPY", + "DELETE", + "MODIFY", + "MOVE", + "UNKNOWN" + ] + }, + "path": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "srcPath": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + } + } + }, + "theirChange": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "ADD", + "COPY", + "DELETE", + "MODIFY", + "MOVE", + "UNKNOWN" + ] + }, + "path": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "srcPath": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + } + } + } + } + }, + "contentId": { + "type": "string", + "example": "abcdef0123abcdef4567abcdef8987abcdef6543" + }, + "fromContentId": { + "type": "string", + "example": "bcdef0123abcdef4567abcdef8987abcdef6543a" + }, + "nodeType": { + "type": "string", + "enum": [ + "DIRECTORY", + "FILE", + "SUBMODULE" + ] + }, + "executable": { + "type": "boolean" + }, + "srcPath": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "RestClusterInformation": { + "properties": { + "localNode": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "foo" + }, + "id": { + "type": "string", + "example": "d4fde8b1-2504-4998-a0ba-14fbe98edd4d" + }, + "address": { + "type": "object", + "properties": { + "address": { + "type": "string", + "example": "node.example.com" + }, + "port": { + "type": "integer", + "format": "int32", + "example": 8230 + } + } + }, + "buildVersion": { + "type": "string", + "example": "7.0.0" + }, + "local": { + "type": "boolean" + } + } + }, + "running": { + "type": "boolean" + }, + "nodes": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestClusterNode" + } + } + } + }, + "RestCommitMessageSuggestion": { + "properties": { + "title": { + "type": "string", + "example": "Pull request #2: add new feature" + }, + "body": { + "type": "string", + "example": "Merge in PROJECT_1/repo_1 from feature/feature-2 to main" + } + } + }, + "RestConflict": { + "properties": { + "ourChange": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "ADD", + "COPY", + "DELETE", + "MODIFY", + "MOVE", + "UNKNOWN" + ] + }, + "path": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "srcPath": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + } + } + }, + "theirChange": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "ADD", + "COPY", + "DELETE", + "MODIFY", + "MOVE", + "UNKNOWN" + ] + }, + "path": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "srcPath": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + } + } + } + } + }, + "RestConflictChange": { + "properties": { + "type": { + "type": "string", + "enum": [ + "ADD", + "COPY", + "DELETE", + "MODIFY", + "MOVE", + "UNKNOWN" + ] + }, + "path": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "srcPath": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + } + } + }, + "RestConnectivitySummary": { + "properties": { + "errorMessage": { + "type": "string", + "example": "Unable to connect to the node." + }, + "reachable": { + "type": "boolean", + "example": true + }, + "roundTripTime": { + "type": "integer", + "format": "int64", + "example": 100 + } + } + }, + "RestCreateBranchRequest": { + "type": "object", + "properties": { + "message": { + "type": "string", + "example": "This is my branch or tag" + }, + "name": { + "type": "string", + "example": "my-branch-or-tag" + }, + "startPoint": { + "type": "string", + "example": "8d351a10fb428c0c1239530256e21cf24f136e73" + } + } + }, + "RestCreateTagRequest": { + "type": "object", + "properties": { + "message": { + "type": "string", + "example": "This is my branch or tag" + }, + "name": { + "type": "string", + "example": "my-branch-or-tag" + }, + "startPoint": { + "type": "string", + "example": "8d351a10fb428c0c1239530256e21cf24f136e73" + } + } + }, + "RestDefaultBranch": { + "type": "object", + "properties": { + "id": { + "type": "string" + } + } + }, + "RestDeployment": { + "properties": { + "key": { + "type": "string", + "example": "PROD-MIR" + }, + "state": { + "type": "string", + "enum": [ + "PENDING", + "IN_PROGRESS", + "CANCELLED", + "FAILED", + "ROLLED_BACK", + "SUCCESSFUL", + "UNKNOWN" + ] + }, + "displayName": { + "type": "string", + "example": "US East Mirror" + }, + "environment": { + "required": [ + "displayName", + "key" + ], + "type": "object", + "properties": { + "key": { + "maxLength": 255, + "minLength": 0, + "type": "string", + "example": "us-east-mirror" + }, + "type": { + "pattern": "DEVELOPMENT|TESTING|STAGING|PRODUCTION", + "type": "string", + "example": "production" + }, + "displayName": { + "maxLength": 255, + "minLength": 0, + "type": "string", + "example": "US East Mirror" + }, + "url": { + "maxLength": 1024, + "minLength": 0, + "type": "string", + "example": "https://foo-bar.production/us-east" + } + } + }, + "fromCommit": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "abcdef0123abcdef4567abcdef8987abcdef6543" + }, + "displayId": { + "type": "string", + "example": "abcdef0" + } + } + }, + "toCommit": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "abcdef0123abcdef4567abcdef8987abcdef6543" + }, + "displayId": { + "type": "string", + "example": "abcdef0" + } + } + }, + "description": { + "type": "string", + "example": "Production and mirror environments" + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "lastUpdated": { + "type": "integer", + "format": "int64", + "example": 1449075920 + }, + "url": { + "type": "string", + "example": "http://example.ci.org/projects/PROJ/deploy/mirror-deploy/100" + }, + "deploymentSequenceNumber": { + "type": "integer", + "format": "int64", + "example": 5 + } + } + }, + "RestDeploymentEnvironment": { + "properties": { + "key": { + "maxLength": 255, + "minLength": 0, + "type": "string", + "example": "us-east-mirror" + }, + "type": { + "pattern": "DEVELOPMENT|TESTING|STAGING|PRODUCTION", + "type": "string", + "example": "production" + }, + "displayName": { + "maxLength": 255, + "minLength": 0, + "type": "string", + "example": "US East Mirror" + }, + "url": { + "maxLength": 1024, + "minLength": 0, + "type": "string", + "example": "https://foo-bar.production/us-east" + } + } + }, + "RestDeploymentSetRequest": { + "required": [ + "deploymentSequenceNumber", + "description", + "displayName", + "environment", + "key", + "state", + "url" + ], + "type": "object", + "properties": { + "deploymentSequenceNumber": { + "type": "integer", + "format": "int64", + "example": 2 + }, + "description": { + "maxLength": 255, + "minLength": 0, + "type": "string", + "example": "2nd deployment of commit 44bca31f4be to US East production" + }, + "displayName": { + "maxLength": 255, + "minLength": 0, + "type": "string", + "example": "US East marketing website production" + }, + "environment": { + "$ref": "#/components/schemas/RestDeploymentEnvironment" + }, + "key": { + "maxLength": 255, + "minLength": 0, + "type": "string", + "example": "marketing-us-prod" + }, + "lastUpdated": { + "minimum": 0, + "type": "integer", + "format": "int64", + "example": 1359075920 + }, + "state": { + "type": "string", + "example": "SUCCESSFUL", + "enum": [ + "PENDING", + "IN_PROGRESS", + "CANCELLED", + "FAILED", + "ROLLED_BACK", + "SUCCESSFUL", + "UNKNOWN" + ] + }, + "url": { + "maxLength": 1024, + "minLength": 0, + "type": "string", + "example": "https://my-dep-tool/marketing-us-prod/2" + } + } + }, + "RestDetailedGroup": { + "properties": { + "name": { + "type": "string", + "example": "group-a" + }, + "deletable": { + "type": "boolean" + } + } + }, + "RestDetailedInvocation": { + "properties": { + "start": { + "type": "integer", + "format": "int32" + }, + "result": { + "type": "object", + "properties": {} + }, + "id": { + "type": "integer", + "format": "int32" + }, + "duration": { + "type": "integer", + "format": "int32" + }, + "eventScope": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "type": "string" + } + } + }, + "request": { + "type": "object", + "properties": {} + }, + "event": { + "type": "string" + }, + "finish": { + "type": "integer", + "format": "int32" + } + } + }, + "RestDetailedUser": { + "properties": { + "deletable": { + "type": "boolean" + }, + "directoryName": { + "type": "string", + "example": "Bitbucket Internal Directory" + }, + "mutableDetails": { + "type": "boolean" + }, + "mutableGroups": { + "type": "boolean" + }, + "lastAuthenticationTimestamp": { + "type": "number", + "example": 1368145580548 + }, + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "RestDiff": { + "properties": { + "truncated": { + "type": "boolean" + }, + "lineComments": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestComment" + } + }, + "destination": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "source": { + "type": "object", + "properties": { + "extension": { + "type": "string", + "example": "txt" + }, + "name": { + "type": "string", + "example": "file.txt" + }, + "parent": { + "type": "string", + "example": "path/to" + }, + "components": { + "type": "array", + "example": [ + "path", + "to", + "file.txt" + ], + "items": { + "type": "string" + } + } + } + }, + "binary": { + "type": "boolean" + }, + "hunks": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDiffHunk" + } + }, + "properties": { + "type": "object" + } + } + }, + "RestDiffHunk": { + "properties": { + "context": { + "type": "string" + }, + "sourceLine": { + "type": "integer", + "format": "int32" + }, + "segments": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDiffSegment" + } + }, + "sourceSpan": { + "type": "integer", + "format": "int32" + }, + "destinationSpan": { + "type": "integer", + "format": "int32" + }, + "destinationLine": { + "type": "integer", + "format": "int32" + }, + "truncated": { + "type": "boolean" + } + } + }, + "RestDiffLine": { + "properties": { + "truncated": { + "type": "boolean" + }, + "conflictMarker": { + "type": "string", + "enum": [ + "MARKER", + "OURS", + "THEIRS" + ] + }, + "commentIds": { + "type": "array", + "items": { + "type": "integer", + "format": "int64" + } + }, + "destination": { + "type": "integer", + "format": "int32" + }, + "source": { + "type": "integer", + "format": "int32" + }, + "line": { + "type": "string" + } + } + }, + "RestDiffSegment": { + "properties": { + "type": { + "type": "string", + "enum": [ + "ADDED", + "CONTEXT", + "REMOVED" + ] + }, + "truncated": { + "type": "boolean" + }, + "lines": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDiffLine" + } + } + } + }, + "RestErasedUser": { + "properties": { + "newIdentifier": { + "type": "string", + "example": "user-123ab" + } + } + }, + "RestExportRequest": { + "required": [ + "repositoriesRequest" + ], + "type": "object", + "properties": { + "exportLocation": { + "type": "string", + "example": "example/sub/directory" + }, + "repositoriesRequest": { + "required": [ + "includes" + ], + "type": "object", + "properties": { + "includes": { + "uniqueItems": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepositorySelector" + } + } + } + } + } + }, + "RestHookScript": { + "properties": { + "version": { + "type": "integer", + "format": "int32" + }, + "name": { + "type": "string" + }, + "id": { + "type": "integer", + "format": "int64" + }, + "type": { + "type": "string", + "enum": [ + "POST", + "PRE" + ] + }, + "createdDate": { + "type": "string", + "format": "date-time" + }, + "updatedDate": { + "type": "string", + "format": "date-time" + }, + "description": { + "type": "string" + }, + "pluginKey": { + "type": "string" + } + } + }, + "RestHookScriptConfig": { + "properties": { + "script": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32" + }, + "name": { + "type": "string" + }, + "id": { + "type": "integer", + "format": "int64" + }, + "type": { + "type": "string", + "enum": [ + "POST", + "PRE" + ] + }, + "createdDate": { + "type": "string", + "format": "date-time" + }, + "updatedDate": { + "type": "string", + "format": "date-time" + }, + "description": { + "type": "string" + }, + "pluginKey": { + "type": "string" + } + } + }, + "scope": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "GLOBAL", + "PROJECT", + "REPOSITORY" + ] + }, + "resourceId": { + "type": "integer", + "format": "int32", + "example": 2 + } + } + }, + "triggerIds": { + "uniqueItems": true, + "type": "array", + "items": { + "type": "string" + } + } + } + }, + "RestHookScriptTriggers": { + "type": "object", + "properties": { + "triggerIds": { + "uniqueItems": true, + "type": "array", + "items": { + "type": "string" + } + } + } + }, + "RestImportRequest": { + "type": "object", + "properties": { + "archivePath": { + "type": "string", + "example": "Bitbucket_export_1.tar" + } + } + }, + "RestInvocationHistory": { + "properties": {} + }, + "RestInvocationRequest": { + "properties": {} + }, + "RestInvocationResult": { + "properties": {} + }, + "RestJob": { + "properties": { + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "state": { + "type": "string", + "enum": [ + "INITIALISING", + "READY", + "RUNNING", + "FINALISING", + "COMPLETED", + "FAILED", + "CANCELING", + "CANCELED", + "TIMED_OUT", + "ABORTED" + ] + }, + "type": { + "type": "string", + "example": "com.atlassian.bitbucket.migration.export" + }, + "progress": { + "type": "object", + "properties": { + "message": { + "type": "string", + "example": "Working on it..." + }, + "percentage": { + "type": "integer", + "format": "int32", + "example": 42 + } + } + }, + "updatedDate": { + "type": "integer", + "format": "int64", + "example": 1497657603000 + }, + "startDate": { + "type": "integer", + "format": "int64", + "example": 1497657601000 + }, + "initiator": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + }, + "nodeId": { + "type": "string", + "example": "1bec7499-077a-4b58-b27c-996a9c2187a4" + }, + "endDate": { + "type": "integer", + "format": "int64", + "example": 1497657603000 + } + } + }, + "RestJobMessage": { + "properties": { + "subject": { + "type": "string", + "example": "job" + }, + "id": { + "type": "string", + "example": "617" + }, + "severity": { + "type": "string", + "enum": [ + "INFO", + "WARN", + "ERROR" + ] + }, + "createdDate": { + "type": "string", + "format": "date-time" + }, + "text": { + "type": "string", + "example": "Something of interest happened" + } + } + }, + "RestLabel": { + "properties": { + "name": { + "type": "string", + "example": "labelName" + } + } + }, + "RestLabelable": { + "properties": { + "labelableType": { + "type": "string", + "enum": [ + "REPOSITORY" + ] + }, + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "RestLogLevel": { + "properties": { + "logLevel": { + "type": "string", + "example": "DEBUG" + } + } + }, + "RestMailConfiguration": { + "properties": { + "port": { + "type": "integer", + "format": "int32", + "example": 465 + }, + "protocol": { + "type": "string", + "enum": [ + "SMTP", + "SMTPS" + ] + }, + "hostname": { + "type": "string", + "example": "smtp.example.com" + }, + "requireStartTls": { + "type": "boolean" + }, + "useStartTls": { + "type": "boolean" + }, + "senderAddress": { + "type": "string", + "example": "stash-no-reply@company.com" + }, + "password": { + "type": "string", + "example": "password" + }, + "username": { + "type": "string", + "example": "user" + } + } + }, + "RestMarkup": { + "properties": { + "html": { + "type": "string", + "example": "

Hello World!

" + } + } + }, + "RestMeshConnectivityReport": { + "properties": { + "reports": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestNodeConnectivityReport" + } + } + } + }, + "RestMeshMigrationQueueStateCounts": { + "properties": {} + }, + "RestMeshMigrationRequest": { + "type": "object", + "properties": { + "all": { + "type": "boolean" + }, + "maxBytesPerSecond": { + "type": "object", + "properties": { + "asLong": { + "type": "integer", + "format": "int64" + }, + "present": { + "type": "boolean" + } + } + }, + "projectIds": { + "uniqueItems": true, + "type": "array", + "items": { + "type": "integer", + "format": "int32" + } + }, + "repositoryIds": { + "uniqueItems": true, + "type": "array", + "items": { + "type": "integer", + "format": "int32" + } + } + } + }, + "RestMeshMigrationSummary": { + "properties": { + "queue": { + "type": "object", + "properties": {} + }, + "state": { + "type": "string", + "example": "RUNNING" + }, + "progress": { + "type": "integer", + "format": "int32", + "example": 53 + }, + "maxBandwidth": { + "type": "integer", + "format": "int64" + }, + "startTime": { + "type": "integer", + "format": "int64", + "example": 1331038800000 + }, + "endTime": { + "type": "integer", + "format": "int64", + "example": 1331038800000 + }, + "jobId": { + "type": "integer", + "format": "int64" + } + } + }, + "RestMeshNode": { + "properties": { + "name": { + "type": "string", + "example": "My node" + }, + "id": { + "type": "string", + "example": "1" + }, + "state": { + "type": "string", + "example": "AVAILABLE", + "enum": [ + "AVAILABLE", + "DELETING", + "DISABLED", + "DRAINING", + "OFFLINE" + ] + }, + "lastSeenDate": { + "type": "number", + "example": 1630041546433 + }, + "offline": { + "type": "boolean", + "example": false + }, + "rpcUrl": { + "type": "string", + "example": "http://127.0.0.1:7999" + }, + "rpcId": { + "type": "string", + "example": "1" + } + } + }, + "RestMigrationRepository": { + "properties": { + "migrationState": { + "type": "string", + "enum": [ + "QUEUED", + "STAGING", + "STAGED", + "MIGRATED", + "FAILED", + "CANCELED", + "SKIPPED" + ] + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "RestNode": { + "properties": { + "name": { + "type": "string", + "example": "My Node" + }, + "id": { + "type": "string", + "example": "1" + }, + "type": { + "type": "string", + "enum": [ + "BITBUCKET", + "MESH" + ] + } + } + }, + "RestNodeConnectivityReport": { + "properties": { + "node": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My Node" + }, + "id": { + "type": "string", + "example": "1" + }, + "type": { + "type": "string", + "enum": [ + "BITBUCKET", + "MESH" + ] + } + } + }, + "summaries": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestNodeConnectivitySummary" + } + } + } + }, + "RestNodeConnectivitySummary": { + "properties": { + "node": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My Node" + }, + "id": { + "type": "string", + "example": "1" + }, + "type": { + "type": "string", + "enum": [ + "BITBUCKET", + "MESH" + ] + } + } + }, + "summary": { + "type": "object", + "properties": { + "errorMessage": { + "type": "string", + "example": "Unable to connect to the node." + }, + "reachable": { + "type": "boolean", + "example": true + }, + "roundTripTime": { + "type": "integer", + "format": "int64", + "example": 100 + } + } + } + } + }, + "RestPermitted": { + "properties": { + "permitted": { + "type": "boolean", + "example": true + } + } + }, + "RestPermittedGroup": { + "properties": { + "permission": { + "type": "string", + "example": "ADMIN" + }, + "group": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "group_a" + } + } + } + } + }, + "RestPermittedUser": { + "properties": { + "permission": { + "type": "string", + "enum": [ + "USER_ADMIN", + "PROJECT_VIEW", + "REPO_READ", + "REPO_WRITE", + "REPO_ADMIN", + "PROJECT_READ", + "PROJECT_WRITE", + "REPO_CREATE", + "PROJECT_ADMIN", + "LICENSED_USER", + "PROJECT_CREATE", + "ADMIN", + "SYS_ADMIN" + ] + }, + "user": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + } + } + }, + "RestProgress": { + "properties": { + "message": { + "type": "string", + "example": "Working on it..." + }, + "percentage": { + "type": "integer", + "format": "int32", + "example": 42 + } + } + }, + "RestProjectSettingsRestriction": { + "properties": { + "featureKey": { + "type": "string", + "example": "my-admin-feature" + }, + "componentKey": { + "type": "string", + "example": "my-admin-component" + }, + "processedState": { + "type": "string", + "example": "PROCESSED", + "enum": [ + "UNPROCESSED", + "PROCESSED", + "FAILED", + "IN_PROGRESS" + ] + }, + "namespace": { + "type": "string", + "example": "org.featuredeveloper" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + } + } + }, + "RestProjectSettingsRestrictionRequest": { + "required": [ + "featureKey", + "namespace" + ], + "type": "object", + "properties": { + "componentKey": { + "type": "string", + "example": "my-admin-component" + }, + "featureKey": { + "type": "string", + "example": "my-admin-feature" + }, + "namespace": { + "type": "string", + "example": "org.featuredeveloper" + } + } + }, + "RestPullRequestActivity": { + "properties": { + "action": { + "type": "string", + "enum": [ + "APPROVED", + "AUTO_MERGE_CANCELLED", + "AUTO_MERGE_REQUESTED", + "COMMENTED", + "DECLINED", + "DELETED", + "MERGED", + "OPENED", + "REOPENED", + "RESCOPED", + "REVIEW_COMMENTED", + "REVIEW_DISCARDED", + "REVIEW_FINISHED", + "REVIEWED", + "UNAPPROVED", + "UPDATED" + ] + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "createdDate": { + "type": "integer", + "format": "int64", + "example": 19990759200 + }, + "user": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + } + } + }, + "RestPullRequestAssignParticipantRoleRequest": { + "type": "object", + "properties": { + "role": { + "type": "string", + "enum": [ + "AUTHOR", + "REVIEWER", + "PARTICIPANT" + ] + }, + "user": { + "type": "object", + "properties": { + "active": { + "type": "boolean" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "name": { + "type": "string", + "example": "jcitizen" + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + } + } + } + } + }, + "RestPullRequestAssignStatusRequest": { + "type": "object", + "properties": { + "status": { + "type": "string", + "enum": [ + "UNAPPROVED", + "NEEDS_WORK", + "APPROVED" + ] + } + } + }, + "RestPullRequestCommitMessageTemplate": { + "properties": { + "title": { + "type": "string", + "example": "Pull request #${id}: ${title}" + }, + "body": { + "type": "string", + "example": "Merge in ${toProjectKey}/${toRepoSlug} from ${crossRepoProjectRepo}${fromRefName} to ${toRefName}" + } + } + }, + "RestPullRequestDeclineRequest": { + "type": "object", + "properties": { + "comment": { + "type": "string", + "example": "An optional comment explaining why the pull request is being declined" + }, + "version": { + "type": "integer", + "format": "int32" + } + } + }, + "RestPullRequestDeleteRequest": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32" + } + } + }, + "RestPullRequestFinishReviewRequest": { + "type": "object", + "properties": { + "commentText": { + "type": "string", + "example": "General comment text" + }, + "participantStatus": { + "type": "string", + "example": "approved" + } + } + }, + "RestPullRequestMergeConfig": { + "properties": { + "type": { + "type": "string", + "readOnly": true, + "example": "repository" + }, + "commitMessageTemplate": { + "type": "object", + "properties": { + "title": { + "type": "string", + "example": "Pull request #${id}: ${title}" + }, + "body": { + "type": "string", + "example": "Merge in ${toProjectKey}/${toRepoSlug} from ${crossRepoProjectRepo}${fromRefName} to ${toRefName}" + } + } + }, + "commitSummaries": { + "type": "integer", + "format": "int32" + }, + "defaultStrategy": { + "type": "object", + "properties": { + "name": { + "type": "string", + "readOnly": true, + "example": "Merge commit" + }, + "id": { + "type": "string", + "example": "no-ff" + }, + "description": { + "type": "string", + "readOnly": true, + "example": "Always create a merge commit" + }, + "enabled": { + "type": "boolean", + "readOnly": true + }, + "flag": { + "type": "string", + "readOnly": true, + "example": "--no-ff" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "strategies": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestMergeStrategy" + } + } + } + }, + "RestPullRequestMergeRequest": { + "type": "object", + "properties": { + "autoMerge": { + "type": "boolean", + "example": false + }, + "autoSubject": { + "type": "string", + "example": "(Optional, 5.7+) true to prepend an auto-generated subject to the message (default), or false to use the message as-is" + }, + "message": { + "type": "string", + "example": "(Optional) A descriptive message for the merge commit" + }, + "strategyId": { + "type": "string", + "example": "(Optional) squash" + }, + "version": { + "type": "integer", + "format": "int32" + } + } + }, + "RestPullRequestMergeStrategy": { + "properties": { + "name": { + "type": "string", + "readOnly": true, + "example": "Merge commit" + }, + "id": { + "type": "string", + "example": "no-ff" + }, + "description": { + "type": "string", + "readOnly": true, + "example": "Always create a merge commit" + }, + "enabled": { + "type": "boolean", + "readOnly": true + }, + "flag": { + "type": "string", + "readOnly": true, + "example": "--no-ff" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "RestPullRequestMergeability": { + "properties": { + "conflicted": { + "type": "boolean" + }, + "outcome": { + "type": "string", + "enum": [ + "CLEAN", + "CONFLICTED", + "UNKNOWN" + ] + }, + "vetoes": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepositoryHookVeto" + } + } + } + }, + "RestPullRequestReopenRequest": { + "type": "object", + "properties": { + "version": { + "type": "integer", + "format": "int32" + } + } + }, + "RestPullRequestSettings": { + "properties": { + "mergeConfig": { + "type": "object", + "properties": { + "type": { + "type": "string", + "readOnly": true, + "example": "repository" + }, + "commitMessageTemplate": { + "type": "object", + "properties": { + "title": { + "type": "string", + "example": "Pull request #${id}: ${title}" + }, + "body": { + "type": "string", + "example": "Merge in ${toProjectKey}/${toRepoSlug} from ${crossRepoProjectRepo}${fromRefName} to ${toRefName}" + } + } + }, + "commitSummaries": { + "type": "integer", + "format": "int32" + }, + "defaultStrategy": { + "type": "object", + "properties": { + "name": { + "type": "string", + "readOnly": true, + "example": "Merge commit" + }, + "id": { + "type": "string", + "example": "no-ff" + }, + "description": { + "type": "string", + "readOnly": true, + "example": "Always create a merge commit" + }, + "enabled": { + "type": "boolean", + "readOnly": true + }, + "flag": { + "type": "string", + "readOnly": true, + "example": "--no-ff" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "strategies": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestMergeStrategy" + } + } + } + } + } + }, + "RestPullRequestSuggestion": { + "properties": { + "refChange": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "ADD", + "DELETE", + "UPDATE" + ] + }, + "ref": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + } + }, + "fromHash": { + "type": "string", + "example": "6053a1eaa1c009dd11092d09a72f3c41af1b59ad" + }, + "refId": { + "type": "string", + "example": "refs/heads/master" + }, + "toHash": { + "type": "string", + "example": "d6edcbf924697ab811a867421dab60d954ccad99" + } + } + }, + "changeTme": { + "type": "integer", + "format": "int64", + "example": 1359075920 + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "fromRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + } + }, + "toRef": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + } + } + } + }, + "RestPushRefChange": { + "properties": { + "updatedType": { + "type": "string", + "enum": [ + "UNKNOWN", + "UNRESOLVED", + "NOT_FORCED", + "FORCED" + ] + }, + "type": { + "type": "string", + "enum": [ + "ADD", + "DELETE", + "UPDATE" + ] + }, + "ref": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + } + }, + "fromHash": { + "type": "string", + "example": "6053a1eaa1c009dd11092d09a72f3c41af1b59ad" + }, + "refId": { + "type": "string", + "example": "refs/heads/master" + }, + "toHash": { + "type": "string", + "example": "d6edcbf924697ab811a867421dab60d954ccad99" + } + } + }, + "RestRateLimitSettings": { + "properties": { + "defaultSettings": { + "type": "object", + "properties": { + "capacity": { + "type": "integer", + "format": "int32", + "example": 60 + }, + "fillRate": { + "type": "integer", + "format": "int32", + "example": 5 + } + } + }, + "enabled": { + "type": "boolean" + } + } + }, + "RestRepositoriesExportRequest": { + "required": [ + "includes" + ], + "type": "object", + "properties": { + "includes": { + "uniqueItems": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepositorySelector" + } + } + } + }, + "RestRepositoryHook": { + "properties": { + "configured": { + "type": "boolean" + }, + "enabled": { + "type": "boolean" + }, + "scope": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "GLOBAL", + "PROJECT", + "REPOSITORY" + ] + }, + "resourceId": { + "type": "integer", + "format": "int32", + "example": 2 + } + } + }, + "details": { + "$ref": "#/components/schemas/RepositoryHookDetails" + } + } + }, + "RestRepositoryPullRequestSettings": { + "properties": { + "mergeConfig": { + "type": "object", + "properties": { + "type": { + "type": "string", + "readOnly": true, + "example": "repository" + }, + "commitMessageTemplate": { + "type": "object", + "properties": { + "title": { + "type": "string", + "example": "Pull request #${id}: ${title}" + }, + "body": { + "type": "string", + "example": "Merge in ${toProjectKey}/${toRepoSlug} from ${crossRepoProjectRepo}${fromRefName} to ${toRefName}" + } + } + }, + "commitSummaries": { + "type": "integer", + "format": "int32" + }, + "defaultStrategy": { + "type": "object", + "properties": { + "name": { + "type": "string", + "readOnly": true, + "example": "Merge commit" + }, + "id": { + "type": "string", + "example": "no-ff" + }, + "description": { + "type": "string", + "readOnly": true, + "example": "Always create a merge commit" + }, + "enabled": { + "type": "boolean", + "readOnly": true + }, + "flag": { + "type": "string", + "readOnly": true, + "example": "--no-ff" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "strategies": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestMergeStrategy" + } + } + } + }, + "requiredApprovers": { + "type": "object", + "properties": { + "count": { + "type": "string", + "example": "3" + }, + "enabled": { + "type": "boolean", + "example": true + } + } + }, + "requiredAllApprovers": { + "type": "boolean" + }, + "requiredApproversDeprecated": { + "type": "integer", + "format": "int32" + }, + "requiredSuccessfulBuildsDeprecated": { + "type": "integer", + "format": "int32" + }, + "requiredAllTasksComplete": { + "type": "boolean" + }, + "requiredSuccessfulBuilds": { + "type": "object", + "properties": { + "count": { + "type": "string", + "example": "3" + }, + "enabled": { + "type": "boolean", + "example": true + } + } + } + } + }, + "RestRepositoryRefChangeActivity": { + "properties": { + "refChange": { + "type": "object", + "properties": { + "updatedType": { + "type": "string", + "enum": [ + "UNKNOWN", + "UNRESOLVED", + "NOT_FORCED", + "FORCED" + ] + }, + "type": { + "type": "string", + "enum": [ + "ADD", + "DELETE", + "UPDATE" + ] + }, + "ref": { + "type": "object", + "properties": { + "id": { + "type": "string", + "example": "refs/heads/master" + }, + "type": { + "type": "string", + "enum": [ + "BRANCH", + "TAG" + ] + }, + "displayId": { + "type": "string", + "example": "master" + } + } + }, + "fromHash": { + "type": "string", + "example": "6053a1eaa1c009dd11092d09a72f3c41af1b59ad" + }, + "refId": { + "type": "string", + "example": "refs/heads/master" + }, + "toHash": { + "type": "string", + "example": "d6edcbf924697ab811a867421dab60d954ccad99" + } + } + }, + "repository": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "origin": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "My repo" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "state": { + "type": "string", + "readOnly": true, + "enum": [ + "AVAILABLE", + "INITIALISATION_FAILED", + "INITIALISING", + "OFFLINE" + ] + }, + "statusMessage": { + "type": "string", + "readOnly": true, + "example": "Available" + }, + "defaultBranch": { + "type": "string", + "readOnly": true, + "example": "main" + }, + "relatedLinks": { + "type": "object", + "properties": {}, + "readOnly": true + }, + "partition": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "My repo description" + }, + "hierarchyId": { + "type": "string", + "readOnly": true, + "example": "e3c939f9ef4a7fae272e" + }, + "project": { + "required": [ + "key" + ], + "type": "object", + "properties": { + "name": { + "pattern": "^[^~].*", + "type": "string", + "readOnly": true, + "example": "My Cool Project" + }, + "key": { + "type": "string", + "example": "PRJ" + }, + "public": { + "type": "boolean", + "readOnly": true + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true + }, + "type": { + "type": "string", + "readOnly": true, + "enum": [ + "NORMAL", + "PERSONAL" + ] + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "readOnly": true, + "example": "The description for my cool project" + }, + "namespace": { + "type": "string", + "readOnly": true, + "deprecated": true + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "PROJECT" + }, + "avatar": { + "type": "string" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "scope": { + "type": "string", + "readOnly": true, + "example": "REPOSITORY" + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + }, + "readOnly": true + }, + "slug": { + "type": "string", + "example": "my-repo" + }, + "forkable": { + "type": "boolean", + "readOnly": true + }, + "archived": { + "type": "boolean", + "readOnly": true + }, + "scmId": { + "type": "string", + "example": "git" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "trigger": { + "type": "string", + "example": "push" + }, + "id": { + "type": "integer", + "format": "int64", + "example": 1 + }, + "createdDate": { + "type": "integer", + "format": "int64", + "example": 19990759200 + }, + "user": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + } + } + }, + "RestRepositorySelector": { + "type": "object", + "properties": { + "projectKey": { + "type": "string", + "example": "PRJ" + }, + "slug": { + "type": "string", + "example": "my-repo" + } + } + }, + "RestReviewerGroup": { + "properties": { + "name": { + "type": "string", + "example": "name" + }, + "id": { + "type": "integer", + "format": "int64" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + }, + "description": { + "type": "string", + "example": "null" + }, + "scope": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "GLOBAL", + "PROJECT", + "REPOSITORY" + ] + }, + "resourceId": { + "type": "integer", + "format": "int32", + "example": 2 + } + } + }, + "users": { + "type": "array", + "items": { + "$ref": "#/components/schemas/ApplicationUser" + } + } + } + }, + "RestScopesExample": { + "properties": { + "scopes": { + "type": "array", + "items": { + "type": "object" + } + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + } + } + }, + "RestSecretScanningAllowlistRule": { + "properties": { + "name": { + "type": "string", + "description": "Human readable name for the rule", + "example": "Bitbucket DC HTTP access token" + }, + "id": { + "type": "integer", + "description": "The ID of the rule", + "format": "int64", + "example": 7 + }, + "lineRegex": { + "type": "string", + "description": "If present, regular expression for matching a secret on a code line", + "example": "(BBDC-[a-zA-Z0-9+]{44})" + }, + "pathRegex": { + "type": "string", + "description": "If present, regular expression matching file names", + "example": "*.pem" + } + } + }, + "RestSecretScanningAllowlistRuleSetRequest": { + "type": "object", + "properties": { + "lineRegex": { + "type": "string", + "description": "Regular expression for matching a secret on a code line", + "example": "(BBDC-[a-zA-Z0-9+]{44})" + }, + "name": { + "type": "string", + "description": "Human readable name for the rule", + "example": "Bitbucket DC HTTP access token" + }, + "pathRegex": { + "type": "string", + "description": "Regular expression matching file names", + "example": "*.pem" + } + } + }, + "RestSecretScanningRule": { + "properties": { + "name": { + "type": "string", + "description": "Human readable name for the rule", + "example": "Bitbucket DC HTTP access token" + }, + "id": { + "type": "integer", + "description": "The ID of the rule", + "format": "int64", + "example": 7 + }, + "lineRegex": { + "type": "string", + "description": "If present, regular expression for matching a secret on a code line", + "example": "(BBDC-[a-zA-Z0-9+]{44})" + }, + "pathRegex": { + "type": "string", + "description": "If present, regular expression matching file names", + "example": "*.pem" + }, + "scope": { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "GLOBAL", + "PROJECT", + "REPOSITORY" + ] + }, + "resourceId": { + "type": "integer", + "format": "int32", + "example": 2 + } + }, + "description": "The scope in which this rule was configured for." + } + } + }, + "RestSecretScanningRuleSetRequest": { + "type": "object", + "properties": { + "lineRegex": { + "type": "string", + "description": "Regular expression for matching a secret on a code line", + "example": "(BBDC-[a-zA-Z0-9+]{44})" + }, + "name": { + "type": "string", + "description": "Human readable name for the rule", + "example": "Bitbucket DC HTTP access token" + }, + "pathRegex": { + "type": "string", + "description": "Regular expression matching file names", + "example": "*.pem" + } + } + }, + "RestSystemSigningConfiguration": { + "properties": { + "enabled": { + "type": "boolean", + "example": false + } + } + }, + "RestTestResults": { + "properties": { + "successful": { + "type": "integer", + "format": "int32", + "example": 134 + }, + "skipped": { + "type": "integer", + "format": "int32", + "example": 5 + }, + "failed": { + "type": "integer", + "format": "int32", + "example": 1 + } + } + }, + "RestTokenBucketSettings": { + "properties": { + "capacity": { + "type": "integer", + "format": "int32", + "example": 60 + }, + "fillRate": { + "type": "integer", + "format": "int32", + "example": 5 + } + } + }, + "RestUserDirectory": { + "properties": { + "name": { + "type": "string", + "example": "Bitbucket Internal Directory" + }, + "type": { + "type": "string", + "example": "Crowd" + }, + "active": { + "type": "boolean", + "example": true + }, + "description": { + "type": "string", + "example": "This directory has users that are able to access Bitbucket DC" + } + } + }, + "RestUserRateLimitSettings": { + "properties": { + "whitelisted": { + "type": "boolean" + }, + "settings": { + "type": "object", + "properties": { + "capacity": { + "type": "integer", + "format": "int32", + "example": 60 + }, + "fillRate": { + "type": "integer", + "format": "int32", + "example": 5 + } + } + }, + "user": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 101 + }, + "type": { + "type": "string", + "enum": [ + "NORMAL", + "SERVICE" + ] + }, + "active": { + "type": "boolean" + }, + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "emailAddress": { + "type": "string", + "example": "jane@example.com" + }, + "links": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "slug": { + "type": "string", + "example": "jcitizen" + }, + "avatarUrl": { + "type": "string", + "writeOnly": true + } + } + } + } + }, + "RestUserRateLimitSettingsUpdateRequest": { + "type": "object", + "properties": { + "settings": { + "type": "object", + "properties": { + "capacity": { + "type": "integer", + "format": "int32", + "example": 60 + }, + "fillRate": { + "type": "integer", + "format": "int32", + "example": 5 + } + } + }, + "whitelisted": { + "type": "boolean" + } + } + }, + "RestWebhook": { + "properties": { + "name": { + "type": "string" + }, + "sslVerificationRequired": { + "type": "boolean" + }, + "statistics": { + "type": "object", + "properties": {}, + "writeOnly": true + }, + "scopeType": { + "type": "string" + }, + "configuration": { + "type": "object" + }, + "credentials": { + "$ref": "#/components/schemas/RestWebhookCredentials" + }, + "url": { + "type": "string" + }, + "events": { + "uniqueItems": true, + "type": "array", + "items": { + "type": "string" + } + }, + "active": { + "type": "boolean" + } + } + }, + "RestWebhookCredentials": { + "properties": { + "password": { + "type": "string" + }, + "username": { + "type": "string" + } + } + }, + "RestWebhookRequestResponse": { + "properties": {} + }, + "RestWebhookScope": { + "properties": { + "id": { + "type": "string" + }, + "type": { + "type": "string" + } + } + }, + "RestX509Certificate": { + "properties": { + "id": { + "type": "integer", + "description": "The ID of the X.509 certificate", + "format": "int64", + "example": 7 + }, + "fingerprint": { + "type": "string", + "description": "The SHA-256 fingerprint of the X.509 certificate", + "example": "e5e8d632c0b86f5bd5ef9a0d55c58ba1fd7776f6bb7c35ca23d85d23281ce58f" + } + } + }, + "UserAndGroups": { + "required": [ + "groups" + ], + "type": "object", + "properties": { + "groups": { + "uniqueItems": true, + "type": "array", + "example": [ + "group_a", + "group_b" + ], + "items": { + "type": "string" + } + }, + "user": { + "type": "string", + "example": "user" + } + } + }, + "UserPasswordUpdate": { + "type": "object", + "properties": { + "oldPassword": { + "type": "string", + "example": "my-old-secret-password" + }, + "password": { + "type": "string", + "writeOnly": true, + "example": "my-secret-password" + }, + "passwordConfirm": { + "type": "string", + "writeOnly": true, + "example": "my-secret-password" + } + } + }, + "UserPickerContext": { + "type": "object", + "properties": { + "context": { + "type": "string", + "example": "group_a" + }, + "itemName": { + "type": "string", + "example": "user_a" + } + } + }, + "UserRename": { + "type": "object", + "properties": { + "name": { + "type": "string", + "example": "jcitizen" + }, + "newName": { + "type": "string", + "example": "jcitizen-new" + } + } + }, + "UserUpdate": { + "type": "object", + "properties": { + "displayName": { + "type": "string", + "example": "Jane Citizen" + }, + "email": { + "type": "string", + "example": "jane@example.com" + }, + "name": { + "type": "string", + "example": "jcitizen" + } + } + } + } + }, + "x-atlassian-narrative": { + "documents": [ + { + "title": "About", + "anchor": "about", + "body": "The Bitbucket Data Center and Server REST API enables you to interact with Bitbucket programmatically. This page documents the REST resources available in Bitbucket, including the HTTP response codes and example requests and responses.\n\nGeneral information about using the REST APIs can be found at [Using the REST API](/server/bitbucket/how-tos/command-line-rest/)\nand [Authenticating with the REST API](/server/bitbucket/how-tos/example-basic-authentication/).\n" + }, + { + "title": "Intro", + "anchor": "intro", + "body": "This is the reference document for the Bitbucket Data Center REST API. The REST API is for developers who want to:\n\n- integrate &product_name; with other applications;\n- create scripts that interact with Bitbucket Data Center or\n- develop plugins that enhance the Bitbucket Data Center UI, using REST to interact with the backend.\n\nYou can read more about developing Bitbucket Data Center plugins in the\n[Developer Documentation](https://developer.atlassian.com/server/bitbucket/)\n\n## Getting started\n\nBecause the REST API is based on open standards, you can use any web development language or command line tool\ncapable of generating an HTTP request to access the API.\n\nIf you're already working with the\n[Atlassian SDK](https://developer.atlassian.com/server/framework/atlassian-sdk/),\nthe [REST API Browser](https://developer.atlassian.com/server/framework/atlassian-sdk/using-the-rest-api-browser)\nis a great tool for exploring and experimenting with the &product_name; REST API.\n\n## Structure of the REST URIs\n\nBitbucket Data Center's REST APIs provide access to resources (data entities) via URI paths. To use a REST API, your application will\nmake an HTTP request and parse the response. The Bitbucket Data Center REST API uses JSON as its communication format, and the standard\nHTTP(S) methods like GET, PUT, POST and DELETE. URIs for Bitbucket Data Center's REST API resource have the following structure:\n\n`http://host:port/context/rest/api-name/api-version/path/to/resource`\n\nFor example, the following URI would retrieve a page of the latest commits to the _jira_ repository in\nthe _Jira_ project on `https://bitbucket.example.com`\n\n```\nhttps://bitbucket.example.com/rest/api/1.0/projects/JIRA/repos/jira/commits\n```\n\nSee the API descriptions on the left for a full list of available resources.\n\nAlternatively we also publish a list of resources in\n[https://en.wikipedia.org/wiki/OpenAPI_Specification](OpenAPI) format. It is available via the triple dot menu above.\n\n## Paged APIs\n\nBitbucket Data Center uses paging to conserve server resources and limit response size for resources that return potentially large\ncollections of items. A request to a paged API will result in a values array wrapped in a JSON object\nwith some paging metadata, like this:\n\n```json\n{\n \"size\": 3,\n \"limit\": 3,\n \"isLastPage\": false,\n \"values\": [\n {\n /* result 0 */\n },\n {\n /* result 1 */\n },\n {\n /* result 2 */\n }\n ],\n \"start\": 0,\n \"filter\": null,\n \"nextPageStart\": 3\n}\n```\n\nClients can use the `limit` and `start` query parameters to retrieve the desired number of results.\n\nThe `limit` parameter indicates how many results to return per page. Most APIs default to returning\n`25` if the limit is left unspecified. This number can be increased, but note that a resource-specific\nhard limit will apply. These hard limits can be configured by server administrators, so it's always best practice to\ncheck the `limit` attribute on the response to see what limit has been applied.\nThe request to get a larger page should look like this:\n\n```\nhttp://host:port/context/rest/api-name/api-version/path/to/resource?limit={desired size of page}\n```\n\nFor example:\n\n```\n https://bitbucket.example.com/rest/api/1.0/projects/JIRA/repos/jira/commits?limit=1000\n```\n\nThe `start` parameter indicates which item should be used as the first item in the page of results. All\npaged responses contain an isLastPage attribute indicating whether another page of items exists.\n\n_Important:_ If more than one page exists (i.e. the response contains\n`\"isLastPage\": false`), the response object will also contain a `nextPageStart` attribute\nwhich _*must*_ be used by the client as the `start` parameter on the next request.\nIdentifiers of adjacent objects in a page may not be contiguous, so the start of the next page is _not_\nnecessarily the start of the last page plus the last page's size. A client should always use\n`nextPageStart` to avoid unexpected results from a paged API.\nThe request to get a subsequent page should look like this:\n\n```\n http://host:port/context/rest/api-name/api-version/path/to/resource?start={nextPageStart from previous response}\n```\n\nFor example:\n\n```\n https://bitbucket.example.com/rest/api/1.0/projects/JIRA/repos/jira/commits?start=25\n```\n\n## Authentication\n\nAny authentication that works against Bitbucket Data Center will work against the REST API. _The preferred authentication methods\nare HTTP Basic (when using SSL) and OAuth_. Other supported methods include: HTTP Cookies and HTTP Aaccess Tokens\n\nYou can find OAuth code samples in several programming languages at\n[bitbucket.org/atlassianlabs/atlassian-oauth-examples/](https://bitbucket.org/atlassianlabs/atlassian-oauth-examples/)\n\nThe log-in page uses cookie-based authentication, so if you are using Bitbucket Data Center in a browser you can call REST from\nJavaScript on the page and rely on the authentication that the browser has established.\n\n## Errors & Validation\n\nIf a request fails due to client error, the resource will return an HTTP response code in the 40x range. These can\nbe broadly categorised into:\n\n| HTTP Code | Description |\n| ---------------------------- | :---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |\n| 400 (Bad Request) | One or more of the required parameters or attributes: were missing from the request; incorrectly formatted; or inappropriate in the given context. |\n| 401 (Unauthorized) | Either: Authentication is required but was not attempted, or authentication was attempted but failed, or authentication was successful but the authenticated user does not have the requisite permission for the resource. See the individual resource documentation for details of required permissions. |\n| 403 (Forbidden) | Actions are usually \"forbidden\" if they involve breaching the licensed user limit of the server, or degrading the authenticated user's permission level. See the individual resource documentation for more details. |\n| 404 (Not Found) | The entity you are attempting to access, or the project or repository containing it, does not exist. |\n| 405 (Method Not Allowed) | The request HTTP method is not appropriate for the targeted resource. For example an HTTP GET to a resource that only accepts an HTTP POST will result in a 405. |\n| 409 (Conflict) | The attempted update failed due to some conflict with an existing resource. For example: creating a project with a key that already exists, merging an out-of-date pull request, deleting a comment that has replies, etc. |\n| 415 (Unsupported Media Type) | The request entity has a `Content-Type` that the server does not support. Almost all of the Bitbucket Data Center REST API accepts `application/json` format, but check the individual resource documentation for more details. Additionally, double-check that you are setting the `Content-Type` header correctly on your request (e.g. using `-H \"Content-Type: application/json\"` in cURL). |\n\nFor _400_ HTTP codes the response will typically contain one or more validation error messages,\nfor example:\n\nSee the individual resource documentation for\n\n```json\n{\n \"errors\": [\n {\n \"context\": \"name\",\n \"message\": \"The name should be between 1 and 255 characters.\",\n \"exceptionName\": null\n },\n {\n \"context\": \"email\",\n \"message\": \"The email should be a valid email address.\",\n \"exceptionName\": null\n }\n ]\n}\n```\n\nThe `context` attribute indicates which parameter or request entity attribute failed validation. Note\nthat the `context` may be null.\n\nFor _401_, _403_, _404_ and _409_\nHTTP codes, the response will contain one or more descriptive error messages:\n\n```json\n{\n \"errors\": [\n {\n \"context\": null,\n \"message\": \"A detailed error message.\",\n \"exceptionName\": null\n }\n ]\n}\n```\n\nA _500_ (Server Error) HTTP code indicates an incorrect resource url or an unexpected server error.\nDouble-check the URL you are trying to access, then report the issue to your server administrator or\n[Atlassian Support](https://getsupport.atlassian.com]) if problems persist.\n\n## Personal Repositories\n\nBitbucket Data Center allows users to manage their own repositories, called personal repositories. These are repositories associated\nwith the user and to which they always have REPO_ADMIN permission.\n\nAccessing personal repositories via REST is achieved through the normal project-centric REST URLs\nusing the user's slug prefixed by tilde as the project key. E.g. to list personal repositories for a\nuser with slug \"johnsmith\" you would make a GET to:\n`http://example.com/rest/api/1.0/projects/~johnsmith/repos`\n\nIn addition to this, Bitbucket Data Center allows access to these repositories through an alternate set of user-centric REST URLs\nbeginning with:\n`http://example.com/rest/api/1.0/users/~{userSlug}/repos`\nE.g. to list the forks of the repository with slug\n\"nodejs\" in the personal project of user with slug \"johnsmith\" using the regular REST URL you would make a GET to:\n`http://example.com/rest/api/1.0/projects/~johnsmith/repos/nodejs/forks`\nUsing the alternate URL, you would make a GET to:\n`http://example.com/rest/api/1.0/users/johnsmith/repos/nodejs/forks`\n" + }, + { + "title": "Rolling Upgrades REST API", + "anchor": "rolling-upgrades", + "body": "Provides Rolling Upgrade capabilities.\n\n### Table of Contents\n\n- [Servers](#servers)\n- [Paths](#paths)\n - [`GET` /state](#op-get-state)\n - [`GET` /nodes/{nodeId}](#op-get-nodes-nodeid)\n - [`GET` /cluster](#op-get-cluster)\n - [`POST` /start](#op-post-start)\n - [`POST` /cancel](#op-post-cancel)\n - [`POST` /approve](#op-post-approve)\n- [Schemas](#schemas)\n - ClusterStateResponse\n - Link\n - NodeInfoDTO\n - Cluster\n\n### Servers\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n
URLDescription
/rest/zduThe ZDU REST resource for the server
\n\n### Paths\n\n### `GET` /state\n\n\n\n> Gets the Cluster State\n\nGets the State of the Cluster and the responding Node's information.\n\n#### Responses\n\n##### â–¶ 200 - Returns full JSON representation of cluster state\n\n###### Headers\n\n_No headers specified_\n\n###### application/json\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameTypeDescriptionAccepted values
state\n string\n The current state of the Cluster.STABLE, READY_TO_UPGRADE, MIXED, READY_TO_RUN_UPGRADE_TASKS, RUNNING_UPGRADE_TASKS, UPGRADE_TASKS_FAILED
buildInfo\n object\n Represents a Cluster Node and its current state.Any
buildInfo.id\n string\n The id of the Node in cluster.Any
buildInfo.name\n string\n The name of the Node.Any
buildInfo.ipAddress\n string\n The IP address of the Node.Any
buildInfo.state\n string\n The current state of the Node.STARTING, ACTIVE, DRAINING, TERMINATING, OFFLINE, ERROR
buildInfo.tasksTotal\n integer\n The total number of active tasks on the Node.Any
buildInfo.activeUserCount\n integer\n The total number of active users on the Node.Any
buildInfo.buildNumber\n string\n The build number (DB schema version) of the Node's installed Product.Any
buildInfo.version\n string\n The version of the Node's installed Product.Any
buildInfo.local\n boolean\n True if this is the local node for the current session; otherwise false for remote nodes.Any
buildInfo.portNumber\n integer\n Any
buildInfo.links\n array(object)\n Hypermedia linksAny
buildInfo.links.rel\n string\n relAny
buildInfo.links.href\n string\n uriAny
\n\n##### Example _(generated)_\n\n```json\n{\n \"state\": \"STABLE\",\n \"buildInfo\": {\n \"id\": \"string\",\n \"name\": \"string\",\n \"ipAddress\": \"string\",\n \"state\": \"STARTING\",\n \"tasksTotal\": 0,\n \"activeUserCount\": 0,\n \"buildNumber\": \"string\",\n \"version\": \"string\",\n \"local\": true,\n \"portNumber\": 0,\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n }\n}\n```\n\n##### â–¶ 401 - Returned if user is not authenticated\n\n###### Headers\n\n_No headers specified_\n\n##### â–¶ 403 - Returned if the calling user does not have permission to view the content\n\n###### Headers\n\n_No headers specified_\n\n#### Tags\n\n
\n
\n
\n\n\n### `GET` /nodes/{nodeId}\n\n\n\n> Gets the Node's overview\n\nGets the requested Node's information.\n\n#### Path parameters\n\n##### ▷ nodeId\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameTypeInDescriptionAccepted values
nodeId (required)\n string\n pathAny
\n\n#### Responses\n\n##### â–¶ 200 - Returns full JSON representation of the cluster node\n\n###### Headers\n\n_No headers specified_\n\n###### application/json\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameTypeDescriptionAccepted values
id\n string\n The id of the Node in cluster.Any
name\n string\n The name of the Node.Any
ipAddress\n string\n The IP address of the Node.Any
state\n string\n The current state of the Node.STARTING, ACTIVE, DRAINING, TERMINATING, OFFLINE, ERROR
tasksTotal\n integer\n The total number of active tasks on the Node.Any
activeUserCount\n integer\n The total number of active users on the Node.Any
buildNumber\n string\n The build number (DB schema version) of the Node's installed Product.Any
version\n string\n The version of the Node's installed Product.Any
local\n boolean\n True if this is the local node for the current session; otherwise false for remote nodes.Any
portNumber\n integer\n Any
links\n array(object)\n Hypermedia linksAny
links.rel\n string\n relAny
links.href\n string\n uriAny
\n\n##### Example _(generated)_\n\n```json\n{\n \"id\": \"string\",\n \"name\": \"string\",\n \"ipAddress\": \"string\",\n \"state\": \"STARTING\",\n \"tasksTotal\": 0,\n \"activeUserCount\": 0,\n \"buildNumber\": \"string\",\n \"version\": \"string\",\n \"local\": true,\n \"portNumber\": 0,\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n}\n```\n\n##### â–¶ 401 - Returned if user is not authenticated\n\n###### Headers\n\n_No headers specified_\n\n##### â–¶ 403 - Returned if the calling user does not have permission to view the content\n\n###### Headers\n\n_No headers specified_\n\n##### â–¶ 404 - Returned if there is no content with the given id\n\n###### Headers\n\n_No headers specified_\n\n#### Tags\n\n
\n
\n
\n\n\n### `GET` /cluster\n\n\n\n> Gets the Cluster overview\n\nGets an overview of a Cluster including its current state and composition of Nodes.\n\n#### Responses\n\n##### â–¶ 200 - Returns full JSON representation of the cluster\n\n###### Headers\n\n_No headers specified_\n\n###### application/json\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameTypeDescriptionAccepted values
upgradeModeEnabled\n boolean\n If true, it's safe to upgrade the nodes of the clusterAny
state\n string\n The current state of the Cluster.STABLE, READY_TO_UPGRADE, MIXED, READY_TO_RUN_UPGRADE_TASKS, RUNNING_UPGRADE_TASKS, UPGRADE_TASKS_FAILED
originalVersion\n string\n The original product version when ZDU was enabledAny
nodes\n array(object)\n The nodes which form the Cluster.Any
nodes.id\n string\n The id of the Node in cluster.Any
nodes.name\n string\n The name of the Node.Any
nodes.ipAddress\n string\n The IP address of the Node.Any
nodes.state\n string\n The current state of the Node.STARTING, ACTIVE, DRAINING, TERMINATING, OFFLINE, ERROR
nodes.tasksTotal\n integer\n The total number of active tasks on the Node.Any
nodes.activeUserCount\n integer\n The total number of active users on the Node.Any
nodes.buildNumber\n string\n The build number (DB schema version) of the Node's installed Product.Any
nodes.version\n string\n The version of the Node's installed Product.Any
nodes.local\n boolean\n True if this is the local node for the current session; otherwise false for remote nodes.Any
nodes.portNumber\n integer\n Any
nodes.links\n array(object)\n Hypermedia linksAny
nodes.links.rel\n string\n relAny
nodes.links.href\n string\n uriAny
links\n array(object)\n Hypermedia linksAny
links.rel\n string\n relAny
links.href\n string\n uriAny
\n\n##### Example _(generated)_\n\n```json\n{\n \"upgradeModeEnabled\": true,\n \"state\": \"STABLE\",\n \"originalVersion\": \"string\",\n \"nodes\": [\n {\n \"id\": \"string\",\n \"name\": \"string\",\n \"ipAddress\": \"string\",\n \"state\": \"STARTING\",\n \"tasksTotal\": 0,\n \"activeUserCount\": 0,\n \"buildNumber\": \"string\",\n \"version\": \"string\",\n \"local\": true,\n \"portNumber\": 0,\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n }\n ],\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n}\n```\n\n##### â–¶ 401 - Returned if user is not authenticated\n\n###### Headers\n\n_No headers specified_\n\n##### â–¶ 403 - Returned if the calling user does not have permission to view the content\n\n###### Headers\n\n_No headers specified_\n\n#### Tags\n\n
\n
\n
\n\n\n### `POST` /start\n\n\n\n> Start ZDU upgrade\n\nEnables Upgrading of individual Nodes within the Cluster, allowing a heterogeneous Cluster formation.\n\n#### Responses\n\n##### â–¶ 200 - Returns full JSON representation of the cluster\n\n###### Headers\n\n_No headers specified_\n\n###### application/json\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameTypeDescriptionAccepted values
upgradeModeEnabled\n boolean\n If true, it's safe to upgrade the nodes of the clusterAny
state\n string\n The current state of the Cluster.STABLE, READY_TO_UPGRADE, MIXED, READY_TO_RUN_UPGRADE_TASKS, RUNNING_UPGRADE_TASKS, UPGRADE_TASKS_FAILED
originalVersion\n string\n The original product version when ZDU was enabledAny
nodes\n array(object)\n The nodes which form the Cluster.Any
nodes.id\n string\n The id of the Node in cluster.Any
nodes.name\n string\n The name of the Node.Any
nodes.ipAddress\n string\n The IP address of the Node.Any
nodes.state\n string\n The current state of the Node.STARTING, ACTIVE, DRAINING, TERMINATING, OFFLINE, ERROR
nodes.tasksTotal\n integer\n The total number of active tasks on the Node.Any
nodes.activeUserCount\n integer\n The total number of active users on the Node.Any
nodes.buildNumber\n string\n The build number (DB schema version) of the Node's installed Product.Any
nodes.version\n string\n The version of the Node's installed Product.Any
nodes.local\n boolean\n True if this is the local node for the current session; otherwise false for remote nodes.Any
nodes.portNumber\n integer\n Any
nodes.links\n array(object)\n Hypermedia linksAny
nodes.links.rel\n string\n relAny
nodes.links.href\n string\n uriAny
links\n array(object)\n Hypermedia linksAny
links.rel\n string\n relAny
links.href\n string\n uriAny
\n\n##### Example _(generated)_\n\n```json\n{\n \"upgradeModeEnabled\": true,\n \"state\": \"STABLE\",\n \"originalVersion\": \"string\",\n \"nodes\": [\n {\n \"id\": \"string\",\n \"name\": \"string\",\n \"ipAddress\": \"string\",\n \"state\": \"STARTING\",\n \"tasksTotal\": 0,\n \"activeUserCount\": 0,\n \"buildNumber\": \"string\",\n \"version\": \"string\",\n \"local\": true,\n \"portNumber\": 0,\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n }\n ],\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n}\n```\n\n##### â–¶ 401 - Returned if user is not authenticated\n\n###### Headers\n\n_No headers specified_\n\n##### â–¶ 403 - Returned if the calling user does not have permission to view the content\n\n###### Headers\n\n_No headers specified_\n\n##### â–¶ 409 - Returned if the cluster is not in a valid state\n\n###### Headers\n\n_No headers specified_\n\n#### Tags\n\n
\n
\n
\n\n\n### `POST` /cancel\n\n\n\n> Cancel ZDU upgrade\n\nProhibits the Upgrading of individual Nodes within the Cluster. All Nodes need to be on the same version before performing this request.\n\n#### Responses\n\n##### â–¶ 200 - Returns full JSON representation of the cluster\n\n###### Headers\n\n_No headers specified_\n\n###### application/json\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameTypeDescriptionAccepted values
upgradeModeEnabled\n boolean\n If true, it's safe to upgrade the nodes of the clusterAny
state\n string\n The current state of the Cluster.STABLE, READY_TO_UPGRADE, MIXED, READY_TO_RUN_UPGRADE_TASKS, RUNNING_UPGRADE_TASKS, UPGRADE_TASKS_FAILED
originalVersion\n string\n The original product version when ZDU was enabledAny
nodes\n array(object)\n The nodes which form the Cluster.Any
nodes.id\n string\n The id of the Node in cluster.Any
nodes.name\n string\n The name of the Node.Any
nodes.ipAddress\n string\n The IP address of the Node.Any
nodes.state\n string\n The current state of the Node.STARTING, ACTIVE, DRAINING, TERMINATING, OFFLINE, ERROR
nodes.tasksTotal\n integer\n The total number of active tasks on the Node.Any
nodes.activeUserCount\n integer\n The total number of active users on the Node.Any
nodes.buildNumber\n string\n The build number (DB schema version) of the Node's installed Product.Any
nodes.version\n string\n The version of the Node's installed Product.Any
nodes.local\n boolean\n True if this is the local node for the current session; otherwise false for remote nodes.Any
nodes.portNumber\n integer\n Any
nodes.links\n array(object)\n Hypermedia linksAny
nodes.links.rel\n string\n relAny
nodes.links.href\n string\n uriAny
links\n array(object)\n Hypermedia linksAny
links.rel\n string\n relAny
links.href\n string\n uriAny
\n\n##### Example _(generated)_\n\n```json\n{\n \"upgradeModeEnabled\": true,\n \"state\": \"STABLE\",\n \"originalVersion\": \"string\",\n \"nodes\": [\n {\n \"id\": \"string\",\n \"name\": \"string\",\n \"ipAddress\": \"string\",\n \"state\": \"STARTING\",\n \"tasksTotal\": 0,\n \"activeUserCount\": 0,\n \"buildNumber\": \"string\",\n \"version\": \"string\",\n \"local\": true,\n \"portNumber\": 0,\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n }\n ],\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n}\n```\n\n##### â–¶ 401 - Returned if user is not authenticated\n\n###### Headers\n\n_No headers specified_\n\n##### â–¶ 403 - Returned if the calling user does not have permission to view the content\n\n###### Headers\n\n_No headers specified_\n\n##### â–¶ 409 - Returned if the cluster is not in a valid state\n\n###### Headers\n\n_No headers specified_\n\n#### Tags\n\n
\n
\n
\n\n\n### `POST` /approve\n\n\n\n> Approve the ZDU upgrade\n\nFinalizes the ZDU upgrade and runs specific tasks such as cleanup scripts.\n\n#### Responses\n\n##### â–¶ 200 - Returns full JSON representation of the cluster\n\n###### Headers\n\n_No headers specified_\n\n###### application/json\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameTypeDescriptionAccepted values
upgradeModeEnabled\n boolean\n If true, it's safe to upgrade the nodes of the clusterAny
state\n string\n The current state of the Cluster.STABLE, READY_TO_UPGRADE, MIXED, READY_TO_RUN_UPGRADE_TASKS, RUNNING_UPGRADE_TASKS, UPGRADE_TASKS_FAILED
originalVersion\n string\n The original product version when ZDU was enabledAny
nodes\n array(object)\n The nodes which form the Cluster.Any
nodes.id\n string\n The id of the Node in cluster.Any
nodes.name\n string\n The name of the Node.Any
nodes.ipAddress\n string\n The IP address of the Node.Any
nodes.state\n string\n The current state of the Node.STARTING, ACTIVE, DRAINING, TERMINATING, OFFLINE, ERROR
nodes.tasksTotal\n integer\n The total number of active tasks on the Node.Any
nodes.activeUserCount\n integer\n The total number of active users on the Node.Any
nodes.buildNumber\n string\n The build number (DB schema version) of the Node's installed Product.Any
nodes.version\n string\n The version of the Node's installed Product.Any
nodes.local\n boolean\n True if this is the local node for the current session; otherwise false for remote nodes.Any
nodes.portNumber\n integer\n Any
nodes.links\n array(object)\n Hypermedia linksAny
nodes.links.rel\n string\n relAny
nodes.links.href\n string\n uriAny
links\n array(object)\n Hypermedia linksAny
links.rel\n string\n relAny
links.href\n string\n uriAny
\n\n##### Example _(generated)_\n\n```json\n{\n \"upgradeModeEnabled\": true,\n \"state\": \"STABLE\",\n \"originalVersion\": \"string\",\n \"nodes\": [\n {\n \"id\": \"string\",\n \"name\": \"string\",\n \"ipAddress\": \"string\",\n \"state\": \"STARTING\",\n \"tasksTotal\": 0,\n \"activeUserCount\": 0,\n \"buildNumber\": \"string\",\n \"version\": \"string\",\n \"local\": true,\n \"portNumber\": 0,\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n }\n ],\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n}\n```\n\n##### â–¶ 401 - Returned if user is not authenticated\n\n###### Headers\n\n_No headers specified_\n\n##### â–¶ 403 - Returned if the calling user does not have permission to view the content\n\n###### Headers\n\n_No headers specified_\n\n##### â–¶ 409 - Returned if the cluster is not in a valid state\n\n###### Headers\n\n_No headers specified_\n\n##### â–¶ 500 - Internal Error\n\n###### Headers\n\n_No headers specified_\n\n#### Tags\n\n
\n
\n
\n\n\n### Schemas\n\n#### ClusterStateResponse\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameTypeDescriptionAccepted values
state\n string\n The current state of the Cluster.STABLE, READY_TO_UPGRADE, MIXED, READY_TO_RUN_UPGRADE_TASKS, RUNNING_UPGRADE_TASKS, UPGRADE_TASKS_FAILED
buildInfo\n object\n Represents a Cluster Node and its current state.Any
buildInfo.id\n string\n The id of the Node in cluster.Any
buildInfo.name\n string\n The name of the Node.Any
buildInfo.ipAddress\n string\n The IP address of the Node.Any
buildInfo.state\n string\n The current state of the Node.STARTING, ACTIVE, DRAINING, TERMINATING, OFFLINE, ERROR
buildInfo.tasksTotal\n integer\n The total number of active tasks on the Node.Any
buildInfo.activeUserCount\n integer\n The total number of active users on the Node.Any
buildInfo.buildNumber\n string\n The build number (DB schema version) of the Node's installed Product.Any
buildInfo.version\n string\n The version of the Node's installed Product.Any
buildInfo.local\n boolean\n True if this is the local node for the current session; otherwise false for remote nodes.Any
buildInfo.portNumber\n integer\n Any
buildInfo.links\n array(object)\n Hypermedia linksAny
buildInfo.links.rel\n string\n relAny
buildInfo.links.href\n string\n uriAny
\n\n##### Example _(generated)_\n\n```json\n{\n \"state\": \"STABLE\",\n \"buildInfo\": {\n \"id\": \"string\",\n \"name\": \"string\",\n \"ipAddress\": \"string\",\n \"state\": \"STARTING\",\n \"tasksTotal\": 0,\n \"activeUserCount\": 0,\n \"buildNumber\": \"string\",\n \"version\": \"string\",\n \"local\": true,\n \"portNumber\": 0,\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n }\n}\n```\n\n#### Link\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameTypeDescriptionAccepted values
rel\n string\n relAny
href\n string\n uriAny
\n\n##### Example _(generated)_\n\n```json\n{\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n}\n```\n\n#### NodeInfoDTO\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameTypeDescriptionAccepted values
id\n string\n The id of the Node in cluster.Any
name\n string\n The name of the Node.Any
ipAddress\n string\n The IP address of the Node.Any
state\n string\n The current state of the Node.STARTING, ACTIVE, DRAINING, TERMINATING, OFFLINE, ERROR
tasksTotal\n integer\n The total number of active tasks on the Node.Any
activeUserCount\n integer\n The total number of active users on the Node.Any
buildNumber\n string\n The build number (DB schema version) of the Node's installed Product.Any
version\n string\n The version of the Node's installed Product.Any
local\n boolean\n True if this is the local node for the current session; otherwise false for remote nodes.Any
portNumber\n integer\n Any
links\n array(object)\n Hypermedia linksAny
links.rel\n string\n relAny
links.href\n string\n uriAny
\n\n##### Example _(generated)_\n\n```json\n{\n \"id\": \"string\",\n \"name\": \"string\",\n \"ipAddress\": \"string\",\n \"state\": \"STARTING\",\n \"tasksTotal\": 0,\n \"activeUserCount\": 0,\n \"buildNumber\": \"string\",\n \"version\": \"string\",\n \"local\": true,\n \"portNumber\": 0,\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n}\n```\n\n#### Cluster\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameTypeDescriptionAccepted values
upgradeModeEnabled\n boolean\n If true, it's safe to upgrade the nodes of the clusterAny
state\n string\n The current state of the Cluster.STABLE, READY_TO_UPGRADE, MIXED, READY_TO_RUN_UPGRADE_TASKS, RUNNING_UPGRADE_TASKS, UPGRADE_TASKS_FAILED
originalVersion\n string\n The original product version when ZDU was enabledAny
nodes\n array(object)\n The nodes which form the Cluster.Any
nodes.id\n string\n The id of the Node in cluster.Any
nodes.name\n string\n The name of the Node.Any
nodes.ipAddress\n string\n The IP address of the Node.Any
nodes.state\n string\n The current state of the Node.STARTING, ACTIVE, DRAINING, TERMINATING, OFFLINE, ERROR
nodes.tasksTotal\n integer\n The total number of active tasks on the Node.Any
nodes.activeUserCount\n integer\n The total number of active users on the Node.Any
nodes.buildNumber\n string\n The build number (DB schema version) of the Node's installed Product.Any
nodes.version\n string\n The version of the Node's installed Product.Any
nodes.local\n boolean\n True if this is the local node for the current session; otherwise false for remote nodes.Any
nodes.portNumber\n integer\n Any
nodes.links\n array(object)\n Hypermedia linksAny
nodes.links.rel\n string\n relAny
nodes.links.href\n string\n uriAny
links\n array(object)\n Hypermedia linksAny
links.rel\n string\n relAny
links.href\n string\n uriAny
\n\n##### Example _(generated)_\n\n```json\n{\n \"upgradeModeEnabled\": true,\n \"state\": \"STABLE\",\n \"originalVersion\": \"string\",\n \"nodes\": [\n {\n \"id\": \"string\",\n \"name\": \"string\",\n \"ipAddress\": \"string\",\n \"state\": \"STARTING\",\n \"tasksTotal\": 0,\n \"activeUserCount\": 0,\n \"buildNumber\": \"string\",\n \"version\": \"string\",\n \"local\": true,\n \"portNumber\": 0,\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n }\n ],\n \"links\": [\n {\n \"rel\": \"string\",\n \"href\": \"http://example.com\"\n }\n ]\n}\n```\n" + } + ] + }, + "tags": [ + { + "name": "Authentication" + }, + { + "name": "Builds and Deployments" + }, + { + "name": "Capabilities" + }, + { + "name": "Dashboard" + }, + { + "name": "Deprecated" + }, + { + "name": "Jira Integration" + }, + { + "name": "Markup" + }, + { + "name": "Mirroring (Mirror)" + }, + { + "name": "Mirroring (Upstream)" + }, + { + "name": "Permission Management" + }, + { + "name": "Project" + }, + { + "name": "Pull Requests" + }, + { + "name": "Repository" + }, + { + "name": "Security" + }, + { + "name": "System Maintenance" + }, + { + "name": "System Signing" + } + ], + "paths": { + "/audit/latest/notification-settings/retention-config-review": { + "delete": { + "tags": [ + "System Maintenance" + ], + "summary": "Dismiss retention config notification", + "description": "Dismisses the retention config review notification displayed by the audit plugin for the user that's currently logged in.", + "operationId": "dismissRetentionConfigReviewNotification", + "responses": { + "200": { + "description": "A blank response", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to dismiss the notification.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/access-tokens/latest/projects/{projectKey}": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get project HTTP tokens", + "description": "Get all access tokens associated with the given project.", + "operationId": "getAllAccessTokens", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A response containing a page of access tokens and associated details.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestAccessToken" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to get access tokens for this project or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Authentication" + ], + "summary": "Create project HTTP token", + "description": "Create an access token for the project according to the given request.", + "operationId": "createAccessToken_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request containing the details of the access token to create.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAccessTokenRequest" + } + } + } + }, + "responses": { + "200": { + "description": "A response containing the raw access token and associated details.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRawAccessToken" + } + } + } + }, + "400": { + "description": "One of the following error cases occurred (check the error message for more details).\n\n- The request does not contain a token name\n- The request does not contain a list of permissions, or the list of permissions is empty\n- One of the provided permission levels are unknown\n- The project already has the maximum number of tokens\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to create an access token for this project or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/access-tokens/latest/projects/{projectKey}/repos/{repositorySlug}": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get repository HTTP tokens", + "description": "Get all access tokens associated with the given repository.", + "operationId": "getAllAccessTokens_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A response containing a page of access tokens and associated details.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestAccessToken" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to get access tokens for this repository or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Authentication" + ], + "summary": "Create repository HTTP token", + "description": "Create an access token for the repository according to the given request.", + "operationId": "createAccessToken_2", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request containing the details of the access token to create.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAccessTokenRequest" + } + } + } + }, + "responses": { + "200": { + "description": "A response containing the raw access token and associated details.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRawAccessToken" + } + } + } + }, + "400": { + "description": "One of the following error cases occurred (check the error message for more details).\n\n- The request does not contain a token name- The request does not contain a list of permissions, or the list of permissions is empty- One of the provided permission levels are unknown- The repository already has the maximum number of tokens", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to create an access token for this repository or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/access-tokens/latest/projects/{projectKey}/repos/{repositorySlug}/{tokenId}": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get HTTP token by ID", + "description": "Get the access token identified by the given ID.", + "operationId": "getById_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "tokenId", + "in": "path", + "description": "The token id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A response containing the access token and associated details.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAccessToken" + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to get access tokens on behalf of this user or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user or token does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Authentication" + ], + "summary": "Update HTTP token", + "description": "Modify an access token according to the given request. Any fields not specified will not be altered.", + "operationId": "updateAccessToken_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "tokenId", + "in": "path", + "description": "The token id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request containing the details of the access token to modify", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAccessTokenRequest" + } + } + } + }, + "responses": { + "200": { + "description": "A response containing the updated access token and associated details.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAccessToken" + } + } + } + }, + "400": { + "description": "One of the provided permission levels are unknown.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to update an access token on behalf of this user or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Authentication" + ], + "summary": "Delete a HTTP token", + "description": "Delete the access token identified by the given ID.", + "operationId": "deleteById_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "tokenId", + "in": "path", + "description": "The token id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response indicating that the token has been deleted." + }, + "401": { + "description": "The currently authenticated user is not permitted to delete an access token on behalf of this user or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user or token does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/access-tokens/latest/projects/{projectKey}/{tokenId}": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get HTTP token by ID", + "description": "Get the access token identified by the given ID.", + "operationId": "getById", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "tokenId", + "in": "path", + "description": "The token id.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A response containing the access token and associated details.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAccessToken" + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to get access tokens on behalf of this user or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user or token does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Authentication" + ], + "summary": "Update HTTP token", + "description": "Modify an access token according to the given request. Any fields not specified will not be altered.", + "operationId": "updateAccessToken", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "tokenId", + "in": "path", + "description": "The token id.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request containing the details of the access token to modify", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAccessTokenRequest" + } + } + } + }, + "responses": { + "200": { + "description": "A response containing the updated access token and associated details.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAccessToken" + } + } + } + }, + "400": { + "description": "One of the provided permission levels are unknown.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to update an access token on behalf of this user or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Authentication" + ], + "summary": "Delete a HTTP token", + "description": "Delete the access token identified by the given ID.", + "operationId": "deleteById", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "tokenId", + "in": "path", + "description": "The token id.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response indicating that the token has been deleted." + }, + "401": { + "description": "The currently authenticated user is not permitted to delete an access token on behalf of this user or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user or token does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/access-tokens/latest/users/{userSlug}": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get personal HTTP tokens", + "description": "Get all access tokens associated with the given user.", + "operationId": "getAllAccessTokens_2", + "parameters": [ + { + "name": "userSlug", + "in": "path", + "description": "The user slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A response containing a page of access tokens and associated details.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestAccessToken" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to get access tokens on behalf of this user or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Authentication" + ], + "summary": "Create personal HTTP token", + "description": "Create an access token for the user according to the given request.", + "operationId": "createAccessToken_3", + "parameters": [ + { + "name": "userSlug", + "in": "path", + "description": "The user slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request containing the details of the access token to create.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAccessTokenRequest" + } + } + } + }, + "responses": { + "200": { + "description": "A response containing the raw access token and associated details.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRawAccessToken" + } + } + } + }, + "400": { + "description": "One of the following error cases occurred (check the error message for more details).\n\n- The request does not contain a token name\n- The request does not contain a list of permissions, or the list of permissions is empty\n- One of the provided permission levels are unknown\n- The user already has their maximum number of tokens\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to create an access token on behalf of this user or authentication failed", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/access-tokens/latest/users/{userSlug}/{tokenId}": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get HTTP token by ID", + "description": "Get the access token identified by the given ID.", + "operationId": "getById_2", + "parameters": [ + { + "name": "tokenId", + "in": "path", + "description": "The token id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "userSlug", + "in": "path", + "description": "The user slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A response containing the access token and associated details.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAccessToken" + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to get access tokens on behalf of this user or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user or token does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Authentication" + ], + "summary": "Update HTTP token", + "description": "Modify an access token according to the given request. Any fields not specified will not be altered.", + "operationId": "updateAccessToken_2", + "parameters": [ + { + "name": "tokenId", + "in": "path", + "description": "The token id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "userSlug", + "in": "path", + "description": "The user slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request containing the details of the access token to modify", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAccessTokenRequest" + } + } + } + }, + "responses": { + "200": { + "description": "A response containing the updated access token and associated details.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAccessToken" + } + } + } + }, + "400": { + "description": "One of the provided permission levels are unknown.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to update an access token on behalf of this user or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Authentication" + ], + "summary": "Delete a HTTP token", + "description": "Delete the access token identified by the given ID.", + "operationId": "deleteById_2", + "parameters": [ + { + "name": "tokenId", + "in": "path", + "description": "The token id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "userSlug", + "in": "path", + "description": "The user slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response indicating that the token has been deleted." + }, + "401": { + "description": "The currently authenticated user is not permitted to delete an access token on behalf of this user or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user or token does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/build-status/latest/commits/{commitId}": { + "get": { + "tags": [ + "Deprecated" + ], + "summary": "Get build statuses for commit", + "description": "Gets build statuses associated with a commit.\n\nDeprecated in 7.14, please use the repository based builds resource instead.", + "operationId": "getBuildStatus", + "parameters": [ + { + "name": "orderBy", + "in": "query", + "description": "How the results should be ordered. Options are NEWEST, OLDEST, STATUS", + "schema": { + "type": "string" + }, + "example": "newest, oldest, or status" + }, + { + "name": "commitId", + "in": "path", + "description": "Full SHA1 of the commit (ex: e00cf62997a027bbf785614a93e2e55bb331d268)", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A Page of build statuses associated with the commit
(limited to the most recent 100 build statuses associated with the commit)", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestBuildStatus" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The user is not authenticated or does not have the LICENSED permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + }, + "post": { + "tags": [ + "Deprecated" + ], + "summary": "Create build status for commit", + "description": "Associates a build status with a commit.The state, the key and the url fields are mandatory. The name anddescription fields are optional.All fields (mandatory or optional) are limited to 255 characters, except for the url,which is limited to 450 characters.Supported values for the state are SUCCESSFUL, FAILEDand INPROGRESS.The authenticated user must have LICENSED permission or higher to call this resource.\n\nDeprecated in 7.14, please use the repository based builds resource instead.", + "operationId": "addBuildStatus", + "parameters": [ + { + "name": "commitId", + "in": "path", + "description": "full SHA1 of the commit", + "required": true, + "schema": { + "type": "string" + }, + "example": "e00cf62997a027bbf785614a93e2e55bb331d268" + } + ], + "requestBody": { + "description": "build status to associate with the commit", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBuildStatus" + } + } + } + }, + "responses": { + "204": { + "description": "An empty response if the build status was successfully stored" + }, + "400": { + "description": "An error message if the commitId is not a full 40-characters SHA1, if the build status has a missing mandatory field or if the fields are too large", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The user is not authenticated or does not have the LICENSED permission", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/build-status/latest/commits/stats/{commitId}": { + "get": { + "tags": [ + "Builds and Deployments", + "Deprecated" + ], + "summary": "Get build status statistics for commit", + "description": "Gets statistics regarding the builds associated with a commit", + "operationId": "getBuildStatusStats", + "parameters": [ + { + "name": "includeUnique", + "in": "query", + "description": "include a unique build result if there is either only one failed build, only one in-progress build or only one successful build", + "schema": { + "type": "boolean" + } + }, + { + "name": "commitId", + "in": "path", + "description": "full SHA1 of the commit", + "required": true, + "schema": { + "type": "string" + }, + "example": "e00cf62997a027bbf785614a93e2e55bb331d268" + } + ], + "responses": { + "200": { + "description": "The number of successful/failed/in-progress/cancelled/unknown builds for the commit", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBuildStats" + } + } + } + }, + "401": { + "description": "The user is not authenticated or does not have the LICENSED permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/build-status/latest/commits/stats": { + "post": { + "tags": [ + "Builds and Deployments", + "Deprecated" + ], + "summary": "Get build status statistics for multiple commits", + "description": "Produces a list of the build statistics for multiple commits. Commits without any builds associated with them will not be returned.
For example if the commit e00cf62997a027bbf785614a93e2e55bb331d268 does not have any build statuses associated with it, it will not be present in the response.", + "operationId": "getMultipleBuildStatusStats", + "requestBody": { + "description": "full SHA1 of each commit", + "content": { + "application/json": { + "schema": { + "type": "array", + "items": { + "type": "string", + "example": "db0dd118fa6ccdf1d593fef00df839dd27702df7" + } + } + } + } + }, + "responses": { + "200": { + "description": "The number of successful/failed/in-progress/cancelled/unknown builds for each commit (with the caveat that the commits without any builds associated with them will not be present in the response)", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMultipleBuildStats" + } + } + } + }, + "401": { + "description": "The user is not authenticated or does not have the LICENSED permission", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/required-builds/latest/projects/{projectKey}/repos/{repositorySlug}/condition": { + "post": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Create a required builds merge check", + "description": "Create a required build merge check for the given repository.\n\nThe authenticated user must have **REPO_ADMIN** permission for the target repository to register a required build merge check.\n\nThe contents of the required build merge check request are:\n\nThese fields are **required**:\n\n- **buildParentKeys**: A non-empty list of build parent keys that require green builds for this merge check to pass\n- **refMatcher.id**: The value to match refs against in the target branch\n- **refMatcher.type.id**: The type of ref matcher, one of: \"ANY_REF\", \"BRANCH\", \"PATTERN\", \"MODEL_CATEGORY\" or \"MODEL_BRANCH\"\n\n\nThese fields are optional:\n\n- **exemptRefMatcher.id** The value to exempt refs in the source branch from this check\n- **exemptRefMatcher.type.id**: The type of exempt ref matcher, one of: \"ANY_REF\", \"BRANCH\", \"PATTERN\", \"MODEL_CATEGORY\" or \"MODEL_BRANCH\"\n\n\n", + "operationId": "createRequiredBuildsMergeCheck", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project that the repository belongs to", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository being used", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request specifying the required build parent keys, ref matcher and exemption matcher", + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestRequiredBuildConditionSetRequest" + } + } + } + }, + "responses": { + "200": { + "description": "A response containing the newly created required build merge check.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRequiredBuildCondition" + } + } + } + }, + "400": { + "description": "The request was malformed. This could be caused because:\n\n- The build parent key list is empty\n- Either of the provided ref matchers is of an unrecognized type\n- Either of the provided ref matchers could not be created with the provided type and id\n\n\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create a required build merge check in this repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/required-builds/latest/projects/{projectKey}/repos/{repositorySlug}/condition/{id}": { + "put": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Update a required builds merge check", + "description": "Update the required builds merge check for the given ID.\n\nThe authenticated user must have **REPO_ADMIN** permission for the target repository to update a required build merge check.\n\nThe contents of the required build merge check request are:\n\nThese fields are **required**:\n\n- **buildParentKeys**: A non-empty list of build parent keys that require green builds for this merge check to pass\n- **refMatcher.id**: The value to match refs against in the target branch\n- **refMatcher.type.id**: The type of ref matcher, one of: \"ANY_REF\", \"BRANCH\", \"PATTERN\", \"MODEL_CATEGORY\" or \"MODEL_BRANCH\"\n\n\nThese fields are optional:\n\n- **exemptRefMatcher.id** The value to exempt refs in the source branch from this check\n- **exemptRefMatcher.type.id**: The type of exempt ref matcher, one of: \"ANY_REF\", \"BRANCH\", \"PATTERN\", \"MODEL_CATEGORY\" or \"MODEL_BRANCH\"\n\n\n", + "operationId": "updateRequiredBuildsMergeCheck", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project that the repository belongs to", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "required": true, + "schema": { + "type": "integer", + "format": "int64" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository being used", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request specifying the required build parent keys, ref matcher and exemption matcher", + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestRequiredBuildConditionSetRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The details needed to update a required build merge check.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRequiredBuildCondition" + } + } + } + }, + "400": { + "description": "The request was malformed. This could be caused because:\n\n- The build parent key list is empty\n- Either of the provided ref matchers is of an unrecognized type\n- Either of the provided ref matchers could not be created with the provided type and id\n\n\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create a required build merge check in this repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Delete a required builds merge check", + "description": "Deletes a required build existing merge check, given it's ID.\n\nThe authenticated user must have **REPO_ADMIN** permission for the target repository to delete a required build merge check.", + "operationId": "deleteRequiredBuildsMergeCheck", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project that the repository belongs to", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "required": true, + "schema": { + "type": "integer", + "format": "int64" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository being used", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response indicating the merge check was successfully deleted, or was never present." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete a required build merge check in this repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/required-builds/latest/projects/{projectKey}/repos/{repositorySlug}/conditions": { + "get": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Get required builds merge checks", + "description": "Returns a page of required build merge checks that have been configured for this repository.\n\nThe authenticated user must have **REPO_READ** permission for the target repository to request a page of required build merge checks.", + "operationId": "getPageOfRequiredBuildsMergeChecks", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project that the repository belongs to", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository being used", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "The required build merge checks associated with the provided repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRequiredBuildCondition" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to request a page of required build merge checks in this repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/branch-utils/latest/projects/{projectKey}/repos/{repositorySlug}/branches": { + "post": { + "tags": [ + "Repository" + ], + "summary": "Create branch", + "description": " Creates a branch in the specified repository.\n\n\nThe authenticated user must have an effective REPO_WRITE permission to call this resource. If\nbranch permissions are set up in the repository, the authenticated user must also have access to the branch name\nthat is to be created.", + "operationId": "createBranch", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBranchCreateRequest" + } + } + }, + "required": true + }, + "responses": { + "201": { + "description": "JSON representation of the newly created branch", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBranch" + } + } + } + }, + "400": { + "description": "The branch was not created because the request was invalid, e.g. the provided\nref name already existed in the repository, or was not a valid ref name in the\nrepository", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create a branch. This could be due to insufficient repository permissions, or lack of branch permission for the provided ref name", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The branch name overlapped with an existing branch", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Repository" + ], + "summary": "Delete branch", + "description": " Deletes a branch in the specified repository.\n\n\n If the branch does not exist, this operation will not raise an error. In other words after calling this resource\n and receiving a 204 response the branch provided in the request is guaranteed to not exist in the specified\n repository any more, regardless of its existence beforehand.\n\n\n The optional 'endPoint' parameter of the request may contain a commit ID that the provided ref name is\n expected to point to. Should the ref point to a different commit ID, a 400 response will be returned with\n appropriate error details.\n\n\n The authenticated user must have an effective REPO_WRITE permission to call this resource. If\n branch permissions are set up in the repository, the authenticated user must also have access to the branch name\n that is to be deleted.", + "operationId": "deleteBranch", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "Branch delete request", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBranchDeleteRequest" + } + } + } + }, + "responses": { + "204": { + "description": "An empty response indicating that the branch no longer exists in the repository" + }, + "400": { + "description": "The branch was not deleted because the request was invalid, e.g. no ref name\nto delete was provided, or the provided ref name points to the default branch\nin the repository that cannot be deleted", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete a\nbranch. This could be due to insufficient repository permissions, or lack of\nbranch permission for the provided ref name.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/branch-utils/latest/projects/{projectKey}/repos/{repositorySlug}/branches/info/{commitId}": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get branch", + "description": "Gets the branch information associated with a single commit from a given repository.", + "operationId": "findByCommit", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "required": true, + "content": { + "application/json": { + "schema": { + "maxLength": 40, + "type": "string" + } + } + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of branch refs associated with the commit", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestMinimalRef" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "500": { + "description": "The request has timed out processing the branch request", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/annotations": { + "get": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Get Code Insights annotations for a commit", + "description": "Get annotations for the given commit ID, filtered by any query parameters given.", + "operationId": "getAnnotations", + "parameters": [ + { + "name": "severity", + "in": "query", + "description": "Return only annotations that have one of the given severities. Can be specified more than once to filter by more than one severity. Valid severities are LOW, MEDIUM and HIGH.", + "schema": { + "type": "string" + } + }, + { + "name": "path", + "in": "query", + "description": "Return only annotations that appear on one of the provided paths. Can be specified more than once to filter by more than one path.", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "externalId", + "in": "query", + "description": "Return only annotations that have one of the provided external IDs. Can be specified more than once to filter by more than one external ID.", + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit ID on which to record the annotation. This must be a full 40 character commit hash.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "type", + "in": "query", + "description": "Return only annotations that have one of the given types. Can be specified more than once to filter by multiple types. Valid types are BUG, CODE_SMELL, and VULNERABILITY.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "key", + "in": "query", + "description": "Return only annotations that belong to one of the provided report keys. Can be specified more than once to filter by more than one report", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The requested annotations.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestInsightAnnotationsResponse" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions (REPO_READ) to get insight annotations.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project, repository, commit, or report does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports": { + "get": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Get all Code Insights reports for a commit", + "description": "Retrieve all reports for the given commit.", + "operationId": "getReports", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit ID on which to record the annotation. This must be a full 40 character commit hash.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of reports", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestInsightReport" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions (REPO_READ) to get insight reports.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project, repository or commit does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}": { + "get": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Get a Code Insights report", + "description": "Retrieve the specified report.", + "operationId": "getACodeInsightsReport", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit ID on which to record the annotation. This must be a full 40 character commit hash.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "key", + "in": "path", + "description": "The report key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The specified report.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestInsightReport" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions (REPO_READ needed) to get insight reports.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project, repository, commit, or report does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Create a Code Insights report", + "description": "Create a new insight report, or replace the existing one if a report already exists for the given repository, commit, and report key. A request to replace an existing report will be rejected if the authenticated user was not the creator of the specified report.\n\nThe report key should be a unique string chosen by the reporter and should be unique enough not to potentially clash with report keys from other reporters. We recommend using reverse DNS namespacing or a similar standard to ensure that collision is avoided.

Report parameters

Parameter Description Required? Restrictions Type
title A short string representing the name of the report Yes Max length: 450 characters (but we recommend that it is shorter so that the display is nicer) String
details A string to describe the purpose of the report. This string may contain escaped newlines and if it does it will display the content accordingly. No Max length: 2000 characters String
result Indicates whether the report is in a passed or failed state No One of: PASS, FAIL String
data An array of data fields (described below) to display information on the report No Maximum 6 data fields Array
reporter A string to describe the tool or company who created the report No Max length: 450 characters String
link A URL linking to the results of the report in an external tool. No Must be a valid http or https URL String
logoUrl A URL to the report logo. If none is provided, the default insights logo will be used. No Must be a valid http or https URL String

Data parameters

The data field on the report is an array with at most 6 data fields (JSON maps) containing information that is to be displayed on the report (see the request example).
Parameter Description Type
title A string describing what this data field represents String
type The type of data contained in the value field. If not provided, then the value will be detected as a boolean, number or string. One of: BOOLEAN, DATE, DURATION, LINK, NUMBER, PERCENTAGE, TEXT String
value A value based on the type provided. Either a raw value (string, number or boolean) or a map. See below.
Type Field Value Field Type Value Field Display
None/Omitted Number, String or Boolean (not an array or object) Plain text
BOOLEAN Boolean The value will be read as a JSON boolean and displayed as 'Yes' or 'No'.
DATE Number The value will be read as a JSON number in the form of a Unix timestamp (milliseconds) and will be displayed as a relative date if the date is less than one week ago, otherwise it will be displayed as an absolute date.
DURATION Number The value will be read as a JSON number in milliseconds and will be displayed in a human readable duration format.
LINK Object: {\"linktext\": \"Link text here\", \"href\": \"https://link.to.annotation/in/external/tool\"} The value will be read as a JSON object containing the fields \"linktext\" and \"href\" and will be displayed as a clickable link on the report.
NUMBER Number The value will be read as a JSON number and large numbers will be displayed in a human readable format (e.g. 14.3k).
PERCENTAGE Number (between 0 and 100) The value will be read as a JSON number between 0 and 100 and will be displayed with a percentage sign.
TEXT String The value will be read as a JSON string and will be displayed as-is
", + "externalDocs": { + "description": "Tutorial adding Code Insights to your CI system", + "url": "https://developer.atlassian.com/server/bitbucket/tutorials-and-examples/code-insights-tutorial/" + }, + "operationId": "setACodeInsightsReport", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit ID on which to record the annotation. This must be a full 40 character commit hash.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "key", + "in": "path", + "description": "A unique string representing the report as chosen by the reporter. This should be unique enough to not clash with other report's keys. To do this, we recommend namespacing the key using reverse DNS", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request object containing the details of the report to create (see example).", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSetInsightReportRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The created report.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestInsightReport" + } + } + } + }, + "400": { + "description": "One of the following error cases occurred (check the error message for more details):\n\n- The request does not contain a report title.\n- The data field contains unsupported objects.\n- The request does not contain a report key/\n- The provided commit hash is invalid, according to the validation rules mentioned for the commitId above.\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to create an insight report or authentication failed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Delete a Code Insights report", + "description": "Delete a report for the given commit. Also deletes any annotations associated with this report.", + "operationId": "deleteACodeInsightsReport", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit ID on which to record the annotation. This must be a full 40 character commit hash.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "key", + "in": "path", + "description": "The key of the report to which this annotation belongs.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The report and associated annotations were successfully deleted." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete insight reports or was not the author (REPO_READ for author otherwise REPO_ADMIN).", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project, repository, commit or report does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}/annotations": { + "get": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Get Code Insights annotations for a report", + "description": "Retrieve the specified report's annotations.", + "operationId": "getAnnotations_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit ID on which to record the annotation. This must be a full 40 character commit hash.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "key", + "in": "path", + "description": "The report key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The specified annotations.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestInsightAnnotationsResponse" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions (REPO_READ needed) to get insight reports.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project, repository, commit, or report does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Add Code Insights annotations", + "description": "Add annotations to the given report. The request should be a JSON object mapping the string \"annotations\" to an array of maps containing the annotation data, as described below. See also the example request.\n\nA few things to note:- Annotations are an extension of a report, so a report must first exist in order to post annotations. Annotations are posted separately from the report, and can be posted in bulk using this endpoint.\n- Only the annotations that are on lines changed in the unified diff will be displayed. This means it is likely not all annotations posted will be displayed on the pull request It also means that if the user is viewing a side-by-side diff, commit diff or iterative review diff they will not be able to view the annotations.\n- A report cannot have more than 1000 annotations by default, however this property is congurable at an instance level. If the request would result in more than the maximum number of annotations being stored then the entire request is rejected and no new annotations are stored. \n- There is no de-duplication of annotations on Bitbucket so be sure that reruns of builds will first delete the report and annotations before creating them.\n\n# Annotation parameters\n\n|Parameter|Description|Required?|Restrictions|Type|\n|--- |--- |--- |--- |--- |\n|path|The path of the file on which this annotation should be placed. This is the path of the filerelative to the git repository. If no path is provided, then it will appear in the overview modalon all pull requests where the tip of the branch is the given commit, regardless of which files weremodified.|No||String|\n|line|The line number that the annotation should belong to. If no line number is provided, then it willdefault to 0 and in a pull request it will appear at the top of the file specified by the path field.|No|Non-negative integer|Integer|\n|message|The message to display to users|Yes|The maximum length accepted is 2000 characters, however the user interface may truncate this valuefor display purposes. We recommend that the message is short and succinct, with further detailsavailable to the user if needed on the page linked to by the the annotation link.|String|\n|severity|The severity of the annotation|Yes|One of: LOW, MEDIUM, HIGH|String|\n|link|An http or https URL representing the location of the annotation in the external tool|No||String|\n|type|The type of annotation posted|No|One of: VULNERABILITY, CODE_SMELL, BUG|String|\n|externalId|If the caller requires a link to get or modify this annotation, then an ID must be provided. It isnot used or required by Bitbucket, but only by the annotation creator for updating or deleting thisspecific annotation.|No|A string value shorter than 450 characters|String|", + "operationId": "addAnnotations", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit ID on which to record the annotation. This must be a full 40 character commit hash.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "key", + "in": "path", + "description": "The key of the report to which this annotation belongs.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The annotations to add.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBulkAddInsightAnnotationRequest" + } + } + } + }, + "responses": { + "204": { + "description": "An empty response indicating that the request succeeded." + }, + "401": { + "description": "The currently authenticated user is not the author of the report, or the author no longer has sufficient permissions (REPO_READ).", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project, repository, commit, or report does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Delete Code Insights annotations", + "description": "Delete annotations for a given report that match the given external IDs, or all annotations if no external IDs are provided.", + "operationId": "deleteAnnotations", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "externalId", + "in": "query", + "description": "The external IDs for the annotations that are to be deleted. Can be specified more than once to delete by more than one external ID, or can be unspecified to delete all annotations.", + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit ID on which to record the annotation. This must be a full 40 character commit hash.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "key", + "in": "path", + "description": "The key of the report to which this annotation belongs.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The annotations were successfully deleted." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete insight reports or was not the author (REPO_READ for author otherwise REPO_ADMIN).", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project, repository, commit or report does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}/annotations/{externalId}": { + "put": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Create or replace a Code Insights annotation", + "description": "Create an annotation with the given external ID, or replace it if it already exists. A request to replace an existing annotation will be rejected if the authenticated user was not the creator of the specified report.", + "operationId": "setAnnotation", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "externalId", + "in": "path", + "description": "The external ID of the annotation that is to be updated or created", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit ID on which to record the annotation. This must be a full 40 character commit hash.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "key", + "in": "path", + "description": "The key of the report to which this annotation belongs", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The new annotation that is to replace the existing one.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSingleAddInsightAnnotationRequest" + } + } + } + }, + "responses": { + "204": { + "description": "No content, indicating that the request succeeded." + }, + "401": { + "description": "The currently authenticated user is not the author of the report, or the author no longer has sufficient permissions (REPO_READ).", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project, repository, commit, report or annotation does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/default-reviewers/latest/projects/{projectKey}/condition": { + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Create default reviewer", + "description": "Create a default reviewer pull request condition for the given project.", + "operationId": "createPullRequestCondition", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The details needed to create a default reviewer pull request condition.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestDefaultReviewersRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The default reviewer pull request condition that was created.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestCondition" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/default-reviewers/latest/projects/{projectKey}/condition/{id}": { + "put": { + "tags": [ + "Pull Requests" + ], + "summary": "Update the default reviewer", + "description": "Update the default reviewer pull request condition for the given ID.", + "operationId": "updatePullRequestCondition", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The ID of the pull request condition.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The new details for the default reviewer pull request condition.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestDefaultReviewersRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The updated default reviewer pull request condition.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestCondition" + } + } + } + }, + "400": { + "description": "The request was malformed", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Pull Requests" + ], + "summary": "Remove default reviewer", + "description": "Delete the default reviewer pull request condition associated with the given ID.", + "operationId": "deletePullRequestCondition", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The ID of the pull request condition.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response indicating that the pull request condition was deleted." + }, + "404": { + "description": "An empty response indicating a pull request condition with the given ID could not be found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/default-reviewers/latest/projects/{projectKey}/conditions": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get default reviewers", + "description": "Return a page of default reviewer pull request conditions that have been configured for this project.", + "operationId": "getPullRequestConditions", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The default reviewer pull request conditions associated with the given project.", + "content": { + "application/json": { + "schema": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestCondition" + } + } + } + } + } + } + } + }, + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/condition": { + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Create default reviewers condition", + "description": "Create a default reviewer pull request condition for the given repository.", + "operationId": "createPullRequestCondition_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The details needed to create a default reviewer pull request condition.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestDefaultReviewersRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The default reviewer pull request condition that was created.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestCondition" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/condition/{id}": { + "put": { + "tags": [ + "Pull Requests" + ], + "summary": "Update a default reviewer condition", + "description": "Update the default reviewer pull request condition for the given ID.", + "operationId": "updatePullRequestCondition_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The ID of the pull request condition", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "requiredApprovals": { + "type": "integer", + "format": "int32", + "example": 1 + }, + "reviewers": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestApplicationUser" + } + }, + "sourceMatcher": { + "type": "object", + "properties": { + "displayId": { + "type": "string", + "example": "main" + }, + "id": { + "type": "string", + "example": "refs/heads/main" + }, + "type": { + "type": "object", + "properties": { + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + }, + "name": { + "type": "string", + "example": "Branch" + } + } + } + } + }, + "targetMatcher": { + "type": "object", + "properties": { + "displayId": { + "type": "string", + "example": "main" + }, + "id": { + "type": "string", + "example": "refs/heads/main" + }, + "type": { + "type": "object", + "properties": { + "id": { + "type": "string", + "enum": [ + "ANY_REF", + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + }, + "name": { + "type": "string", + "example": "Branch" + } + } + } + } + } + } + } + } + } + }, + "responses": { + "200": { + "description": "The updated default reviewer pull request condition.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestCondition" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Pull Requests" + ], + "summary": "Delete a default reviewer condition", + "description": "Delete the default reviewer pull request condition associated with the given ID.", + "operationId": "deletePullRequestCondition_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "required": true, + "schema": { + "type": "integer", + "format": "int32" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response indicating that the pull request condition was deleted" + }, + "404": { + "description": "An empty response indicating a pull request condition with the given ID could not be found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/conditions": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get configured default reviewers", + "description": "Return a page of default reviewer pull request conditions that have been configured for this repository.", + "operationId": "getPullRequestConditions_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The default reviewer pull request conditions associated with the given repository.", + "content": { + "application/json": { + "schema": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestCondition" + } + } + } + } + } + } + } + }, + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/reviewers": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get required reviewers for PR creation", + "description": "Return a set of users who are required reviewers for pull requests created from the given source repository and ref to the given target ref in this repository.", + "operationId": "getReviewers", + "parameters": [ + { + "name": "targetRepoId", + "in": "query", + "description": "The ID of the repository in which the target ref exists", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "sourceRepoId", + "in": "query", + "description": "The ID of the repository in which the source ref exists", + "schema": { + "type": "string" + } + }, + { + "name": "sourceRefId", + "in": "query", + "description": "The ID of the source ref", + "schema": { + "type": "string" + } + }, + { + "name": "targetRefId", + "in": "query", + "description": "The ID of the target ref", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The default reviewer pull request conditions associated with the given repository.", + "content": { + "application/json": { + "schema": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestCondition" + } + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestErrors" + } + } + } + } + } + } + }, + "/comment-likes/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}/likes": { + "get": { + "tags": [ + "Deprecated" + ], + "summary": "Get comment likes", + "description": "Get a page of users who liked a commit comment in the specified repository, identified by commitId and commentId.\n\nThe authenticated user must have the **REPO_READ** (or higher) permission for the specified repository to access this resource.\n\nDeprecated in 8.0 to be removed in 9.0.", + "operationId": "getLikers", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "required": true, + "schema": { + "type": "integer", + "format": "int64" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "Page of users who liked the specified comment", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestApplicationUser" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user does not have sufficient permission (REPO_READ) to query the comment likes", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository, commit or comment does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + }, + "post": { + "tags": [ + "Deprecated" + ], + "summary": "Like a commit comment", + "description": "Like a commit comment in the specified repository, identified by commitId and commentId.\n\nThe authenticated user must have the REPO_READ (or higher) permission for the specified repository to access this resource.\n\nDeprecated in 8.0 to be removed in 9.0. Likes have been replaced with reactions. For backwards compatibility, the
thumbsup
reaction is treated as a like.", + "operationId": "like", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "required": true, + "schema": { + "type": "integer", + "format": "int64" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "No content response indicating that the request succeeded" + }, + "400": { + "description": "The currently authenticated user is the comment author", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user does not have sufficient permission", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository, commit or comment does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + }, + "delete": { + "tags": [ + "Deprecated" + ], + "summary": "Unlike a commit comment", + "description": "Unlike a commit comment in the specified repository, identified by commitId and commentId.\n\nThe authenticated user must have the REPO_READ (or higher) permission for the specified repository to access this resource.\n\nDeprecated in 8.0 to be removed in 9.0. Likes have been replaced with reactions. For backwards compatibility, the
thumbsup
reaction is treated as a like.", + "operationId": "unlike", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "required": true, + "schema": { + "type": "integer", + "format": "int64" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "No content response indicating that the request succeeded" + }, + "400": { + "description": "The currently authenticated user is the comment author", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user does not have sufficient permission", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository, commit or comment does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/comment-likes/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}/reactions/{emoticon}": { + "put": { + "tags": [ + "Repository" + ], + "summary": "React to a comment", + "description": "Add an emoticon reaction to a comment", + "operationId": "react", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The comment id", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit id", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "emoticon", + "in": "path", + "description": "The emoticon to add", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The added reaction", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestUserReaction" + } + } + } + } + } + }, + "delete": { + "tags": [ + "Repository" + ], + "summary": "Remove a reaction from comment", + "description": "Remove an emoticon reaction from a comment", + "operationId": "unReact", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The comment id", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit id", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "emoticon", + "in": "path", + "description": "The emoticon to remove", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The added reaction" + } + } + } + }, + "/comment-likes/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}/likes": { + "get": { + "tags": [ + "Deprecated" + ], + "summary": "Get pull request comment likes", + "description": "Get a page of users who liked a pull request comment in the specified repository, identified by pullRequestId and commentId. \n\nThe authenticated user must have the REPO_READ (or higher) permission for the specified repository to access this resource.\n\n**Deprecated in 8.0 to be removed in 9.0.**", + "operationId": "getLikers_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The comment id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "Page of users who liked the specified comment", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestApplicationUser" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user does not have sufficient permission (REPO_READ) to query the comment likes", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository, pull request or comment does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + }, + "post": { + "tags": [ + "Deprecated" + ], + "summary": "Like a pull request comment", + "description": "Like a pull request comment in the specified repository, identified by pullRequestId and commentId. The like will be recorded against the requesting user.\n\nThe authenticated user must have the REPO_READ (or higher) permission for the specified repository to access this resource.\n\n**Deprecated in 8.0 to be removed in 9.0.** Likes have been replaced with reactions. For backwards compatibility, the
thumbsup
reaction is treated as a like.", + "operationId": "like_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The comment id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "No content response indicating that the request succeeded" + }, + "401": { + "description": "he currently authenticated user does not have sufficient permission (REPO_READ)", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository, pull request or comment does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + }, + "delete": { + "tags": [ + "Deprecated" + ], + "summary": "Unlike a pull request comment", + "description": "Unlike a pull request comment in the specified repository, identified by pullRequestId and commentId.\n\nThe authenticated user must have the REPO_READ (or higher) permission for the specified repository to access this resource.\n\n**Deprecated in 8.0 to be removed in 9.0.** Likes have been replaced with reactions. For backwards compatibility, the
thumbsup
reaction is treated as a like.", + "operationId": "unlike_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The comment id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "No content response indicating that the request succeeded" + }, + "400": { + "description": "The currently authenticated user is the comment author", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user does not have sufficient permission (REPO_READ)", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository, pull request or comment does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/comment-likes/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}/reactions/{emoticon}": { + "put": { + "tags": [ + "Pull Requests" + ], + "summary": "React to a PR comment", + "description": "Add an emoticon reaction to a pull request comment", + "operationId": "react_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The comment id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "emoticon", + "in": "path", + "description": "The emoticon to add", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The added reaction", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestUserReaction" + } + } + } + } + } + }, + "delete": { + "tags": [ + "Pull Requests" + ], + "summary": "Remove a reaction from a PR comment", + "description": "Remove an emoticon reaction from a pull request comment", + "operationId": "unReact_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The comment id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "emoticon", + "in": "path", + "description": "The emoticon to remove", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The added reaction" + } + } + } + }, + "/git/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/rebase": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Check PR rebase precondition", + "description": "Checks preconditions to determine whether the pull request can be rebased.\n\nSome of the preconditions are:\n\n- The pull request is between Git repositories\n- The pull request is currently open\n- The pull request's {@link PullRequest#getFromRef \"from\" ref} is a branch\n - In other words, the qualified ID for the \"from\" ref must start with refs/heads/\n - Tags, and other non-standard refs, cannot be rebased\n- The current user has an e-mail address\n - Pull requests cannot be rebased anonymously\n - `git rebase` records the current user as the committer for the rebased commits, which requires a name and e-mail address\n- The current user has write access to the {@link PullRequest#getFromRef \"from\" ref}'s repository\n - Note that in order to view a pull request a user is only required to have read access to the {@link PullRequest#getToRef toRef}'s repository, so just because a user can see a pull request does not mean they can request a rebase\n\n\nThis list is not exhaustive, and the exact set of preconditions applied can be extended by third-party add-ons.\n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "canRebase", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The rebaseability status of the pull request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestRebaseability" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the specified pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Rebase pull request", + "description": "Rebases the specified pull request, rewriting the incoming commits to start from the tip commit of the pull request's target branch. This operation alters the pull request's source branch and cannot be undone.\n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets and REPO_WRITE permission for the pull request's source repository to call this resource.", + "operationId": "rebase", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The pull request rebase request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestRebaseRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The merged pull request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestRebaseResult" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request and/or to update its source branch.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "Any of the following error cases occurred (check the error message for more details):\n\n- The rebase encountered conflicts.\n- The rebase discarded all of the incoming commits and would have left the pull request empty\n- A PreRepositoryHook vetoed the rebase.\n- The specified version is out of date.\n- The specified pull request is not open.\n- The target repository is archived.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/git/latest/projects/{projectKey}/repos/{repositorySlug}/tags": { + "post": { + "tags": [ + "Repository" + ], + "summary": "Create tag", + "description": "Creates a tag in the specified repository.\n\nThe authenticated user must have an effective REPO_WRITE permission to call this resource.\n\n'LIGHTWEIGHT' and 'ANNOTATED' are the two type of tags that can be created. The 'startPoint' can either be a ref or a 'commit'.", + "operationId": "createTag", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The create git tag request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestGitTagCreateRequest" + } + } + } + }, + "responses": { + "201": { + "description": "A JSON representation of the newly created tag.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestTag" + } + } + } + }, + "400": { + "description": "The tag was not created because the request was invalid, e.g. the provided ref name already existed in the repository, or was not a valid ref name in the repository, or the start point is invalid.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create a tag. This could be due to insufficient repository permissions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/git/latest/projects/{projectKey}/repos/{repositorySlug}/tags/{name}": { + "delete": { + "tags": [ + "Repository" + ], + "summary": "Delete tag", + "description": "Deletes a tag in the specified repository.\n\nThe authenticated user must have an effective REPO_WRITE permission to call this resource.", + "operationId": "deleteTag", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "name", + "in": "path", + "description": "The name of the tag to be deleted.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response indicating that the tag no longer exists in the repository." + }, + "400": { + "description": "The tag was not deleted because repository is either empty, or is not a git repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete a tag. This could be due to insufficient repository permissions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "If the tag doesn't exist in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/gpg/latest/keys": { + "get": { + "tags": [ + "Security" + ], + "summary": "Get all GPG keys", + "description": "Find all the keys for the currently authenticated user. Optionally, users with ADMIN and higher permissions may choose to specify the user parameter to retrieve GPG keys for another user.\n\nOnly authenticated users may call this endpoint.", + "operationId": "getKeysForUser", + "parameters": [ + { + "name": "user", + "in": "query", + "description": "The name of the user to get keys for (optional; requires ADMIN permission or higher).", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "Returns a paged response of of keys for the user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestGpgKey" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to perform this operation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Security" + ], + "summary": "Create a GPG key", + "description": "Add a GPG key to the authenticated user's account. Optionally, users with ADMIN and higher permissions may choose to specify the user parameter to add a GPG key for another user.\n\nOnly authenticated users may call this endpoint.", + "operationId": "addKey", + "parameters": [ + { + "name": "user", + "in": "query", + "description": "The name of the user to add a key for (optional; requires ADMIN permission or higher).", + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request body.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestGpgKey" + } + } + } + }, + "responses": { + "200": { + "description": "Response contains the GPG key that was just created.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestGpgKey" + } + } + } + }, + "400": { + "description": "The request has failed validation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to perform this operation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Security" + ], + "summary": "Delete all GPG keys for user", + "description": "Delete all GPG keys for a supplied user.", + "operationId": "deleteForUser", + "parameters": [ + { + "name": "user", + "in": "query", + "description": "The username of the user to delete the keys for. If no username is specified, the GPG keys will be deleted for the currently authenticated user.", + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The GPG keys matching the supplied user were deleted." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the GPG keys. This is only possible when a user is explicitly supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "No user matches the supplied user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/gpg/latest/keys/{fingerprintOrId}": { + "delete": { + "tags": [ + "Security" + ], + "summary": "Delete a GPG key", + "description": "Delete the GPG key with the specified ID or Key Fingerprint.", + "operationId": "deleteKey", + "parameters": [ + { + "name": "fingerprintOrId", + "in": "path", + "description": "The GPG fingerprint or ID.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The key has been deleted successfully." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to perform this operation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/jira/latest/comments/{commentId}/issues": { + "post": { + "tags": [ + "Jira Integration" + ], + "summary": "Create Jira Issue", + "description": "Create a Jira issue and associate it with a comment on a pull request.\n\nThis resource can only be used with comments on a pull request. Attempting to call this resource with a different type of comment (for example, a comment on a commit) will result in an error. \n\n The authenticated user must have REPO_READ permission for the repository containing the comment to call this resource.\n\nThe JSON structure for the create issue format is specified by Jira's REST v2 API.", + "operationId": "createIssue", + "parameters": [ + { + "name": "commentId", + "in": "path", + "description": "the comment to associate the created Jira issue to", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "applicationId", + "in": "query", + "description": "id of the Jira server", + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "A String representation of the JSON format Jira create issue request see: Jira REST API", + "content": { + "application/json": { + "schema": { + "type": "string", + "description": "application/json" + } + } + } + }, + "responses": { + "200": { + "description": "The created Jira issue key and the associated comment ID", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestCommentJiraIssue" + } + } + } + }, + "400": { + "description": "The specified application link ID does not match any linked Jira instance.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "Authentication with the Jira instance is required.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/jira/latest/issues/{issueKey}/commits": { + "get": { + "tags": [ + "Jira Integration" + ], + "summary": "Get changesets for issue key", + "description": "Retrieve a page of changesets associated with the given issue key.", + "operationId": "getCommitsByIssueKey", + "parameters": [ + { + "name": "issueKey", + "in": "path", + "description": "The issue key to search by", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "maxChanges", + "in": "query", + "description": "The maximum number of changes to retrieve for each changeset", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of detailed changesets", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestChangeset" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + } + } + } + }, + "/jira/latest/projects/{projectKey}/primary-enhanced-entitylink": { + "get": { + "tags": [ + "Jira Integration" + ], + "summary": "Get entity link", + "description": "Retrieves the enchanced primary entitylink \n\nThe authenticated user must have PROJECT_READ permission for the project having the primary enhanced entitylink. \n\n", + "operationId": "getEnhancedEntityLinkForProject", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The primary enhanced entitylink.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestEnhancedEntityLink" + } + } + } + } + } + } + }, + "/jira/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/issues": { + "get": { + "tags": [ + "Jira Integration" + ], + "summary": "Get issues for a pull request", + "description": "Retrieves Jira issue keys that are associated with the commits in the specified pull request. The number of commits checked for issues is limited to a default of 100.", + "operationId": "getIssueKeysForPullRequest", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request id", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A list of Jira issues keys for the pull request", + "content": { + "application/json;charset=UTF-8": { + "schema": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestJiraIssue" + } + } + } + } + } + } + } + }, + "/mirroring/latest/mesh/config/refresh": { + "post": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Refresh sidecar configuration", + "description": "Refreshes configuration of the sidecar running on each node in the farm", + "operationId": "refresh", + "responses": { + "200": { + "description": "The configuration of the sidecar running on each node in the farm has been refreshed", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to refresh sidecar configuration.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/supportInfo/refChangesQueue": { + "get": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Get items in ref changes queue", + "description": "Retrieves a list of up to plugin.mirroring.farm.max.ref.change.queue.dump.size items currently in the ref changes queue. The ref changes queue is an internal component of every mirror farm, and is shared between all nodes. When the contents of an upstream repository changes, an item is added to this queue so that the mirror farm nodes know to synchronize. The mirror farm constantly polls and removes items from this queue for processing, so it is empty most of the time.", + "operationId": "getRefChangesQueue", + "responses": { + "200": { + "description": "The contents of the ref changes queue", + "content": { + "application/json;charset=UTF-8": { + "schema": { + "$ref": "#/components/schemas/RestRefSyncQueue" + } + } + } + } + } + } + }, + "/mirroring/latest/supportInfo/refChangesQueue/count": { + "get": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Get total number of items in ref changes queue", + "description": "Retrieves the total number of items currently in the ref changes queue", + "operationId": "getRefChangesQueueCount", + "responses": { + "200": { + "description": "The total number of items currently in the ref changes queue", + "content": { + "application/json": {} + } + } + } + } + }, + "/mirroring/latest/supportInfo/repoSyncStatus": { + "get": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Get sync status of repositories", + "description": "Retrieves a page of sync statuses of the repositories on this mirror node", + "operationId": "getRepoSyncStatus", + "parameters": [ + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "The sync status of the repositories on this node", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestMirrorRepositorySynchronizationStatus" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/upstreamServers": { + "get": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Get upstream servers", + "description": "Retrieves a page of upstream servers", + "operationId": "listUpstreamServers", + "parameters": [ + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of upstream servers", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestUpstreamServer" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/upstreamServers/{upstreamId}": { + "get": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Get upstream server by ID", + "description": "Retrieves upstream server details by ID.", + "operationId": "getUpstreamServer", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "description": "The upstream server ID to retrieve settings for.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The upstream server.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestUpstreamServer" + } + } + } + }, + "404": { + "description": "The upstream server could not be found", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/upstreamServers/{upstreamId}/addon/disabled": { + "post": { + "tags": [ + "Deprecated", + "Mirroring (Mirror)" + ], + "summary": "On disable of mirror addon", + "description": "This REST endpoint is retained for backwards compatibility only. It is a no-op. Starting from 4.6.0, mirrors no longer specify a disabled lifecycle callback in their addon descriptor. Prior to 4.6.0, this was the callback method that was called when the mirroring atlassian-connect add-on has been disabled in the upstream server identified by upstreamId.", + "operationId": "onAddonDisabled", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "description": "the upstream server ID to retrieve settings for", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response indicating that callback has been processed" + } + }, + "deprecated": true + } + }, + "/mirroring/latest/upstreamServers/{upstreamId}/addon/enabled": { + "post": { + "tags": [ + "Deprecated", + "Mirroring (Mirror)" + ], + "summary": "On enabled of mirror addon", + "description": "This REST endpoint is retained for backwards compatibility only. It is a no-op. Starting from 4.6.0, mirrors no longer specify an enabled lifecycle callback in their addon descriptor. Prior\nto 4.6.0, this was the callback method that was called when the mirroring atlassian-connect add-on has been\nenabled in the upstream server identified by upstreamId.", + "operationId": "onAddonEnabled", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "description": "the upstream server ID to retrieve settings for", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response indicating that callback has been processed" + } + }, + "deprecated": true + } + }, + "/mirroring/latest/upstreamServers/{upstreamId}/farmNodes": { + "get": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Get farm nodes", + "description": "Retrieves the list of farm nodes in this cluster", + "operationId": "getFarmNodes", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "description": "the upstream server ID to retrieve settings for", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The list of farm nodes", + "content": { + "application/json;charset=UTF-8": { + "schema": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestClusterNode" + } + } + } + } + }, + "404": { + "description": "The upstream server could not be found", + "content": { + "application/json;charset=UTF-8": { + "schema": { + "$ref": "#/components/schemas/RestErrors" + } + } + } + } + } + } + }, + "/mirroring/latest/upstreamServers/{upstreamId}/progress": { + "get": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Get synchronization progress state", + "description": " Retrieves synchronization progress state for the specified upstream server.If there's no progress to report, this resource will return
 {\"discovering\":false,\"syncedRepos\":0,\"totalRepos\":0}
If there are repositories in the process of synchronizing, but the precise number hasn't been discovered yet, this resource will return:
 {\"discovering\":true,\"syncedRepos\":3,\"totalRepos\":100}
If there is progress to report and the total number of repositories is known, this resource will return:
  {\"discovering\":false,\"syncedRepos\":242,\"totalRepos\":1071} 
", + "operationId": "getSynchronizationProgress", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "description": "the upstream server ID to retrieve settings for", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "the synchronization progress state", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSyncProgress" + } + } + } + }, + "404": { + "description": "The upstream server could not be found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/upstreamServers/{upstreamId}/repos/{upstreamRepoId}": { + "get": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Get clone URLs", + "description": "Retrieves all available clone urls for the specified repository.", + "operationId": "getMirroredRepository", + "parameters": [ + { + "name": "upstreamRepoId", + "in": "path", + "description": "the repository ID", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "upstreamId", + "in": "path", + "description": "the upstream server ID", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The mirrored repository's information.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMirroredRepository" + } + } + } + }, + "404": { + "description": "The upstream server or the repository could not be found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/upstreamServers/{upstreamId}/repos/{upstreamRepoId}/synchronization": { + "post": { + "tags": [ + "Deprecated", + "Mirroring (Mirror)" + ], + "summary": "Get upstream settings", + "description": "This method is no longer supported", + "operationId": "synchronizeRepositoryWithUpstream", + "parameters": [ + { + "name": "upstreamRepoId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "level", + "in": "query", + "description": "the level of synchronization to perform", + "schema": { + "type": "string" + } + }, + { + "name": "upstreamId", + "in": "path", + "description": "the upstream server ID to retrieve settings for", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "410": { + "description": "this operation is no longer supported", + "content": { + "application/json": {} + } + } + }, + "deprecated": true + } + }, + "/mirroring/latest/upstreamServers/{upstreamId}/settings": { + "get": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Get upstream settings", + "description": "Retrieves upstream settings", + "operationId": "getMirrorSettings", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "the mirror settings", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestUpstreamSettings" + } + } + } + }, + "404": { + "description": "The upstream server could not be found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Update upstream settings", + "description": "Sets the settings for the specified upstream", + "operationId": "setMirrorSettings", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "the mirror settings to update to", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestUpstreamSettings" + } + } + } + }, + "responses": { + "200": { + "description": "the updated mirror settings", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestUpstreamSettings" + } + } + } + }, + "404": { + "description": "The upstream server could not be found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/upstreamServers/{upstreamId}/settings/mode": { + "get": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Get mirror mode", + "description": "Gets the current mirror mode for the specified upstream", + "operationId": "getMirrorMode", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "the current mirror mode", + "content": { + "application/json": {} + } + }, + "404": { + "description": "The upstream server could not be found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Update mirror mode", + "description": "Sets the mirror mode for the specified upstream", + "operationId": "setMirrorMode", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "string" + } + } + } + }, + "responses": { + "200": { + "description": "the mode to set", + "content": { + "application/json": {} + } + }, + "400": { + "description": "The provided mode is invalid", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/upstreamServers/{upstreamId}/settings/projects": { + "get": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Get mirrored project IDs", + "description": "Returns the IDs of the projects that the mirror is configured to mirror", + "operationId": "getMirroredProjects", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "the currently mirrored project IDs", + "content": { + "application/json": {} + } + } + } + }, + "post": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Add multiple projects to be mirrored", + "description": "Configures the mirror to mirror the provided projects", + "operationId": "startMirroringProjects", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "array", + "items": { + "type": "string" + } + } + } + } + }, + "responses": { + "200": { + "description": "the currently mirrored project IDs", + "content": { + "application/json": {} + } + } + } + }, + "delete": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Stop mirroring projects", + "description": "Configures the mirror to no longer mirror the provided projects", + "operationId": "stopMirroringProjects", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "array", + "items": { + "type": "string" + } + } + } + } + }, + "responses": { + "204": { + "description": "the request has been processed" + } + } + } + }, + "/mirroring/latest/upstreamServers/{upstreamId}/settings/projects/{projectId}": { + "post": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Add project to be mirrored", + "description": "Configures the mirror to mirror the provided project", + "operationId": "startMirroringProject", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "projectId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "the currently mirrored project IDs", + "content": { + "application/json": {} + } + } + } + }, + "delete": { + "tags": [ + "Mirroring (Mirror)" + ], + "summary": "Stop mirroring project", + "description": "Configures the mirror to no longer mirror the provided project", + "operationId": "stopMirroringProject", + "parameters": [ + { + "name": "upstreamId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "projectId", + "in": "path", + "description": "the project ID to stop mirroring", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "the request has been processed" + } + } + } + }, + "/mirroring/latest/upstreamServers/{upstreamId}/synchronization": { + "post": { + "tags": [ + "Deprecated", + "Mirroring (Mirror)" + ], + "summary": "Change upstream settings", + "description": "This method is no longer supported", + "operationId": "synchronizeWithUpstream", + "parameters": [ + { + "name": "level", + "in": "query", + "schema": { + "type": "string", + "default": "DEFAULT" + } + }, + { + "name": "upstreamId", + "in": "path", + "description": "the upstream server ID to retrieve settings for", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "410": { + "description": "this operation is no longer supported", + "content": { + "application/json": {} + } + } + }, + "deprecated": true + } + }, + "/policies/latest/admin/repos/archive": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get repository archive policy", + "description": "Retrieves the repository archive policy for the instance.\n\nThe user must be authenticated to access this resource.", + "operationId": "getRepositoryArchivePolicy", + "responses": { + "200": { + "description": "A response containing the repository archive policy for the instance", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryPolicy" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the repository archive policy", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Update repository archive policy", + "description": "Sets the repository archive policy for the instance.\n\nThe authenticated user must have SYS_ADMIN permission.", + "operationId": "setRepositoryArchivePolicy", + "requestBody": { + "description": "The request containing the details of the policy.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryPolicy" + } + } + } + }, + "responses": { + "200": { + "description": "A response containing the repository archive policy for the instance", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryPolicy" + } + } + } + }, + "400": { + "description": "The permission was invalid or does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to set the repository archive policy", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/policies/latest/admin/repos/delete": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get repository delete policy", + "description": "Retrieves the repository delete policy for the instance.\n\nThe user must be authenticated to access this resource.", + "operationId": "getRepositoryDeletePolicy", + "responses": { + "200": { + "description": "A response containing the repository delete policy for the instance", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryPolicy" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the repository delete policy", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Update the repository delete policy", + "description": "Sets the repository delete policy for the instance.\n\nThe authenticated user must have SYS_ADMIN permission.", + "operationId": "setRepositoryDeletePolicy", + "requestBody": { + "description": "The request containing the details of the policy.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryPolicy" + } + } + } + }, + "responses": { + "200": { + "description": "A response containing the repository delete policy for the instance", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryPolicy" + } + } + } + }, + "400": { + "description": "The permission was invalid or does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to set the repository delete policy", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/account/settings/preferred-mirror": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get preferred mirror", + "description": "Retrieves the current user's preferred mirror server", + "operationId": "getPreferredMirrorId", + "responses": { + "200": { + "description": "the preferred mirror server", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMirrorServer" + } + } + } + }, + "404": { + "description": "The user's preferred mirror server could not be found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Set preferred mirror", + "description": "Sets the mirror specified by a mirror ID as the current user's preferred mirror", + "operationId": "setPreferredMirrorId", + "requestBody": { + "description": "the mirror ID", + "content": { + "application/json": { + "schema": { + "type": "string" + } + } + } + }, + "responses": { + "204": { + "description": "an empty response indicating that the user setting has been updated" + }, + "404": { + "description": "The mirror could not be found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Remove preferred mirror", + "description": "Removes the current user's preferred mirror", + "operationId": "deletePreferredMirrorId", + "responses": { + "204": { + "description": "an empty response indicating that the user setting has been updated" + } + } + } + }, + "/mirroring/latest/analyticsSettings": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get analytics settings from upstream", + "description": "Gets the analytics settings from the mirroring upstream", + "operationId": "analyticsSettings", + "responses": { + "200": { + "description": "The analytics settings from upstream", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAnalyticsSettings" + } + } + } + } + } + } + }, + "/mirroring/latest/authenticate": { + "post": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Authenticate on behalf of a user", + "description": "Authenticates on behalf of a user. Used by mirrors to check the credentials supplied to them by users. If successful a user and their effective permissions are returned as follows -\n\n* For SSH credentials - all the effective user permissions are returned.\n* For all other credentials - the highest global permission is returned along with highest repository permission if repository ID is also provided in the request.\n\nCurrently only username/password, bearer token and SSH credentials are supported.", + "operationId": "authenticate", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAuthenticationRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The user for the supplied credentials and their effective permissions}.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestApplicationUserWithPermissions" + } + } + } + }, + "400": { + "description": "If the supplied credentials are incomplete or not understood.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": " The currently authenticated user is not permitted to authenticate on behalf of users or authentication with the supplied user credentials failed for some reason", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/mirrorServers": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get all mirrors", + "description": "Returns a list of mirrors", + "operationId": "listMirrors", + "parameters": [ + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "a page of mirrors", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestMirrorServer" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/mirrorServers/{mirrorId}": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get mirror by ID", + "description": "Returns the mirror specified by a mirror ID", + "operationId": "getMirror", + "parameters": [ + { + "name": "mirrorId", + "in": "path", + "description": "the mirror ID", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "the mirror", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMirrorServer" + } + } + } + }, + "404": { + "description": "The mirror could not be found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Upgrade add-on for a mirror", + "description": "Upgrades the add-on for the mirror server in question This endpoint can only be called by the mirror instance or system administrators
Since 5.8", + "operationId": "upgrade", + "parameters": [ + { + "name": "mirrorId", + "in": "path", + "description": "the ID of the mirror to upgrade", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMirrorUpgradeRequest" + } + } + } + }, + "responses": { + "200": { + "description": "the mirror", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMirrorServer" + } + } + } + } + } + }, + "delete": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Delete mirror by ID", + "description": "Removes a mirror, disabling all access and notifications for the mirror server in question", + "operationId": "remove", + "parameters": [ + { + "name": "mirrorId", + "in": "path", + "description": "the ID of the mirror to remove", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "an empty response indicating that the mirror has been removed" + } + } + } + }, + "/mirroring/latest/mirrorServers/{mirrorId}/events": { + "post": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Publish RepositoryMirrorEvent", + "description": "Publishes a RepositoryMirrorEvent on the event queue.", + "operationId": "publishEvent", + "parameters": [ + { + "name": "mirrorId", + "in": "path", + "description": "the server id of the mirror that raised this event", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryMirrorEvent" + } + } + } + }, + "responses": { + "204": { + "description": "The event was successfully placed on the queue" + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/mirrorServers/{mirrorId}/token": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get mirror auth token", + "description": "Returns an authentication token for the mirror server in question", + "operationId": "getAuthToken", + "parameters": [ + { + "name": "mirrorId", + "in": "path", + "description": "the mirror ID", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "the mirror auth token", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMirrorAuthToken" + } + } + } + }, + "404": { + "description": "The mirror could not be found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/mirrorServers/{mirrorId}/webPanels/config": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get HTML for remote-connect web-panel on mirror", + "description": "Gets the rendered HTML that is needed to get the remote connect web-panel on the mirror.", + "operationId": "getPanelHtml", + "parameters": [ + { + "name": "mirrorId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "default": { + "description": "default response", + "content": { + "text/html": {} + } + } + } + } + }, + "/mirroring/latest/projects/{projectId}": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get project", + "description": "Returns the requested project using its primary key ID.
Since 6.7", + "operationId": "getProjectById", + "parameters": [ + { + "name": "projectId", + "in": "path", + "description": "the ID of the requested project", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The project with the specified ID", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestProject" + } + } + } + }, + "404": { + "description": "Project not found", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/projects/{projectId}/repos": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get hashes for repositories in project", + "description": "Returns a page of repositories for a given project, enriched with a content hash", + "operationId": "getAllReposForProject", + "parameters": [ + { + "name": "includeDefaultBranch", + "in": "query", + "description": "includes defaultBranchId in the response, if true. Default value is false", + "schema": { + "type": "string", + "default": "false", + "enum": [ + "true", + "false" + ] + } + }, + { + "name": "projectId", + "in": "path", + "description": "the id of the requested project", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of repositories with content hashes", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/EnrichedRepository" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "409": { + "description": "Mirroring is not available", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/repos": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get content hashes for repositories", + "description": "Returns a page of repositories enriched with a content hash and default branch", + "operationId": "getAllContentHashes", + "parameters": [ + { + "name": "includeDefaultBranch", + "in": "query", + "description": "includes defaultBranchId for each repository in the response, if true. Default value is false.", + "schema": { + "type": "string", + "default": "false", + "enum": [ + "true", + "false" + ] + } + } + ], + "responses": { + "200": { + "description": "A page of repositories with content hashes and default branch", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/EnrichedRepository" + } + } + } + }, + "409": { + "description": "Mirroring is not available", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/repos/{repoId}": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get content hash for a repository", + "description": "Returns a repository enriched with a content hash and default branch", + "operationId": "getContentHashById", + "parameters": [ + { + "name": "repoId", + "in": "path", + "description": "the ID of the requested repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "includeDefaultBranch", + "in": "query", + "schema": { + "type": "boolean", + "default": false + } + } + ], + "responses": { + "200": { + "description": "The repository with the specified repoId", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/EnrichedRepository" + } + } + } + }, + "404": { + "description": "Repository not found", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/repos/{repoId}/mirrors": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get mirrors for repository", + "description": "Returns a page of mirrors for a repository. This resource will return all mirrors along with authorized links to the mirror's repository REST resource. To determine if a repository is available on the mirror, the returned URL needs to be called.", + "operationId": "getRepositoryMirrors", + "parameters": [ + { + "name": "repoId", + "in": "path", + "description": "the ID of the requested repository", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The mirrored repository descriptor", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMirroredRepositoryDescriptor" + } + } + } + }, + "409": { + "description": "Mirroring is not available", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/requests": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get mirroring requests", + "description": "Retrieves a mirroring request", + "operationId": "listRequests", + "parameters": [ + { + "name": "state", + "in": "query", + "description": "(optional) the request state to filter on", + "schema": { + "type": "string", + "enum": [ + "PENDING", + "ACCEPTED", + "REJECTED" + ] + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of mirroring requests", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestMirroringRequest" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Create a mirroring request", + "description": "Creates a new mirroring request", + "operationId": "register", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMirroringRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The created mirroring request", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMirroringRequest" + } + } + } + }, + "409": { + "description": "The request was invalid or missing", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/requests/{mirroringRequestId}": { + "get": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Get a mirroring request", + "description": "Retrieves a mirroring request", + "operationId": "getMirroringRequest", + "parameters": [ + { + "name": "mirroringRequestId", + "in": "path", + "description": "the ID of the mirroring request to retrieve", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The mirroring request", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMirroringRequest" + } + } + } + }, + "409": { + "description": "The request could not be found", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Delete a mirroring request", + "description": "Deletes a mirroring request", + "operationId": "deleteMirroringRequest", + "parameters": [ + { + "name": "mirroringRequestId", + "in": "path", + "description": "the ID of the mirroring request to delete", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The request was deleted" + }, + "409": { + "description": "The request could not be found", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/requests/{mirroringRequestId}/accept": { + "post": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Accept a mirroring request", + "description": "Accepts a mirroring request", + "operationId": "accept", + "parameters": [ + { + "name": "mirroringRequestId", + "in": "path", + "description": "the ID of the request to accept", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The accepted mirror server", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMirrorServer" + } + } + } + }, + "409": { + "description": "The request could not be found", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/mirroring/latest/requests/{mirroringRequestId}/reject": { + "post": { + "tags": [ + "Mirroring (Upstream)" + ], + "summary": "Reject a mirroring request", + "description": "Rejects a mirroring request", + "operationId": "reject", + "parameters": [ + { + "name": "mirroringRequestId", + "in": "path", + "description": "the ID of the request to reject", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The rejected mirror server", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMirrorServer" + } + } + } + }, + "409": { + "description": "The request could not be found", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/branch-permissions/latest/projects/{projectKey}/repos/{repositorySlug}/restrictions": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Search for ref restrictions", + "description": "Search for restrictions using the supplied parameters.\n\nThe authenticated user must have REPO_ADMIN permission or higher to call this resource. Only authenticated users may call this resource.", + "operationId": "getRestrictions_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "matcherType", + "in": "query", + "description": "Matcher type to filter on", + "schema": { + "type": "string", + "enum": [ + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + } + }, + { + "name": "matcherId", + "in": "query", + "description": "Matcher id to filter on. Requires the matcherType parameter to be specified also.", + "schema": { + "type": "string" + } + }, + { + "name": "type", + "in": "query", + "description": "Types of restrictions to filter on.", + "schema": { + "type": "string", + "enum": [ + "read-only", + "no-deletes", + "fast-forward-only", + "pull-request-only" + ] + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A response containing a page of restrictions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRefRestriction" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request has failed validation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to get restrictions on the provided project", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "No restriction exists for the provided ID.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Repository" + ], + "summary": "Create multiple ref restrictions", + "description": "Allows creating multiple restrictions at once.", + "operationId": "createRestrictions_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request containing a list of the details of the restrictions to create.", + "content": { + "application/vnd.atl.bitbucket.bulk+json": { + "schema": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRestrictionRequest" + } + } + } + } + }, + "responses": { + "200": { + "description": "Response contains the ref restriction that was just created.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRefRestriction" + } + } + } + }, + "400": { + "description": "The request has failed validation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to perform this operation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/branch-permissions/latest/projects/{projectKey}/repos/{repositorySlug}/restrictions/{id}": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get a ref restriction", + "description": "Returns a restriction as specified by a restriction id. \n\nThe authenticated user must have REPO_ADMIN permission or higher to call this resource. Only authenticated users may call this resource.", + "operationId": "getRestriction_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The restriction id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A response containing the restriction.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRefRestriction" + } + } + } + }, + "400": { + "description": "The request has failed validation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to get restrictions on the provided project", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "No restriction exists for the provided ID.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Repository" + ], + "summary": "Delete a ref restriction", + "description": "Deletes a restriction as specified by a restriction id.\n\nThe authenticated user must have REPO_ADMIN permission or higher to call this resource. Only authenticated users may call this resource.", + "operationId": "deleteRestriction_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The restriction id.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response indicating that the operation was successful" + }, + "400": { + "description": "The request has failed validation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to delete restrictions on the provided project", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/branch-permissions/latest/projects/{projectKey}/restrictions": { + "get": { + "tags": [ + "Project" + ], + "summary": "Search for ref restrictions", + "description": "Search for restrictions using the supplied parameters.\n\nThe authenticated user must have PROJECT_ADMIN permission or higher to call this resource. Only authenticated users may call this resource.", + "operationId": "getRestrictions", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "matcherType", + "in": "query", + "description": "Matcher type to filter on", + "schema": { + "type": "string", + "enum": [ + "BRANCH", + "PATTERN", + "MODEL_CATEGORY", + "MODEL_BRANCH" + ] + } + }, + { + "name": "matcherId", + "in": "query", + "description": "Matcher id to filter on. Requires the matcherType parameter to be specified also.", + "schema": { + "type": "string" + } + }, + { + "name": "type", + "in": "query", + "description": "Types of restrictions to filter on.", + "schema": { + "type": "string", + "enum": [ + "read-only", + "no-deletes", + "fast-forward-only", + "pull-request-only" + ] + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A response containing a page of restrictions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRefRestriction" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request has failed validation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to get restrictions on the provided project", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "No restriction exists for the provided ID.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Project" + ], + "summary": "Create multiple ref restrictions", + "description": "Allows creating multiple restrictions at once.", + "operationId": "createRestrictions", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request containing a list of the details of the restrictions to create.", + "content": { + "application/vnd.atl.bitbucket.bulk+json": { + "schema": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRestrictionRequest" + } + } + } + } + }, + "responses": { + "200": { + "description": "Response contains the ref restriction that was just created.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRefRestriction" + } + } + } + }, + "400": { + "description": "The request has failed validation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to perform this operation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/branch-permissions/latest/projects/{projectKey}/restrictions/{id}": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get a ref restriction", + "description": "Returns a restriction as specified by a restriction id.\n\nThe authenticated user must have PROJECT_ADMIN permission or higher to call this resource. Only authenticated users may call this resource.", + "operationId": "getRestriction", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The restriction id.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A response containing the restriction.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRefRestriction" + } + } + } + }, + "400": { + "description": "The request has failed validation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to get restrictions on the provided project", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "No restriction exists for the provided ID.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Project" + ], + "summary": "Delete a ref restriction", + "description": "Deletes a restriction as specified by a restriction id.\n\nThe authenticated user must have PROJECT_ADMIN permission or higher to call this resource. Only authenticated users may call this resource.", + "operationId": "deleteRestriction", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The restriction id.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response indicating that the operation was successful" + }, + "400": { + "description": "The request has failed validation.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not permitted to delete restrictions on the provided project", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/sync/latest/projects/{projectKey}/repos/{repositorySlug}": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get synchronization status", + "description": "Retrieves the synchronization status for the specified repository. In addition to listing refs which cannot be synchronized, if any, the status also provides the timestamp for the most recent synchronization and indicates whether synchronization is available and enabled. If \"?at\" is specified in the URL, the synchronization status for the specified ref is returned, rather than the complete repository status.\n\nThe authenticated user must have REPO_READ permission for the repository, or it must be public if the request is anonymous. Additionally, after synchronization is enabled for a repository, meaning synchronization was available at that time, permission changes and other actions can cause it to become unavailable. Even when synchronization is enabled, if it is no longer available for the repository it will not be performed.", + "operationId": "getStatus", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "at", + "in": "query", + "description": "Retrieves the synchronization status for the specified ref within the repository, rather than for the entire repository", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "Synchronization status for the specified repository, or specific ref within that repository.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRefSyncStatus" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository, or the repository is not public if the request is anonymous.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Repository" + ], + "summary": "Disable synchronization", + "description": "Enables or disables synchronization for the specified repository. When synchronization is enabled, branches within the repository are immediately synchronized and the status is updated with the outcome. That initial synchronization is performed before the REST request returns, allowing it to return the updated status.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository. Anonymous users cannot manage synchronization, even on public repositories. Additionally, synchronization must be available for the specified repository. Synchronization is only available if:\n\n- The repository is a fork, since its origin is used as upstream\n- The owning user still has access to the fork's origin, if the repository is a personalfork", + "operationId": "setEnabled", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRefSyncStatus" + } + } + } + }, + "responses": { + "200": { + "description": "The updated synchronization status for the repository, after enabling synchronization. 204 NO CONTENT is returned instead after disabling synchronization.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRefSyncStatus" + } + } + } + }, + "204": { + "description": "Synchronization has successfully been disabled. 200 OK, with updated status information, is returned instead after enabling synchronization." + }, + "400": { + "description": "The JSON payload for the request did not define the \"enabled\" property.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to manage synchronization in the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/sync/latest/projects/{projectKey}/repos/{repositorySlug}/synchronize": { + "post": { + "tags": [ + "Repository" + ], + "summary": "Manual synchronization", + "description": "Allows developers to apply a manual operation to bring a ref back in sync with upstream when it becomes out of sync due to conflicting changes. The following actions are supported:\n\n- MERGE: Merges in commits from the upstream ref. After applying this action, the synchronized ref will be AHEAD (as it still includes commits that do not exist upstream.\n - This action is only supported for DIVERGED refs\n - If a \"commitMessage\" is provided in the context, it will be used on the merge commit. Otherwise a default message is used.\n- DISCARD: Throws away local changes in favour of those made upstream. This is a destructive operation where commits in the local repository are lost.\n - No context entries are supported for this action\n - If the upstream ref has been deleted, the local ref is deleted as well\n - Otherwise, the local ref is updated to reference the same commit as upstream, even if the update is not fast-forward (similar to a forced push)\n\n\nThe authenticated user must have REPO_WRITE permission for the specified repository. Anonymous users cannot synchronize refs, even on public repositories. Additionally, synchronization must be enabled and available for the specified repository.", + "operationId": "synchronize", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRefSyncRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The requested action was successfully performed, and has updated the ref's state, but the ref if is still not in sync with upstream. For example, after applying the MERGE action, the ref will still be AHEAD of upstream. If the action brings the ref in sync with upstream, 204 NO CONTENT is returned instead.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRejectedRef" + } + } + } + }, + "204": { + "description": "The requested action was successfully performed and the ref is now in sync with upstream. If the action updates the ref but does not bring it in sync with upstream, 200 OK is returned instead." + }, + "400": { + "description": "The requested synchronization action was not understood.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update refs within the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "Synchronization is not available or enabled for the specified repository, or the ref is already in sync with upstream.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "501": { + "description": "The requested synchronization action was understood by the server, but the mechanism to apply it has not been implemented.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/admin": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get global SSH key settings", + "description": "Gets the global settings that enforce the maximum expiry of SSH keys and restrictions on SSH key types.", + "operationId": "getGlobalSettings", + "responses": { + "200": { + "description": "The global ssh key settings configuration.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshKeySettings" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the ssh keys global settings configuration.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Update global SSH key settings", + "description": "Updates the global settings that enforces the maximum expiry of SSH keys and restrictions on SSH key types.", + "operationId": "updateGlobalSettings", + "requestBody": { + "description": "A request containing expiry length to be set for SSH keys and a list of SSH key type restrictions.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshKeySettings" + } + } + } + }, + "responses": { + "204": { + "description": "The ssh key global settings were updated." + }, + "400": { + "description": "The request was invalid, which may be due to:\n\n\n- attempted to set expiry to less than 1 day\n- attempted to set expiry using partial days\n- attempted to set a restriction on a key type which was invalid\n\n\nThe exact reason for the error will be provided in the error message.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update these settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/admin/supported-key-types": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get supported SSH key algorithms and lengths", + "description": "Retrieves a list of all supported SSH key algorithms and lengths.", + "operationId": "getSupportedKeyTypes", + "responses": { + "200": { + "description": "A list of supported SSH key algorithms and lengths.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve this list.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/ssh/latest/settings": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get SSH settings", + "description": "Gets the SSH settings from the upstream.", + "operationId": "sshSettings", + "responses": { + "200": { + "description": "The ssh settings from upstream", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshSettings" + } + } + } + }, + "401": { + "description": "The request was not authenticated", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/keys/latest/projects/{projectKey}/ssh/{keyId}/permission/{permission}": { + "put": { + "tags": [ + "Authentication" + ], + "summary": "Update project SSH key permission", + "description": "Updates the permission granted to the specified SSH key to the project identified in the URL.", + "operationId": "updatePermission", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "keyId", + "in": "path", + "description": "The newly created access key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "path", + "description": "The new permission to be granted to the SSH key", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The newly created access key.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshAccessKey" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions on the project to edit its access keys.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/keys/latest/projects/{projectKey}/repos/{repositorySlug}/ssh/{keyId}/permission/{permission}": { + "put": { + "tags": [ + "Authentication" + ], + "summary": "Update repository SSH key permission", + "description": "Updates the permission granted to the specified SSH key to the repository identified in the URL.", + "operationId": "updatePermission_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "keyId", + "in": "path", + "description": "The newly created access key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "path", + "description": "The new permission to be granted to the SSH key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The newly created access key.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshAccessKey" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions on the repository to edit its access keys.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/keys/latest/projects/{projectKey}/ssh": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get SSH key", + "description": "Retrieves the access keys for the project identified in the URL.", + "operationId": "getSshKeysForProject", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only SSH access keys with a label prefixed with the supplied string will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "query", + "description": "If specified only SSH access keys with at least the supplied permission will be returned Default is PROJECT_READ.", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A single page of access keys associated with the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestSshAccessKey" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the access keys for this project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Authentication" + ], + "summary": "Add project SSH key", + "description": "Register a new SSH key and grants access to the project identified in the URL.", + "operationId": "addForProject", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshAccessKey" + } + } + } + }, + "responses": { + "201": { + "description": "The newly created access key.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshAccessKey" + } + } + } + }, + "400": { + "description": "The current request contains invalid or missing values.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to add an access key to the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/keys/latest/projects/{projectKey}/repos/{repositorySlug}/ssh": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get repository SSH keys", + "description": "Retrieves the access keys for the repository identified in the URL.", + "operationId": "getForRepository_1", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only SSH access keys with a label prefixed with the supplied string will be returned", + "schema": { + "type": "string" + } + }, + { + "name": "effective", + "in": "query", + "description": "Controls whether SSH access keys configured at the project level should be included in the results or not. When set to true all keys that have access to the repository (including project level keys) are included in the results. When set to false, only access keys configured for the specified repository are considered. Default is false.", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "minimumPermission", + "in": "query", + "description": "If specified only SSH access keys with at least the supplied permission will be returned. Default is Permission.REPO_READ.", + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "query", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A single page of access keys for the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestSshAccessKey" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the access keys for this repository", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Authentication" + ], + "summary": "Add repository SSH key", + "description": "Register a new SSH key and grants access to the repository identified in the URL.", + "operationId": "addForRepository", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshAccessKey" + } + } + } + }, + "responses": { + "201": { + "description": "The newly created access key.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshAccessKey" + } + } + } + }, + "400": { + "description": "The current request contains invalid or missing values.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to add an access key to the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/keys/latest/projects/{projectKey}/repos/{repositorySlug}/ssh/{keyId}": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get repository SSH key", + "description": "Retrieves the access key for the SSH key with id keyId on the repository identified in the URL.", + "operationId": "getForRepository", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "keyId", + "in": "path", + "description": "The key id", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The access key for the repository and SSH key with ID keyId.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshAccessKey" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the access keys for this repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or key does not exist or the key does not have access on the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Authentication" + ], + "summary": "Revoke repository SSH key", + "description": "Remove an existing access key for the repository identified in the URL. If the same SSH key is used as an access key for multiple projects or repositories, only the access to the repository identified in the URL will be revoked.", + "operationId": "revokeForRepository", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "keyId", + "in": "path", + "description": "The key id", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The access key was deleted (or none was found matching the given id)." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to remove access keys for this repository", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/keys/latest/projects/{projectKey}/ssh/{keyId}": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get project SSH key", + "description": "Retrieves the access key for the SSH key with id keyId on the project identified in the URL.", + "operationId": "getForProject", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "keyId", + "in": "path", + "description": "The key id", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The access key for the repository and SSH key with ID keyId.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshAccessKey" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the access keys for this repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or key does not exist or the key does not have access on the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Authentication" + ], + "summary": "Revoke project SSH key", + "description": "Remove an existing access key for the project identified in the URL. If the same SSH key is used as an access key for multiple projects or repositories, only the access to the project identified in the URL will be revoked.", + "operationId": "revokeForProject", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "keyId", + "in": "path", + "description": "The key id", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The access key was deleted (or none was found matching the given id)." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to remove access keys for this project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/keys/latest/ssh/{keyId}/projects": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get project SSH keys", + "description": "Retrieves all project-related access keys for the SSH key with id keyId. If the current user is not an admin any of the projects the key provides access to, none are returned.", + "operationId": "getForProjects", + "parameters": [ + { + "name": "keyId", + "in": "path", + "required": true, + "schema": { + "type": "integer", + "format": "int32" + } + } + ], + "responses": { + "200": { + "description": "The SSH key with ID keyId.", + "content": { + "application/json": {} + } + }, + "404": { + "description": "The specified key does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/keys/latest/ssh/{keyId}/repos": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get repository SSH key", + "description": "Retrieves all repository-related access keys for the SSH key with id keyId. If the current user is not an admin of any of the projects the key provides access to, none are returned.", + "operationId": "getForRepositories", + "parameters": [ + { + "name": "keyId", + "in": "path", + "description": "The key id", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "withRestrictions", + "in": "query", + "description": "Include the readOnly field. The `readOnly` field is contextual for the user making the request. `readOnly` returns true if there is a restriction and the user does not have`PROJECT_ADMIN` access for the repository the key is associated with.", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The SSH key with ID keyId.", + "content": { + "application/json": {} + } + }, + "404": { + "description": "The specified key does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/keys/latest/ssh/{keyId}": { + "delete": { + "tags": [ + "Authentication" + ], + "summary": "Revoke project SSH key", + "description": "Remove an existing access key for the projects and repositories in the submitted entity. If the same SSH key is used as an access key for multiple projects or repositories not supplied, only the access to the projects or repositories identified will be revoked.", + "operationId": "revokeMany", + "parameters": [ + { + "name": "keyId", + "in": "path", + "description": "The identifier of the SSH key", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "projects": { + "$ref": "#/components/schemas/RestProject" + }, + "repositories": { + "$ref": "#/components/schemas/RestRepository" + } + } + } + } + } + }, + "responses": { + "204": { + "description": "The access keys were deleted (or none was found matching the given id and repositories or projects)." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to remove access keys for one or more of the specified projects or repositories.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "On or more of the specified repositories or projects does not exist or the key itself does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/ssh/latest/keys": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get SSH keys for user", + "description": "Retrieve a page of SSH keys.", + "operationId": "getSshKeys", + "parameters": [ + { + "name": "userName", + "in": "query", + "description": "the username of the user to retrieve the keys for. If no username is specified, the SSH keys will be retrieved for the current authenticated user.", + "schema": { + "type": "string" + } + }, + { + "name": "user", + "in": "query", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of SSH keys.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestSshKey" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissionsto retrieve the SSH keys. This is only possible when auser is explicitly supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "No user matches the supplied user", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Authentication" + ], + "summary": "Add SSH key for user", + "description": "Add a new SSH key to a supplied user.", + "operationId": "addSshKey", + "parameters": [ + { + "name": "user", + "in": "query", + "description": "the username of the user to add the SSH key for. If no username is specified, the SSH key will be added for the current authenticated user.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshKey" + } + } + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "algorithmType": { + "type": "string" + }, + "bitLength": { + "type": "integer", + "format": "int32" + }, + "createdDate": { + "type": "string", + "format": "date-time", + "readOnly": true + }, + "expiryDays": { + "type": "integer", + "format": "int32", + "example": 30 + }, + "fingerprint": { + "type": "string", + "readOnly": true, + "example": "Cbg38r+gDCiNHqBk6Y1BKO+EvufFBqhFWIEXh8oq9MI" + }, + "id": { + "type": "integer", + "format": "int32", + "readOnly": true, + "example": 1 + }, + "label": { + "type": "string", + "example": "me@127.0.0.1" + }, + "lastAuthenticated": { + "type": "string", + "readOnly": true, + "example": "1630041546434" + }, + "text": { + "type": "string", + "example": "ssh-rsa AAAAB3... me@127.0.0.1" + } + } + } + } + } + }, + "responses": { + "201": { + "description": "The newly created SSH key.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshKey" + } + } + } + }, + "400": { + "description": "The SSH key was not created because the key was not a valid RSA/DSA/ECDSA/Ed25519 key of a supported length.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "Either there is no authenticated user or the currently authenticated user has insufficient permissions to add an SSH key. The latter is only possible when a user is explicitly supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "No user matches the supplied user", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The SSH key already exists on the system.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Authentication" + ], + "summary": "Delete all user SSH key", + "description": "Delete all SSH keys for a supplied user.", + "operationId": "deleteSshKeys", + "parameters": [ + { + "name": "userName", + "in": "query", + "description": "the username of the user to delete the keys for. If no username is specified, the SSH keys will be deleted for the current authenticated user.", + "schema": { + "type": "string" + } + }, + { + "name": "user", + "in": "query", + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The SSH keys matching the supplied user were deleted." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the SSH keys. This is only possible when a user is explicitly supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "No user matches the supplied user", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/ssh/latest/keys/{keyId}": { + "get": { + "tags": [ + "Authentication" + ], + "summary": "Get SSH key for user by keyId", + "description": "Retrieve an SSH key by keyId", + "operationId": "getSshKey", + "parameters": [ + { + "name": "keyId", + "in": "path", + "description": "the ID of the key to retrieve.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "An SSH key.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSshKey" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissionsto retrieve the SSH key. This is only possible when akeyId is explicitly supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "No SSH key matches the supplied keyId", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Authentication" + ], + "summary": "Remove SSH key", + "description": "Delete an SSH key.", + "operationId": "deleteSshKey", + "parameters": [ + { + "name": "keyId", + "in": "path", + "description": "the id of the key to delete.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The SSH key matching the supplied id was deleted or did not exist." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the SSH key.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/banner": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get announcement banner", + "description": "Gets the announcement banner, if one exists and is available to the user", + "operationId": "getBanner", + "responses": { + "200": { + "description": "The requested banner", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAnnouncementBanner" + } + } + } + }, + "204": { + "description": "There is no banner to display" + }, + "401": { + "description": "The user does not have permission to access the banner service through this endpoint", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Update/Set announcement banner", + "description": "Sets the announcement banner with the provided JSON.\nOnly users authenticated as Admins may call this resource", + "operationId": "setBanner", + "requestBody": { + "content": { + "application/json": { + "schema": { + "required": [ + "audience" + ], + "type": "object", + "properties": { + "audience": { + "type": "string", + "enum": [ + "AUTHENTICATED", + "ALL" + ] + }, + "enabled": { + "type": "boolean" + }, + "message": { + "type": "string" + } + } + } + } + } + }, + "responses": { + "204": { + "description": "The banner was set successfully" + }, + "400": { + "description": "There was malformed or incorrect data in the provided JSON", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The user does not have permission to access the banner service through this endpoint", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "System Maintenance" + ], + "summary": "Delete announcement banner", + "description": "Deletes a banner, if one is present in the database.", + "operationId": "deleteBanner", + "responses": { + "204": { + "description": "The query executed successfully, whether a banner was deleted or not" + }, + "401": { + "description": "The user does not have permission to access the banner service through this endpoint", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/cluster": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get cluster node information", + "description": "Gets information about the nodes that currently make up the stash cluster.\n\nThe authenticated user must have the SYS_ADMIN permission to call this resource.", + "operationId": "getInformation", + "responses": { + "200": { + "description": "A response containing information about the cluster", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestClusterInformation" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the cluster information.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/default-branch": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get the default branch", + "description": "Retrieves the configured global default branch, which is used when creating new repositories if an explicit default branch is not specified.\n\nThe user must be authenticated to call this resource.", + "operationId": "getDefaultBranch", + "responses": { + "200": { + "description": "The configured global default branch.", + "content": { + "application/json": {} + } + }, + "404": { + "description": "No global default branch has been configured.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Update/Set default branch", + "description": "Configures the global default branch, which is used when creating new repositories if an explicit default branch is not specified.\n\nThe authenticated user must have ADMIN permission to call this resource.", + "operationId": "setDefaultBranch", + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "id": { + "type": "string" + } + } + } + } + } + }, + "responses": { + "204": { + "description": "The default branch has been set." + }, + "401": { + "description": "The current user does not have sufficient permissions to configure the global default branch.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "System Maintenance" + ], + "summary": "Clear default branch", + "description": "Clears the global default branch, which is used when creating new repositories if an explicit default branch is not specified, if one has been configured.\n\nThe authenticated user must have ADMIN permission to call this resource.", + "operationId": "clearDefaultBranch", + "responses": { + "204": { + "description": "The default branch has been cleared." + }, + "401": { + "description": "The current user does not have sufficient permissions to clear the global default branch.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/git/mesh/config/control-plane.pem": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get the control plane PEM", + "description": "Obtain the control plane PEM.\n\nThe authenticated user must have **SYS_ADMIN** permission.", + "operationId": "getControlPlanePublicKey", + "responses": { + "200": { + "description": "The control plane PEM.", + "content": { + "text/plain": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestErrors" + } + } + } + } + } + } + }, + "/api/latest/admin/git/mesh/diagnostics/connectivity": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Generate Mesh connectivity report", + "description": "Generates a connectivity report between the Bitbucket node(s) and the Mesh node(s).\n\nThe authenticated user must have **SYS_ADMIN** permission.", + "operationId": "connectivity", + "responses": { + "200": { + "description": "The connectivity report between the Bitbucket node(s) and Mesh node(s).", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMeshConnectivityReport" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/git/mesh/nodes": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get all registered Mesh nodes", + "description": "Get all the registered Mesh nodes.\n\nThe authenticated user must have **SYS_ADMIN** permission.", + "operationId": "getAllRegisteredMeshNodes", + "responses": { + "200": { + "description": "The list of registered Mesh nodes.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMeshNode" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Register new Mesh node", + "description": "Register a new Mesh node.\n\nThe authenticated user must have **SYS_ADMIN** permission.", + "operationId": "registerNewMeshNode", + "requestBody": { + "description": "The request specifying the new Mesh node.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMeshNode" + } + } + } + }, + "responses": { + "200": { + "description": "The newly registered Mesh node.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMeshNode" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/git/mesh/nodes/{id}": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get Mesh node", + "description": "Get the registered Mesh node that matches the supplied ID.\n\nThe authenticated user must have **SYS_ADMIN** permission.", + "operationId": "getRegisteredMeshNodeById", + "parameters": [ + { + "name": "id", + "in": "path", + "description": "The ID of the Mesh node.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The Mesh node that matches the ID.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMeshNode" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The Mesh node does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Update Mesh node", + "description": "Update a Mesh node.\n\nThe authenticated user must have **SYS_ADMIN** permission.", + "operationId": "updateMeshNode", + "parameters": [ + { + "name": "id", + "in": "path", + "description": "The ID of the Mesh node to update.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request specifying the updated Mesh node.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMeshNode" + } + } + } + }, + "responses": { + "200": { + "description": "The updated Mesh node.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMeshNode" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "System Maintenance" + ], + "summary": "Delete Mesh node", + "description": "Delete a Mesh node\n\nThe authenticated user must have **SYS_ADMIN** permission.", + "operationId": "delete_2", + "parameters": [ + { + "name": "force", + "in": "query", + "schema": { + "type": "boolean", + "default": false + } + }, + { + "name": "id", + "in": "path", + "required": true, + "schema": { + "type": "integer", + "format": "int64" + } + } + ], + "responses": { + "default": { + "description": "default response", + "content": { + "application/json;charset=UTF-8": {} + } + } + } + } + }, + "/api/latest/admin/git/mesh/support-zips": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get support zips for all Mesh nodes", + "description": "Get the support zips for all the Mesh nodes.\n\nThe authenticated user must have **SYS_ADMIN** permission.", + "operationId": "getSupportZips", + "responses": { + "200": { + "description": "The support zips for all the Mesh nodes.", + "content": { + "application/octet-stream": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestErrors" + } + } + } + } + } + } + }, + "/api/latest/admin/git/mesh/support-zips/{id}": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get support zip for node", + "description": "Get the support zip for the Mesh node that matches the specified ID.\n\nThe authenticated user must have **SYS_ADMIN** permission.", + "operationId": "getSupportZip", + "parameters": [ + { + "name": "id", + "in": "path", + "description": "The ID of the Mesh node.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The support zip for the Mesh node that matches the ID.", + "content": { + "application/octet-stream": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestErrors" + } + } + } + }, + "404": { + "description": "The Mesh node does not exist.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestErrors" + } + } + } + } + } + } + }, + "/api/latest/admin/groups": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get groups", + "description": "Retrieve a page of groups. \n\nThe authenticated user must have LICENSED_USER permission or higher to call this resource.", + "operationId": "getGroups_1", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only group names containing the supplied string will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of groups.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDetailedGroup" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a licensed user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Permission Management" + ], + "summary": "Create group", + "description": "Create a new group. \n\nThe authenticated user must have ADMIN permission or higher to call this resource.", + "operationId": "createGroup", + "parameters": [ + { + "name": "name", + "in": "query", + "description": "Name of the group.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The newly created group.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestDetailedGroup" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not an administrator.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "A group with this name already exists.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Permission Management" + ], + "summary": "Remove group", + "description": "Deletes the specified group, removing them from the system. This also removes any permissions that may have been granted to the group.\n\nA user may not delete the last group that is granting them administrative permissions, or a group with greater permissions than themselves.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "deleteGroup", + "parameters": [ + { + "name": "name", + "in": "query", + "description": "The name identifying the group to delete.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The deleted group.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestDetailedGroup" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as the authenticated user has a lower permission level than the group being deleted.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified group does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The action was disallowed as it would lower the authenticated user's permission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/groups/add-user": { + "post": { + "tags": [ + "Deprecated", + "Permission Management" + ], + "summary": "Add user to group", + "description": "Deprecated since 2.10. Use /rest/users/add-groups instead.\n\nAdd a user to a group.\n\nIn the request entity, the context attribute is the group and the itemName is the user.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "addUserToGroup", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/UserPickerContext" + } + } + } + }, + "responses": { + "200": { + "description": "The user was added to the group.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as it would exceed the server's licensing limit, or the groups permissions exceed the authenticated user's permission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user or group does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/api/latest/admin/groups/add-users": { + "post": { + "tags": [ + "Permission Management" + ], + "summary": "Add multiple users to group", + "description": "Add multiple users to a group. \n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "addUsersToGroup", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GroupAndUsers" + } + } + } + }, + "responses": { + "200": { + "description": "All the users were added to the group", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as it would exceed the server's licensing limit, or the groups permissions exceed the authenticated user's permission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user or group does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/groups/more-members": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get group members", + "description": "Retrieves a list of users that are members of a specified group.

The authenticated user must have the LICENSED_USER permission to call this resource.", + "operationId": "findUsersInGroup", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only users with usernames, display names or email addresses containing the supplied string will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "context", + "in": "query", + "description": "The group which should be used to locate members.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of users.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDetailedUser" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a licensed user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/groups/more-non-members": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get members not in group", + "description": "Retrieves a list of users that are not members of a specified group.

The authenticated user must have the LICENSED_USER permission to call this resource.", + "operationId": "findUsersNotInGroup", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only users with usernames, display names or email addresses containing the supplied string will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "context", + "in": "query", + "description": "The group which should be used to locate members.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of users.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDetailedUser" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a licensed user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/groups/remove-user": { + "post": { + "tags": [ + "Deprecated", + "Permission Management" + ], + "summary": "Remove user from group", + "description": "Deprecated since 2.10. Use /rest/users/remove-groups instead.\n\nRemove a user from a group.\n\nThe authenticated user must have the ADMIN permission to call this resource.\n\nIn the request entity, the context attribute is the group and the itemName is the user.", + "operationId": "removeUserFromGroup", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/UserPickerContext" + } + } + } + }, + "responses": { + "200": { + "description": "The user was removed from the group.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as the group has a higher permission level than the context user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user or group does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/api/latest/admin/license": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get license details", + "description": "Retrieves details about the current license, as well as the current status of the system with regards to the installed license. The status includes the current number of users applied toward the license limit, as well as any status messages about the license (warnings about expiry or user counts exceeding license limits). \n\nThe authenticated user must have ADMIN permission. Unauthenticated users, and non-administrators, are not permitted to access license details.", + "operationId": "get_2", + "responses": { + "200": { + "description": "The currently-installed license.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBitbucketLicense" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the license, or the request is anonymous.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "No license has been installed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Update license", + "description": "Decodes the provided encoded license and sets it as the active license. If no license was provided, a 400 is returned. If the license cannot be decoded, or cannot be applied, a 409 is returned. Some possible reasons a license may not be applied include: \n\n- It is for a different product\n- It is already expired\n\n\nOtherwise, if the license is updated successfully, details for the new license are returned with a 200 response.\n\nWarning: It is possible to downgrade the license during update, applying a license with a lower number of permitted users. If the number of currently-licensed users exceeds the limits of the new license, pushing will be disabled until the licensed user count is brought into compliance with the new license.\n\nThe authenticated user must have SYS_ADMIN permission. ADMIN users may view the current license details, but they may not update the license.", + "operationId": "updateLicense", + "requestBody": { + "description": "a JSON payload containing the encoded license to apply", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBitbucketLicense" + } + } + } + }, + "responses": { + "200": { + "description": "The newly-installed license.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBitbucketLicense" + } + } + } + }, + "400": { + "description": "No encoded license was provided in the JSON body for the POST.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update the license.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The encoded license could not be decoded, or it is not valid for use on this server. Some possible reasons a license may not be applied include: it may be for a different product, it may have already expired, or this Bitbucket version doesn't support Server licenses.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/mail-server": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get mail configuration", + "description": "Retrieves the current mail configuration. \n\nThe authenticated user must have the SYS_ADMIN permission to call this resource.", + "operationId": "getMailConfig", + "responses": { + "200": { + "description": "The mail configuration", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMailConfiguration" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the mail configuration.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The mail server hasn't been configured", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Update mail configuration", + "description": "Updates the mail configuration. \n\nThe authenticated user must have the SYS_ADMIN permission to call this resource.", + "operationId": "setMailConfig", + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "hostname": { + "type": "string", + "example": "smtp.example.com" + }, + "password": { + "type": "string", + "example": "password" + }, + "port": { + "type": "integer", + "format": "int32", + "example": 465 + }, + "protocol": { + "type": "string", + "enum": [ + "SMTP", + "SMTPS" + ] + }, + "requireStartTls": { + "type": "boolean" + }, + "senderAddress": { + "type": "string", + "example": "stash-no-reply@company.com" + }, + "useStartTls": { + "type": "boolean" + }, + "username": { + "type": "string", + "example": "user" + } + } + } + } + } + }, + "responses": { + "200": { + "description": "The updated mail configuration.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMailConfiguration" + } + } + } + }, + "400": { + "description": "The mail configuration was not updated due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update themail configuration.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "System Maintenance" + ], + "summary": "Delete mail configuration", + "description": "Deletes the current mail configuration.\n\nThe authenticated user must have the SYS_ADMIN permission to call this resource.", + "operationId": "deleteMailConfig", + "responses": { + "204": { + "description": "The mail configuration was successfully deleted." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the mail server configuration.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/mail-server/sender-address": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get server mail address", + "description": "Retrieves the server email address", + "operationId": "getSenderAddress", + "responses": { + "200": { + "description": "The server email address", + "content": { + "application/json": {} + } + }, + "401": { + "description": "he currently authenticated user has insufficient permissions to retrieve the server email address.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Update server mail address", + "description": "Updates the server email address \n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "setSenderAddress", + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "string" + } + } + } + }, + "responses": { + "200": { + "description": "The from address used in notification emails", + "content": { + "application/json": {} + } + }, + "400": { + "description": "The server email address was not updated due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update the server email address.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "System Maintenance" + ], + "summary": "Update mail configuration", + "description": "Clears the server email address.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "clearSenderAddress", + "responses": { + "204": { + "description": "he server email address was successfully cleared." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions toclear the server email address.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/permissions/groups": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get groups with a global permission", + "description": "Retrieve a page of groups that have been granted at least one global permission.\n\n\nThe authenticated user must have ADMIN permission or higher to call this resource.", + "operationId": "getGroupsWithAnyPermission", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only group names containing the supplied string will be returned", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of groups and their highest global permissions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPermittedGroup" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not an administrator.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Permission Management" + ], + "summary": "Update global permission for group", + "description": "Promote or demote a group's global permission level. Available global permissions are:\n\n\n- LICENSED_USER\n- PROJECT_CREATE\n- ADMIN\n- SYS_ADMIN\n\nSee the Bitbucket Data Center documentation for a detailed explanation of what each permission entails.\n\n\nThe authenticated user must have:\n\n\n- ADMIN permission or higher; and\n- the permission they are attempting to grant or higher; and\n- greater or equal permissions than the current permission level of the group (a user may not demote the permission level of a group with higher permissions than them)\n\n\nto call this resource. In addition, a user may not demote a group's permission level if their own permission\nlevel would be reduced as a result.", + "operationId": "setPermissionForGroups", + "parameters": [ + { + "name": "name", + "in": "query", + "description": "The names of the groups", + "required": true, + "schema": { + "type": "array", + "items": { + "type": "string" + } + } + }, + { + "name": "permission", + "in": "query", + "description": "The permission to grant", + "required": true, + "schema": { + "type": "string", + "enum": [ + "LICENSED_USER", + "PROJECT_CREATE", + "ADMIN", + "SYS_ADMIN" + ] + } + } + ], + "responses": { + "204": { + "description": "The specified permission was granted to the specified user." + }, + "400": { + "description": "The request was malformed or the specified permission does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not an administrator or doesn't have the\nspecified permission they are attempting to grant.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as it would exceed the server's license limits.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified group does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The action was disallowed as it would reduce the currently authenticated user's\npermission level or the currently authenticated user has a lower permission\nlevel than the group they are attempting to modify.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Permission Management" + ], + "summary": "Revoke all global permissions for group", + "description": "Revoke all global permissions for a group.\n\n\n\nThe authenticated user must have:\n\n\n- ADMIN permission or higher; and\n- greater or equal permissions than the current permission level of the group (a user may not demote the permission level of a group with higher permissions than them)\n\n\nto call this resource. In addition, a user may not revoke a group's permissions if their own permission level\nwould be reduced as a result.", + "operationId": "revokePermissionsForGroup", + "parameters": [ + { + "name": "name", + "in": "query", + "description": "The name of the group", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "All global permissions were revoked from the group." + }, + "401": { + "description": "TThe currently authenticated user is not an administrator.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified group does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The action was disallowed as it would reduce the currently authenticated user's\npermission level or the currently authenticated user has a lower permission\nlevel than the group they are attempting to modify.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/permissions/groups/none": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get groups with no global permission", + "description": "Retrieve a page of groups that have no granted global permissions.\n\n\nThe authenticated user must have ADMIN permission or higher to call this resource.", + "operationId": "getGroupsWithoutAnyPermission", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only user names containing the supplied string will be returned", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of groups that have not been granted any global permissions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDetailedGroup" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not an administrator.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/permissions/users": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get users with a global permission", + "description": "Retrieve a page of users that have been granted at least one global permission.\n\n\nThe authenticated user must have ADMIN permission or higher to call this resource.", + "operationId": "getUsersWithAnyPermission", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only user names containing the supplied string will be returned", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of users and their highest global permissions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPermittedGroup" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not an administrator.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Permission Management" + ], + "summary": "Update global permission for user", + "description": "Promote or demote the global permission level of a user. Available global permissions are:\n\n\n- LICENSED_USER\n- PROJECT_CREATE\n- ADMIN\n- SYS_ADMIN\n\n\nSee the Bitbucket Data Center documentation for a detailed explanation of what each permission entails.\n\n\nThe authenticated user must have:\n\n\n- ADMIN permission or higher; and\n- the permission they are attempting to grant; and\n- greater or equal permissions than the current permission level of the user (a user may not demote the permission level of a user with higher permissions than them)\n\n\nto call this resource. In addition, a user may not demote their own permission level.", + "operationId": "setPermissionForUsers", + "parameters": [ + { + "name": "name", + "in": "query", + "description": "The names of the users", + "required": true, + "schema": { + "type": "array", + "items": { + "type": "string" + } + } + }, + { + "name": "permission", + "in": "query", + "description": "The permission to grant", + "required": true, + "schema": { + "type": "string", + "enum": [ + "LICENSED_USER", + "PROJECT_CREATE", + "ADMIN", + "SYS_ADMIN" + ] + } + } + ], + "responses": { + "204": { + "description": "The requested permission was granted." + }, + "400": { + "description": "The request was malformed or the specified permission does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not an administrator or doesn't have the\nspecified permission they are attempting to grant.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as it would exceed the server's license limits.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The action was disallowed as it would reduce the currently authenticated user's\npermission level or the currently authenticated user has a lower permission\nlevel than the user they are attempting to modify.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Permission Management" + ], + "summary": "Revoke all global permissions for user", + "description": "Revoke all global permissions for a user.\n\n\nThe authenticated user must have:\n\n\n- ADMIN permission or higher; and\n- greater or equal permissions than the current permission level of the user (a user may not demote the permission level of a user with higher permissions than them)\n\n\nto call this resource. In addition, a user may not demote their own permission level.", + "operationId": "revokePermissionsForUser", + "parameters": [ + { + "name": "name", + "in": "query", + "description": "The name of the user", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "All global permissions were revoked from the user." + }, + "401": { + "description": "The currently authenticated user is not an administrator.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The action was disallowed as it would reduce the currently authenticated user's\npermission level or the currently authenticated user has a lower permission\nlevel than the user they are attempting to modify.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/permissions/users/none": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get users with no global permission", + "description": "Retrieve a page of users that have no granted global permissions.\n\n\nThe authenticated user must have ADMIN permission or higher to call this resource.", + "operationId": "getUsersWithoutAnyPermission", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only user names containing the supplied string will be returned", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of users that have not been granted any global permissions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestApplicationUser" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not an administrator.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/pull-requests/{scmId}": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get merge strategies", + "description": "Retrieve the merge strategies available for this instance. \n\nThe user must be authenticated to call this resource.", + "operationId": "getMergeConfig", + "parameters": [ + { + "name": "scmId", + "in": "path", + "description": "the id of the scm to get strategies for", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The merge configuration of this instance.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestMergeConfig" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to see the request repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The request repository does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Update merge strategies", + "description": "Update the pull request merge strategies for the context repository. \n\nThe authenticated user must have ADMIN permission to call this resource. \n\nOnly the strategies provided will be enabled, only one may be set to default \n\nThe commit message template will not be updated if not provided, and will be deleted if the `commitMessageTemplate` attribute is empty, i.e: `commitMessageTemplate: {}`.\n\nAn explicitly set pull request merge strategy configuration can be deleted by POSTing a document with an empty `mergeConfig` attribute. i.e:\n```\n{ \n \"mergeConfig\": {} \n} \n```\n\nUpon completion of this request, the effective configuration will be the default configuration.", + "operationId": "setMergeConfig", + "parameters": [ + { + "name": "scmId", + "in": "path", + "description": "the id of the scm to get strategies for", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "the settings", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestSettings" + } + } + } + }, + "responses": { + "200": { + "description": "The repository pull request merge strategies for the context repository.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestMergeConfig" + } + } + } + }, + "400": { + "description": "The repository pull request merge strategies were not updated due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to administrate thespecified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "Setting or deleting merge configurations isn't supported on archived repositories.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/rate-limit/history": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get rate limit history", + "description": "Retrieves the recent rate limit history for the instance.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "getHistory", + "parameters": [ + { + "name": "order", + "in": "query", + "description": "An optional sort category to arrange the results in descending order", + "schema": { + "type": "string", + "enum": [ + "NEWEST", + "FREQUENCY" + ] + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A response containing a page of aggregated counters for users who have been recently rate limited.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestAggregateRejectCounter" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The sort query parameter is invalid.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve rate limit history.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/rate-limit/settings": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get rate limit settings", + "description": "Retrieves the rate limit settings for the instance.\n\nThe user must be authenticated to call this resource.", + "operationId": "getSettings_2", + "responses": { + "200": { + "description": "A response containing the rate limit plugin settings for the instance.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRateLimitSettings" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve rate limit settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Set rate limit", + "description": "Sets the rate limit settings for the instance.\n\nThe authenticated user must have ADMIN permission to call this resource.", + "operationId": "setSettings_2", + "requestBody": { + "description": "Sets the rate limit settings for the instance.\n\nThe authenticated user must have ADMIN permission to call this resource.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRateLimitSettings" + } + } + } + }, + "responses": { + "200": { + "description": "A response containing the updated rate limit plugin settings for the instance.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRateLimitSettings" + } + } + } + }, + "400": { + "description": "One of the following error cases occurred (check the error message for more details):\n\n- The request is empty\n- The enabled field of the request is not a boolean\n- The defaultSettings field of the request does not contain both capacity and fillRate\n- The capacity and fillRate are not positive integers\n\n\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to set rate limit settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/rate-limit/settings/users": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get rate limit settings for user", + "description": "Retrieves the user-specific rate limit settings for the given user.\n\nThe authenticated user must have ADMIN permission to call this resource.", + "operationId": "getAllRateLimitSettings", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "Optional filter", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A response containing all the user-specific rate limit settings filtered by the optional filter.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestUserRateLimitSettings" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve rate limit settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Set rate limit settings for users", + "description": "Sets the given rate limit settings for the given users.\n\nThe authenticated user must have ADMIN permission to call this resource.", + "operationId": "set_2", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBulkUserRateLimitSettingsUpdateRequest" + } + } + } + }, + "responses": { + "200": { + "description": "A response containing the updated user settings.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestUserRateLimitSettings" + } + } + } + }, + "400": { + "description": "One of the following valid state error cases occurred (check the error message for more details):\n\n- The request is empty\n- No users are provided in the request\n- One or more of the users are invalid\n- Whitelisted is false or not provided, and no settings are provided either\n- Whitelisted is false or not provided, settings are provided, but do not contain both capacity and fillRate\n- Whitelisted is false or not provided, settings are provided, but capacity and fillRate are not positive integers\n- Whitelisted is true, and settings are provided (only one must be provided)\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to set user settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/rate-limit/settings/users/{userSlug}": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get user specific rate limit settings", + "description": "Retrieves the user-specific rate limit settings for the given user.\n\nTo call this resource, the user must be authenticated and either have ADMIN permission or be the same user as the one whose settings are requested. A user with ADMIN permission cannot get the settings of a user with SYS_ADMIN permission.", + "operationId": "get_6", + "parameters": [ + { + "name": "userSlug", + "in": "path", + "description": "The user slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A response containing the user-specific rate limit settings for the given user.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestUserRateLimitSettings" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve rate limit settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist, or has no settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Set rate limit settings for user", + "description": "Sets the given rate limit settings for the given user.\n\nThe authenticated user must have ADMIN permission to call this resource.", + "operationId": "set_3", + "parameters": [ + { + "name": "userSlug", + "in": "path", + "description": "The user slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestUserRateLimitSettingsUpdateRequest" + } + } + } + }, + "responses": { + "200": { + "description": "A response containing the updated user settings", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestUserRateLimitSettings" + } + } + } + }, + "400": { + "description": "One of the following valid state error cases occurred (check the error message for more details):\n\n- The request is empty\n- Whitelisted is false or not provided, and no settings are provided either\n- Whitelisted is false or not provided, settings are provided, but do not contain both capacity and fillRate\n- Whitelisted is false or not provided, settings are provided, but capacity and fillRate are not positive integers\n- Whitelisted is true, and settings are provided (only one must be provided)\n\n\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to set user settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "System Maintenance" + ], + "summary": "Delete user specific rate limit settings", + "description": "Deletes the user-specific rate limit settings for the given user.\n\nThe authenticated user must have ADMIN permission to call this resource.", + "operationId": "delete_8", + "parameters": [ + { + "name": "userSlug", + "in": "path", + "description": "The user slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response indicating that the user settings have been deleted." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve rate limit settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist, or has no settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/user-directories": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get directories", + "description": "Retrieve a list of active directories. \n\n The authenticated user must have the ADMIN permission to call this resource.", + "operationId": "getUserDirectories", + "parameters": [ + { + "name": "includeInactive", + "in": "query", + "description": "Set true to include inactive directories; otherwise, false to only return active directories.", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A list of directories", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestUserDirectory" + } + } + } + }, + "401": { + "description": "The currently authenticated user is not an administrator", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/users": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get users", + "description": "Retrieve a page of users. \n\n The authenticated user must have the LICENSED_USER permission to call this resource.", + "operationId": "getUsers_1", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only users with usernames, display name or email addresses containing the supplied string will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of users.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDetailedUser" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a licensed user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Permission Management" + ], + "summary": "Update user details", + "description": "Update a user's details. \n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "updateUserDetails", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/UserUpdate" + } + } + } + }, + "responses": { + "200": { + "description": "The updated user.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestDetailedUser" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission or has a lower permission level than the user being updated.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Permission Management" + ], + "summary": "Create user", + "description": "Creates a new user from the assembled query parameters.\n\nThe default group can be used to control initial permissions for new users, such as granting users the ability to login or providing read access to certain projects or repositories. If the user is not added to the default group, they may not be able to login after their account is created until explicit permissions are configured.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "createUser", + "parameters": [ + { + "name": "emailAddress", + "in": "query", + "description": "The e-mail address for the new user.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "password", + "in": "query", + "description": "The password for the new user. Required if the notify parameter is not present or is set to false", + "schema": { + "type": "string" + } + }, + { + "name": "addToDefaultGroup", + "in": "query", + "description": "Set true to add the user to the default group, which can be used to grant them a set of initial permissions; otherwise, false to not add them to a group.", + "schema": { + "type": "boolean", + "default": true + } + }, + { + "name": "displayName", + "in": "query", + "description": "The display name for the new user.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "name", + "in": "query", + "description": "The username for the new user.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "notify", + "in": "query", + "description": "If present and not false instead of requiring a password, the create user will be notified via email their account has been created and requires a password to be reset. This option can only be used if a mail server has been configured.", + "schema": { + "type": "boolean" + } + } + ], + "responses": { + "204": { + "description": "The user was successfully created." + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not an administrator.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "Adding the user to the default group would exceed the server's license limit.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "Another user with the same name already exists.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Permission Management" + ], + "summary": "Remove user", + "description": "Deletes the specified user, removing them from the system. This also removes any permissions that may have been granted to the user.\n\nA user may not delete themselves, and a user with ADMIN permissions may not delete a user with SYS_ADMINpermissions.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "deleteUser", + "parameters": [ + { + "name": "name", + "in": "query", + "description": "The username identifying the user to delete.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The deleted user.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestDetailedUser" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as the authenticated user has a lower permission level than the user being deleted.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The action was disallowed as a user can not delete themselves.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/users/add-group": { + "post": { + "tags": [ + "Deprecated", + "Permission Management" + ], + "summary": "Add user to group", + "description": "Deprecated since 2.10. Use /rest/users/add-groups instead.\n\nAdd a user to a group. This is very similar to groups/add-user, but with the context and itemName attributes of the supplied request entity reversed. On the face of it this may appear redundant, but it facilitates a specific UI component in the application.\n\nIn the request entity, the context attribute is the user and the itemName is the group.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "addGroupToUser", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GroupPickerContext" + } + } + } + }, + "responses": { + "200": { + "description": "The user was added to the group", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as it would exceed the server's licensing limit, or the groups permissions exceed the authenticated user's permission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user or group does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/api/latest/admin/users/add-groups": { + "post": { + "tags": [ + "Permission Management" + ], + "summary": "Add user to groups", + "description": "Add a user to one or more groups. \n\n The authenticated user must have the ADMIN permission to call this resource.", + "operationId": "addUserToGroups", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/UserAndGroups" + } + } + } + }, + "responses": { + "200": { + "description": "The user was added to all the groups", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as it would exceed the server's licensing limit, or the groups permissions exceed the authenticated user's permission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user or group does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/users/captcha": { + "delete": { + "tags": [ + "Permission Management" + ], + "summary": "Clear CAPTCHA for user", + "description": "Clears any CAPTCHA challenge that may constrain the user with the supplied username when they authenticate. Additionally any counter or metric that contributed towards the user being issued the CAPTCHA challenge (for instance too many consecutive failed logins) will also be reset.\n\nThe authenticated user must have the ADMIN permission to call this resource, and may not clear the CAPTCHA of a user with greater permissions than themselves.", + "operationId": "clearUserCaptchaChallenge", + "parameters": [ + { + "name": "name", + "in": "query", + "description": "The username", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The CAPTCHA was successfully cleared." + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as the authenticated user has a lower permission level than the user to clear captcha for.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/users/credentials": { + "put": { + "tags": [ + "Permission Management" + ], + "summary": "Set password for user", + "description": "Update a user's password. \n\nThe authenticated user must have the ADMIN permission to call this resource, and may not update the password of a user with greater permissions than themselves.", + "operationId": "updateUserPassword", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/AdminPasswordUpdate" + } + } + } + }, + "responses": { + "204": { + "description": "The user's password was successfully updated." + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission or has a lower permission level than the user having their password updated.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/users/erasure": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Check user removal", + "description": "Validate if a user can be erased.\n\nA username is only valid for erasure if it exists as the username of a deleted user. This endpoint will return an appropriate error response if the supplied username is invalid for erasure.\n\nThis endpoint does not perform the actual user erasure, and will not modify the application in any way.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "validateErasable", + "parameters": [ + { + "name": "name", + "in": "query", + "description": "The username of the user to validate erasability for.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "the user is erasable" + }, + "400": { + "description": "The request was malformed (e.g. if no username was supplied).", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission or has a lower permission level than the user being erased.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The requested username does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The requested username is the username of a not deleted user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Permission Management" + ], + "summary": "Erase user information", + "description": "Erases personally identifying user data for a deleted user.\n\nReferences in the application to the original username will be either removed or updated to a new non-identifying username. Refer to the support guide for details about what data is and isn't erased.\n\nUser erasure can only be performed on a deleted user. If the user has not been deleted first then this endpoint will return a bad request and no erasure will be performed.\n\nErasing user data is irreversible and may lead to a degraded user experience. This method should not be used as part of a standard user deletion and cleanup process.\n\nPlugins can participate in user erasure by defining a <user-erasure-handler> module. If one or more plugin modules fail, an error summary of the failing modules is returned.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "eraseUser", + "parameters": [ + { + "name": "name", + "in": "query", + "description": "The username identifying the user to erase.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The identifier of the erased user.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestErasedUser" + } + } + } + }, + "400": { + "description": "The request was malformed (e.g. if no username was supplied).", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission or has a lower permission level than the user being erased.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The requested username does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The requested username is the username of a not deleted user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/users/more-members": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get groups for user", + "description": "Retrieves a list of users that are not members of a specified group.

The authenticated user must have the LICENSED_USER permission to call this resource.", + "operationId": "findGroupsForUser", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only users with usernames, display names or email addresses containing the supplied string will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "context", + "in": "query", + "description": "The group which should be used to locate members.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of users.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDetailedUser" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a licensed user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/users/more-non-members": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Find other groups for user", + "description": "Retrieves a list of groups the specified user is not a member of.

The authenticated user must have the LICENSED_USER permission to call this resource.", + "operationId": "findOtherGroupsForUser", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only groups with names containing the supplied string will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "context", + "in": "query", + "description": "The user which should be used to locate groups.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of groups.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDetailedGroup" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a licensed user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/users/remove-group": { + "post": { + "tags": [ + "Permission Management" + ], + "summary": "Remove user from group", + "description": "Remove a user from a group. This is very similar to groups/remove-user, but with the context and itemName attributes of the supplied request entity reversed. On the face of it this may appear redundant, but it facilitates a specific UI component in the application.\n\nIn the request entity, the context attribute is the user and the itemName is the group.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "removeGroupFromUser", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GroupPickerContext" + } + } + } + }, + "responses": { + "200": { + "description": "The user was removed from the group.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as the group has a higher permission level than the context user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user or group does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/admin/users/rename": { + "post": { + "tags": [ + "Permission Management" + ], + "summary": "Rename user", + "description": "Rename a user. \n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "renameUser", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/UserRename" + } + } + } + }, + "responses": { + "200": { + "description": "The renamed user.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestDetailedUser" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user does not have the ADMIN permission or has a lower permission level than the user being renamed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/application-properties": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get application properties", + "description": "Retrieve version information and other application properties.\n\nNo authentication is required to call this resource.", + "operationId": "getApplicationProperties", + "responses": { + "200": { + "description": "The application properties", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestApplicationProperties" + } + } + } + } + } + } + }, + "/api/latest/build/capabilities": { + "get": { + "tags": [ + "Capabilities" + ], + "summary": "Get build capabilities", + "description": "Returns the build capabilities of this instance", + "operationId": "getCapabilities", + "responses": { + "200": { + "description": "capabilities", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBuildCapabilities" + } + } + } + } + } + } + }, + "/api/latest/dashboard/pull-request-suggestions": { + "get": { + "tags": [ + "Dashboard" + ], + "summary": "Get pull request suggestions", + "description": "Retrieves a page of suggestions for pull requests that the currently authenticated user may wish to raise. Such suggestions are based on ref changes occurring and so contain the ref change that prompted the suggestion plus the time the change event occurred. Changes will be returned in descending order based on the time the change that prompted the suggestion occurred. \n\nNote that although the response is a page object, the interface does not support paging, however a limit can be applied to the size of the returned page.", + "operationId": "getPullRequestSuggestions", + "parameters": [ + { + "name": "changesSince", + "in": "query", + "description": "restrict pull request suggestions to be based on events that occurred since some timein the past. This is expressed in seconds since \"now\". So to return suggestionsbased only on activity within the past 48 hours, pass a value of 172800.", + "schema": { + "type": "string" + } + }, + { + "name": "limit", + "in": "query", + "description": "restricts the result set to return at most this many suggestions.", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A page of pull requests that match the search criteria.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestSuggestion" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The current user is not authenticated", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/dashboard/pull-requests": { + "get": { + "tags": [ + "Dashboard" + ], + "summary": "Get pull requests for a user", + "description": "Retrieve a page of pull requests where a user is involved as either a reviewer, author or a participant. The request may be filtered by pull request state, role or participant status.", + "operationId": "getPullRequests_1", + "parameters": [ + { + "name": "closedSince", + "in": "query", + "description": "(optional, defaults to returning pull requests regardless of closed since date). Permits returning only pull requests with a closed timestamp set more recently that (now - closedSince). Units are in seconds. So for example if closed since 86400 is set only pull requests closed in the previous 24 hours will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "role", + "in": "query", + "description": "(optional, defaults to returning pull requests for any role). If a role is supplied only pull requests where the authenticated user is a participant in the given role will be returned. Either REVIEWER, AUTHOR or PARTICIPANT.", + "schema": { + "type": "string" + } + }, + { + "name": "participantStatus", + "in": "query", + "description": "(optional, defaults to returning pull requests with any participant status). A comma separated list of participant status. That is, one or more of UNAPPROVED, NEEDS_WORK, or APPROVED.", + "schema": { + "type": "string" + } + }, + { + "name": "state", + "in": "query", + "description": "(optional, defaults to returning pull requests in any state). If a state is supplied only pull requests in the specified state will be returned. Either OPEN, DECLINED or MERGED. Omit this parameter to return pull request in any state.", + "schema": { + "type": "string" + } + }, + { + "name": "user", + "in": "query", + "description": "The name of the involved user, defaults to the current user.", + "schema": { + "type": "string" + } + }, + { + "name": "order", + "in": "query", + "description": "(optional, defaults to NEWEST) the order/(s) to return pull requests in; can choose from OLDEST (as in: \"oldest first\"), NEWEST, DRAFT_STATUS, PARTICIPANT_STATUS, and/or CLOSED_DATE. Where CLOSED_DATE is specified and the result set includes pull requests that are not in the closed state, these pull requests will appear first in the result set, followed by most recently closed pull requests.", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of pull requests that match the search criteria.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequest" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The current user is not authenticated", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/deployment/capabilities": { + "get": { + "tags": [ + "Capabilities" + ], + "summary": "Get deployment capabilities", + "description": "Returns the Deployment capabilities of this instance", + "operationId": "getCapabilities_1", + "responses": { + "200": { + "description": "capabilities", + "content": { + "application/json": {} + } + }, + "404": { + "description": "This instance of Bitbucket Data Center does not support deployments (for example, it has been disabled using the property 'plugin.deployment.capability.disabled').", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/groups": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get group names", + "description": "Retrieve a page of group names.\n\nThe authenticated user must have LICENSED_USER permission or higher to call this resource.", + "operationId": "getGroups", + "parameters": [ + { + "name": "filter", + "in": "query", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of group names.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "type": "string" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a project administrator.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/hook-scripts": { + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Create a new hook script", + "description": "Create a new hook script.\n\nThis endpoint requires **SYS_ADMIN** permission.", + "operationId": "createHookScript", + "requestBody": { + "description": "The multipart form data containing the hook script", + "content": { + "multipart/form-data": { + "schema": { + "$ref": "#/components/schemas/ExamplePostMultipartFormData" + } + } + } + }, + "responses": { + "200": { + "description": "The newly created hook script.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestHookScript" + } + } + } + }, + "400": { + "description": "The hook script was not created due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/hook-scripts/{scriptId}": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get a hook script", + "description": "Retrieves a hook script by ID.", + "operationId": "getHookScript", + "parameters": [ + { + "name": "scriptId", + "in": "path", + "description": "The ID of the hook script to retrieve", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The hook script.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestHookScript" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The hook script ID supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Update a hook script", + "description": "Updates a hook script.\n\nThis endpoint requires **SYS_ADMIN** permission.", + "operationId": "updateHookScript", + "parameters": [ + { + "name": "scriptId", + "in": "path", + "description": "The ID of the hook script", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The multipart form data containing the hook script", + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/ExamplePutMultipartFormData" + } + } + } + }, + "responses": { + "200": { + "description": "The updated hook script.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestHookScript" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The hook script ID supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "A hook script with the same name already exists.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "422": { + "description": "One or more fields to update must be specified: content, description and/or name.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "System Maintenance" + ], + "summary": "Delete a hook script.", + "description": "Deletes a registered hook script.\n\nThis endpoint requires **SYS_ADMIN** permission.", + "operationId": "deleteHookScript", + "parameters": [ + { + "name": "scriptId", + "in": "path", + "description": "The ID of the hook script to delete", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The hook script was deleted." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied hook script ID.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/hook-scripts/{scriptId}/content": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get hook script content", + "description": "Retrieves the hook script content.\n\nThis endpoint requires **SYS_ADMIN** permission.", + "operationId": "read", + "parameters": [ + { + "name": "scriptId", + "in": "path", + "description": "The ID of the hook script", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The hook script content.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The hook script ID supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/hooks/{hookKey}/avatar": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get project avatar", + "description": "Retrieve the avatar for the project matching the supplied moduleKey.", + "operationId": "getAvatar", + "parameters": [ + { + "name": "hookKey", + "in": "path", + "description": "The complete module key of the hook module.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "version", + "in": "query", + "description": "(optional) Version used for HTTP caching only - any non-blank version will result in a large max-age Cache-Control header. Note that this does not affect the Last-Modified header.", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The avatar of the project matching the supplied moduleKey.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/inbox/pull-requests": { + "get": { + "summary": "Get pull requests in inbox", + "description": "Returns a page of pull requests in the user's inbox.", + "operationId": "getPullRequests_2", + "parameters": [ + { + "name": "role", + "in": "query", + "schema": { + "type": "string", + "default": "reviewer" + } + }, + { + "name": "limit", + "in": "query", + "schema": { + "type": "integer", + "format": "int32", + "default": 25 + } + }, + { + "name": "start", + "in": "query", + "schema": { + "type": "integer", + "format": "int32", + "default": 0 + } + } + ], + "responses": { + "default": { + "description": "default response", + "content": { + "application/json;charset=UTF-8": {} + } + } + } + } + }, + "/api/latest/inbox/pull-requests/count": { + "get": { + "summary": "Get total number of pull requests in inbox", + "description": "Returns the total number of pull requests in the user's inbox", + "operationId": "getPullRequestCount", + "responses": { + "default": { + "description": "default response", + "content": { + "application/json;charset=UTF-8": {} + } + } + } + } + }, + "/api/latest/labels": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get all labels", + "description": "Returns a paged response of all the labels in the system.\n\nThe user needs to be authenticated to use this resource.", + "operationId": "getLabels", + "parameters": [ + { + "name": "prefix", + "in": "query", + "description": "(optional) prefix to filter the labels on.", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "Page of returned labels.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestLabel" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The user is currently not authenticated.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/labels/{labelName}": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get label", + "description": "Returns a label.\n\nThe user needs to be authenticated to use this resource.", + "operationId": "getLabel", + "parameters": [ + { + "name": "labelName", + "in": "path", + "description": "the label name", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The label.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestLabel" + } + } + } + }, + "401": { + "description": "The user is currently not authenticated.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified label does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/labels/{labelName}/labeled": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get labelables for label", + "description": "Returns a page of labelables for a given label.\n\nOnly labelables that the authenticated user has view access to will be returned.", + "operationId": "getLabelables", + "parameters": [ + { + "name": "type", + "in": "query", + "description": " the type of labelables to be returned. Supported values: REPOSITORY", + "schema": { + "type": "string" + } + }, + { + "name": "labelName", + "in": "path", + "description": "The page of labelables.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "The page of labelables.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestLabelable" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The type of labelable is incorrect, correct values are REPOSITORY.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the labelables", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified label does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/logs/logger/{loggerName}": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get current log level", + "description": "Retrieve the current log level for a given logger.\n\nThe authenticated user must have ADMIN permission or higher to call this resource.", + "operationId": "getLevel", + "parameters": [ + { + "name": "loggerName", + "in": "path", + "description": "The name of the logger.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The log level of the logger.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestLogLevel" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the log level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/logs/logger/{loggerName}/{levelName}": { + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Set log level", + "description": "Set the current log level for a given logger.\n\nThe authenticated user must have ADMIN permission or higher to call this resource.", + "operationId": "setLevel", + "parameters": [ + { + "name": "levelName", + "in": "path", + "description": "The level to set the logger to. Either TRACE, DEBUG, INFO, WARN or ERROR", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "loggerName", + "in": "path", + "description": "The name of the logger.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The log level was successfully changed." + }, + "400": { + "description": "The log level was invalid.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to set the log level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/logs/rootLogger": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get root log level", + "description": " Retrieve the current log level for the root logger.\n\nThe authenticated user must have ADMIN permission or higher to call this resource.", + "operationId": "getRootLevel", + "responses": { + "200": { + "description": "The log level of the logger.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestLogLevel" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the log level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/logs/rootLogger/{levelName}": { + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Set root log level", + "description": "Set the current log level for the root logger.\n\nThe authenticated user must have ADMIN permission or higher to call this resource.", + "operationId": "setRootLevel", + "parameters": [ + { + "name": "levelName", + "in": "path", + "description": "the level to set the logger to. Either TRACE, DEBUG, INFO, WARN or ERROR", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The log level was successfully changed." + }, + "400": { + "description": "The log level was invalid.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to set the log level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/markup/preview": { + "post": { + "tags": [ + "Markup" + ], + "summary": "Preview markdown render", + "description": "Preview generated HTML for the given markdown content.\n\nOnly authenticated users may call this resource.", + "operationId": "preview", + "parameters": [ + { + "name": "htmlEscape", + "in": "query", + "description": "(Optional) true if HTML should be escaped in the input markup, false otherwise.", + "schema": { + "type": "string" + } + }, + { + "name": "urlMode", + "in": "query", + "description": "(Optional) The mode to use when building URLs. One of: ABSOLUTE, RELATIVE or, CONFIGURED. By default this is RELATIVE.", + "schema": { + "type": "string" + } + }, + { + "name": "includeHeadingId", + "in": "query", + "description": "(Optional) true if headers should contain an ID based on the heading content.", + "schema": { + "type": "string" + } + }, + { + "name": "hardwrap", + "in": "query", + "description": "(Optional) Whether the markup implementation should convert newlines to breaks. By default this is false which reflects the standard markdown specification.", + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "*/*": { + "schema": { + "type": "string", + "example": "# Hello World!" + } + } + } + }, + "responses": { + "200": { + "description": "The rendered markdown.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMarkup" + } + } + } + }, + "400": { + "description": "The markdown was invalid.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions preview rendered markdown.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/exports": { + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Start export job", + "description": "Starts a background job that exports the selected repositories.\n\nOnly 2 concurrent exports are supported _per cluster node_. If a request ends up on a node that is already running that many export jobs, the request will be rejected and an error returned.\n\nThe response includes a description of the job that has been started, and its ID can be used to query these details again, including the current progress, warnings and errors that occurred while processing the job, and to interrupt and cancel the execution of this job.\n\nThe request to start an export is similar to the one for previewing an export. Additionally, it accepts an optional parameter, `exportLocation`, which can be used to specify a _relative_ path within `data/migration/export` in the shared home directory. No locations outside of that directory will be accepted for exports.\n\nThere are essentially three ways to select repositories for export. Regardless of which you use, a few general rules apply:\n\n- You can supply a list of selectors. The selection will be additive.\n- Repositories that are selected more than once due to overlapping selectors will be de-duplicated and effectively exported only once.\n- For every selected repository, its full fork hierarchy will be considered selected, even if parts of that hierarchy would otherwise not be matched by the provided selectors. For example, when you explicitly select a single repository only, but that repository is a fork, then its origin will be exported (and eventually imported), too.\n\nNow, a single repository can be selected like this:\n\n```\n\n\n\n{\n \"projectKey\": \"PRJ\",\n \"slug\": \"my-repo\"\n}\n\n```\n\nSecond, all repositories in a specific project can be selected like this:\n\n```\n\n\n\n{\n \"projectKey\": \"PRJ\",\n \"slug\": *\"\n}\n\n```\n\nAnd third, all projects and repositories in the system would be selected like this:\n\n```\n\n\n\n{\n \"projectKey\": \"*\",\n \"slug\": *\"\n}\n\n```\n\nThe authenticated user must have **ADMIN** permission or higher to call this resource.", + "operationId": "startExport", + "requestBody": { + "description": "The request", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestExportRequest" + } + } + } + }, + "responses": { + "200": { + "description": "Details about the export job.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestJob" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to start anexport", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "503": { + "description": "The export could not be started because the limit of concurrent migration jobs has been reached.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/exports/preview": { + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Preview export", + "description": "Enumerates the projects and repositories that would be exported for a given export request.\n\nAll affected repositories will be enumerated explicitly, and while projects are listed as individual items in responses from this endpoint, their presence does not imply that all their repositories are included.\n\nWhile this endpoint can be used to verify that all selectors in the request apply as intended, it should be noted that a subsequent, actual export might contain a different set of repositories, as they might have been added or deleted in the meantime.\n\nNote that the overall response from this endpoint can become very large when a lot of repositories end up in the selection. This is why the server is streaming the response while it is being generated (as opposed to creating it in memory and then sending it all at once) and it can be consumed in a streaming way, too.\n\nAlso, due to the potential size of the response, projects and repositories are listed with fewer details than in other REST responses.\n\nFor a more detailed description of selectors, see the endpoint documentation for starting an export.\n\nThe authenticated user must have **ADMIN** permission or higher to call this resource.", + "operationId": "previewExport", + "requestBody": { + "description": "the export request", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestExportRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The effectively selected projects and repositories.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestScopesExample" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to generate a preview.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/exports/{jobId}": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get export job details", + "description": "Gets the details, including the current status and progress, of the export job identified by the given ID.\n\nThe authenticated user must have **ADMIN** permission or higher to call this resource.", + "operationId": "getExportJob", + "parameters": [ + { + "name": "jobId", + "in": "path", + "description": "the ID of the job", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The job, including status and progress information.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestJob" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve information about this job.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified job does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/exports/{jobId}/cancel": { + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Cancel export job", + "description": "Requests the cancellation of an export job.\n\nThe request to cancel a job will be processed successfully if the job is actually still running. If it has already finished (successfully or with errors) or if it has already been canceled before, then an error will be returned.\n\nThere might be a small delay between accepting the request and actually cancelling the job. In most cases, the delay will be close to instantaneously. In the unlikely case of communication issues across a cluster, it can however take a few seconds to cancel a job.\n\nA client should always actively query the job status to confirm that a job has been successfully canceled.\n\nThe authenticated user must have **ADMIN** permission or higher to call this resource.", + "operationId": "cancelExportJob", + "parameters": [ + { + "name": "jobId", + "in": "path", + "description": "the ID of the job to cancel", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The job has successfully been marked for cancellation" + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to cancel this job.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified job does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The job was in a state that does not allow cancellation, e.g. it has already finished.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/exports/{jobId}/messages": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get job messages", + "description": "Gets the messages generated by the job.\n\nWithout any filter, all messages will be returned, but the response can optionally be filtered for the following severities. The severity parameter can be repeated to include multiple severities in one response.\n\n- INFO\n- WARN\n- ERROR\n\nThe authenticated user must have **ADMIN** permission or higher to call this resource.", + "operationId": "getExportJobMessages", + "parameters": [ + { + "name": "severity", + "in": "query", + "description": "The severity to include in the results", + "schema": { + "type": "string" + } + }, + { + "name": "jobId", + "in": "path", + "description": "The ID of the job", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "subject", + "in": "query", + "description": "The subject", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "The messages generated by this job.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestJobMessage" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve information about this job.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified job does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/imports": { + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Start import job", + "description": "Starts a background job that imports the specified archive.\n\nOnly 1 import at a time is supported _per cluster_. If another request is made while an import is already running, the request will be rejected and an error returned.\n\nThe path in the request must point to a valid archive file. The file must be located within the `data/migration/import` directory in the shared home directory.\n\nThe authenticated user must have **ADMIN** permission or higher to call this resource.", + "operationId": "startImport", + "requestBody": { + "description": "The request", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestImportRequest" + } + } + } + }, + "responses": { + "200": { + "description": "Details about the export job.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestJob" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to start an import.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "503": { + "description": "The import could not be started because the limit of concurrent migration jobs has been reached.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/imports/{jobId}": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get import job status", + "description": "Gets the details, including the current status and progress, of the import job identified by the given ID.\n\nThe authenticated user must have **ADMIN** permission or higher to call this resource.", + "operationId": "getImportJob", + "parameters": [ + { + "name": "jobId", + "in": "path", + "description": "The ID of the job", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The job, including status and progress information.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestJob" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve information about this job.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified job does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/imports/{jobId}/cancel": { + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Cancel import job", + "description": "Requests the cancellation of an import job.\n\nThe request to cancel a job will be processed successfully if the job is actually still running. If it has already finished (successfully or with errors) or if it has already been canceled before, then an error will be returned.\n\nNote that import jobs are not canceled as instantaneously as export jobs. Rather, once the request has been accepted, there are a number of checkpoints at which the job will actually apply it and stop. This is to keep the system in a reasonably consistent state:\n\n- After the current fork hierarchy has been imported and verified.\n- Before the next repository is imported.\n- Before the next pull request is imported.\n\nA client should always actively query the job status to confirm that a job has been successfully canceled.\n\nThe authenticated user must have **ADMIN** permission or higher to call this resource.", + "operationId": "cancelImportJob", + "parameters": [ + { + "name": "jobId", + "in": "path", + "description": "the ID of the job to cancel", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The job has successfully been marked for cancellation." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to cancel this job.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified job does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The job was in a state that does not allow cancellation, e.g. it has already finished.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/imports/{jobId}/messages": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get import job messages", + "description": "Gets the messages generated by the job.\n\nWithout any filter, all messages will be returned, but the response can optionally be filtered for the following severities. The severity parameter can be repeated to include multiple severities in one response.\n\n- INFO\n- WARN\n- ERROR\n\nThe authenticated user must have **ADMIN** permission or higher to call this resource.", + "operationId": "getImportJobMessages", + "parameters": [ + { + "name": "severity", + "in": "query", + "description": "The severity to include in the results", + "schema": { + "type": "string" + } + }, + { + "name": "jobId", + "in": "path", + "description": "The ID of the job", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "subject", + "in": "query", + "description": "The subject", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "The messages generated by this job.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestJobMessage" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve information about this job.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified job does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/mesh": { + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Start Mesh migration job", + "description": "Starts a background job that migrates selected projects/repositories to Mesh. \n\nOnly 1 job is supported _per cluster_.\n\nThe response includes a description of the job that has been started, and its ID can be used to query these details again, including the current progress, and to interrupt and cancel the execution of this job. \n\nThe request to start a migration is similar to the one for previewing a migration. \n\nThere are essentially three ways to select repositories for migration. Regardless of which you use, a few general rules apply: \n\n - You can supply a list of repository IDs and project IDs. The selection will be additive. All repositories in the system are migrated if both lists are empty. - Repositories that are selected more than once due to overlapping IDs will be de-duplicated and effectively migrated only once. - For every selected repository, its full fork hierarchy will be considered selected, even if parts of that hierarchy would otherwise not be matched by the provided IDs. For example, when you explicitly select a single repository only, but that repository is a fork, then its origin will be migrated too. \n\nNow, a single repository can be selected like this: \n\n```\n\n {\n \"repositoryIds\": [1]\n }\n```\n\nMultiple repositories can be selected like this:\n\n\n\n```\n\n {\n \"repositoryIds\": [1, 2]\n }\n```\n\nSecond, all repositories in a specific project can be selected like this:\n\n\n\n```\n\n {\n \"projectIds\": [1]\n }\n```\n\nAnd third, all projects and repositories in the system would be selected like this:\n\n\n\n```\n\n {\n \"projectIds\": [],\n \"repositoryIds\": []\n }\n```\n\nThe authenticated user must have **SYS_ADMIN** permission to call this resource.", + "operationId": "startMeshMigration", + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "all": { + "type": "boolean" + }, + "maxBytesPerSecond": { + "type": "object", + "properties": { + "asLong": { + "type": "integer", + "format": "int64" + }, + "present": { + "type": "boolean" + } + } + }, + "projectIds": { + "uniqueItems": true, + "type": "array", + "items": { + "type": "integer", + "format": "int32" + } + }, + "repositoryIds": { + "uniqueItems": true, + "type": "array", + "items": { + "type": "integer", + "format": "int32" + } + } + } + } + } + } + }, + "responses": { + "200": { + "description": "The started job", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestJob" + } + } + } + }, + "400": { + "description": "The migration request failed one/more validation checks.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "503": { + "description": "A migration job is already in progress", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/mesh/preview": { + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Preview Mesh migration", + "description": "Enumerates the projects and repositories that would be migrated for a given request.\n\nAll affected repositories will be enumerated explicitly, and while projects are listed as individual items in responses from this endpoint, their presence does not imply that all their repositories are included.\n\nWhile this endpoint can be used to verify that all selectors in the request apply as intended, it should be noted that a subsequent, actual export might contain a different set of repositories, as they might have been added or deleted in the meantime.\n\nNote that the overall response from this endpoint can become very large when a lot of repositories end up in the selection. This is why the server is streaming the response while it is being generated (as opposed to creating it in memory and then sending it all at once) and it can be consumed in a streaming way, too.\n\nAlso, due to the potential size of the response, projects and repositories are listed with fewer details than in other REST responses.\n\nThe authenticated user must have **SYS_ADMIN** permission to call this resource.", + "operationId": "previewMeshMigration", + "requestBody": { + "description": "The export request", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMeshMigrationRequest" + } + } + } + }, + "responses": { + "200": { + "description": "Enumeration of projects and repositories that would be migrated for a given request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ExamplePreviewMigration" + } + } + } + }, + "400": { + "description": "The request was invalid or missing.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/mesh/repos": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Find repositories by Mesh migration state", + "description": "Searches for repositories in the system matching the specified criteria and enriches their MeshMigrationQueueState migration state if a migration is currently in progress. \n\nThe currently active migration can optionally be specified by passing a migrationId, if known. If this isn't passed, an attempt is made to locate the active migration and its ID is used. \n\nIf a migration is currently active, only repositories that are a part of the migration are filtered and returned. Otherwise, all repositories in the systems are filtered and returned. \n\nFiltering by state is ignored when no migration is currently in progress. In such a case, results are not enriched with their MeshMigrationQueueState migration state. \n\nThe authenticated user must have **SYS_ADMIN** permission to call this resource.", + "operationId": "searchMeshMigrationRepos", + "parameters": [ + { + "name": "migrationId", + "in": "query", + "description": "(optional) The currently active migration job. If not passed, this is looked up internally.", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "query", + "description": "(optional) The project key. Can be specified more than once to filter by more than one project.", + "schema": { + "type": "string" + } + }, + { + "name": "name", + "in": "query", + "description": "(optional) The repository name", + "schema": { + "type": "string" + } + }, + { + "name": "state", + "in": "query", + "description": "(optional) If a migration is active, the MeshMigrationQueueState state to filter results by. Can be specified more than once to filter by more than one state.", + "schema": { + "type": "string" + } + }, + { + "name": "remote", + "in": "query", + "description": "(optional) Whether the repository has been fully migrated to Mesh. If not present, all repositories are considered regardless of where they're located.", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of repositories matching the specified criteria.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestMigrationRepository" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "No migration job with the given ID exists.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/mesh/summaries": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get all Mesh migration job summaries", + "description": "Retrieve a page of Mesh migration job summaries. Jobs are ordered by when they were started, newest first. \n\nThe authenticated user must have **SYS_ADMIN** permission to call this resource.", + "operationId": "getAllMeshMigrationSummaries", + "parameters": [ + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "The summary of the migration job.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestMeshMigrationSummary" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/mesh/summary": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get summary for Mesh migration job", + "description": "Gets the summary, including the queue status and progress, of the currently active Mesh migration job.\n\nThe authenticated user must have **SYS_ADMIN** permission to call this resource.", + "operationId": "getActiveMeshMigrationSummary", + "responses": { + "200": { + "description": "The summary of the currently active migration job.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMeshMigrationSummary" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "No active migration job found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/mesh/{jobId}": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get Mesh migration job details", + "description": "Gets the details, including the current status and progress, of the job identified by the given ID.\n\nThe authenticated user must have **SYS_ADMIN** permission to call this resource.", + "operationId": "getMeshMigrationJob", + "parameters": [ + { + "name": "jobId", + "in": "path", + "description": "The ID of the job", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The details of the migration job.", + "content": { + "application/json": {} + } + }, + "400": { + "description": "The job ID parameter was not supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified job ID does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/mesh/{jobId}/cancel": { + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Cancel Mesh migration job", + "description": "Requests the cancellation of a migration job. \n\nThe request to cancel a job will be processed successfully if the job is actually still running. If it has already finished (successfully or with errors) or if it has already been canceled before, then an error will be returned. \n\nThere might be a small delay between accepting the request and actually cancelling the job. In most cases, the delay will be close to instantaneously. In the unlikely case of communication issues across a cluster, it can however take a few seconds to cancel a job.\n\nA client should always actively query the job status to confirm that a job has been successfully canceled.\n\nThe authenticated user must have **SYS_ADMIN** permission to call this resource.", + "operationId": "cancelMeshMigrationJob", + "parameters": [ + { + "name": "jobId", + "in": "path", + "description": "The ID of the job to cancel", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The migration job was successfully marked for cancellation." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified job ID does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The migration job has already been canceled or finished.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/mesh/{jobId}/messages": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get Mesh migration job messages", + "description": "Gets the messages generated by the job. \n\nWithout any filter, all messages will be returned, but the response can optionally be filtered for the following severities. The severity parameter can be repeated to include multiple severities in one response. \n\n - INFO\n - WARN\n - ERROR\n\n\nThe authenticated user must have **SYS_ADMIN** permission to call this resource.", + "operationId": "getMeshMigrationJobMessages", + "parameters": [ + { + "name": "severity", + "in": "query", + "description": "The severity to include in the results", + "schema": { + "type": "string" + } + }, + { + "name": "jobId", + "in": "path", + "description": "The ID of the job", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "subject", + "in": "query", + "description": "The subject", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "The details of the migration job.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestJobMessage" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The job ID parameter was not supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified job ID does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/migration/mesh/{jobId}/summary": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get Mesh migration job summary", + "description": "Gets the summary, including the queue status and progress, of a Mesh migration job. \n\nThe authenticated user must have **SYS_ADMIN** permission to call this resource.", + "operationId": "getMeshMigrationJobSummary", + "parameters": [ + { + "name": "jobId", + "in": "path", + "description": "The ID of the job", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The summary of the migration job.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestMeshMigrationSummary" + } + } + } + }, + "400": { + "description": "The job ID parameter was not supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to call this resource.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified job ID does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/profile/recent/repos": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get recently accessed repositories", + "description": "Retrieve a page of recently accessed repositories for the currently authenticated user. \n\nRepositories are ordered from most recently to least recently accessed.

Only authenticated users may call this resource.", + "operationId": "getRepositoriesRecentlyAccessed", + "parameters": [ + { + "name": "permission", + "in": "query", + "description": "(optional) If specified, it must be a valid repository permission level name and will limit the resulting repository list to ones that the requesting user has the specified permission level to. If not specified, the default REPO_READ permission level will be assumed.", + "schema": { + "type": "string", + "default": "REPO_READ" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of recently accessed repositories.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepository" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The permission level is unknown or not related to repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The request is unauthenticated.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get projects", + "description": "Retrieve a page of projects. \n\nOnly projects for which the authenticated user has the PROJECT_VIEW permission will be returned.", + "operationId": "getProjects", + "parameters": [ + { + "name": "name", + "in": "query", + "description": "Name to filter by.", + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "query", + "description": "Permission to filter by", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of projects.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestProject" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The permission level is unknown or not related to projects.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Project" + ], + "summary": "Create a new project", + "description": "Create a new project. \n\nTo include a custom avatar for the project, the project definition should contain an additional attribute with the key avatar and the value a data URI containing Base64-encoded image data. The URI should be in the following format:

    data:(content type, e.g. image/png);base64,(data) 
If the data is not Base64-encoded, or if a character set is defined in the URI, or the URI is otherwise invalid, project creation will fail. \n\nThe authenticated user must have PROJECT_CREATE permission to call this resource.", + "operationId": "createProject", + "requestBody": { + "description": "The project.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestProject" + } + } + } + }, + "responses": { + "201": { + "description": "The newly created project.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestProject" + } + } + } + }, + "400": { + "description": "The currently authenticated user has insufficient permissions to update the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create a project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The project key or name is already in use.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get a project", + "description": "Retrieve the project matching the supplied projectKey. \n\nThe authenticated user must have PROJECT_VIEW permission for the specified project to call this resource.", + "operationId": "getProject", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The project matching the supplied projectKey.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestProject" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Project" + ], + "summary": "Update project", + "description": "Update the project matching the projectKey supplied in the resource path. \n\nTo include a custom avatar for the updated project, the project definition should contain an additional attribute with the key avatar and the value a data URI containing Base64-encoded image data. The URI should be in the following format: \n``` data:(content type, e.g. image/png);base64,(data)```\n\nIf the data is not Base64-encoded, or if a character set is defined in the URI, or the URI is otherwise invalid, project creation will fail. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "updateProject", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "Project parameters to update.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestProject" + } + } + } + }, + "responses": { + "200": { + "description": "The updated project. The project's key was not updated.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestProject" + } + } + } + }, + "201": { + "description": "The updated project. The project's key was updated.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestProject" + } + } + } + }, + "400": { + "description": "The project was not updated due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Project" + ], + "summary": "Delete project", + "description": "Delete the project matching the supplied projectKey. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "deleteProject", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The project matching the supplied projectKey was deleted." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The project can not be deleted as it contains repositories.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/avatar.png": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get avatar for project", + "description": "Retrieve the avatar for the project matching the supplied projectKey. \n\nThe authenticated user must have PROJECT_VIEW permission for the specified project to call this resource.", + "operationId": "getProjectAvatar", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "s", + "in": "query", + "description": "The desired size of the image. The server will return an image as close as possible to the specified size.", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The avatar of the project matching the supplied projectKey.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Project" + ], + "summary": "Update project avatar", + "description": "Update the avatar for the project matching the supplied projectKey. \n\nThis resource accepts POST multipart form data, containing a single image in a form-field named 'avatar'. \n\nThere are configurable server limits on both the dimensions (1024x1024 pixels by default) and uploaded file size (1MB by default). Several different image formats are supported, but PNG and JPEG are preferred due to the file size limit. \n\nThis resource has Cross-Site Request Forgery (XSRF) protection. To allow the request to pass the XSRF check the caller needs to send an X-Atlassian-Token HTTP header with the value no-check. \n\nAn example curl request to upload an image name 'avatar.png' would be: ```curl -X POST -u username:password -H \"X-Atlassian-Token: no-check\" http://example.com/rest/api/1.0/projects/STASH/avatar.png -F avatar=@avatar.png ```\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "uploadAvatar", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The mutlipart form data containing the file.", + "content": { + "multipart/form-data": { + "schema": { + "$ref": "#/components/schemas/ExampleAvatarMultipartFormData" + } + } + } + }, + "responses": { + "201": { + "description": "The avatar was uploaded successfully.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/hook-scripts": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get configured hook scripts", + "description": "Return a page of hook scripts configured for the specified project. \n\nThis endpoint requires **PROJECT_ADMIN** permission.", + "operationId": "getConfigurations", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of hook scripts.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestHookScriptConfig" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the specified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/hook-scripts/{scriptId}": { + "put": { + "tags": [ + "Project" + ], + "summary": "Create/update a hook script", + "description": "Creates/updates the hook script configuration for the provided hook script and project. \n\nThis endpoint requires **PROJECT_ADMIN** permission.", + "operationId": "setConfiguration", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "scriptId", + "in": "path", + "description": "The ID of the hook script", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The hook triggers for which the hook script should be run", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestHookScriptTriggers" + } + } + } + }, + "responses": { + "200": { + "description": "The updated hook script.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestHookScriptConfig" + } + } + } + }, + "400": { + "description": "The hook script was not created/updated due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the specified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The project key supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Project" + ], + "summary": "Remove a hook script", + "description": "Removes the hook script from the set of hook scripts configured to run in all repositories under the project. \n\nThis endpoint requires **PROJECT_ADMIN** permission.", + "operationId": "removeConfiguration", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "scriptId", + "in": "path", + "description": "The ID of the hook script", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The hook script was successfully deleted." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the specified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The project key or hook script ID supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/permissions": { + "delete": { + "tags": [ + "Project" + ], + "summary": "Revoke project permissions", + "description": "Revoke all permissions for the specified project for the given groups and users.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project or a higher global permission to call this resource.\n\nIn addition, a user may not revoke a group's permission if their own permission would be revoked as a result, nor may they revoke their own permission unless they have a global permission that already implies that permission.", + "operationId": "revokePermissions", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "user", + "in": "query", + "description": "The names of the users", + "schema": { + "type": "string" + } + }, + { + "name": "group", + "in": "query", + "description": "The names of the groups", + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "All project permissions were revoked from the users and groups for the specified project." + }, + "400": { + "description": "No permissions were revoked because the request was invalid. No users or groups were provided.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user is not an administrator for the specifiedspecified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist, or one or more of the users or groups provided does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The action was disallowed as it would revoke the currently authenticated user's permission on the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/permissions/groups": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get groups with permission to project", + "description": "Retrieve a page of groups that have been granted at least one permission for the specified project.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project or a higher global permission to call this resource.", + "operationId": "getGroupsWithAnyPermission_1", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only group names containing the supplied string will be returned", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of groups and their highest permissions for the specified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPermittedGroup" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a project administrator for the specified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Project" + ], + "summary": "Update group project permission", + "description": "Promote or demote a group's permission level for the specified project.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project or a higher global permission to call this resource. In addition, a user may not demote a group's permission level if theirown permission level would be reduced as a result.", + "operationId": "setPermissionForGroups_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "name", + "in": "query", + "description": "The names of the groups", + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "query", + "description": "The permission to grant.See the [permissions documentation](https://confluence.atlassian.com/display/BitbucketServer/Using+project+permissions)for a detailed explanation of what each permission entails. Available project permissions are:\n\n- PROJECT_READ\n- PROJECT_WRITE\n- PROJECT_ADMIN\n\n\n", + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The requested permission was granted." + }, + "400": { + "description": "The request was malformed or the specified permission does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not an administrator for the specifiedspecified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as it would reduce the currently authenticated user'spermission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Project" + ], + "summary": "Revoke group project permission", + "description": " Revoke all permissions for the specified project for a group.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project or a higher global permission to call this resource.\n\nIn addition, a user may not revoke a group's permissions if it will reduce their own permission level.", + "operationId": "revokePermissionsForGroup_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "name", + "in": "query", + "description": "The name of the group", + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "All project permissions were revoked from the group for the specified project." + }, + "401": { + "description": "The currently authenticated user is not an administrator for the specifiedspecified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": " The action was disallowed as it would reduce the currently authenticated user'spermission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/permissions/groups/none": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get groups without project permission", + "description": "Retrieve a page of groups that have no granted permissions for the specified project.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project or a higher", + "operationId": "getGroupsWithoutAnyPermission_1", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only group names containing the supplied string will be returned", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "202": { + "description": "A page of groups that have not been granted any permissions for the specifiedproject.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDetailedGroup" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a project administrator for thespecified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/permissions/search": { + "get": { + "tags": [ + "Project" + ], + "summary": "Search project permissions", + "description": "Search direct and implied permissions of principals (users and groups). This endpoint returns a superset of the results returned by the /users and /groups endpoints because it allows filtering by global permissions too.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project or a higher global permission to call this resource.", + "operationId": "searchPermissions", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "query", + "description": "Permissions to filter by. See the [permissions documentation](https://confluence.atlassian.com/display/BitbucketServer/Using+project+permissions)for a detailed explanation of what each permission entails. This parameter can be specified multiple times to filter by more than one permission, and can contain global and project permissions.\n\n", + "schema": { + "type": "string" + } + }, + { + "name": "filterText", + "in": "query", + "description": "Name of the user or group to filter the name of", + "schema": { + "type": "string" + } + }, + { + "name": "type", + "in": "query", + "description": "Type of entity (user or group)Valid entity types are:\n\n- USER- GROUP", + "schema": { + "type": "string" + } + } + ], + "responses": { + "default": { + "description": "default response", + "content": { + "application/json;charset=UTF-8": {} + } + } + } + } + }, + "/api/latest/projects/{projectKey}/permissions/users": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get users with permission to project", + "description": "Retrieve a page of users that have been granted at least one permission for the specified project.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project or a higher global permission to call this resource.", + "operationId": "getUsersWithAnyPermission_1", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only user names containing the supplied string will be returned", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of users and their highest permissions for the specified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPermittedUser" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a project administrator for thespecified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Project" + ], + "summary": "Update user project permission", + "description": "Promote or demote a user's permission level for the specified project.\n\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project or a higher global permission to call this resource. In addition, a user may not reduce their own permission level unless they have a global permission that already implies that permission.", + "operationId": "setPermissionForUsers_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "name", + "in": "query", + "description": "The names of the users", + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "query", + "description": "The permission to grant.See the [permissions documentation](https://confluence.atlassian.com/display/BitbucketServer/Using+project+permissions)for a detailed explanation of what each permission entails. Available project permissions are:\n\n- PROJECT_READ\n- PROJECT_WRITE\n- PROJECT_ADMIN\n\n\n", + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The requested permission was granted." + }, + "400": { + "description": "The request was malformed or the specified permission does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not an administrator for the specifiedspecified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as it would reduce the currently authenticated user'spermission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Project" + ], + "summary": "Revoke user project permission", + "description": "Revoke all permissions for the specified project for a user.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project or a higher global permission to call this resource.\n\nIn addition, a user may not revoke their own project permissions if they do not have a higher global permission.", + "operationId": "revokePermissionsForUser_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "name", + "in": "query", + "description": "The name of the user", + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "All project permissions were revoked from the user for the specified project." + }, + "401": { + "description": "The currently authenticated user is not an administrator for the specifiedspecified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": " The action was disallowed as it would reduce the currently authenticated user'spermission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/permissions/users/none": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get users without project permission", + "description": "Retrieve a page of licensed users that have no granted permissions for the specified project.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project or a higher global permission to call this resource.", + "operationId": "getUsersWithoutPermission", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only user names containing the supplied string will be returned", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of users that have not been granted any permissions for the specified project", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestApplicationUser" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a project administrator for thespecified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/permissions/{permission}/all": { + "get": { + "tags": [ + "Project" + ], + "summary": "Check default project permission", + "description": "Check whether the specified permission is the default permission (granted to all users) for a project.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project or a higher global permission to call this resource.", + "operationId": "hasAllUserPermission", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "path", + "description": "The permission to grant. Available project permissions are:\n\n- PROJECT_READ\n- PROJECT_WRITE\n- PROJECT_ADMIN\n\n\n", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A simple entity indicating whether the specified permission is the defaultpermission for this project.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPermitted" + } + } + } + }, + "400": { + "description": "The request was malformed or the specified permission does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not an administrator for the specifiedspecified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as it would reduce the currently authenticated user'spermission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Project" + ], + "summary": "Grant project permission", + "description": "Grant or revoke a project permission to all users, i.e. set the default permission.\n\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project or a higher\nglobal permission to call this resource.", + "operationId": "modifyAllUserPermission", + "parameters": [ + { + "name": "allow", + "in": "query", + "description": "true to grant the specified permission to all users, or false to revoke it", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "path", + "description": "The permission to grant. Available project permissions are:\n\n- PROJECT_READ\n- PROJECT_WRITE\n- PROJECT_ADMIN\n\n\n", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The requested permission was successfully granted or revoked." + }, + "400": { + "description": "The request was malformed or the specified permission does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not an administrator for the specified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get repositories for project", + "description": "Retrieve repositories from the project corresponding to the supplied projectKey. \n\nThe authenticated user must have PROJECT_READ permission for the specified project to call this resource.", + "operationId": "getRepositories", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "The repositories matching the supplied projectKey.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepository" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to see the specified project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Project" + ], + "summary": "Create repository", + "description": "Create a new repository. Requires an existing project in which this repository will be created. The only parameters which will be used are name and scmId. \n\nThe authenticated user must have REPO_CREATE permission or higher, for the context project to call this resource.", + "operationId": "createRepository", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The repository", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepository" + } + } + } + }, + "responses": { + "201": { + "description": "The newly created repository.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepository" + } + } + } + }, + "400": { + "description": "The repository was not created due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create a repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "A repository with same name already exists.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get repository", + "description": "Retrieve the repository matching the supplied projectKey and repositorySlug. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "getRepository", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The repository which matches the supplied projectKey and repositorySlug.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepository" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to see the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Project" + ], + "summary": "Update repository", + "description": "Update the repository matching the repositorySlug supplied in the resource path. \n\nThe repository's slug is derived from its name. If the name changes the slug may also change. \n\nThis resource can be used to change the repository's default branch by specifying a new default branch in the request. For example: \"defaultBranch\":\"main\"\n\nThis resource can be used to move the repository to a different project by specifying a new project in the request. For example: \"project\":{\"key\":\"NEW_KEY\"}\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "updateRepository", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The updated repository.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepository" + } + } + } + }, + "responses": { + "201": { + "description": "The updated repository.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepository" + } + } + } + }, + "400": { + "description": "The repository was not updated due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update a repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "Cannot archive repository because it has open pull requests.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "A repository with the same name as the target already exists, or the repository is archived.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Project" + ], + "summary": "Fork repository", + "description": "Create a new repository forked from an existing repository. \n\nThe JSON body for this POST is not required to contain any properties. Even the name may be omitted. The following properties will be used, if provided: \n\n- \"name\":\"Fork name\" - Specifies the forked repository's name \n - Defaults to the name of the origin repository if not specified\n- \"defaultBranch\":\"main\" - Specifies the forked repository's default branch\n - Defaults to the origin repository's default branch if not specified\n- \"project\":{\"key\":\"TARGET_KEY\"} - Specifies the forked repository's target project by key\n - Defaults to the current user's personal project if not specified\n\n\nThe authenticated user must have REPO_READ permission for the specified repository and PROJECT_ADMIN on the target project to call this resource. Note that users always have PROJECT_ADMIN permission on their personal projects.", + "operationId": "forkRepository", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The rest fork.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepository" + } + } + } + }, + "responses": { + "201": { + "description": "The newly created fork.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepository" + } + } + } + }, + "400": { + "description": "A validation error prevented the fork from being created. Possible validation errors include: The name or slug for the fork collides with another repository in the target project; an SCM type was specified in the JSON body; a project was specified in the JSON body without a \"key\" property.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create a fork.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist, or, if a target project was specified, the target project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Project" + ], + "summary": "Delete repository", + "description": "Schedule the repository matching the supplied projectKey and repositorySlug to be deleted. \n\nThe authenticated user must have sufficient permissions specified by the repository delete policy to call this resource. The default permission required is REPO_ADMIN permission.", + "operationId": "deleteRepository", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "202": { + "description": "The repository has been scheduled for deletion.", + "content": { + "application/json": {} + } + }, + "204": { + "description": "No repository matching the supplied projectKey and repositorySlug was found.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/archive": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Stream archive of repository", + "description": "Streams an archive of the repository's contents at the requested commit. If no `at=` commit is requested, an archive of the default branch is streamed.\n\nThe filename= query parameter may be used to specify the exact filename to include in the \"Content-Disposition\" header. If an explicit filename is not provided, one will be automatically generated based on what is being archived. Its format depends on the at= value: \n\n- No at= commit: <slug>-<default-branch-name>@<commit>.<format>; e.g. example-master@43c2f8a0fe8.zip\n- at=sha: <slug>-<at>.<format>; e.g. example-09bcbb00100cfbb5310fb6834a1d5ce6cac253e9.tar.gz\n- at=branchOrTag: <slug>-<branchOrTag>@<commit>.<format>; e.g. example-feature@bbb225f16e1.tar \n\n - If the branch or tag is qualified (e.g. refs/heads/master, the short name (master) will be included in the filename\n - If the branch or tag's short name includes slashes (e.g. release/4.6), they will be converted to hyphens in the filename (release-4.5)\n\n\n\n\nArchives may be requested in the following formats by adding the format= query parameter: \n\n- zip: A zip file using standard compression (Default)\n- tar: An uncompressed tarball\n- tar.gz or tgz: A GZip-compressed tarball\n\n\nThe contents of the archive may be filtered by using the path= query parameter to specify paths to include. path= may be specified multiple times to include multiple paths. \n\nThe prefix= query parameter may be used to define a directory (or multiple directories) where the archive's contents should be placed. If the prefix does not end with /, one will be added automatically. The prefix is always treated as a directory; it is not possible to use it to prepend characters to the entries in the archive. \n\nArchives of public repositories may be streamed by any authenticated or anonymous user. Streaming archives for non-public repositories requires an authenticated user with at least REPO_READ permission.", + "operationId": "getArchive", + "parameters": [ + { + "name": "path", + "in": "query", + "description": "Paths to include in the streamed archive; may be repeated to include multiple paths", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "filename", + "in": "query", + "description": "A filename to include the \"Content-Disposition\" header", + "schema": { + "type": "string" + } + }, + { + "name": "at", + "in": "query", + "description": "The commit to stream an archive of; if not supplied, an archive of the default branch is streamed", + "schema": { + "type": "string" + } + }, + { + "name": "prefix", + "in": "query", + "description": "A prefix to apply to all entries in the streamed archive; if the supplied prefix does not end with a trailing /, one will be added automatically", + "schema": { + "type": "string" + } + }, + { + "name": "format", + "in": "query", + "description": "The format to stream the archive in; must be one of: zip, tar, tar.gz or tgz", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "An archive or the requested commit, in zip, tar or gzipped-tar format.", + "content": { + "application/json": {} + } + }, + "400": { + "description": "The requested format is not supported.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository does not exist or does not contain the at commit.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/attachments/{attachmentId}": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get an attachment", + "description": "Retrieve the attachment.\n\nThe authenticated user must have REPO_READ permission for the specified repository that is associated to the attachment.\n\nRange requests (see IETF RFC7233) are supported. However only a single range issupported. If multiple ranges are passed the ranges will be ignored and the entire content will be returned in the response.", + "operationId": "getAttachment", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "User-Agent", + "in": "header", + "schema": { + "type": "string" + } + }, + { + "name": "attachmentId", + "in": "path", + "description": "the attachment ID", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "Range", + "in": "header", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "the attachment", + "content": { + "application/json": {} + } + }, + "206": { + "description": "the requested range of bytes from the attachment", + "content": { + "application/json": {} + } + }, + "401": { + "description": "the user is currently not authenticated", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The attachment does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Repository" + ], + "summary": "Delete an attachment", + "description": "Delete an attachment.\n\nThe user must be authenticated and have REPO_ADMIN permission for the specified repository.", + "operationId": "deleteAttachment", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "attachmentId", + "in": "path", + "description": "the attachment ID", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "" + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the attachment", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The attachment does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/attachments/{attachmentId}/metadata": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get attachment metadata", + "description": "Retrieve the attachment metadata.\n\nThe authenticated user must have REPO_READ permission for the specified repository that is associated to the attachment that has the attachment metadata.", + "operationId": "getAttachmentMetadata", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "attachmentId", + "in": "path", + "description": "the attachment ID", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The attachment metadata", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAttachmentMetadata" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the attachment metadata", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The attachment or the attachment metadata does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Repository" + ], + "summary": "Save attachment metadata", + "description": "Save attachment metadata.\n\nThe authenticated user must have REPO_READ permission for the specified repository that is associated to the attachment that has the attachment metadata.", + "operationId": "saveAttachmentMetadata", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "attachmentId", + "in": "path", + "description": "the attachment ID", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The attachment metadata can be any valid JSON content", + "content": { + "application/json": { + "schema": { + "type": "string", + "description": "any valid JSON content" + } + } + } + }, + "responses": { + "200": { + "description": "The attachment metadata", + "content": { + "application/json": {} + } + }, + "400": { + "description": "The supplied content is not valid JSON", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to save theattachment metadata", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository or the attachment does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Repository" + ], + "summary": "Delete attachment metadata", + "description": "Delete attachment metadata.\n\nThe user must be authenticated and have REPO_ADMIN permission for the specified repository.", + "operationId": "deleteAttachmentMetadata", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "attachmentId", + "in": "path", + "description": "the attachment ID", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "" + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete theattachment metadata", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The attachment or the attachment metadata does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/branches": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Find branches", + "description": "Retrieve the branches matching the supplied filterText param. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "getBranches", + "parameters": [ + { + "name": "boostMatches", + "in": "query", + "description": "Controls whether exact and prefix matches will be boosted to the top", + "schema": { + "type": "boolean" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "orderBy", + "in": "query", + "description": "Ordering of refs either ALPHABETICAL (by name) or MODIFICATION (last updated)", + "schema": { + "type": "string", + "enum": [ + "ALPHABETICAL", + "MODIFICATION" + ] + } + }, + { + "name": "details", + "in": "query", + "description": "Whether to retrieve plugin-provided metadata about each branch", + "schema": { + "type": "boolean" + } + }, + { + "name": "filterText", + "in": "query", + "description": "The text to match on", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "base", + "in": "query", + "description": "Base branch or tag to compare each branch to (for the metadata providers that uses that information", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "The branches matching the supplied filterText.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestBranch" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to read the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Repository" + ], + "summary": "Create branch", + "description": "Creates a branch using the information provided in the RestCreateBranchRequest request \n\nThe authenticated user must have REPO_WRITE permission for the context repository to call this resource.", + "operationId": "createBranchForRepository", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request to create a branch containing a name, startPoint, and optionally a message", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestCreateBranchRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The created branch.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBranch" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to write to the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/branches/default": { + "get": { + "tags": [ + "Deprecated", + "Repository" + ], + "summary": "Get default branch", + "description": "Retrieves the repository's default branch, if it has been created. If the repository is empty, 204 No Content will be returned. For non-empty repositories, if the configured default branch has not yet been created a 404 Not Found will be returned. \n\nThis URL is deprecated. Callers should use GET /projects/{key}/repos/{slug}/default-branch instead, which allows retrieving the configured default branch even if the ref has not been created yet. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "getDefaultBranch_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The configured default branch for the repository.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBranch" + } + } + } + }, + "204": { + "description": "The repository is empty, and has no default branch." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to read the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist, or its configured default branch does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + }, + "put": { + "tags": [ + "Deprecated", + "Repository" + ], + "summary": "Update default branch", + "description": "Update the default branch of a repository. \n\nThis URL is deprecated. Callers should use PUT /projects/{key}/repos/{slug}/default-branch instead. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "setDefaultBranch_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The branch to set as default", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBranch" + } + } + } + }, + "responses": { + "204": { + "description": "The operation was successful." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/browse": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get file content at revision", + "description": "Retrieve a page of content for a file path at a specified revision. \n\nResponses from this endpoint vary widely depending on the query parameters. The example JSON is for a request that does not use size, type, blame or noContent. \n\n1. size will return a response like {\"size\":10000}\n2. type will return a response like {\"type\":\"FILE\"}, where possible values are \"DIRECTORY\", \"FILE\" and \"SUBMODULE\"\n3. blame without noContent will include blame for the lines of content returned on the page\n4. blame with noContent will omit file contents and only return blame for the requested lines\n5. noContent without blame is ignored and does nothing\n\n\nThe various parameters are \"processed\" in the above order. That means ?size=true&type=truewill return a size response, not a type one; the type parameter will be ignored. \n\nThe blame and noContent query parameters are handled differently from size and type. For blame and noContent, the presence of the parameter implies \"true\" if no value is specified; size and and type both require an explicit=true or they're treated as \"false\". \n\n- ?blame is the same as ?blame=true\n- ?blame&noContent is the same as ?blame=true&noContent=true\n- ?size is the same as ?size=false\n- ?type is the same as ?type=false\n\n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "getContent", + "parameters": [ + { + "name": "noContent", + "in": "query", + "description": "If blame&noContent only the blame is retrieved instead of the contents", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "at", + "in": "query", + "description": "The commit ID or ref to retrieve the content for", + "schema": { + "type": "string" + } + }, + { + "name": "size", + "in": "query", + "description": "If true only the size will be returned for the file path instead of the contents", + "schema": { + "type": "string" + } + }, + { + "name": "blame", + "in": "query", + "description": "If present and not equal to 'false', the blame will be returned for the file as well", + "schema": { + "type": "string" + } + }, + { + "name": "type", + "in": "query", + "description": "If true only the type will be returned for the file path instead of the contents", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A page of contents from a file.", + "content": { + "application/json": {} + } + }, + "400": { + "description": "The path parameter was not supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/browse/{path}": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get file content", + "description": "Retrieve a page of content for a file path at a specified revision. \n\nResponses from this endpoint vary widely depending on the query parameters. The example JSON is for a request that does not use size, type, blame or noContent. \n\n1. size will return a response like {\"size\":10000}\n2. type will return a response like {\"type\":\"FILE\"}, where possible values are \"DIRECTORY\", \"FILE\" and \"SUBMODULE\"\n3. blame without noContent will include blame for the lines of content returned on the page\n4. blame with noContent will omit file contents and only return blame for the requested lines\n5. noContent without blame is ignored and does nothing\n\n\nThe various parameters are \"processed\" in the above order. That means ?size=true&type=truewill return a size response, not a type one; the type parameter will be ignored. \n\nThe blame and noContent query parameters are handled differently from size and type. For blame and noContent, the presence of the parameter implies \"true\" if no value is specified; size and and type both require an explicit=true or they're treated as \"false\". \n\n- ?blame is the same as ?blame=true\n- ?blame&noContent is the same as ?blame=true&noContent=true\n- ?size is the same as ?size=false\n- ?type is the same as ?type=false\n\n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "getContent_1", + "parameters": [ + { + "name": "noContent", + "in": "query", + "description": "If blame&noContent only the blame is retrieved instead of the contents", + "schema": { + "type": "string" + } + }, + { + "name": "path", + "in": "path", + "description": "The file path to retrieve content from", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "at", + "in": "query", + "description": "The commit ID or ref to retrieve the content for", + "schema": { + "type": "string" + } + }, + { + "name": "size", + "in": "query", + "description": "If true only the size will be returned for the file path instead of the contents", + "schema": { + "type": "string" + } + }, + { + "name": "blame", + "in": "query", + "description": "If present and not equal to 'false', the blame will be returned for the file as well", + "schema": { + "type": "string" + } + }, + { + "name": "type", + "in": "query", + "description": "If true only the type will be returned for the file path instead of the contents", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A page of contents from a file.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "lines": { + "type": "array", + "items": { + "type": "object", + "properties": { + "text": { + "type": "string" + } + } + } + }, + "isLastPage": { + "type": "boolean" + }, + "nextPageStart": { + "type": "number" + } + } + } + } + } + }, + "400": { + "description": "The path or until parameters were not supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Repository" + ], + "summary": "Edit file", + "description": "Update the content of path, on the given repository and branch. \n\nThis resource accepts PUT multipart form data, containing the file in a form-field named content. \n\nAn example curl request to update 'README.md' would be:\n\n```curl -X PUT -u username:password -F content=@README.md -F 'message=Updated using file-edit REST API' -F branch=master -F sourceCommitId=5636641a50b http://example.com/rest/api/latest/projects/PROJECT_1/repos/repo_1/browse/README.md ```\n\n- branch: the branch on which the path should be modified or created\n- content: the full content of the file at path \n- message: the message associated with this change, to be used as the commit message. Or null if the default message should be used.\n- sourceCommitId: the commit ID of the file before it was edited, used to identify if content has changed. Or null if this is a new file\n\n\nThe file can be updated or created on a new branch. In this case, the sourceBranch parameter should be provided to identify the starting point for the new branch and the branch parameter identifies the branch to create the new commit on.", + "operationId": "editFile", + "parameters": [ + { + "name": "path", + "in": "path", + "description": "The path of the file that is to be modified or created", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The multipart form data containing the file", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ExampleMultipartFormData" + } + } + } + }, + "responses": { + "200": { + "description": "The newly created commit.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestCommit" + } + } + } + }, + "400": { + "description": "There are validation errors, e.g. The branch or content parameters were not supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user does not have write permission for the given repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The request was authenticated using a project or repository access token, which does not have a valid user associated with it", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The file already exists when trying to create a file, or the given content does not modify the file, or the file has changed since the given sourceCommitId, or the repository is archived.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/changes": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get changes made in commit", + "description": "Retrieve a page of changes made in a specified commit. \n\nNote: The implementation will apply a hard cap ({@code page.max.changes}) and it is not possible to request subsequent content when that cap is exceeded. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "getChanges_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "until", + "in": "query", + "description": "The commit to retrieve changes for", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "since", + "in": "query", + "description": "The commit to which until should be compared to produce a page of changes. If not specified the commit's first parent is assumed (if one exists)", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of changes", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestChange" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The until parameter was not supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository or the since or until parameters supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get commits", + "description": "Retrieve a page of commits from a given starting commit or \"between\" two commits. If no explicit commit is specified, the tip of the repository's default branch is assumed. commits may be identified by branch or tag name or by ID. A path may be supplied to restrict the returned commits to only those which affect that path. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "getCommits", + "parameters": [ + { + "name": "avatarScheme", + "in": "query", + "description": "The desired scheme for the avatar URL. If the parameter is not present URLs will use the same scheme as this request", + "schema": { + "type": "string" + } + }, + { + "name": "path", + "in": "query", + "description": "An optional path to filter commits by", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "withCounts", + "in": "query", + "description": "Optionally include the total number of commits and total number of unique authors", + "schema": { + "type": "string" + } + }, + { + "name": "followRenames", + "in": "query", + "description": "If true, the commit history of the specified file will be followed past renames. Only valid for a path to a single file.", + "schema": { + "type": "string" + } + }, + { + "name": "until", + "in": "query", + "description": "The commit ID (SHA1) or ref (inclusively) to retrieve commits before", + "schema": { + "type": "string" + } + }, + { + "name": "avatarSize", + "in": "query", + "description": "If present the service adds avatar URLs for commit authors. Should be an integer specifying the desired size in pixels. If the parameter is not present, avatar URLs will not be set", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "since", + "in": "query", + "description": "The commit ID or ref (exclusively) to retrieve commits after", + "schema": { + "type": "string" + } + }, + { + "name": "merges", + "in": "query", + "description": "If present, controls how merge commits should be filtered. Can be either exclude, to exclude merge commits, include, to include both merge commits and non-merge commits or only, to only return merge commits.", + "schema": { + "type": "string" + } + }, + { + "name": "ignoreMissing", + "in": "query", + "description": "true to ignore missing commits, false otherwise", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of commits", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestCommit" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "One of the supplied commit IDs or refs was invalid.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get commit by ID", + "description": "Retrieve a single commit identified by its ID. In general, that ID is a SHA1. From 2.11, ref names like \"refs/heads/master\" are no longer accepted by this resource.\n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "getCommit", + "parameters": [ + { + "name": "path", + "in": "query", + "description": "An optional path to filter the commit by. If supplied the details returned may not be for the specified commit. Instead, starting from the specified commit, they will be the details for the first commit affecting the specified path.", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit ID to retrieve", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A commit", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestCommit" + } + } + } + }, + "400": { + "description": "The supplied commit ID was invalid", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/builds": { + "get": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Get a specific build status", + "description": "Get a specific build status.\n\n\nThe authenticated user must have **REPO_READ** permission for the provided repository.The request can also be made with anonymous 2-legged OAuth.
Since 7.14", + "operationId": "get", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "key", + "in": "query", + "description": "the key of the build status", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The build status associated with the provided commit and key", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestBuildStatus" + } + } + } + }, + "400": { + "description": "The request has failed validation", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions this repository", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository, commit or build status does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Store a build status", + "description": "Store a build status.\n\n\nThe authenticated user must have **REPO_READ** permission for the repository that this build status is for. The request can also be made with anonymous 2-legged OAuth.", + "operationId": "add", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The contents of the build status request are:\nThese fields are **required**:\n\n\n- **key**: The string referring to this branch plan/job\n- **state**: The build status state, one of: \"SUCCESSFUL\", \"FAILED\", \"INPROGRESS\", \"CANCELLED\", \"UNKNOWN\"\n- **url**: URL referring to the build result page in the CI tool.\n\n\nThese fields are optional:\n\n\n- **buildNumber** (optional): A unique identifier for this particular run of a plan<\n- **dateAdded** (optional): milliseconds since epoch. If not provided current date is used.\n- **description** (optional): Describes the build result\n- **duration** (optional): Duration of a completed build in milliseconds.\n- **name** (optional): A short string that describes the build plan\n- **parent** (optional): The identifier for the plan or job that ran the branch plan that produced this build status.\n- **ref** (optional): The fully qualified git reference e.g. refs/heads/master.\n- **testResults** (optional): A summary of the passed, failed and skipped tests.\n", + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestBuildStatusSetRequest" + } + } + } + }, + "responses": { + "204": { + "description": "The build status was posted" + }, + "400": { + "description": "The build status was not added as the request was invalid. This could be because of a number of things:\n\n\n- an invalid commit hash was provided\n- build key was blank or longer than 255 characters\n- invalid branch was provided\n- invalid state was provided\n- build status url was blank or longer than 450 characters\n\nThe specifics will be included in the error message.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to push a build status to this repository", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Builds and Deployments" + ], + "summary": "Delete a specific build status", + "description": "Delete a specific build status. \n\nThe authenticated user must have **REPO_ADMIN** permission for the provided repository.", + "operationId": "delete", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "key", + "in": "query", + "description": "the key of the build status", + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The build status associated with the provided commit and key has been deleted" + }, + "400": { + "description": "The request has failed validation", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions this repository", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/changes": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get changes in commit", + "description": "Retrieve a page of changes made in a specified commit. \n\n Note: The implementation will apply a hard cap (page.max.changes) and it is not possible to request subsequent content when that cap is exceeded. \n\n The authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "getChanges", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The commit to retrieve changes for", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "withComments", + "in": "query", + "description": "true to apply comment counts in the changes (the default); otherwise, false to stream changes without comment counts", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "since", + "in": "query", + "description": "The commit to which until should be compared to produce a page of changes. If not specified the commit's first parent is assumed (if one exists)", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of changes", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestChange" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The until parameter was not supplied", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository or the since or until parameters supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Search for commit comments", + "description": "Retrieves the commit discussion comments that match the specified search criteria.\n\nIt is possible to retrieve commit discussion comments that are anchored to a range of commits by providing the sinceId that the comments anchored from.\n\nThe authenticated user must have REPO_READ permission for the repository that the commit is in to call this resource.", + "operationId": "getComments", + "parameters": [ + { + "name": "path", + "in": "query", + "description": "The path to the file on which comments were made", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commitId", + "in": "path", + "description": "The full ID of the commit within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "since", + "in": "query", + "description": "For a merge commit, a parent can be provided to specify which diff the comments are on. For a commit range, a sinceId can be provided to specify where the comments are anchored from.", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of comments that match the search criteria", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestComment" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the comment", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied project, repository, or commit. The missing entity will be specified in the error details.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Repository" + ], + "summary": "Add a new commit comment", + "description": "Add a new comment.\n\nComments can be added in a few places by setting different attributes:\n\nGeneral commit comment:\n\n```{\n \"text\": \"An insightful general comment on a commit.\"\n}\n\n\nReply to a comment:\n
{\n      \"text\": \"A measured reply.\",\n      \"parent\": {\n          \"id\": 1\n      }\n}\n
\nGeneral file comment:\n
{\n      \"text\": \"An insightful general comment on a file.\",\n      \"anchor\": {\n          \"diffType\": \"COMMIT\",\n          \"fromHash\": \"6df3858eeb9a53a911cd17e66a9174d44ffb02cd\",\n          \"path\": \"path/to/file\",\n          \"srcPath\": \"path/to/file\",\n          \"toHash\": \"04c7c5c931b9418ca7b66f51fe934d0bd9b2ba4b\"\n      }\n}\n
\nFile line comment:\n
{\n      \"text\": \"A pithy comment on a particular line within a file.\",\n      \"anchor\": {\n          \"diffType\": \"COMMIT\",\n          \"line\": 1,\n          \"lineType\": \"CONTEXT\",\n          \"fileType\": \"FROM\",\n          \"fromHash\": \"6df3858eeb9a53a911cd17e66a9174d44ffb02cd\",\n          \"path\": \"path/to/file\",\n          \"srcPath\": \"path/to/file\",\n          \"toHash\": \"04c7c5c931b9418ca7b66f51fe934d0bd9b2ba4b\"\n      }\n}\n```\n\nNote: general file comments are an experimental feature and may change in the near future!\n\nFor file and line comments, 'path' refers to the path of the file to which the comment should be applied and 'srcPath' refers to the path the that file used to have (only required for copies and moves). Also, fromHash and toHash refer to the sinceId / untilId (respectively) used to produce the diff on which the comment was added. Finally diffType refers to the type of diff the comment was added on.\n\nFor line comments, 'line' refers to the line in the diff that the comment should apply to. 'lineType' refers to the type of diff hunk, which can be:- 'ADDED' - for an added line;- 'REMOVED' - for a removed line; or- 'CONTEXT' - for a line that was unmodified but is in the vicinity of the diff.'fileType' refers to the file of the diff to which the anchor should be attached - which is of relevance when displaying the diff in a side-by-side way. Currently the supported values are:- 'FROM' - the source file of the diff- 'TO' - the destination file of the diffIf the current user is not a participant the user is added as one and updated to watch the commit.\n\nThe authenticated user must have REPO_READ permission for the repository that the commit is in to call this resource.",
+        "operationId": "createComment",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commitId",
+            "in": "path",
+            "description": "The full ID of the commit within the repository",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "since",
+            "in": "query",
+            "description": "For a merge commit, a parent can be provided to specify which diff the comments should be on. For a commit range, a sinceId can be provided to specify where the comments should be anchored from.",
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "requestBody": {
+          "description": "the comment",
+          "content": {
+            "application/json": {
+              "schema": {
+                "$ref": "#/components/schemas/RestComment"
+              }
+            }
+          }
+        },
+        "responses": {
+          "201": {
+            "description": "The newly created comment.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/RestComment"
+                }
+              }
+            }
+          },
+          "400": {
+            "description": "The comment was not created due to a validation error.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the commit, create a comment or watch the commit.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Unable to find the supplied project, repository, commit or parent comment. The missing entity will be specified in the error details.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "409": {
+            "description": "Adding, deleting, or editing comments isn't supported on archived repositories.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Get a commit comment",
+        "description": "Retrieves a commit discussion comment.\n\nThe authenticated user must have REPO_READ permission for the repository that the commit is in to call this resource.",
+        "operationId": "getComment",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commentId",
+            "in": "path",
+            "description": "The ID of the comment to retrieve",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commitId",
+            "in": "path",
+            "description": "The full ID of the commit within the repository",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "The requested comment.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/RestComment"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the comment",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Unable to find the supplied project, repository, commit or comment. The missing entity will be specified in the error details.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      },
+      "put": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Update a commit comment",
+        "description": "Update a comment, with the following restrictions:\n\n- only the author of the comment may update the text of the comment\n- only the author of the comment or repository admins and above may update the other   fields of a comment\n\n\nNote: the supplied supplied JSON object must contain a version that must match the server's version of the comment or the update will fail. To determine the current version of the comment, the comment should be fetched from the server prior to the update. Look for the 'version' attribute in the returned JSON structure.\n\nThe authenticated user must have REPO_READ permission for the repository that the commit is in to call this resource.",
+        "operationId": "updateComment",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commentId",
+            "in": "path",
+            "description": "The ID of the comment to retrieve",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commitId",
+            "in": "path",
+            "description": "The full ID of the commit within the repository",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "requestBody": {
+          "description": "The comment to update",
+          "content": {
+            "application/json": {
+              "schema": {
+                "$ref": "#/components/schemas/RestComment"
+              }
+            }
+          }
+        },
+        "responses": {
+          "200": {
+            "description": "The newly updated comment.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/RestComment"
+                }
+              }
+            }
+          },
+          "400": {
+            "description": "The comment was not updated due to a validation error.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the commit, update the comment or watch the commit.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Unable to find the supplied project, repository, commit or comment. The missing entity will be specified in the error details.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "409": {
+            "description": "The comment version supplied does not match the current version or the repository is archived.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      },
+      "delete": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Delete a commit comment",
+        "description": "Delete a commit comment. Anyone can delete their own comment. Only users with REPO_ADMIN and above may delete comments created by other users. Comments which have replies may not be deleted, regardless of the user's granted permissions.\n\nThe authenticated user must have REPO_READ permission for the repository that the commit is in to call this resource.",
+        "operationId": "deleteComment",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commentId",
+            "in": "path",
+            "description": "the comment",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commitId",
+            "in": "path",
+            "description": "The full ID of the commit within the repository",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "version",
+            "in": "query",
+            "description": "The expected version of the comment. This must match the server's version of the comment or the delete will fail. To determine the current version of the comment, the comment should be fetched from the server prior to the delete. Look for the 'version' attribute in the returned JSON structure.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "204": {
+            "description": "The operation was successful"
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to delete the comment.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Unable to find the supplied project, repository or commit. The missing entity will be specified in the error details.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "409": {
+            "description": "The comment has replies, the version supplied does not match the comment's current version or the repository is archived.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/deployments": {
+      "get": {
+        "tags": [
+          "Builds and Deployments"
+        ],
+        "summary": "Get a deployment",
+        "description": "Get the deployment matching the specified Repository, key, environmentKey and deploymentSequenceNumber. \n\nThe user must have REPO_READ.",
+        "operationId": "get_1",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "deploymentSequenceNumber",
+            "in": "query",
+            "description": "the sequence number of the deployment, as detailed by the query param",
+            "schema": {
+              "type": "string"
+            },
+            "example": "deploymentSequenceNumber"
+          },
+          {
+            "name": "commitId",
+            "in": "path",
+            "description": "the commitId that was deployed as indicated by the query parameter",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "key",
+            "in": "query",
+            "description": "the key of the deployment, as detailed by the query parameter",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "environmentKey",
+            "in": "query",
+            "description": "the key of the environment, as detailed by the query parameter",
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "The deployment",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/RestDeployment"
+                }
+              }
+            }
+          },
+          "400": {
+            "description": "could not get the deployment because the request was invalid",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the repository",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The specified repository or deployment does not exist",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      },
+      "post": {
+        "tags": [
+          "Builds and Deployments"
+        ],
+        "summary": "Create or update a deployment",
+        "description": "Create or update a deployment. \n\n The authenticated user must have REPO_READ permission for the repository.",
+        "operationId": "createOrUpdateDeployment",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commitId",
+            "in": "path",
+            "description": "the commitId that was deployed as indicated by the path",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "requestBody": {
+          "description": "the details of the deployment to create, as detailed by the request body",
+          "content": {
+            "*/*": {
+              "schema": {
+                "$ref": "#/components/schemas/RestDeploymentSetRequest"
+              }
+            }
+          }
+        },
+        "responses": {
+          "200": {
+            "description": "The deployment was created",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/RestDeployment"
+                }
+              }
+            }
+          },
+          "400": {
+            "description": "the deployment was not created because the request was invalid",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the repository",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The specified repository does not exist",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      },
+      "delete": {
+        "tags": [
+          "Builds and Deployments"
+        ],
+        "summary": "Delete a deployment",
+        "description": "Delete the deployment matching the specified Repository, key, environmentKey and deploymentSequenceNumber. \n\nThe user must have REPO_ADMIN.",
+        "operationId": "delete_1",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "deploymentSequenceNumber",
+            "in": "query",
+            "description": "the sequence number of the deployment, as detailed by the query parameter",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commitId",
+            "in": "path",
+            "description": "the commitId that was deployed as indicated by the path",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "key",
+            "in": "query",
+            "description": "the key of the deployment, as detailed by the query parameter",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "environmentKey",
+            "in": "query",
+            "description": "the key of the environment, as detailed by the query parameter",
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "204": {
+            "description": "the request has been processed"
+          },
+          "400": {
+            "description": "the deployment was not deleted because the request was invalid",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to delete a deployment",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The specified repository does not exist",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/diff/{path}": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Get diff between revisions",
+        "description": "Retrieve the diff between two provided revisions.\n\nTo stream a raw text representation of the diff, this endpoint can be called with the request header 'Accept: text/plain'. \n\nNote: This resource is currently not paged. The server will internally apply a hard cap to the streamed lines, and it is not possible to request subsequent pages if that cap is exceeded. In the event that the cap is reached, the diff will be cut short and one or more {@code truncated} flags will be set to true on the \"segments\", \"hunks\" and \"diffs\" properties, as well as the top-level object, in the returned JSON response.\n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.",
+        "operationId": "streamDiff",
+        "parameters": [
+          {
+            "name": "srcPath",
+            "in": "query",
+            "description": "The source path for the file, if it was copied, moved or renamed",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commitId",
+            "in": "path",
+            "description": "The full ID of the commit within the repository",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "avatarSize",
+            "in": "query",
+            "description": "If present the service adds avatar URLs for comment authors where the provided value specifies the desired avatar size in pixels. Not applicable if streaming raw diff",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "filter",
+            "in": "query",
+            "description": "Text used to filter files and lines (optional). Not applicable if streaming raw diff",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "avatarScheme",
+            "in": "query",
+            "description": "The security scheme for avatar URLs. If the scheme is not present then it is inherited from the request. It can be set to \"https\" to force the use of secure URLs. Not applicable if streaming raw diff",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "path",
+            "in": "path",
+            "description": "The path to the file which should be diffed (optional)",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "contextLines",
+            "in": "query",
+            "description": "The number of context lines to include around added/removed lines in the diff.Not applicable if streaming raw diff",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "autoSrcPath",
+            "in": "query",
+            "description": "true to automatically try to find the source path when it's not provided, false otherwise. Requires the path to be provided.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "whitespace",
+            "in": "query",
+            "description": "Optional whitespace flag which can be set to ignore-all",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "withComments",
+            "in": "query",
+            "description": "true to embed comments in the diff (the default); otherwise false to stream the diff without comments. Not applicable if streaming raw diff",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "since",
+            "in": "query",
+            "description": "The base revision to diff from. If omitted the parent revision of the until revision is used",
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "A diff between two revisions.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/RestDiff"
+                }
+              }
+            }
+          },
+          "400": {
+            "description": "The until parameter was not supplied.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The repository does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/merge-base": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Get the common ancestor between two commits",
+        "description": "Returns the best common ancestor between two commits.\n\nIf more than one best common ancestor exists, only one will be returned. It is unspecified which will be returned.",
+        "operationId": "getMergeBase",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commitId",
+            "in": "path",
+            "description": "The full ID of the commit within the repository",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "otherCommitId",
+            "in": "query",
+            "description": "The other commit id to calculate the merge-base on",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "The common ancestor of the two given commits",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/RestCommit"
+                }
+              }
+            }
+          },
+          "204": {
+            "description": "No common parent between the two commits exist"
+          },
+          "400": {
+            "description": "The supplied commit ID(s) was/were invalid",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The project, repository, or commit(s) does not exist",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/pull-requests": {
+      "get": {
+        "tags": [
+          "Pull Requests"
+        ],
+        "summary": "Get repository pull requests containing commit",
+        "description": "Retrieve a page of pull requests in the current repository that contain the given commit.\n\nThe user must be authenticated and have access to the specified repository to call this resource.",
+        "operationId": "getPullRequests",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commitId",
+            "in": "path",
+            "description": "the commit ID",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "start",
+            "in": "query",
+            "description": "Start number for the page (inclusive). If not passed, first page is assumed.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 0
+            },
+            "example": 0
+          },
+          {
+            "name": "limit",
+            "in": "query",
+            "description": "Number of items to return. If not passed, a page size of 25 is used.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 25
+            },
+            "example": 25
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Return a page of pull requests in the current repository containing the given commit.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "values": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestPullRequest"
+                      }
+                    },
+                    "size": {
+                      "type": "number",
+                      "example": 1
+                    },
+                    "limit": {
+                      "type": "number",
+                      "example": 25
+                    },
+                    "nextPageStart": {
+                      "type": "integer",
+                      "format": "int32"
+                    },
+                    "isLastPage": {
+                      "type": "boolean"
+                    },
+                    "start": {
+                      "type": "integer",
+                      "format": "int32"
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to see the request repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The request repository does not exist",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/watch": {
+      "post": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Watch commit",
+        "description": "Add the authenticated user as a watcher for the specified commit.\n\nThe authenticated user must have REPO_READ permission for the repository containing the commit to call this resource.",
+        "operationId": "watch",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commitId",
+            "in": "path",
+            "description": "The full ID of the commit within the repository",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "204": {
+            "description": "The user is now watching the commit."
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the pull request",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The specified project, repository or commit does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      },
+      "delete": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Stop watching commit",
+        "description": "Remove the authenticated user as a watcher for the specified commit.\n\nThe authenticated user must have REPO_READ permission for the repository containing the commit to call this resource.",
+        "operationId": "unwatch",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "commitId",
+            "in": "path",
+            "description": "The full ID of the commit within the repository",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "204": {
+            "description": "The user is no longer watching the commit."
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the pull request.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The specified project, repository or commit does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/compare/changes": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Compare commits",
+        "description": "Gets the file changes available in the  from commit but not in the  to commit.\n\n\nIf either the  from or  to commit are not specified, they will be replaced by the default branch of their containing repository.",
+        "operationId": "streamChanges",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "fromRepo",
+            "in": "query",
+            "description": "an optional parameter specifying the source repository containing the source commit if that commit is not present in the current repository; the repository can be specified by either its ID fromRepo=42 or by its project key plus its repo slug separated by a slash: fromRepo=projectKey/repoSlug",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "from",
+            "in": "query",
+            "description": "the source commit (can be a partial/full commit ID or qualified/unqualified ref name)",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "to",
+            "in": "query",
+            "description": "the target commit (can be a partial/full commit ID or qualified/unqualified ref name)",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "start",
+            "in": "query",
+            "description": "Start number for the page (inclusive). If not passed, first page is assumed.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 0
+            },
+            "example": 0
+          },
+          {
+            "name": "limit",
+            "in": "query",
+            "description": "Number of items to return. If not passed, a page size of 25 is used.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 25
+            },
+            "example": 25
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "A page of changes.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "values": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestChange"
+                      }
+                    },
+                    "size": {
+                      "type": "number",
+                      "example": 1
+                    },
+                    "limit": {
+                      "type": "number",
+                      "example": 25
+                    },
+                    "nextPageStart": {
+                      "type": "integer",
+                      "format": "int32"
+                    },
+                    "isLastPage": {
+                      "type": "boolean"
+                    },
+                    "start": {
+                      "type": "integer",
+                      "format": "int32"
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The source repository,target repository, or commit does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/compare/commits": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Get accessible commits",
+        "description": "Gets the commits accessible from the from commit but not in the to commit.\n\nIf either the from or to commit are not specified, they will be replaced by the default branch of their containing repository.",
+        "operationId": "streamCommits",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "fromRepo",
+            "in": "query",
+            "description": "an optional parameter specifying the source repository containing the source commit if that commit is not present in the current repository; the repository can be specified by either its ID fromRepo=42 or by its project key plus its repo slug separated by a slash: fromRepo=projectKey/repoSlug",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "from",
+            "in": "query",
+            "description": "the source commit (can be a partial/full commit ID or qualified/unqualified ref name)",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "to",
+            "in": "query",
+            "description": "the target commit (can be a partial/full commit ID or qualified/unqualified ref name)",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "start",
+            "in": "query",
+            "description": "Start number for the page (inclusive). If not passed, first page is assumed.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 0
+            },
+            "example": 0
+          },
+          {
+            "name": "limit",
+            "in": "query",
+            "description": "Number of items to return. If not passed, a page size of 25 is used.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 25
+            },
+            "example": 25
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "A page of commits.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "values": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestCommit"
+                      }
+                    },
+                    "size": {
+                      "type": "number",
+                      "example": 1
+                    },
+                    "limit": {
+                      "type": "number",
+                      "example": 25
+                    },
+                    "nextPageStart": {
+                      "type": "integer",
+                      "format": "int32"
+                    },
+                    "isLastPage": {
+                      "type": "boolean"
+                    },
+                    "start": {
+                      "type": "integer",
+                      "format": "int32"
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The source repository,target repository, or commit does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/compare/diff{path}": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Get diff between commits",
+        "description": "Gets a diff of the changes available in the from commit but not in the  to commit.\n\nIf either the  from or  to commit are not specified, they will be replaced by the default branch of their containing repository.",
+        "operationId": "streamDiff_1",
+        "parameters": [
+          {
+            "name": "path",
+            "in": "path",
+            "description": "the path to the file to diff (optional)",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "contextLines",
+            "in": "query",
+            "description": "an optional number of context lines to include around each added or removed lines in the diff",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "fromRepo",
+            "in": "query",
+            "description": "an optional parameter specifying the source repository containing the source commit if that commit is not present in the current repository; the repository can be specified by either its ID fromRepo=42 or by its project key plus its repo slug separated by a slash: fromRepo=projectKey/repoSlug",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "srcPath",
+            "in": "query",
+            "description": "source path",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "from",
+            "in": "query",
+            "description": "the source commit (can be a partial/full commit ID or qualified/unqualified ref name)",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "to",
+            "in": "query",
+            "description": "the target commit (can be a partial/full commit ID or qualified/unqualified ref name)",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "whitespace",
+            "in": "query",
+            "description": "an optional whitespace flag which can be set to ignore-all",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "start",
+            "in": "query",
+            "description": "Start number for the page (inclusive). If not passed, first page is assumed.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 0
+            },
+            "example": 0
+          },
+          {
+            "name": "limit",
+            "in": "query",
+            "description": "Number of items to return. If not passed, a page size of 25 is used.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 25
+            },
+            "example": 25
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "The diff of the changes.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "values": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestDiff"
+                      }
+                    },
+                    "size": {
+                      "type": "number",
+                      "example": 1
+                    },
+                    "limit": {
+                      "type": "number",
+                      "example": 25
+                    },
+                    "nextPageStart": {
+                      "type": "integer",
+                      "format": "int32"
+                    },
+                    "isLastPage": {
+                      "type": "boolean"
+                    },
+                    "start": {
+                      "type": "integer",
+                      "format": "int32"
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The source repository,target repository, or commit does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/contributing": {
+      "get": {
+        "tags": [
+          "Project"
+        ],
+        "summary": "Get repository contributing guidelines",
+        "description": "Retrieves the contributing guidelines for the repository, if they've been defined. \n\nThis checks the repository for a CONTRIBUTING file, optionally with an md or txt extension, and, if found, streams it. By default, the raw content of the file is streamed. Appending ?markup to the URL will stream an HTML-rendered version instead. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.",
+        "operationId": "streamContributing",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "at",
+            "in": "query",
+            "description": "A specific commit or ref to retrieve the guidelines at, or the default branch if not specified",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "markup",
+            "in": "query",
+            "description": "If present or \"true\", triggers the raw content to be markup-rendered and returned as HTML; otherwise, if not specified, or any value other than \"true\", the content is streamed without markup",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "htmlEscape",
+            "in": "query",
+            "description": "(Optional) true if HTML should be escaped in the input markup, false otherwise. If not specified, the value of the markup.render.html.escape property, which is true by default, will be used",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "includeHeadingId",
+            "in": "query",
+            "description": "(Optional) true if headings should contain an ID based on the heading content. If not specified, the value of the markup.render.headerids property, which is false by default, will be used",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "hardwrap",
+            "in": "query",
+            "description": "(Optional) Whether the markup implementation should convert newlines to breaks. If not specified, the value of the markup.render.hardwrap property, which is true by default, will be used",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "The contributing guidelines for the repository.",
+            "content": {
+              "application/json": {}
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to read the repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The specified repository does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/default-branch": {
+      "get": {
+        "tags": [
+          "Project"
+        ],
+        "summary": "Get repository default branch",
+        "description": "Retrieves the repository's configured default branch. \n\nEvery repository has a configured default branch, but that branch may not actually exist in the repository. For example, a newly-created repository will have a configured default branch even though no branches have been pushed yet. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.",
+        "operationId": "getDefaultBranch_2",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "The configured default branch for the repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/RestMinimalRef"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to read the repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The specified repository does not exist, or its configured default branch does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      },
+      "put": {
+        "tags": [
+          "Project"
+        ],
+        "summary": "Update default branch for repository",
+        "description": "Update the default branch of a repository. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.",
+        "operationId": "setDefaultBranch_2",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "requestBody": {
+          "description": "The branch to set as default",
+          "content": {
+            "application/json": {
+              "schema": {
+                "$ref": "#/components/schemas/RestBranch"
+              }
+            }
+          }
+        },
+        "responses": {
+          "204": {
+            "description": "The default branch was updated."
+          },
+          "401": {
+            "description": "The authenticated user does not have permission to modify the default branch.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The specified repository does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/diff": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Get raw diff for path",
+        "description": "Stream the raw diff between two provided revisions. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.",
+        "operationId": "streamRawDiff",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "contextLines",
+            "in": "query",
+            "description": "The number of context lines to include around added/removed lines in the diff",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "srcPath",
+            "in": "query",
+            "description": "The source path for the file, if it was copied, moved or renamed",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "until",
+            "in": "query",
+            "description": "The target revision to diff to (required)",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "whitespace",
+            "in": "query",
+            "description": "Optional whitespace flag which can be set to ignore-all",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "since",
+            "in": "query",
+            "description": "The base revision to diff from. If omitted the parent revision of the until revision is used",
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "A raw diff between two revisions.",
+            "content": {
+              "application/json": {}
+            }
+          },
+          "400": {
+            "description": "The path parameter was not supplied.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The repository does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/diff/{path}": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Get raw diff for path",
+        "description": "Stream the raw diff between two provided revisions. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.",
+        "operationId": "streamRawDiff_1",
+        "parameters": [
+          {
+            "name": "path",
+            "in": "path",
+            "description": "The path to the file which should be diffed (required)",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "contextLines",
+            "in": "query",
+            "description": "The number of context lines to include around added/removed lines in the diff",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "srcPath",
+            "in": "query",
+            "description": "The source path for the file, if it was copied, moved or renamed",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "until",
+            "in": "query",
+            "description": "The target revision to diff to (required)",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "whitespace",
+            "in": "query",
+            "description": "Optional whitespace flag which can be set to ignore-all",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "since",
+            "in": "query",
+            "description": "The base revision to diff from. If omitted the parent revision of the until revision is used",
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "A raw diff between two revisions.",
+            "content": {
+              "application/json": {}
+            }
+          },
+          "400": {
+            "description": "The until parameter was not supplied.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The repository does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/files": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Get files in directory",
+        "description": "Retrieve a page of files from particular directory of a repository. The search is done recursively, so all files from any sub-directory of the specified directory will be returned. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.",
+        "operationId": "streamFiles",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "at",
+            "in": "query",
+            "description": "The commit ID or ref (e.g. a branch or tag) to list the files at. If not specified the default branch will be used instead.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "start",
+            "in": "query",
+            "description": "Start number for the page (inclusive). If not passed, first page is assumed.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 0
+            },
+            "example": 0
+          },
+          {
+            "name": "limit",
+            "in": "query",
+            "description": "Number of items to return. If not passed, a page size of 25 is used.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 25
+            },
+            "example": 25
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "A page of files.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "values": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/FileListResource"
+                      }
+                    },
+                    "size": {
+                      "type": "number",
+                      "example": 1
+                    },
+                    "limit": {
+                      "type": "number",
+                      "example": 25
+                    },
+                    "nextPageStart": {
+                      "type": "integer",
+                      "format": "int32"
+                    },
+                    "isLastPage": {
+                      "type": "boolean"
+                    },
+                    "start": {
+                      "type": "integer",
+                      "format": "int32"
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "400": {
+            "description": "The path parameter was not supplied.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The path requested does not exist at the supplied commit.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/files/{path}": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Get files in directory",
+        "description": "Retrieve a page of files from particular directory of a repository. The search is done recursively, so all files from any sub-directory of the specified directory will be returned. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.",
+        "operationId": "streamFiles_1",
+        "parameters": [
+          {
+            "name": "path",
+            "in": "path",
+            "description": "The directory to list files for.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "at",
+            "in": "query",
+            "description": "The commit ID or ref (e.g. a branch or tag) to list the files at. If not specified the default branch will be used instead.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "start",
+            "in": "query",
+            "description": "Start number for the page (inclusive). If not passed, first page is assumed.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 0
+            },
+            "example": 0
+          },
+          {
+            "name": "limit",
+            "in": "query",
+            "description": "Number of items to return. If not passed, a page size of 25 is used.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 25
+            },
+            "example": 25
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "A page of files.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "values": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/FileListResource"
+                      }
+                    },
+                    "size": {
+                      "type": "number",
+                      "example": 1
+                    },
+                    "limit": {
+                      "type": "number",
+                      "example": 25
+                    },
+                    "nextPageStart": {
+                      "type": "integer",
+                      "format": "int32"
+                    },
+                    "isLastPage": {
+                      "type": "boolean"
+                    },
+                    "start": {
+                      "type": "integer",
+                      "format": "int32"
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "400": {
+            "description": "The path requested is not a directory at the supplied commit.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The path requested does not exist at the supplied commit.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/forks": {
+      "get": {
+        "tags": [
+          "Project"
+        ],
+        "summary": "Get repository forks",
+        "description": "Retrieve repositories which have been forked from this one. Unlike #getRelatedRepositories(Repository, PageRequest) related repositories, this only looks at a given repository's direct forks. If those forks have themselves been the origin of more forks, such \"grandchildren\" repositories will not be retrieved. \n\nOnly repositories to which the authenticated user has REPO_READ permission will be included, even if other repositories have been forked from this one.",
+        "operationId": "getForkedRepositories",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "start",
+            "in": "query",
+            "description": "Start number for the page (inclusive). If not passed, first page is assumed.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 0
+            },
+            "example": 0
+          },
+          {
+            "name": "limit",
+            "in": "query",
+            "description": "Number of items to return. If not passed, a page size of 25 is used.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 25
+            },
+            "example": 25
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "A page of repositories related to the request repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "values": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestRepository"
+                      }
+                    },
+                    "size": {
+                      "type": "number",
+                      "example": 1
+                    },
+                    "limit": {
+                      "type": "number",
+                      "example": 25
+                    },
+                    "nextPageStart": {
+                      "type": "integer",
+                      "format": "int32"
+                    },
+                    "isLastPage": {
+                      "type": "boolean"
+                    },
+                    "start": {
+                      "type": "integer",
+                      "format": "int32"
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to see the request repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The request repository does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/hook-scripts": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Get hook scripts",
+        "description": "Return a page of hook scripts configured for the specified repository. \n\nThis endpoint requires **REPO_ADMIN** permission.",
+        "operationId": "getConfigurations_1",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "start",
+            "in": "query",
+            "description": "Start number for the page (inclusive). If not passed, first page is assumed.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 0
+            },
+            "example": 0
+          },
+          {
+            "name": "limit",
+            "in": "query",
+            "description": "Number of items to return. If not passed, a page size of 25 is used.",
+            "required": false,
+            "schema": {
+              "type": "number",
+              "example": 25
+            },
+            "example": 25
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "A page of hook scripts.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "values": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestHookScriptConfig"
+                      }
+                    },
+                    "size": {
+                      "type": "number",
+                      "example": 1
+                    },
+                    "limit": {
+                      "type": "number",
+                      "example": 25
+                    },
+                    "nextPageStart": {
+                      "type": "integer",
+                      "format": "int32"
+                    },
+                    "isLastPage": {
+                      "type": "boolean"
+                    },
+                    "start": {
+                      "type": "integer",
+                      "format": "int32"
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the specified repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The specified repository does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/hook-scripts/{scriptId}": {
+      "put": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Create/update a hook script",
+        "description": "Creates/updates the hook script configuration for the provided hook script and repository. \n\nThis endpoint requires **REPO_ADMIN** permission.",
+        "operationId": "setConfiguration_1",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "scriptId",
+            "in": "path",
+            "description": "The ID of the hook script",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "requestBody": {
+          "description": "The hook triggers for which the hook script should be run",
+          "content": {
+            "application/json": {
+              "schema": {
+                "$ref": "#/components/schemas/RestHookScriptTriggers"
+              }
+            }
+          }
+        },
+        "responses": {
+          "200": {
+            "description": "The updated hook script.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/RestHookScriptConfig"
+                }
+              }
+            }
+          },
+          "400": {
+            "description": "The hook script was not created/updated due to a validation error.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the specified repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The repository slug supplied does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      },
+      "delete": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Remove a hook script",
+        "description": "Removes the hook script from the set of hook scripts configured to run in the repository. \n\nThis endpoint requires **REPO_ADMIN** permission.",
+        "operationId": "removeConfiguration_1",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "scriptId",
+            "in": "path",
+            "description": "The ID of the hook script",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "204": {
+            "description": "The hook script was successfully deleted."
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the specified repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The repository slug or hook script ID supplied does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/labels": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Get repository labels",
+        "description": "Get all labels applied to the given repository. \n\nThe authenticated user must have REPO_READ permission for the specified repository.",
+        "operationId": "getAllLabelsForRepository",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "The applied label.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/RestLabel"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the labels.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The specified repository does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      },
+      "post": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Add repository label",
+        "description": "Applies a label to the repository. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository.",
+        "operationId": "addLabel",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "requestBody": {
+          "description": "The label to apply",
+          "content": {
+            "application/json": {
+              "schema": {
+                "$ref": "#/components/schemas/RestLabel"
+              }
+            }
+          }
+        },
+        "responses": {
+          "200": {
+            "description": "The applied label.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/RestLabel"
+                }
+              }
+            }
+          },
+          "400": {
+            "description": "A validation error prevented the label from being created or applied. Possible validation errors include: The name of the label contains uppercase characters, the name is smaller than 3 characters or longer than 50 characters, the label contains other characters than a-z 0-9 and - or the label is already applied to the given repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to apply a label.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The specified repository does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/labels/{labelName}": {
+      "delete": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Remove repository label",
+        "description": "Remove label that is applied to the given repository. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository.",
+        "operationId": "removeLabel",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "labelName",
+            "in": "path",
+            "description": "The label to remove",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "204": {
+            "description": "An empty response indicating that the label is no longer associated to the repository."
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to remove the label.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The specified repository does not exist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/last-modified": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Stream files",
+        "description": "Streams files from the repository's root with the last commit to modify each file. Commit modifications are traversed starting from the at commit or, if not specified, from the tip of the default branch.\n\nUnless the repository is public, the authenticated user must have REPO_READ access to call this resource.",
+        "operationId": "stream",
+        "parameters": [
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "at",
+            "in": "query",
+            "description": "The commit to use as the starting point when listing files and calculating modifications",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "A map of files to the last commit that modified them, and the latest commit to the repository (by nature, any commit to a repository modifies its root).",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ExampleFiles"
+                }
+              }
+            }
+          },
+          "400": {
+            "description": "No at commit was specified. When streaming modifications, an explicit starting commit must be supplied.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The repository does not exist or does not contain the at commit.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/last-modified/{path}": {
+      "get": {
+        "tags": [
+          "Repository"
+        ],
+        "summary": "Stream files with last modified commit in path",
+        "description": "Streams files in the requested path with the last commit to modify each file. Commit modifications are traversed starting from the at commit or, if not specified, from the tip of the default branch.\n\nUnless the repository is public, the authenticated user must have REPO_READ access to call this resource.",
+        "operationId": "stream_1",
+        "parameters": [
+          {
+            "name": "path",
+            "in": "path",
+            "description": "The path within the repository whose files should be streamed",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "projectKey",
+            "in": "path",
+            "description": "The project key",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "at",
+            "in": "query",
+            "description": "The commit to use as the starting point when listing files and calculating modifications",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repositorySlug",
+            "in": "path",
+            "description": "The repository slug",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "A map of files to the last commit that modified them, and the latest commit to update the requested path.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ExampleFiles"
+                }
+              }
+            }
+          },
+          "400": {
+            "description": "No at commit was specified. When streaming modifications, an explicit starting commit must be supplied.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "The currently authenticated user has insufficient permissions to view the repository.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "The repository does not exist or does not contain the at commit, or the at commit does not contain the requested path.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "object",
+                  "properties": {
+                    "errors": {
+                      "type": "array",
+                      "items": {
+                        "$ref": "#/components/schemas/RestErrorMessage"
+                      }
+                    }
+                  }
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/api/latest/projects/{projectKey}/repos/{repositorySlug}/license": {
+      "get": {
+        "tags": [
+          "Project"
+        ],
+        "summary": "Get repository license",
+        "description": "Retrieves the license for the repository, if it's been defined. \n\nThis checks the repository for a 
LICENSE
file, optionally with an
md
or
txt
extension, and, if found, streams it. By default, the raw content of the file is streamed. Appending
?markup
to the URL will stream an HTML-rendered version instead. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "streamLicense", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "at", + "in": "query", + "description": "A specific commit or ref to retrieve the guidelines at, or the default branch if not specified", + "schema": { + "type": "string" + } + }, + { + "name": "markup", + "in": "query", + "description": "If present or \"true\", triggers the raw content to be markup-rendered and returned as HTML; otherwise, if not specified, or any value other than \"true\", the content is streamed without markup", + "schema": { + "type": "string" + } + }, + { + "name": "htmlEscape", + "in": "query", + "description": "(Optional) true if HTML should be escaped in the input markup, false otherwise. If not specified, the value of the markup.render.html.escape property, which is true by default, will be used", + "schema": { + "type": "string" + } + }, + { + "name": "includeHeadingId", + "in": "query", + "description": "(Optional) true if headings should contain an ID based on the heading content. If not specified, the value of the markup.render.headerids property, which is false by default, will be used", + "schema": { + "type": "string" + } + }, + { + "name": "hardwrap", + "in": "query", + "description": "(Optional) Whether the markup implementation should convert newlines to breaks. If not specified, the value of the markup.render.hardwrap property, which is true by default, will be used", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The license for the repository.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to read the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/participants": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Search pull request participants", + "description": "Retrieve a page of participant users for all the pull requests to or from the specified repository. \n\nOptionally clients can specify following filters.", + "operationId": "search", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "(optional) Return only users, whose username, name or email address contain the filter value", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "role", + "in": "query", + "description": "(optional) The role associated with the pull request participant. This must be one of AUTHOR, REVIEWER, or PARTICIPANT", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "direction", + "in": "query", + "description": "(optional), Defaults to INCOMING) the direction relative to the specified repository. Either INCOMING or OUTGOING.", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of users that match the search criteria.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestApplicationUser" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/patch": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get patch content at revision", + "description": "Retrieve the patch content for a repository at a specified revision. \n\nCache headers are added to the response (only if full commit hashes are used, not in the case of short hashes). \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "streamPatch", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "until", + "in": "query", + "description": "The target revision from which to generate the patch (required)", + "schema": { + "type": "string" + } + }, + { + "name": "allAncestors", + "in": "query", + "description": "indicates whether or not to generate a patch which includes all the ancestors of the 'until' revision. If true, the value provided by 'since' is ignored.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "since", + "in": "query", + "description": "The base revision from which to generate the patch. This is only applicable when 'allAncestors' is false. If omitted the patch will represent one single commit, the 'until'.", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The patch contents from a repository.", + "content": { + "application/json": {} + } + }, + "400": { + "description": "The until parameter was not supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/permissions": { + "delete": { + "tags": [ + "Permission Management" + ], + "summary": "Revoke all repository permissions for users and groups", + "description": "Revoke all permissions for the specified repository for the given groups and users.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified repository or a higher global permission to call this resource.\n\nIn addition, a user may not revoke a group's permission if their own permission would be revoked as a result, nor may they revoke their own permission unless they have a global permission that already implies that permission.", + "operationId": "revokePermissions_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "user", + "in": "query", + "description": "The names of the users", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "group", + "in": "query", + "description": "The names of the groups", + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "All repository permissions were revoked from the users and groups for the specified repository." + }, + "400": { + "description": "No permissions were revoked because the request was invalid. No users or groups were provided.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user is not an administrator for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist, or one or more of the users or groups provided does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The action was disallowed as it would revoke the currently authenticated user's permission on the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/permissions/groups": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get groups with permission to repository", + "description": "Retrieve a page of groups that have been granted at least one permission for the specified repository.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository or a higher project or global permission to call this resource.", + "operationId": "getGroupsWithAnyPermission_2", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only group names containing the supplied string will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of groups and their highest permissions for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPermittedGroup" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a repository administrator for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Permission Management" + ], + "summary": "Update group repository permission", + "description": "Promote or demote a group's permission level for the specified repository. Available repository permissions are:\n\n- REPO_READ\n- REPO_WRITE\n- REPO_ADMIN\n\n\nSee the Bitbucket Data Center documentation for a detailed explanation of what each permission entails.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository or a higher project or global permission to call this resource. In addition, a user may not demote a group's permission level if their own permission level would be reduced as a result.", + "operationId": "setPermissionForGroup", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "name", + "in": "query", + "description": "The names of the groups.", + "required": true, + "schema": { + "type": "array", + "items": { + "type": "string" + } + } + }, + { + "name": "permission", + "in": "query", + "description": "The permission to grant", + "required": true, + "schema": { + "type": "string", + "enum": [ + "REPO_READ", + "REPO_WRITE", + "REPO_ADMIN" + ] + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The requested permission was granted." + }, + "400": { + "description": "The request was malformed or the specified permission does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a repository administrator for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as it would reduce the currently authenticated user's permission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Permission Management" + ], + "summary": "Revoke group repository permission", + "description": "Revoke all permissions for the specified repository for a group.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository or a higher project or global permission to call this resource.\n\nIn addition, a user may not revoke a group's permissions if it will reduce their own permission level.", + "operationId": "revokePermissionsForGroup_2", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "name", + "in": "query", + "description": "The name of the group.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "All repository permissions were revoked from the group for the specified repository." + }, + "401": { + "description": "The currently authenticated user is not a repository administrator for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The action was disallowed as it would reduce the currently authenticated user's permission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/permissions/groups/none": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get groups without repository permission", + "description": "Retrieve a page of groups that have no granted permissions for the specified repository.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository or a higher project or global permission to call this resource.", + "operationId": "getGroupsWithoutAnyPermission_2", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only group names containing the supplied string will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of groups that have not been granted any permissions for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDetailedGroup" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a repository administrator for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/permissions/search": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Search repository permissions", + "description": "Search direct and implied permissions of users and groups. This endpoint returns a superset of the results returned by the /users and /groups endpoints because it allows filtering by project and global permissions too.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository or a higher project/global permission to call this resource.", + "operationId": "searchPermissions_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "query", + "description": "Permissions to filter by. See the [permissions documentation](https://confluence.atlassian.com/display/BitbucketServer/Using+repository+permissions)for a detailed explanation of what each permission entails. This parameter can be specified multiple times to filter by more than one permission, and can contain repository, project, and global permissions.\n\n", + "schema": { + "type": "string" + } + }, + { + "name": "filterText", + "in": "query", + "description": "Name of the user or group to filter the name of", + "schema": { + "type": "string" + } + }, + { + "name": "type", + "in": "query", + "description": "Type of entity (user or group)Valid entity types are:\n\n- USER- GROUP", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "default": { + "description": "default response", + "content": { + "application/json;charset=UTF-8": {} + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/permissions/users": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get users with permission to repository", + "description": "Retrieve a page of users that have been granted at least one permission for the specified repository.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository or a higher project or global permission to call this resource.", + "operationId": "getUsersWithAnyPermission_2", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only user names containing the supplied string will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of users and their highest permissions for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPermittedUser" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a repository administrator for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Permission Management" + ], + "summary": "Update user repository permission", + "description": "Promote or demote a user's permission level for the specified repository. Available repository permissions are:\n\n- REPO_READ- REPO_WRITE- REPO_ADMINSee the Bitbucket Data Center documentation for a detailed explanation of what each permission entails.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository or a higher project or global permission to call this resource. In addition, a user may not reduce their own permission level unless they have a project or global permission that already implies that permission.", + "operationId": "setPermissionForUser", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "name", + "in": "query", + "description": "The names of the users.", + "required": true, + "schema": { + "type": "array", + "items": { + "type": "string" + } + } + }, + { + "name": "permission", + "in": "query", + "description": "The permission to grant", + "required": true, + "schema": { + "type": "string", + "enum": [ + "REPO_READ", + "REPO_WRITE", + "REPO_ADMIN" + ] + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The requested permission was granted." + }, + "400": { + "description": "The request was malformed or the specified permission does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a repository administrator for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The action was disallowed as it would reduce the currently authenticated user's permission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Permission Management" + ], + "summary": "Revoke user repository permission", + "description": "Revoke all permissions for the specified repository for a user.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository or a higher project or global permission to call this resource.\n\nIn addition, a user may not revoke their own repository permissions if they do not have a higher project or global permission.", + "operationId": "revokePermissionsForUser_2", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "name", + "in": "query", + "description": "The name of the user.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "All repository permissions were revoked from the user for the specified repository." + }, + "401": { + "description": "The currently authenticated user is not a repository administrator for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The action was disallowed as it would reduce the currently authenticated user's permission level.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/permissions/users/none": { + "get": { + "tags": [ + "Permission Management" + ], + "summary": "Get users without repository permission", + "description": "Retrieve a page of licensed users that have no granted permissions for the specified repository.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository or a higher project or global permission to call this resource.", + "operationId": "getUsersWithoutPermission_1", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "If specified only user names containing the supplied string will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of users that have not been granted any permissions for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestApplicationUser" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user is not a repository administrator for the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get pull requests for repository", + "description": "Retrieve a page of pull requests to or from the specified repository. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource. Optionally clients can specify PR participant filters. Each filter has a mandatory username.N parameter, and the optional role.N and approved.N parameters. \n\n- username.N - the \"root\" of a single participant filter, where \"N\" is a natural number starting from 1. This allows clients to specify multiple participant filters, by providing consecutive filters as username.1, username.2 etc. Note that the filters numbering has to start with 1 and be continuous for all filters to be processed. The total allowed number of participant filters is 10 and all filters exceeding that limit will be dropped.\n- role.N(optional) the role associated with username.N. This must be one of AUTHOR, REVIEWER, or PARTICIPANT\n- approved.N (optional) the approved status associated with username.N. That is whether username.N has approved the PR. Either true, or false\n", + "operationId": "getPage", + "parameters": [ + { + "name": "withAttributes", + "in": "query", + "description": "(optional) defaults to true, whether to return additional pull request attributes", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "at", + "in": "query", + "description": "(optional) a fully-qualified branch ID to find pull requests to or from, such as refs/heads/master", + "schema": { + "type": "string" + } + }, + { + "name": "withProperties", + "in": "query", + "description": "(optional) defaults to true, whether to return additional pull request properties", + "schema": { + "type": "string" + } + }, + { + "name": "draft", + "in": "query", + "description": "(optional) If specified, only pull requests matching the supplied draft status will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "filterText", + "in": "query", + "description": "(optional) If specified, only pull requests where the title or description contains the supplied string will be returned.", + "schema": { + "type": "string" + } + }, + { + "name": "state", + "in": "query", + "description": "(optional, defaults to OPEN). Supply ALL to return pull request in any state. If a state is supplied only pull requests in the specified state will be returned. Either OPEN, DECLINED or MERGED.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "order", + "in": "query", + "description": "(optional, defaults to NEWEST) the order to return pull requests in, either OLDEST (as in: \"oldest first\") or NEWEST.", + "schema": { + "type": "string" + } + }, + { + "name": "direction", + "in": "query", + "description": "(optional, defaults to INCOMING) the direction relative to the specified repository. Either INCOMING or OUTGOING.", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of pull requests that match the search criteria.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequest" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the specified pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Create pull request", + "description": "Create a new pull request from a source branch or tag to a target branch. The source and target may be in the same repository, or different ones. (Note that different repositories must belong to the same Repository#getHierarchyId() hierarchy.) \n\nThe fromRef may be a branch or a tag. The toRef is required to be a branch. Tags are not allowed as targets because tags are intended to be immutable and should not be changed after they are created. \n\nThe authenticated user must have REPO_READ permission for the fromRef and toRef repositories to call this resource.", + "operationId": "create", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The pull request data", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequest" + } + } + } + }, + "responses": { + "201": { + "description": "The newly created pull request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequest" + } + } + } + }, + "400": { + "description": "The pull request entity supplied in the request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create a pull request between the two specified repositories.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "One of the specified repositories or branches does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "One of the following error cases occurred (check the error message for more details): \n\n- There was a problem resolving one or more reviewers.\n- The specified branches were the same.\n- The to branch is already up-to-date with all the commits on the from branch.\n- A pull request between the two branches already exists.\n- The to repository is archived.\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get pull request", + "description": "Retrieve a pull request. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "get_3", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The specified pull request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequest" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the specified pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Pull Requests" + ], + "summary": "Update pull request metadata", + "description": "Update the title, description, reviewers, destination branch or draft status of an existing pull request. \n\n**Note:** the reviewers list may be updated using this resource. However the author and participants list may not. \n\nThe authenticated user must either: \n\n- be the author of the pull request and have the REPO_READ permission for the repository that this pull request targets; or\n- have the REPO_WRITE permission for the repository that this pull request targets\n\n\nto call this resource.", + "operationId": "update", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The updated pull request", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The updated pull request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequest" + } + } + } + }, + "400": { + "description": "One of the following error cases occurred (check the error message for more details): \n\n- The request tried to modify the author or participants.\n- The pull request's version attribute was not specified.\n- A reviewer's username was not specified.\n- The toRef ID value was incorrectly left blank\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update the specified pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "One of the specified repositories or branches does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "One of the following error cases occurred (check the error message for more details): \n\n- The specified version is out of date.\n- One of the reviewers could not be added to the pull request.\n- If updating the destination branch: - There is already an open pull request with an identical to branch\n - The from and new to branch are the same\n - The new destination branch up-to-date is up-to-date with all of changes from the from branch, resulting in a pull request with nothing to merge \n- The to repository is archived.\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Pull Requests" + ], + "summary": "Delete pull request", + "description": "Deletes a pull request. \n\nTo call this resource, users must be authenticated and have permission to view the pull request. Additionally, they must: \n\n- be the pull request author, if the system is configured to allow authors to delete their own pull requests (this is the default) OR \n- have repository administrator permission for the repository the pull request is targeting\n\n\nA body containing the version of the pull request must be provided with this request. \n\n`{ \"version\": 1 }`", + "operationId": "delete_3", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "A body containing the version of the pull request", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestDeleteRequest" + } + } + } + }, + "responses": { + "204": { + "description": "The pull request was deleted." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the specified pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "Deleting pull requests isn't supported on archived repositories.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}.diff": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Stream raw pull request diff", + "description": "Streams the raw diff for a pull request. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "streamRawDiff_2", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "contextLines", + "in": "query", + "description": "The number of context lines to include around added/removed lines in the diff", + "schema": { + "type": "string" + } + }, + { + "name": "whitespace", + "in": "query", + "description": "optional whitespace flag which can be set to ignore-all", + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A raw diff for the specified pull request.", + "content": { + "text/plain": {} + } + }, + "400": { + "description": "The currently authenticated user has insufficient permissions to view the specified pull request.", + "content": { + "text/html": {} + } + }, + "404": { + "description": "The pull request does not exist.", + "content": { + "text/html": {} + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}.patch": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Stream pull request as patch", + "description": "Streams a patch representing a pull request. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "streamPatch_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A patch representing the specified pull request.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to access the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/activities": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get pull request activity", + "description": "Retrieve a page of activity associated with a pull request. \n\nActivity items include comments, approvals, rescopes (i.e. adding and removing of commits), merges and more. \n\nDifferent types of activity items may be introduced in newer versions of Stash or by user installed plugins, so clients should be flexible enough to handle unexpected entity shapes in the returned page. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "getActivities", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "fromType", + "in": "query", + "description": "(required if fromId is present) the type of the activity item specified by fromId (either COMMENT or ACTIVITY)", + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "fromId", + "in": "query", + "description": "(optional) the ID of the activity item to use as the first item in the returned page", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of activity relating to the specified pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestActivity" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the specified pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/approve": { + "post": { + "tags": [ + "Deprecated", + "Pull Requests" + ], + "summary": "Approve pull request", + "description": "Approve a pull request as the current user. Implicitly adds the user as a participant if they are not already. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource. \n\nDeprecated since 4.2. Use /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants/{userSlug} instead", + "operationId": "approve", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "Details of the new participant.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The pull request is not open.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + }, + "delete": { + "tags": [ + "Deprecated", + "Pull Requests" + ], + "summary": "Unapprove pull request", + "description": "Remove approval from a pull request as the current user. This does not remove the user as a participant. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource. \n\nDeprecated since 4.2. Use /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants/{userSlug} instead", + "operationId": "withdrawApproval", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "Details of the updated participant.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist or the current user is not a participant on the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The pull request is not open.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/auto-merge": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get auto-merge request for pull request", + "description": "Returns an auto-merge request for the pull request, if requested.\n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "getAutoMergeRequest", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The auto-merge request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoMergeRequest" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the specified pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Auto-merge pull request", + "description": "Requests the system to try merging the pull request if auto-merge was requested on it.\n\nThe authenticated user must have REPO_WRITE permission for the repository that this pull request targets to call this resource.", + "operationId": "tryAutoMerge", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The result of trying to auto-merge the pull request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoMergeProcessingResult" + } + } + } + }, + "400": { + "description": "An auto-merge request was not submitted for this pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to modify the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The auto-merge setting is not enabled for the repository that this pull request targets.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Pull Requests" + ], + "summary": "Cancel auto-merge for pull request", + "description": "Cancels a request to auto-merge the pull request, if the pull request was not merged yet.\n\nThe authenticated user must have REPO_WRITE permission for the repository that this pull request targets to call this resource.", + "operationId": "cancelAutoMerge", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The auto-merge request was cancelled." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to modify the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The specified pull request is not open.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Search pull request comments", + "description": "Gets comments matching the given set of field values for the specified pull request. (Note this does not perform any kind of searching for comments by their text). \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "getComments_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "count", + "in": "query", + "description": "If true only the count of the comments by state will be returned (and not the body of the comments).", + "schema": { + "type": "string" + } + }, + { + "name": "state", + "in": "query", + "schema": { + "type": "array", + "items": { + "type": "string" + } + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "states", + "in": "query", + "description": "(optional). If supplied, only comments with a state in the given list will be returned. The state can be OPEN or RESOLVED.", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of Comments from the supplied pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestComment" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository or pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Add new blocker comment", + "description": "Add a new blocker comment. \n\nComments can be added in a few places by setting different attributes: \n\nGeneral pull request blocker comment: \n```\n\n{ \n \"text\": \"A task on a pull request.\" \n}\n```\n\nBlocker reply to a comment: \n\n```\n\n{\n \"text\": \"This reply is a task.\", \n \"parent\": { \n \"id\": 1 \n } \n} \n```\n\nGeneral blocker file comment:\n\n```\n\n{\n \"text\": \"A blocker comment on a file.\", \n \"anchor\": { \n \"diffType\": \"RANGE\", \n \"fromHash\": \"6df3858eeb9a53a911cd17e66a9174d44ffb02cd\", \n \"path\": \"path/to/file\", \n \"srcPath\": \"path/to/file\", \n \"toHash\": \"04c7c5c931b9418ca7b66f51fe934d0bd9b2ba4b\" \n } \n } \n```\n\nBlocker file line comment: \n\n```\n\n{ \n \"text\": \"A task on a particular line within a file.\", \n \"anchor\": { \n \"diffType\": \"COMMIT\", \n \"line\": 1, \n \"lineType\": \"CONTEXT\", \n \"fileType\": \"FROM\", \n \"fromHash\": \"6df3858eeb9a53a911cd17e66a9174d44ffb02cd\", \n \"path\": \"path/to/file\", \n \"srcPath\": \"path/to/file\", \n \"toHash\": \"04c7c5c931b9418ca7b66f51fe934d0bd9b2ba4b\" \n } \n } \n```\n\nFor file and line comments, 'path' refers to the path of the file to which the comment should be applied and 'srcPath' refers to the path the that file used to have (only required for copies and moves). Also, fromHash and toHash refer to the sinceId / untilId (respectively) used to produce the diff on which the comment was added. Finally diffType refers to the type of diff the comment was added on. For backwards compatibility purposes if no diffType is provided and no fromHash/toHash pair is provided the diffType will be resolved to 'EFFECTIVE'. In any other cases the diffType is REQUIRED. \n\nFor line comments, 'line' refers to the line in the diff that the comment should apply to. 'lineType' refers to the type of diff hunk, which can be: \n\n- 'ADDED' - for an added line;\n- 'REMOVED' - for a removed line; or\n- 'CONTEXT' - for a line that was unmodified but is in the vicinity of the diff.\n \n\n'fileType' refers to the file of the diff to which the anchor should be attached - which is of relevance when displaying the diff in a side-by-side way. Currently the supported values are: \n\n- 'FROM' - the source file of the diff\n - 'TO' - the destination file of the diff\n\n\nIf the current user is not a participant the user is added as a watcher of the pull request. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "createComment_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The comment to add.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestComment" + } + } + } + }, + "responses": { + "201": { + "description": "The newly created comment.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestComment" + } + } + } + }, + "400": { + "description": "The comment was not created due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request, create a comment or watch the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied project, repository, pull request or parent comment.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The new created name already exists or adding, deleting, or editing comments isn't supported on archived repositories.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments/{commentId}": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get pull request comment", + "description": "Retrieves a pull request comment.\n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "getComment_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The ID of the comment to retrieve", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The requested comment.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestComment" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the comment.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied project, repository, pull request or comment.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Pull Requests" + ], + "summary": "Update pull request comment", + "description": "Update a comment, with the following restrictions: \n\n- only the author of the comment may update the text of the comment\n- only the author of the comment, the author of the pull request or repository admins and above may update the other fields of a comment\n\n\nConvert a comment to a task or vice versa. \n\nComments can be converted to tasks by setting the 'severity' attribute to 'BLOCKER': \n```\n\n{ \n\"severity\": \"BLOCKER\" \n}\n\n```\n\nTasks can be converted to comments by setting the 'severity' attribute to 'NORMAL': ```\n\n{ \n\"severity\": \"NORMAL\" \n}\n\n```\n\nResolve a blocker comment. \n\nBlocker comments can be resolved by setting the 'state' attribute to 'RESOLVED': ```\n\n{ \n\"state\": \"RESOLVED\" \n} \n```\n\nNote: the supplied JSON object must contain a version that must match the server's version of the comment or the update will fail. To determine the current version of the comment, the comment should be fetched from the server prior to the update. Look for the 'version' attribute in the returned JSON structure. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "updateComment_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The ID of the comment to retrieve.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The comment to add.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestComment" + } + } + } + }, + "responses": { + "200": { + "description": "The newly updated comment.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestComment" + } + } + } + }, + "400": { + "description": "The comment was not updated due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request, update a comment or watch the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied project, repository, pull request or comment.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The comment version supplied does not match the current version or the repository is archived.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Pull Requests" + ], + "summary": "Delete pull request comment", + "description": "Delete a pull request comment. Anyone can delete their own comment. Only users with REPO_ADMIN and above may delete comments created by other users.\n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "deleteComment_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The ID of the comment to retrieve.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "version", + "in": "query", + "description": "The expected version of the comment. This must match the server's version of the comment or the delete will fail. To determine the current version of the comment, the comment should be fetched from the server prior to the delete. Look for the 'version' attribute in the returned JSON structure.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The operation was successful." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the comment.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied project, repository or pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The comment has replies, the version supplied does not match the current version or the repository is archived.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/changes": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Gets pull request changes", + "description": "Gets changes for the specified PullRequest.\n\nIf the changeScope query parameter is set to 'UNREVIEWED', the application will attempt to stream unreviewed changes based on the lastReviewedCommit of the current user, which are the changes between the lastReviewedCommit and the latest commit of the source branch. The current user is considered to not have any unreviewed changes for the pull request when the lastReviewedCommit is either null (everything is unreviewed, so all changes are streamed), equal to the latest commit of the source branch (everything is reviewed), or no longer on the source branch (the source branch has been rebased). In these cases, the application will fall back to streaming all changes (the default), which is the effective diff for the pull request. The type of changes streamed can be determined by the changeScope parameter included in the properties map of the response. \n\nNote: This resource is currently not paged. The server will return at most one page. The server will truncate the number of changes to either the request's page limit or an internal maximum, whichever is smaller. The start parameter of the page request is also ignored. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "streamChanges_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "sinceId", + "in": "query", + "description": "The since commit hash to stream changes for a RANGE arbitrary change scope", + "schema": { + "type": "string" + } + }, + { + "name": "changeScope", + "in": "query", + "description": "UNREVIEWED to stream the unreviewed changes for the current user (if they exist); RANGE to stream changes between two arbitrary commits (requires 'sinceId' and 'untilId'); otherwise ALL to stream all changes (the default)", + "schema": { + "type": "string" + } + }, + { + "name": "untilId", + "in": "query", + "description": "The until commit hash to stream changes for a RANGE arbitrary change scope", + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "withComments", + "in": "query", + "description": "true to apply comment counts in the changes (the default); otherwise, false to stream changes without comment counts", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of unreviewed Changes for the current user from the supplied pull request, including the unreviewedCommits in the properties map.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestChange" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository or pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get pull request comments for path", + "description": "Gets comments for the specified pull request and path. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "getComments_2", + "parameters": [ + { + "name": "path", + "in": "query", + "description": "The path to stream comments for a given path", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "fromHash", + "in": "query", + "description": "The from commit hash to stream comments for a RANGE or COMMIT arbitrary change scope", + "schema": { + "type": "string" + } + }, + { + "name": "anchorState", + "in": "query", + "description": "ACTIVE to stream the active comments; ORPHANED to stream the orphaned comments; ALL to stream both the active and the orphaned comments;", + "schema": { + "type": "string" + } + }, + { + "name": "diffType", + "in": "query", + "schema": { + "type": "array", + "items": { + "type": "string" + } + } + }, + { + "name": "toHash", + "in": "query", + "description": "The to commit hash to stream comments for a RANGE or COMMIT arbitrary change scope", + "schema": { + "type": "string" + } + }, + { + "name": "state", + "in": "query", + "schema": { + "type": "array", + "items": { + "type": "string" + } + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "diffTypes", + "in": "query", + "description": "EFFECTIVE to stream the comments related to the effective diff of the pull request; RANGE to stream comments related to a commit range between two arbitrary commits (requires 'fromHash' and 'toHash'); COMMIT to stream comments related to a commit between two arbitrary commits (requires 'fromHash' and 'toHash')", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "states", + "in": "query", + "description": "(optional). If supplied, only comments with a state in the given list will be returned. The state can be OPEN or RESOLVED.", + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of Comments from the supplied pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestComment" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository or pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Add pull request comment", + "description": "Add a new comment. \n\nComments can be added in a few places by setting different attributes:

General pull request comment: \n
 { \n   \"text\": \"An insightful general comment on a pull request.\" \n } \n 
Reply to a comment:
 { \n   \"text\": \"A measured reply.\", \n   \"parent\": { \n      \"id\": 1 \n    } \n } \n 
General file comment:
 { \n   \"text\": \"An insightful general comment on a file.\", \n   \"anchor\": { \n      \"diffType\": \"RANGE\", \n      \"fromHash\": \"6df3858eeb9a53a911cd17e66a9174d44ffb02cd\", \n      \"path\": \"path/to/file\", \n      \"srcPath\": \"path/to/file\", \n      \"toHash\": \"04c7c5c931b9418ca7b66f51fe934d0bd9b2ba4b\" \n   } \n } \n 
File line comment:
 { \n   \"text\": \"A pithy comment on a particular line within a file.\", \n   \"anchor\": { \n      \"diffType\": \"COMMIT\", \n      \"line\": 1, \n      \"lineType\": \"CONTEXT\", \n      \"fileType\": \"FROM\", \n      \"fromHash\": \"6df3858eeb9a53a911cd17e66a9174d44ffb02cd\", \n      \"path\": \"path/to/file\", \n      \"srcPath\": \"path/to/file\", \n      \"toHash\": \"04c7c5c931b9418ca7b66f51fe934d0bd9b2ba4b\" \n    } \n } \n 
\n\n Add a new task. \n\nTasks are just comments with the attribute 'severity' set to 'BLOCKER': \n\nGeneral pull request task:
 { \n   \"text\": \"A task on a pull request.\", \n   \"severity\": \"BLOCKER\" \n } \n 
\n\n Add a pending comment. \n\nPending comments are just comments with the attribute 'state' set to 'PENDING': \n\nPending comment:
 { \n   \"text\": \"This is a pending comment\", \n   \"state\": \"PENDING\" \n } \n 
\n\nFor file and line comments, 'path' refers to the path of the file to which the comment should be applied and 'srcPath' refers to the path the that file used to have (only required for copies and moves). Also, fromHash and toHash refer to the sinceId / untilId (respectively) used to produce the diff on which the comment was added. Finally diffType refers to the type of diff the comment was added on. For backwards compatibility purposes if no diffType is provided and no fromHash/toHash pair is provided the diffType will be resolved to 'EFFECTIVE'. In any other cases the diffType is REQUIRED. \n\nFor line comments, 'line' refers to the line in the diff that the comment should apply to. 'lineType' refers to the type of diff hunk, which can be: \n\n- 'ADDED' - for an added line;\n- 'REMOVED' - for a removed line; or\n- 'CONTEXT' - for a line that was unmodified but is in the vicinity of the diff.\n'fileType' refers to the file of the diff to which the anchor should be attached - which is of relevance when displaying the diff in a side-by-side way. Currently the supported values are: \n\n- 'FROM' - the source file of the diff\n- 'TO' - the destination file of the diff\nIf the current user is not a participant the user is added as a watcher of the pull request. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "createComment_2", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The comment to add", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestComment" + } + } + } + }, + "responses": { + "201": { + "description": "The newly created comment.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestComment" + } + } + } + }, + "400": { + "description": "The comment was not created due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request, create a comment or watch the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied project, repository, pull request or parent comment.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "Adding, deleting, or editing comments isn't supported on archived repositories.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get a pull request comment", + "description": "Retrieves a pull request comment. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "getComment_2", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The ID of the comment to retrieve.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The requested comment.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestComment" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the comment.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied project, repository, pull request or comment.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Pull Requests" + ], + "summary": "Update pull request comment", + "description": "Update a comment, with the following restrictions: \n\n- only the author of the comment may update the text of the comment\n- only the author of the comment, the author of the pull request or repository admins and above may update the other fields of a comment\n \n\nConvert a comment to a task or vice versa. \n\nComments can be converted to tasks by setting the 'severity' attribute to 'BLOCKER': \n
 { \n \"severity\": \"BLOCKER\" \n } \n 
\n\nTasks can be converted to comments by setting the 'severity' attribute to 'NORMAL':
 { \n \"severity\": \"NORMAL\" \n } \n 
\n\nResolve a task. \n\nTasks can be resolved by setting the 'state' attribute to 'RESOLVED':
 { \n \"state\": \"RESOLVED\" \n } \n 
\n\nNote: the supplied JSON object must contain a version that must match the server's version of the comment or the update will fail. To determine the current version of the comment, the comment should be fetched from the server prior to the update. Look for the 'version' attribute in the returned JSON structure. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "updateComment_2", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The ID of the comment to retrieve.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The updated comment", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestComment" + } + } + } + }, + "responses": { + "200": { + "description": "The newly updated comment.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestComment" + } + } + } + }, + "400": { + "description": "The comment was not updated due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request, update a comment or watch the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied project, repository, pull request or comment.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The comment version supplied does not match the current version or the repository is archived.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Pull Requests" + ], + "summary": "Delete a pull request comment", + "description": "Delete a pull request comment. Anyone can delete their own comment. Only users with REPO_ADMIN and above may delete comments created by other users. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "deleteComment_2", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The ID of the comment to retrieve.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "version", + "in": "query", + "description": "The expected version of the comment. This must match the server's version of the comment or the delete will fail. To determine the current version of the comment, the comment should be fetched from the server prior to the delete. Look for the 'version' attribute in the returned JSON structure.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The operation was successful." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the comment.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied project, repository or pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The comment has replies, the version supplied does not match the current version or the repository is archived.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}/apply-suggestion": { + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Apply pull request suggestion", + "description": "Apply a suggestion contained within a comment.", + "operationId": "applySuggestion", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "commentId", + "in": "path", + "description": "The ID of the comment to retrieve.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "A request containing other parameters required to apply a suggestion - The given versions/hashes must match the server's version/hashes or the suggestion application will fail (in order to avoid applying the suggestion to the wrong place", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestApplySuggestionRequest" + } + } + } + }, + "responses": { + "204": { + "description": "An empty response indicating the suggestion has been applied." + }, + "400": { + "description": "The suggestion was not applied due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to apply the suggestion.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied project, repository, pull request or parent comment.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "There was an error applying the suggestion to the source branch. It must be applied manually.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/commit-message-suggestion": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get commit message suggestion", + "description": "Retrieve a suggested commit message for the given Pull Request.", + "operationId": "getCommitMessageSuggestion", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request to generate the suggestion for", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The suggested commit message", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestCommitMessageSuggestion" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the specified pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/commits": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get pull request commits", + "description": "Retrieve commits for the specified pull request. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "getCommits_1", + "parameters": [ + { + "name": "avatarScheme", + "in": "query", + "description": "The desired scheme for the avatar URL. If the parameter is not present URLs will use the same scheme as this request", + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "withCounts", + "in": "query", + "description": "If set to true, the service will add \"authorCount\" and \"totalCount\" at the end of the page. \"authorCount\" is the number of different authors and \"totalCount\" is the total number of commits.", + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "ID of the pullrequest, part of the path", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "avatarSize", + "in": "query", + "description": "If present the service adds avatar URLs for commit authors. Should be an integer specifying the desired size in pixels. If the parameter is not present, avatar URLs will not be setCOMMIT to stream comments related to a commit between two arbitrary commits (requires 'fromHash' and 'toHash')", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of commits from the supplied pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestCommit" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository or pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/decline": { + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Decline pull request", + "description": "Decline a pull request. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "decline", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pullrequest ID provided by the path", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "version", + "in": "query", + "description": "The current version of the pull request. If the server's version isn't the same as the specified version the operation will fail. To determine the current version of the pull request it should be fetched from the server prior to this operation. Look for the 'version' attribute in the returned JSON structure.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The body holder", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestDeclineRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The pull request was declined.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequest" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The pull request is not OPEN or has been updated since the version specified by the request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/diff/{path}": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Stream a diff within a pull request", + "description": "Streams a diff within a pull request. \n\nIf the specified file has been copied, moved or renamed, the srcPath must also be specified to produce the correct diff. \n\nTo stream a raw text representation of the diff, this endpoint can be called with the request header 'Accept: text/plain'. \n\nNote: This RESTful endpoint is currently not paged. The server will internally apply a hard cap to the streamed lines, and it is not possible to request subsequent pages if that cap is exceeded. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "streamDiff_2", + "parameters": [ + { + "name": "avatarScheme", + "in": "query", + "description": "The security scheme for avatar URLs. If the scheme is not present then it is inherited from the request. It can be set to \"https\" to force the use of secure URLs. Not applicable if streaming raw diff", + "schema": { + "type": "string" + } + }, + { + "name": "path", + "in": "path", + "description": "The path to the file which should be diffed (optional)", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "contextLines", + "in": "query", + "description": "The number of context lines to include around added/removed lines in the diff", + "schema": { + "type": "string" + } + }, + { + "name": "sinceId", + "in": "query", + "description": "The since commit hash to stream a diff between two arbitrary hashes", + "schema": { + "type": "string" + } + }, + { + "name": "srcPath", + "in": "query", + "description": "The previous path to the file, if the file has been copied, moved or renamed", + "schema": { + "type": "string" + } + }, + { + "name": "diffType", + "in": "query", + "description": "The type of diff being requested. When withComments is true this works as a hint to the system to attach the correct set of comments to the diff. Not applicable if streaming raw diff", + "schema": { + "type": "string" + } + }, + { + "name": "untilId", + "in": "query", + "description": "The until commit hash to stream a diff between two arbitrary hashes", + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "whitespace", + "in": "query", + "description": "Optional whitespace flag which can be set to ignore-all", + "schema": { + "type": "string" + } + }, + { + "name": "withComments", + "in": "query", + "description": "true to embed comments in the diff (the default); otherwise, false to stream the diff without comments. Not applicable if streaming raw diff", + "schema": { + "type": "string" + } + }, + { + "name": "avatarSize", + "in": "query", + "description": "If present the service adds avatar URLs for comment authors where the provided value specifies the desired avatar size in pixels. Not applicable if streaming raw diff", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of differences from a pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestDiff" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "If the request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository or pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/merge": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Test if pull request can be merged", + "description": "Test whether a pull request can be merged. \n\nA pull request may not be merged if: \n\n- there are conflicts that need to be manually resolved before merging; and/or\n- one or more merge checks have vetoed the merge.\n\n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "canMerge", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The mergeability status of the pull request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestMergeability" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the specified pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The specified pull request is not open.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Merge pull request", + "description": "Merge the specified pull request immediately or set the pull request to auto-merge when all the merge checks pass by setting autoMerge field in the request body.\n\nThe authenticated user must have REPO_WRITE permission for the repository that this pull request targets to call this resource.", + "operationId": "merge", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "version", + "in": "query", + "description": "The current version of the pull request. If the server's version isn't the same as the specified version the operation will fail. To determine the current version of the pull request it should be fetched from the server prior to this operation. Look for the 'version' attribute in the returned JSON structure.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The body holder", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestMergeRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The merged pull request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequest" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to merge the specified pull request", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The auto-merge setting is not enabled for the repository that this pull request targets.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "One of the following error cases occurred (check the error message for more details): \n\n- The pull request has conflicts.\n- A merge check vetoed the merge.\n- The specified version is out of date.\n- The specified pull request is not open.\n- The to repository is archived.\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/merge-base": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get the common ancestor between the latest commits of the source and target branches of the pull request", + "description": "Returns the best common ancestor between the latest commits of the source and target branches of the pull request.\n\nIf more than one best common ancestor exists, only one will be returned. It is unspecified which will be returned.", + "operationId": "getMergeBase_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The common ancestor of the latest commits in the source and target branches of this pull request", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestCommit" + } + } + } + }, + "204": { + "description": "No common parent between exist" + }, + "404": { + "description": "The project, repository, or pull request does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get pull request participants", + "description": "Retrieves a page of the participants for a given pull request. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "listParticipants", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "Details of the participants in this pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Assign pull request participant role", + "description": "Assigns a participant to an explicit role in pull request. Currently only the REVIEWER role may be assigned. \n\nIf the user is not yet a participant in the pull request, they are made one and assigned the supplied role. \n\nIf the user is already a participant in the pull request, their previous role is replaced with the supplied role unless they are already assigned the AUTHOR role which cannot be changed and will result in a Bad Request (400) response code. \n\nThe authenticated user must have REPO_WRITE permission for the repository that this pull request targets to call this resource.", + "operationId": "assignParticipantRole", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The participant to be added to the pull request, includes the user and their role", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestAssignParticipantRoleRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "Details of the participants in this pull request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + } + } + }, + "400": { + "description": "The request does not have the username and role, or is attempting an invalid assignment.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "Adding reviewers isn't supported on archived repositories", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Deprecated", + "Pull Requests" + ], + "summary": "Unassign pull request participant", + "description": "Unassigns a participant from the REVIEWER role they may have been given in a pull request. \n\nIf the participant has no explicit role this method has no effect. \n\nAfterwards, the user will still remain a participant in the pull request but their role will be reduced to PARTICIPANT. This is because once made a participant of a pull request, a user will forever remain a participant. Only their role may be altered. \n\nThe authenticated user must have REPO_WRITE permission for the repository that this pull request targets to call this resource. \n\nDeprecated since 4.2. Use /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants/{userSlug} instead.", + "operationId": "unassignParticipantRole_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "username", + "in": "query", + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The update completed." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "Removing reviewers isn't supported on archived repositories.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants/{userSlug}": { + "put": { + "tags": [ + "Pull Requests" + ], + "summary": "Change pull request status", + "description": "Change the current user's status for a pull request. Implicitly adds the user as a participant if they are not already. If the current user is the author, this method will fail. \n\nThe possible values for {@code status} are UNAPPROVED, NEEDS_WORK (which is referred to as \"Requested changes\" in the frontend from 8.10 onward), or APPROVED. \n\nIf the new {@code status} is NEEDS_WORK or APPROVED then the {@code lastReviewedCommit} for the participant will be updated to the latest commit of the source branch of the pull request. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "updateStatus", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "userSlug", + "in": "path", + "description": "The slug for the user changing their status", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "version", + "in": "query", + "description": "The current version of the pull request. If the server's version isn't the same as the specified version the operation will fail. To determine the current version of the pull request it should be fetched from the server prior to this operation. Look for the 'version' attribute in the returned JSON structure.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The participant representing the status to set, includes the status of the participant", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestAssignStatusRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "Details of the new participant.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestParticipant" + } + } + } + }, + "400": { + "description": "The specified status was invalid or the currently authenticated user is the author of the PR and cannot have its status updated.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The pull request is not open, or has been updated since the version specified by the request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Pull Requests" + ], + "summary": "Unassign pull request participant", + "description": "Unassigns a participant from the REVIEWER role they may have been given in a pull request. \n\nIf the participant has no explicit role this method has no effect. \n\nAfterwards, the user will still remain a participant in the pull request but their role will be reduced to PARTICIPANT. This is because once made a participant of a pull request, a user will forever remain a participant. Only their role may be altered. \n\nThe authenticated user must have REPO_WRITE permission for the repository that this pull request targets to call this resource.", + "operationId": "unassignParticipantRole", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "userSlug", + "in": "path", + "description": "The slug for the user being unassigned", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The update completed." + }, + "400": { + "description": "The request does not have the username.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "Removing reviewers isn't supported on archived repositories.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/reopen": { + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Re-open pull request", + "description": "Re-open a declined pull request. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "reopen", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The ID of the pull request within the repository", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "version", + "in": "query", + "description": "The current version of the pull request. If the server's version isn't the same as the specified version the operation will fail. To determine the current version of the pull request it should be fetched from the server prior to this operation. Look for the 'version' attribute in the returned JSON structure.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The body holder", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestReopenRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The merged pull request.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequest" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to reopen the specified pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "One of the following error cases occurred (check the error message for more details): \n\n- The pull request is not in a declined state.\n- The specified version is out of date.\n- The to repository is archived.\n", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/review": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get pull request comment thread", + "description": "Get the CommentThread threads which have Comment comments that have a CommentState#PENDING pending state and are part of the pull request review for the authenticated user.", + "operationId": "getReview", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of Comments from the supplied pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestComment" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository or pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Pull Requests" + ], + "summary": "Complete pull request review", + "description": "Complete a review on a pull request.", + "operationId": "finishReview", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "version", + "in": "query", + "description": "The current version of the pull request. If the server's version isn't the same as the specified version the operation will fail. To determine the current version of the pull request it should be fetched from the server prior to this operation. Look for the 'version' attribute in the returned JSON structure.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The REST request which contains comment text and participant status", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestFinishReviewRequest" + } + } + } + }, + "responses": { + "200": { + "description": "Getting back the number of published comments and completing the review on a pull request.", + "content": { + "application/json": {} + } + }, + "400": { + "description": "The request is invalid when there is no request body provided, or the participant status in the request is invalid.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request, update a comment or watch the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "There is no pull request review for the user to finish.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The pull request has been updated since the version specified by the request, or reviews cannot be made on pull requests in archived repositories.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Pull Requests" + ], + "summary": "Discard pull request review", + "description": "Discard a pull request review for the authenticated user. \n\nThe authenticated user must have REPO_READ permission for the repository to call this resource.", + "operationId": "discardReview", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The pull request review has been discarded." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to discard the the pull request review", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified pull request or repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/tasks": { + "get": { + "tags": [ + "Deprecated" + ], + "summary": "Get pull request tasks", + "description": "Retrieve the tasks associated with a pull request. \n\n**Removed in 8.0**. Tasks are now managed using Comments with BLOCKER severity. Use /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments instead \n\n**Deprecated since 7.2, changed to 404 in 8.0, remove in 9.0.** Use /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments instead", + "operationId": "getPullRequestTasks", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "404": { + "description": "This endpoint has been removed as tasks are now managed using Comments with severity BLOCKER.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/tasks/count": { + "get": { + "tags": [ + "Deprecated" + ], + "summary": "Get pull request task count", + "description": "Retrieve the total number of OPEN and RESOLVED tasks associated with a pull request. \n\nDeprecated since 7.2. Tasks are now managed using Comments with BLOCKER severity. Use /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments?count=true instead.", + "operationId": "countPullRequestTasks", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "404": { + "description": "This endpoint has been removed as tasks are now managed using Comments with severity BLOCKER.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/watch": { + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Watch pull request", + "description": "Add the authenticated user as a watcher for the specified pull request. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "watch_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The user is now watching the pull request." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Pull Requests" + ], + "summary": "Stop watching pull request", + "description": "Remove the authenticated user as a watcher for the specified pull request. \n\nThe authenticated user must have REPO_READ permission for the repository that this pull request targets to call this resource.", + "operationId": "unwatch_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "pullRequestId", + "in": "path", + "description": "The pull request ID.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The user is no longer watching the pull request." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the pull request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or pull request does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/raw/{path}": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get raw content of a file at revision", + "description": "Retrieve the raw content for a file path at a specified revision. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "streamRaw", + "parameters": [ + { + "name": "path", + "in": "path", + "description": "The file path to retrieve content from", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "at", + "in": "query", + "description": "A specific commit or ref to retrieve the raw content at, or the default branch if not specified", + "schema": { + "type": "string" + } + }, + { + "name": "markup", + "in": "query", + "description": "If present or \"true\", triggers the raw content to be markup-rendered and returned as HTML; otherwise, if not specified, or any value other than \"true\", the content is streamed without markup", + "schema": { + "type": "string" + } + }, + { + "name": "htmlEscape", + "in": "query", + "description": "(Optional) true if HTML should be escaped in the input markup, false otherwise. If not specified, the value of the markup.render.html.escape property, which is true by default, will be used", + "schema": { + "type": "string" + } + }, + { + "name": "includeHeadingId", + "in": "query", + "description": "(Optional) true if headings should contain an ID based on the heading content. If not specified, the value of the markup.render.headerids property, which is false by default, will be used", + "schema": { + "type": "string" + } + }, + { + "name": "hardwrap", + "in": "query", + "description": "(Optional) Whether the markup implementation should convert newlines to breaks. If not specified, the value of the markup.render.hardwrap property, which is true by default, will be used", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The raw contents from a file.", + "content": { + "application/json": {} + } + }, + "400": { + "description": "The path parameter was not supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/readme": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get repository readme", + "description": "Retrieves the README for the repository, if it's been defined. \n\nThis checks the repository for a
README
file, optionally with an
md
or
txt
extension, and, if found, streams it. By default, the raw content of the file is streamed. Appending
?markup
to the URL will stream an HTML-rendered version instead. Note that, when streaming HTML, relative URLs in the README will not work if applied relative to this URL. \n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "streamReadme", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "at", + "in": "query", + "description": "A specific commit or ref to retrieve the guidelines at, or the default branch if not specified", + "schema": { + "type": "string" + } + }, + { + "name": "markup", + "in": "query", + "description": "If present or \"true\", triggers the raw content to be markup-rendered and returned as HTML; otherwise, if not specified, or any value other than \"true\", the content is streamed without markup", + "schema": { + "type": "string" + } + }, + { + "name": "htmlEscape", + "in": "query", + "description": "(Optional) true if HTML should be escaped in the input markup, false otherwise. If not specified, the value of the markup.render.html.escape property, which is true by default, will be used", + "schema": { + "type": "string" + } + }, + { + "name": "includeHeadingId", + "in": "query", + "description": "(Optional) true if headings should contain an ID based on the heading content. If not specified, the value of the markup.render.headerids property, which is false by default, will be used", + "schema": { + "type": "string" + } + }, + { + "name": "hardwrap", + "in": "query", + "description": "(Optional) Whether the markup implementation should convert newlines to breaks. If not specified, the value of the markup.render.hardwrap property, which is true by default, will be used", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The README for the repository.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to read the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/recreate": { + "post": { + "tags": [ + "Project" + ], + "summary": "Retry repository creation", + "description": "If a create or fork operation fails, calling this method will clean up the broken repository and try again. The repository must be in an INITIALISATION_FAILED state. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "retryCreateRepository", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The newly created repository.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepository" + } + } + } + }, + "400": { + "description": "The repository was not created due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create a repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/ref-change-activities": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get ref change activity", + "description": "Retrieve a page of repository ref change activity. \n\nThe authenticated user must have REPO_ADMIN permission to call this resource.", + "operationId": "getRefChangeActivity", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "ref", + "in": "query", + "description": "(optional) exact match for a ref ID to filter ref change activity for", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of ref change activity.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepositoryRefChangeActivity" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The user is currently not authenticated or the user does not have REPO_ADMIN permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/ref-change-activities/branches": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get branches with ref change activities for repository", + "description": "Retrieve a page of branches with ref change activities for a specific repository. \n\nThe authenticated user must have REPO_ADMIN permission to call this resource.", + "operationId": "findBranches", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "filterText", + "in": "query", + "description": "(optional) Partial match for a ref ID to filter minimal refs for", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of branches with ref change activities.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestMinimalRef" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The user is currently not authenticated or the user does not have REPO_ADMIN permission.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/related": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get related repository", + "description": "Retrieve repositories which are related to this one. Related repositories are from the same Repository#getHierarchyId() hierarchy as this repository. \n\nOnly repositories to which the authenticated user has REPO_READ permission will be included, even if more repositories are part of this repository's hierarchy.", + "operationId": "getRelatedRepositories", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of repositories related to the request repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepository" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to see the request repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The request repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/secret-scanning/allowlist": { + "get": { + "tags": [ + "Security" + ], + "summary": "Find repository secret scanning allowlist rules", + "description": "Find repository secret scanning allowlist rules by filtering.\n\nRepository **Admin** is required", + "operationId": "search_2", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "Filter names by the provided text", + "schema": { + "type": "string" + }, + "example": "Access" + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "order", + "in": "query", + "description": "Order by", + "schema": { + "type": "string", + "enum": [ + "NAME_ASC", + "NAME_DESC" + ] + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "Page of allowlist rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestSecretScanningAllowlistRule" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request was not a correctly formed allowlist rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to view repository rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Security" + ], + "summary": "Create repository secret scanning allowlist rule", + "description": "Create a new repository secret scanning allowlist rule. Repository allowlist rules are used when scanning the given repository.\n\nRepository **Admin** is required", + "operationId": "createAllowlistRule_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "Allowlist rule to create, either the line regular expression or the path regular expression must be present", + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningAllowlistRuleSetRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "The created rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningAllowlistRule" + } + } + } + }, + "400": { + "description": "The request did not contain a correctly formed allowlist rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to create repository rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/secret-scanning/allowlist/{id}": { + "get": { + "tags": [ + "Security" + ], + "summary": "Get a repository secret scanning allowlist rule", + "description": "Get a repository secret scanning allowlist rule by ID.\n\nRepository **Admin** is required", + "operationId": "getAllowlistRule_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The allowlist rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The requested allowlist rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningAllowlistRule" + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to view repository allowlist rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The requested allowlist rule was not found", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Security" + ], + "summary": "Edit an existing repository secret scanning allowlist rule", + "description": "Edit a repository secret scanning allowlist rule.\n\nRepository **Admin** is required", + "operationId": "editAllowlistRule_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The allowlist rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningAllowlistRuleSetRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "The updated allowlist rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningAllowlistRule" + } + } + } + }, + "400": { + "description": "The request did not contain a correctly formed allowlist rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to edit repository allowlist rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Security" + ], + "summary": "Delete a repository secret scanning allowlist rule", + "description": "Delete a repository secret scanning allowlist rule with the provided ID.\n\nRepository **Admin** is required", + "operationId": "deleteAllowlistRule_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The allowlist rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "Empty response indicating that the allowlist rule was deleted" + }, + "401": { + "description": "The authenticated user is not permitted to delete repository allowlist rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/secret-scanning/exempt": { + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "get": { + "tags": [ + "Security" + ], + "summary": "Get whether a repository is exempt", + "description": "Check whether a repository is exempt from secret scanning", + "operationId": "isRepoExempt", + "responses": { + "200": { + "description": "True if the repository is exempt from secret scanning, false otherwise", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The authenticated user is not permitted to check whether a repository is exempt from secret scanning", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Security" + ], + "summary": "Exempt a repo from secret scanning", + "description": "Exempt a repository from being scanned for secrets \n\nDeprecated since 8.6. Exemptions are now managed by scope. \nUse POST /rest/api/1.0/secret-scanning/exempt for global scope \nUse POST /rest/api/1.0/projects/{projectKey}/secret-scanning/exempt for the project scope", + "operationId": "addExemptRepo", + "responses": { + "204": { + "description": "An exempt repo was added" + }, + "401": { + "description": "The authenticated user is not permitted to exempt a repository from secret scanning", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "At least one of specified repositories have already been previously made exempt.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + }, + "delete": { + "tags": [ + "Security" + ], + "summary": "Delete an exempt repository", + "description": "Remove a repository from being exempt from secret scanning", + "operationId": "deleteExemptRepo", + "responses": { + "204": { + "description": "Empty response indicating that the exempt repository was deleted" + }, + "401": { + "description": "The authenticated user is not permitted to delete an exempt repository", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/secret-scanning/rules": { + "get": { + "tags": [ + "Security" + ], + "summary": "Find repository secret scanning rules", + "description": "Find repository secret scanning rules by filtering.\n\nRepository **Admin** is required", + "operationId": "search_3", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "Filter names by the provided text", + "schema": { + "type": "string" + }, + "example": "Access" + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "order", + "in": "query", + "description": "Order by", + "schema": { + "type": "string", + "enum": [ + "NAME_ASC", + "NAME_DESC" + ] + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "Page of rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestSecretScanningRule" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request was not correctly formed rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to view repository rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Security" + ], + "summary": "Create repository secret scanning rule", + "description": "Create a new repository secret scanning rule. Repository rules are used when scanning the given repository.\n\nRepository **Admin** is required", + "operationId": "createRule_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "Rule to create, either the line regular expression or the path regular expression must be present", + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRuleSetRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "The created rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRule" + } + } + } + }, + "400": { + "description": "The request did not contain a correctly formed rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to create repository rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/secret-scanning/rules/{id}": { + "get": { + "tags": [ + "Security" + ], + "summary": "Get a repository secret scanning rule", + "description": "Get a repository secret scanning rule by ID.\n\nRepository **Admin** is required", + "operationId": "getRule_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The requested rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRule" + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to view repository rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The requested rule was not found", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Security" + ], + "summary": "Edit an existing repository secret scanning rule", + "description": "Edit a repository secret scanning rule.\n\nRepository **Admin** is required", + "operationId": "editRule_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRuleSetRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "The updated rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRule" + } + } + } + }, + "400": { + "description": "The request did not contain a correctly formed rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to edit repository rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Security" + ], + "summary": "Delete a repository secret scanning rule", + "description": "Delete a repository secret scanning rule with the provided ID.\n\nRepository **Admin** is required", + "operationId": "deleteRule_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "Empty response indicating that the rule was deleted" + }, + "401": { + "description": "The authenticated user is not permitted to delete repository rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-decline": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get auto decline settings", + "description": "Retrieves the auto decline settings for the supplied repository. Project settings will be returned if no explicit settings have been set for the repository. In the case that there are no project settings, the default settings will be returned.\n\nThe authenticated user must have REPO_READ permission for this repository to call the resource.", + "operationId": "getAutoDeclineSettings_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The auto decline settings", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoDeclineSettings" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the auto decline settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Repository" + ], + "summary": "Create auto decline settings", + "description": "Creates or updates the auto decline settings for the supplied repository.\n\nThe authenticated user must have REPO_ADMIN permission for this repository to call the resource", + "operationId": "setAutoDeclineSettings_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The settings to create or update", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoDeclineSettingsRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The auto decline settings", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoDeclineSettings" + } + } + } + }, + "400": { + "description": "inactivityWeeks was not one of 1, 2, 4, 8, or, 12, or the enabled parameter was not included in the request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create or update the auto decline settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Repository" + ], + "summary": "Delete auto decline settings", + "description": "Delete auto decline settings for the supplied repository.\n\nThe authenticated user must have REPO_ADMIN permission for this repository to call the resource.", + "operationId": "deleteAutoDeclineSettings_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The auto decline settings have been deleted successfully." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the auto decline settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-merge": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get pull request auto-merge settings", + "description": "Retrieves the pull request auto-merge settings for the supplied repository. Project settings will be returned if no explicit settings have been set for the repository. In the case that there are no project settings, the default settings will be returned. If the repository's project has restricted its auto-merge settings, then the settings of the project will be returned.\n\nThe authenticated user must have REPO_READ permission for this repository to call the resource.", + "operationId": "get_5", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The pull request auto-merge settings", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoMergeRestrictedSettings" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the pull request auto-merge settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Repository" + ], + "summary": "Create or update the pull request auto-merge settings", + "description": "Creates or updates the pull request auto-merge settings for the supplied repository.\n\nThe authenticated user must have REPO_ADMIN permission for this repository to call the resource.", + "operationId": "set_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The settings to create or update", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoMergeSettingsRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The pull request auto-merge settings", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoMergeRestrictedSettings" + } + } + } + }, + "400": { + "description": "The 'enabled' field was not provided correctly.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create or update the pull request auto-merge settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The pull request auto-merge settings cannot be modified due to a restriction enforced by the supplied repository's project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Repository" + ], + "summary": "Delete pull request auto-merge settings", + "description": "Deletes pull request auto-merge settings for the supplied repository.\n\nThe authenticated user must have REPO_ADMIN permission for this repository to call the resource.", + "operationId": "delete_5", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The pull request auto-merge settings" + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the pull request auto-merge settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "403": { + "description": "The pull request auto-merge settings cannot be modified due to a restriction enforced by the supplied repository's project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get repository hooks", + "description": "Retrieve a page of repository hooks for this repository. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "getRepositoryHooks_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "type", + "in": "query", + "description": "The optional type to filter by.", + "schema": { + "type": "string", + "enum": [ + "PRE_RECEIVE", + "POST_RECEIVE" + ] + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of repository hooks with their associated enabled state.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepositoryHook" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the hooks.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get repository hook", + "description": "Retrieve a repository hook for this repository. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "getRepositoryHook_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "hookKey", + "in": "path", + "description": "The hook key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The repository hooks with their associated enabled state for the supplied hookKey.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryHook" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the hook.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository hook does not exist for the given repository, or the repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Repository" + ], + "summary": "Delete repository hook", + "description": "Delete repository hook configuration for the supplied hookKey and repositorySlug\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "deleteRepositoryHook", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "hookKey", + "in": "path", + "description": "The hook key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The hook configuration matching the supplied hookKey and repositorySlug was deleted" + }, + "400": { + "description": "The settings specified are invalid.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the hook.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or hook does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}/enabled": { + "put": { + "tags": [ + "Repository" + ], + "summary": "Enable repository hook", + "description": "Enable a repository hook for this repository and optionally apply new configuration. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource. \n\nA JSON document may be provided to use as the settings for the hook. These structure and validity of the document is decided by the plugin providing the hook.", + "operationId": "enableHook_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "hookKey", + "in": "path", + "description": "The hook key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "Content-Length", + "in": "header", + "description": "The content length.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The repository hooks with their associated enabled state for the supplied hookKey.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryHook" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to enable the hook.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or hook does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Repository" + ], + "summary": "Disable repository hook", + "description": "Disable a repository hook for this repository. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "disableHook_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "hookKey", + "in": "path", + "description": "The hook key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The repository hooks with their associated enabled state for the supplied hookKey.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryHook" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to disable the hook.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or hook does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}/settings": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get repository hook settings", + "description": "Retrieve the settings for a repository hook for this repository. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "getSettings_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "hookKey", + "in": "path", + "description": "The hook key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The settings for the hook.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ExampleSettings" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the hook settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or hook does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Repository" + ], + "summary": "Update repository hook settings", + "description": "Modify the settings for a repository hook for this repository. \n\nThe service will reject any settings which are too large, the current limit is 32KB once serialized. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource. \n\nA JSON document can be provided to use as the settings for the hook. These structure and validity of the document is decided by the plugin providing the hook.", + "operationId": "setSettings_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "hookKey", + "in": "path", + "description": "The hook key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The raw settings.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ExampleSettings" + } + } + } + }, + "responses": { + "200": { + "description": "The settings for the hook.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ExampleSettings" + } + } + } + }, + "400": { + "description": "The settings specified are invalid.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to modify the hook settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository or hook does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/pull-requests": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get pull request settings", + "description": "Retrieve the pull request settings for the context repository. \n\nThe authenticated user must have REPO_READ permission for the context repository to call this resource. \n\nThis resource will call all RestFragments that are registered with the key bitbucket.repository.settings.pullRequests. If any fragment fails validations by returning a non-empty Map of errors, then no fragments will execute. \n\nThe property keys for the settings that are bundled with the application are \n\n- mergeConfig - the merge strategy configuration for pull requests\n- requiredApprovers - (Deprecated, please use com.atlassian.bitbucket.server.bundled-hooks.requiredApproversMergeHook instead) the number of approvals required on a pull request for it to be mergeable, or 0 if the merge check is disabled\n- com.atlassian.bitbucket.server.bundled-hooks.requiredApproversMergeHook - the merge check configuration for required approvers\n- requiredAllApprovers - whether or not all approvers must approve a pull request for it to be mergeable\n- requiredAllTasksComplete - whether or not all tasks on a pull request need to be completed for it to be mergeable\n- requiredSuccessfulBuilds - (Deprecated, please use com.atlassian.bitbucket.server.bitbucket-build.requiredBuildsMergeCheck instead) the number of successful builds on a pull request for it to be mergeable, or 0 if the merge check is disabled\n- com.atlassian.bitbucket.server.bitbucket-build.requiredBuildsMergeCheck - the merge check configuration for required builds\n\n\n", + "operationId": "getPullRequestSettings_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The repository pull request settings for the context repository.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryPullRequestSettings" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to see the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Repository" + ], + "summary": "Update pull request settings", + "description": "Update the pull request settings for the context repository. \n\nThe authenticated user must have REPO_ADMIN permission for the context repository to call this resource. \n\nThis resource will call all RestFragments that are registered with the key bitbucket.repository.settings.pullRequests. If any fragment fails validations by returning a non-empty Map of errors, then no fragments will execute. \n\nOnly the settings that should be updated need to be included in the request. \n\nThe property keys for the settings that are bundled with the application are \n\n- mergeConfig - the merge strategy configuration for pull requests\n- requiredApprovers - (Deprecated, please use com.atlassian.bitbucket.server.bundled-hooks.requiredApproversMergeHook instead) the number of approvals required on a pull request for it to be mergeable, or 0 to disable the merge check\n- com.atlassian.bitbucket.server.bundled-hooks.requiredApproversMergeHook - a json map containing the keys 'enabled' (a boolean to enable or disable this merge check) and 'count' (an integer to set the number of required approvals)\n- requiredAllApprovers - whether or not all approvers must approve a pull request for it to be mergeable\n- requiredAllTasksComplete - whether or not all tasks on a pull request need to be completed for it to be mergeable\n- requiredSuccessfulBuilds - (Deprecated, please use com.atlassian.bitbucket.server.bitbucket-build.requiredBuildsMergeCheck instead) the number of successful builds on a pull request for it to be mergeable, or 0 to disable the merge check\n- com.atlassian.bitbucket.server.bitbucket-build.requiredBuildsMergeCheck - a json map containing the keys 'enabled' (a boolean to enable or disable this merge check) and 'count' (an integer to set the number of required builds)\n\n\nMerge strategy configuration deletion:\n\nAn explicitly set pull request merge strategy configuration can be deleted by POSTing a document with an empty \"mergeConfig\" attribute. i.e: \n\n\n```{ \n \"mergeConfig\": { \n } \n} \n```\n\nUpon completion of this request, the effective configuration will be: \n\n- The configuration set for this repository's SCM type as set at the project level, if present, otherwise\n- the configuration set for this repository's SCM type as set at the instance level, if present, otherwise\n- the default configuration for this repository's SCM type\n\n\n", + "operationId": "updatePullRequestSettings_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The updated settings.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryPullRequestSettings" + } + } + } + }, + "responses": { + "200": { + "description": "The repository pull request settings for the context repository.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryPullRequestSettings" + } + } + } + }, + "400": { + "description": "The repository pull request settings were not updated due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to see the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get all reviewer groups", + "description": "Retrieve a page of reviewer groups of a given scope.\n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "getReviewerGroups_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A `page` of reviewer group(s) of the provided scope and its inherited scope.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestReviewerGroup" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository scope supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Create reviewer group", + "description": "Create a reviewer group.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "create_2", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request containing the details of the reviewer group.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestReviewerGroup" + } + } + } + }, + "responses": { + "201": { + "description": "The newly created reviewer group.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestReviewerGroup" + } + } + } + }, + "400": { + "description": "The request is missing a reviewer group name.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository scope supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The new created name already exists.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups/{id}": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get reviewer group", + "description": "Retrieve a reviewer group.\n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "getReviewerGroup_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The ID of the reviewer group to be retrieved", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The reviewer group.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestReviewerGroup" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The ID supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Pull Requests" + ], + "summary": "Update reviewer group attributes", + "description": "Update the attributes of a reviewer group.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "update_2", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The ID of the reviewer group to be updated", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request containing the attributes of the reviewer group to be updated. Only the attributes to be updated need to be present in this object.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestReviewerGroup" + } + } + } + }, + "responses": { + "200": { + "description": "The updated reviewer group.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestReviewerGroup" + } + } + } + }, + "400": { + "description": "The updated attribute does not meet the requirements. E.g. the name exceeds 50 characters, setting name to blank.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository scope supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The new updated name already exists.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Pull Requests" + ], + "summary": "Delete reviewer group", + "description": "Deletes a reviewer group.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "delete_7", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The ID of the reviewer group to be deleted", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The operation was successful" + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the reviewer group in this repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied reviewer group ID.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups/{id}/users": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get reviewer group users", + "description": "Retrieve a list of the users of a reviewer group.\n\nThis does not return all the users of the group, only the users who are licensed and have REPO_READ permission for the specified repository.\n\nThe authenticated user must have REPO_READ permission for the specified repository to call this resource.", + "operationId": "getUsers", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The ID of the reviewer group to be retrieved", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The list of users of a reviewer group.", + "content": { + "application/json;charset=UTF-8": { + "schema": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestApplicationUser" + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json;charset=UTF-8": { + "schema": { + "$ref": "#/components/schemas/RestErrors" + } + } + } + }, + "404": { + "description": "The ID supplied does not exist.d", + "content": { + "application/json;charset=UTF-8": { + "schema": { + "$ref": "#/components/schemas/RestErrors" + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/tags": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Find tag", + "description": "Retrieve the tags matching the supplied filterText param. \n\nThe authenticated user must have REPO_READ permission for the context repository to call this resource.", + "operationId": "getTags", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "orderBy", + "in": "query", + "description": "Ordering of refs either ALPHABETICAL (by name) or MODIFICATION (last updated)", + "schema": { + "type": "string" + } + }, + { + "name": "filterText", + "in": "query", + "description": "The text to match on.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "The tags matching the supplied filterText.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestTag" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to read the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Repository" + ], + "summary": "Create tag", + "description": "Creates a tag using the information provided in the RestCreateTagRequest request \n\nThe authenticated user must have REPO_WRITE permission for the context repository to call this resource.", + "operationId": "createTagForRepository", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request to create a tag containing a name, startPoint, and optionally a message", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestCreateTagRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The created tag.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestTag" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to write to the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/tags/{name}": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get tag", + "description": "Retrieve a tag in the specified repository. \n\nThe authenticated user must have REPO_READ permission for the context repository to call this resource.", + "operationId": "getTag", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "name", + "in": "path", + "description": "The name of the tag to be retrieved.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The tag which matches the supplied name.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestTag" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to read the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified tag does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/watch": { + "post": { + "tags": [ + "Repository" + ], + "summary": "Watch repository", + "description": "Add the authenticated user as a watcher for the specified repository. \n\nThe authenticated user must have REPO_READ permission for the repository to call this resource.", + "operationId": "watch_2", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The repository to watch.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepository" + } + } + } + }, + "responses": { + "204": { + "description": "The user is now watching the repository." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Repository" + ], + "summary": "Stop watching repository", + "description": "Remove the authenticated user as a watcher for the specified repository. \n\nThe authenticated user must have REPO_READ permission for the repository to call this resource.", + "operationId": "unwatch_2", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The user is no longer watching the repository." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Find webhooks", + "description": "Find webhooks in this repository. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "findWebhooks_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "event", + "in": "query", + "description": "List of com.atlassian.webhooks.WebhookEvent IDs to filter for", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "statistics", + "in": "query", + "description": "true if statistics should be provided for all found webhooks", + "schema": { + "type": "boolean" + } + } + ], + "responses": { + "200": { + "description": "A page of webhooks.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to find webhooks in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Repository" + ], + "summary": "Create webhook", + "description": "Create a webhook for the repository specified via the URL. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "createWebhook_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The webhook to be created for this repository.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhook" + } + } + } + }, + "responses": { + "200": { + "description": "A created webhook.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhook" + } + } + } + }, + "400": { + "description": "The webhook parameters were invalid or not supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create webhooks in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/search": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Search webhooks", + "description": "Search webhooks in this repository and parent project. This endpoint returns a superset of the results returned by the /webhooks endpoint because it allows filtering by project scope too, not just repository webhooks.\n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "searchWebhooks", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "scopeType", + "in": "query", + "description": "Scopes to filter by. This parameter can be specified once e.g. \"scopeType=repository\", or twice e.g. \"scopeType=repository&scopeType=project\", to filter by more than one scope level. ", + "schema": { + "type": "string" + } + }, + { + "name": "event", + "in": "query", + "description": "List of com.atlassian.webhooks.WebhookEvent ids to filter for", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "statistics", + "in": "query", + "description": "true if statistics should be provided for all found webhooks", + "schema": { + "type": "boolean" + } + } + ], + "responses": { + "200": { + "description": "A page of webhooks.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to find webhooks in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/test": { + "post": { + "tags": [ + "Repository" + ], + "summary": "Test webhook", + "description": "Test connectivity to a specific endpoint. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "testWebhook_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "query", + "schema": { + "type": "integer", + "format": "int32" + } + }, + { + "name": "sslVerificationRequired", + "in": "query", + "description": "Whether SSL verification is required for the specified webhook URL. Default value is true.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "url", + "in": "query", + "description": "The url in which to connect to", + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "Basic authentication credentials, if required.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhookCredentials" + } + } + } + }, + "responses": { + "200": { + "description": "A webhook.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhookRequestResponse" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to test a connection.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get webhook", + "description": "Get a webhook by ID. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "getWebhook_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "path", + "description": "ID of the webhook", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "statistics", + "in": "query", + "description": "true if statistics should be provided for the webhook", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A webhook.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhook" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to get a webhook in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository does not exist, or the webhook does not exist in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Repository" + ], + "summary": "Update webhook", + "description": "Update an existing webhook. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "updateWebhook_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "path", + "description": "Id of the existing webhook", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The representation of the updated values for the webhook", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhook" + } + } + } + }, + "responses": { + "200": { + "description": "A webhook.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhook" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update a webhook in this repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository does not exist, or the webhook does not exist in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Repository" + ], + "summary": "Delete webhook", + "description": "Delete a webhook for the repository specified via the URL. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "deleteWebhook_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "path", + "description": "The ID of the webhook to be deleted.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The webhook for the repository has been deleted." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete webhooks in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist, or webhook does not exist in this repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}/latest": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get last webhook invocation details", + "description": "Get the latest invocations for a specific webhook. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "getLatestInvocation_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "path", + "description": "ID of the webhook", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "event", + "in": "query", + "description": "The string ID of a specific event to retrieve the last invocation for.", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "outcome", + "in": "query", + "description": "The outcome to filter for. Can be SUCCESS, FAILURE, ERROR. None specified means that the all will be considered", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A webhook invocation dataset.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestDetailedInvocation" + } + } + } + }, + "204": { + "description": "No webhook invocations exist." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to get webhook invocations in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist, or the webhook does not exist in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}/statistics": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get webhook statistics", + "description": "Get the statistics for a specific webhook. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "getStatistics_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "path", + "description": "ID of the webhook", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "event", + "in": "query", + "description": "The string ID of a specific event to retrieve the last invocation for. May be empty, in which case all events are considered", + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A webhook invocation dataset.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestInvocationHistory" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to get webhook statistics in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist, or the webhook does not exist in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}/statistics/summary": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Get webhook statistics summary", + "description": "Get the statistics summary for a specific webhook. \n\nThe authenticated user must have REPO_ADMIN permission for the specified repository to call this resource.", + "operationId": "getStatisticsSummary_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "path", + "description": "ID of the webhook", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "repositorySlug", + "in": "path", + "description": "The repository slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A webhook invocation dataset.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestInvocationHistory" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to get webhook statistics summary in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The repository does not exist, or the webhook does not exist in the repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/secret-scanning/allowlist": { + "get": { + "tags": [ + "Security" + ], + "summary": "Find project secret scanning allowlist rules", + "description": "Find project secret scanning allowlist rules by filtering.\n\nProject **Admin** is required", + "operationId": "searchAllowlistRule", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "Filter names by the provided text", + "schema": { + "type": "string" + }, + "example": "Access" + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "order", + "in": "query", + "description": "Order by", + "schema": { + "type": "string", + "enum": [ + "NAME_ASC", + "NAME_DESC" + ] + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "Page of allowlist rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestSecretScanningAllowlistRule" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request was not correctly formed allowlist rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to view project allowlist rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Security" + ], + "summary": "Create project secret scanning allowlist rule", + "description": "Create a new project level secret scanning allowlist rule. Project allowlist rules are used when scanning all non exempt repositories in the provided project.\n\nProject **Admin** is required", + "operationId": "createAllowlistRule", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "Allowlist rule to create, either the line regular expression or the path regular expression must be present", + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningAllowlistRuleSetRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "The created allowlist rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningAllowlistRule" + } + } + } + }, + "400": { + "description": "The request did not contain a correctly formed allowlist rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to create project allowlist rules.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/secret-scanning/allowlist/{id}": { + "get": { + "tags": [ + "Security" + ], + "summary": "Get a project secret scanning allowlist rule", + "description": "Get a project secret scanning allowlist rule by ID.\n\nProject **Admin** is required", + "operationId": "getAllowlistRule", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The allowlist rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + } + ], + "responses": { + "200": { + "description": "The requested allowlist rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningAllowlistRule" + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to view project allowlist rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The requested allowlist rules was not found", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Security" + ], + "summary": "Edit an existing project secret scanning allowlist rule", + "description": "Edit a project secret scanning allowlist rule.\n\nProject **Admin** is required", + "operationId": "editAllowlistRule", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The allowlist rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + } + ], + "requestBody": { + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningAllowlistRuleSetRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "The updated allowlist rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningAllowlistRule" + } + } + } + }, + "400": { + "description": "The request did not contain a correctly formed allowlist rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to modify project allowlist rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Security" + ], + "summary": "Delete a project secret scanning allowlist rule", + "description": "Delete a project secret scanning allowlist rule with the provided ID.\n\nProject **Admin** is required", + "operationId": "deleteAllowlistRule", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The allowlist rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + } + ], + "responses": { + "204": { + "description": "Empty response indicating that the rule was deleted, or not found at this location" + }, + "401": { + "description": "The authenticated user is not permitted to delete project rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/secret-scanning/exempt": { + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "get": { + "tags": [ + "Security" + ], + "summary": "Find repos exempt from secret scanning for a project", + "description": "Find repositories exempt from secret scanning in a project", + "operationId": "findExemptReposByProject", + "parameters": [ + { + "name": "order", + "in": "query", + "description": "Order by project name followed by repository name either ascending or descending, defaults to ascending.", + "schema": { + "type": "string", + "enum": [ + "NAME_ASC", + "NAME_DESC" + ] + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "Page of repositories", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepository" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to search exempt repositories for this project", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Security" + ], + "summary": "Bulk exempt repos from secret scanning", + "description": "Bulk exempt a list of repositories from being scanned for secrets. User must be have **PROJECT ADMIN** permissions.", + "operationId": "bulkAddExemptRepositories_1", + "requestBody": { + "content": { + "*/*": { + "schema": { + "uniqueItems": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepositorySelector" + } + } + } + } + }, + "responses": { + "204": { + "description": "All requested repositories were made exempt" + }, + "401": { + "description": "The authenticated user is not permitted to exempt a repository from secret scanning. No repositories were made exempt.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/secret-scanning/rules": { + "get": { + "tags": [ + "Security" + ], + "summary": "Find project secret scanning rules", + "description": "Find project secret scanning rules by filtering.\n\nProject **Admin** is required", + "operationId": "search_1", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "Filter names by the provided text", + "schema": { + "type": "string" + }, + "example": "Access" + }, + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "order", + "in": "query", + "description": "Order by", + "schema": { + "type": "string", + "enum": [ + "NAME_ASC", + "NAME_DESC" + ] + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "Page of rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestSecretScanningRule" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request was not correctly formed rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to view project rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Security" + ], + "summary": "Create project secret scanning rule", + "description": "Create a new project level secret scanning rule. Project rules are used when scanning all non exempt repositories in the provided project.\n\nProject **Admin** is required", + "operationId": "createRule", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "Rule to create, either the line regular expression or the path regular expression must be present", + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRuleSetRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "The created rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRule" + } + } + } + }, + "400": { + "description": "The request did not contain a correctly formed rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to create project rules.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/secret-scanning/rules/{id}": { + "get": { + "tags": [ + "Security" + ], + "summary": "Get a project secret scanning rule", + "description": "Get a project secret scanning rule by ID.\n\nProject **Admin** is required", + "operationId": "getRule", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + } + ], + "responses": { + "200": { + "description": "The requested rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRule" + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to view project rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The requested rules was not found", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Security" + ], + "summary": "Edit an existing project secret scanning rule", + "description": "Edit a project secret scanning rule.\n\nProject **Admin** is required", + "operationId": "editRule", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + } + ], + "requestBody": { + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRuleSetRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "The updated rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRule" + } + } + } + }, + "400": { + "description": "The request did not contain a correctly formed rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to modify project rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Security" + ], + "summary": "Delete a project secret scanning rule", + "description": "Delete a project secret scanning rule with the provided ID.\n\nProject **Admin** is required", + "operationId": "deleteRule", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + } + ], + "responses": { + "204": { + "description": "Empty response indicating that the rule was deleted, or not found at this location" + }, + "401": { + "description": "The authenticated user is not permitted to delete project rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/settings-restriction": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get enforcing project setting", + "description": "Get a specified project settings restriction for the given namespace, feature key and component key.\nNote that not providing the component key will **not** return restrictions for the namespace and feature key with a component key set.\n\nThe authenticated user must have **PROJECT_VIEW** permission for the target project to retrieve a settings restriction.", + "operationId": "get_7", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "namespace", + "in": "query", + "description": "The namespace used to identify the provider of the feature", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "componentKey", + "in": "query", + "description": "The component key to uniquely identify individually restrictable subcomponents of a feature within the provided feature key and namespace", + "schema": { + "type": "string" + } + }, + { + "name": "featureKey", + "in": "query", + "description": "The feature key to uniquely identify the feature within the provided namespace", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The settings restriction associated with the provided namespace and feature key", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestProjectSettingsRestriction" + } + } + } + }, + "400": { + "description": "The settings restriction could not be retrieved because the provided parameters were invalid. Possible issues include:\n\n- The namespace was not provided, or longer than 255 characters\n- The featureKey was not provided, or longer than 255 characters\n- The provided componentKey was fewer than 2 characters, or longer than 255 characters", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve a settings restriction", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project, or settings restriction does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Project" + ], + "summary": "Enforce project restriction", + "description": "Create a new project settings restriction for the given project.\n\nThe authenticated user must have **PROJECT_ADMIN** permission for the target project to create a settings restriction.", + "operationId": "create_3", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The project settings restriction to create", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestProjectSettingsRestrictionRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "The settings restriction was successfully created", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestProjectSettingsRestriction" + } + } + } + }, + "400": { + "description": "The settings restriction was not created because the request was invalid. Possible issues include:\n\n- The namespace was not provided, or longer than 255 characters\n- The featureKey was not provided, or longer than 255 characters\n- The provided componentKey was fewer than 2 characters, or longer than 255 characters", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create a settings restriction", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "A settings restriction with the same namespace, featureKey and componentKey already exists on this project", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Project" + ], + "summary": "Stop enforcing project restriction", + "description": "Delete a specified project settings restriction.\n\nIf a restriction does not exist for the specified project, namespace, featureKey, and componentKey, the request will be ignored and a 204 response will be returned.\n\nThe authenticated user must have **PROJECT_ADMIN** permission for the target project to delete a settings restriction.", + "operationId": "delete_9", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "namespace", + "in": "query", + "description": "A namespace used to identify the provider of the feature", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "componentKey", + "in": "query", + "description": "A key to uniquely identify individually restrictable subcomponents of a feature within the provided feature key and namespace", + "schema": { + "type": "string" + } + }, + { + "name": "featureKey", + "in": "query", + "description": "A key to uniquely identify the feature within the provided namespace", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The specified settings restriction was successfully deleted or there were no existing restrictions that match the specified criteria." + }, + "400": { + "description": "The settings restriction was not deleted because the request was invalid. Possible issues include:\n\n- The namespace was not provided, or longer than 255 characters\n- The featureKey was not provided, or longer than 255 characters\n- The provided componentKey was fewer than 2 characters, or longer than 255 characters", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete a settings restriction", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/settings-restriction/all": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get all enforcing project settings", + "description": "Get all project settings restrictions for the given namespace and feature key, including those with a component key set.\n\nThe authenticated user must have **PROJECT_VIEW** permission for the target project to retrieve a settings restrictions.", + "operationId": "getAll", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "namespace", + "in": "query", + "description": "A namespace used to identify the provider of the feature", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "featureKey", + "in": "query", + "description": "A key to uniquely identify the feature within the provided namespace", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of settings restrictions associated with the provided namespace and feature key", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestProjectSettingsRestriction" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The settings restrictions could not be retrieved because the provided parameters were invalid. Possible issues include:\n\n- The namespace was not provided, or longer than 255 characters\n- The featureKey was not provided, or longer than 255 characters", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve project settings restrictions", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/settings/auto-decline": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get auto decline settings", + "description": "Retrieves the auto decline settings for the supplied project. Default settings are returned if no explicit settings have been set for the project.", + "operationId": "getAutoDeclineSettings", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The auto decline settings", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoDeclineSettings" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the auto decline settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Project" + ], + "summary": "Create/Update auto decline settings", + "description": "Creates or updates the auto decline settings for the supplied project.\n\nThe authenticated user must have PROJECT_ADMIN permission for this project to call the resource.", + "operationId": "setAutoDeclineSettings", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The settings to create or update", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoDeclineSettingsRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The auto decline settings", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoDeclineSettings" + } + } + } + }, + "400": { + "description": "inactivityWeeks was not one of 1, 2, 4, 8, or, 12, or the enabled parameter was not included in the request.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create or update the auto decline settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Project" + ], + "summary": "Delete auto decline settings", + "description": "Delete auto decline settings for the supplied project.\n\nThe authenticated user must have PROJECT_ADMIN permission for this project to call the resource.", + "operationId": "deleteAutoDeclineSettings", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The auto decline settings have been deleted successfully." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the auto decline settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/settings/auto-merge": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get pull request auto-merge settings", + "description": "Retrieves the pull request auto-merge settings for the supplied project. Default settings will be returned if no explicit settings have been set for the project\n\nThe authenticated user must have PROJECT_VIEW permission for this project to call the resource.", + "operationId": "get_4", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The pull request auto-merge settings", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoMergeRestrictedSettings" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the pull request auto-merge settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Project" + ], + "summary": "Create or update the pull request auto-merge settings", + "description": "Creates or updates the pull request auto-merge settings for the supplied project, and applies the restriction action specified in the request.\n\nThe authenticated user must have PROJECT_ADMIN permission for this project to call the resource.", + "operationId": "set", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The settings to create or update", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoMergeProjectSettingsRequest" + } + } + } + }, + "responses": { + "200": { + "description": "The pull request auto-merge settings", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestAutoMergeRestrictedSettings" + } + } + } + }, + "400": { + "description": "The 'enabled' and 'restrictionAction' fields were not provided correctly.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create or update the pull request auto-merge settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Project" + ], + "summary": "Delete pull request auto-merge settings", + "description": "Deletes pull request auto-merge settings for the supplied project.\n\nThe authenticated user must have PROJECT_ADMIN permission for this project to call the resource.", + "operationId": "delete_4", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The pull request auto-merge settings" + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the pull request auto-merge settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/settings/hooks": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get repository hooks", + "description": "Retrieve a page of repository hooks for this project. \n\nThe authenticated user must have PROJECT_READ permission for the specified project to call this resource.", + "operationId": "getRepositoryHooks", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "type", + "in": "query", + "description": "The optional type to filter by.", + "schema": { + "type": "string", + "enum": [ + "PRE_RECEIVE", + "POST_RECEIVE" + ] + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of repository hooks with their associated enabled state.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepositoryHook" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the hooks.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/settings/hooks/{hookKey}": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get a repository hook", + "description": "Retrieve a repository hook for this project. \n\nThe authenticated user must have PROJECT_READ permission for the specified project to call this resource.", + "operationId": "getRepositoryHook", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "hookKey", + "in": "path", + "description": "The hook key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "Returns the repository hooks with their associated enabled state for the supplied hookKey.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryHook" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to enable the hook.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository hook does not exist for the given project, or the project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/settings/hooks/{hookKey}/enabled": { + "put": { + "tags": [ + "Project" + ], + "summary": "Enable repository hook", + "description": "Enable a repository hook for this project and optionally apply new configuration. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource. \n\nA JSON document may be provided to use as the settings for the hook. These structure and validity of the document is decided by the plugin providing the hook.", + "operationId": "enableHook", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "hookKey", + "in": "path", + "description": "The hook key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "Content-Length", + "in": "header", + "description": "The content length.", + "schema": { + "type": "integer", + "format": "int64" + } + } + ], + "responses": { + "200": { + "description": "The repository hooks with their associated enabled state for the supplied hookKey.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryHook" + } + } + } + }, + "400": { + "description": "The settings specified are invalid.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to enable the hook.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project or hook does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Project" + ], + "summary": "Disable repository hook", + "description": "Disable a repository hook for this project. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "disableHook", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "hookKey", + "in": "path", + "description": "The hook key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The repository hooks with their associated enabled state for the supplied hookKey.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestRepositoryHook" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to disable the hook.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project or hook does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/settings/hooks/{hookKey}/settings": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get repository hook settings", + "description": "Retrieve the settings for a repository hook for this project. \n\nThe authenticated user must have PROJECT_READ permission for the specified project to call this resource.", + "operationId": "getSettings", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "hookKey", + "in": "path", + "description": "The hook key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The settings for the hook.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ExampleSettings" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the hook settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project or hook does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Project" + ], + "summary": "Update repository hook settings", + "description": "Modify the settings for a repository hook for this project. \n\nThe service will reject any settings which are too large, the current limit is 32KB once serialized. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource. \n\nA JSON document can be provided to use as the settings for the hook. These structure and validity of the document is decided by the plugin providing the hook.", + "operationId": "setSettings", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "hookKey", + "in": "path", + "description": "The complete module key of the hook module.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The raw settings.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ExampleSettings" + } + } + } + }, + "responses": { + "200": { + "description": "The settings for the hook.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ExampleSettings" + } + } + } + }, + "400": { + "description": "The settings specified are invalid.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to modify the hook settings.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project or hook does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/settings/pull-requests/{scmId}": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get merge strategy", + "description": "Retrieve the merge strategy configuration for this project and SCM. \n\nThe authenticated user must have PROJECT_READ permission for the context repository to call this resource.", + "operationId": "getPullRequestSettings", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "scmId", + "in": "path", + "description": "The SCM to get strategies for.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The merge configuration of the request project.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestSettings" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to see the request repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The request repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Project" + ], + "summary": "Update merge strategy", + "description": "Update the pull request merge strategy configuration for this project and SCM. \n\nThe authenticated user must have PROJECT_ADMIN permission for the context repository to call this resource. \n\nOnly the strategies provided will be enabled, the default must be set and included in the set of strategies. \n\nAn explicitly set pull request merge strategy configuration can be deleted by POSTing a document with an empty \"mergeConfig\" attribute. i.e: \n
{ \n    \"mergeConfig\": {} \n} \n
\n\nUpon completion of this request, the effective configuration will be the configuration explicitly set for the SCM, or if no such explicit configuration is set then the default configuration will be used.", + "operationId": "updatePullRequestSettings", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "scmId", + "in": "path", + "description": "The SCM to get strategies for.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The settings.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestSettings" + } + } + } + }, + "responses": { + "200": { + "description": "The merge configuration of the request project.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestPullRequestSettings" + } + } + } + }, + "400": { + "description": "The repository pull request merge strategies were not updated due to a validation error.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to administrate the specified repository.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified repository does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/settings/reviewer-groups": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get all reviewer groups", + "description": "Retrieve a page of reviewer groups of a given scope.\n\nThe authenticated user must have PROJECT_READ permission for the specified project to call this resource.", + "operationId": "getReviewerGroups", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of reviewer group(s) of the provided scope.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestReviewerGroup" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The project scope supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Pull Requests" + ], + "summary": "Create reviewer group", + "description": "Create a reviewer group.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "create_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The reviewer group to be create", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestReviewerGroup" + } + } + } + }, + "responses": { + "201": { + "description": "The newly created reviewer group.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestReviewerGroup" + } + } + } + }, + "400": { + "description": "The request is missing a reviewer group name.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The project scope supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The new created name already exists.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/settings/reviewer-groups/{id}": { + "get": { + "tags": [ + "Pull Requests" + ], + "summary": "Get reviewer group", + "description": "Retrieve a reviewer group.\n\nThe authenticated user must have PROJECT_READ permission for the specified project to call this resource.", + "operationId": "getReviewerGroup", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The ID of the reviewer group to be retrieved", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The reviewer group.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestReviewerGroup" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The ID supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Pull Requests" + ], + "summary": "Update reviewer group attributes", + "description": "Update the attributes of a reviewer group.\n\nThe authenticated user must have PROJECT_READ permission for the specified project to call this resource.", + "operationId": "update_1", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The ID of the reviewer group to be updated", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The request containing the attributes of the reviewer group to be updated. Only the attributes to be updated need to be present in this object.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestReviewerGroup" + } + } + } + }, + "responses": { + "200": { + "description": "A page of changes.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestReviewerGroup" + } + } + } + }, + "400": { + "description": "The updated attribute does not meet the requirements. E.g. the name exceeds 50 characters, setting name to blank.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The project scope supplied does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "The new updated name already exists.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Pull Requests" + ], + "summary": "Delete reviewer group", + "description": "Deletes a reviewer group.\n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "delete_6", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "description": "The ID of the reviewer group to be deleted", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The operation was successful." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete the reviewer group in this project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "Unable to find the supplied reviewer group ID.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/webhooks": { + "get": { + "tags": [ + "Project" + ], + "summary": "Find webhooks", + "description": "Find webhooks in this project. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "findWebhooks", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "event", + "in": "query", + "description": "List of com.atlassian.webhooks.WebhookEvent IDs to filter for", + "schema": { + "type": "string" + } + }, + { + "name": "statistics", + "in": "query", + "description": "true if statistics should be provided for all found webhooks", + "schema": { + "type": "boolean" + } + } + ], + "responses": { + "200": { + "description": "A page of webhooks.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to find webhooks in the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Project" + ], + "summary": "Create webhook", + "description": "Create a webhook for the project specified via the URL. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "createWebhook", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The webhook to be created for this project.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhook" + } + } + } + }, + "responses": { + "200": { + "description": "A created webhook.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhook" + } + } + } + }, + "400": { + "description": "The webhook parameters were invalid or not supplied.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to create webhooks in the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/webhooks/test": { + "post": { + "tags": [ + "Project" + ], + "summary": "Test webhook", + "description": "Test connectivity to a specific endpoint. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "testWebhook", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "query", + "schema": { + "type": "integer", + "format": "int32" + } + }, + { + "name": "sslVerificationRequired", + "in": "query", + "schema": { + "type": "boolean", + "default": true + } + }, + { + "name": "url", + "in": "query", + "description": "The url in which to connect to", + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "Basic authentication credentials, if required.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhookCredentials" + } + } + } + }, + "responses": { + "200": { + "description": "A webhook.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhookRequestResponse" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to test a connection.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/webhooks/{webhookId}": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get webhook", + "description": "Get a webhook by ID. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "getWebhook", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "path", + "description": "ID of the webhook", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "statistics", + "in": "query", + "description": "true if statistics should be provided for the webhook", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A webhook.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhook" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to get a webhook in the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The project does not exist, or the webhook does not exist in the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Project" + ], + "summary": "Update webhook", + "description": "Update an existing webhook. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "updateWebhook", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "path", + "description": "Id of the existing webhook", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "The representation of the updated values for the webhook", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhook" + } + } + } + }, + "responses": { + "200": { + "description": "A webhook.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestWebhook" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update a webhook in this project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The project does not exist, or the webhook does not exist in the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Project" + ], + "summary": "Delete webhook", + "description": "Delete a webhook for the project specified via the URL. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "deleteWebhook", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "path", + "description": "The ID of the webhook to be deleted.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "The webhook for the project has been deleted." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to delete webhooks in the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist, or webhook does not exist in this project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/webhooks/{webhookId}/latest": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get last webhook invocation details", + "description": "Get the latest invocations for a specific webhook. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "getLatestInvocation", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "path", + "description": "ID of the webhook", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "event", + "in": "query", + "description": "The string ID of a specific event to retrieve the last invocation for.", + "schema": { + "type": "string" + } + }, + { + "name": "outcome", + "in": "query", + "description": "The outcome to filter for. Can be SUCCESS, FAILURE, ERROR. None specified means that the all will be considered", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A webhook invocation dataset.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestDetailedInvocation" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to get webhook invocations in the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist, or the webhook does not exist in the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/webhooks/{webhookId}/statistics": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get webhook statistics", + "description": "Get the statistics for a specific webhook. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "getStatistics", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "path", + "description": "ID of the webhook", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "event", + "in": "query", + "description": "The string ID of a specific event to retrieve the last invocation for. May be empty, in which case all events are considered", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A webhook invocation dataset.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestInvocationHistory" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to get webhook statistics in the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project does not exist, or the webhook does not exist in the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/projects/{projectKey}/webhooks/{webhookId}/statistics/summary": { + "get": { + "tags": [ + "Project" + ], + "summary": "Get webhook statistics summary", + "description": "Get the statistics summary for a specific webhook. \n\nThe authenticated user must have PROJECT_ADMIN permission for the specified project to call this resource.", + "operationId": "getStatisticsSummary", + "parameters": [ + { + "name": "projectKey", + "in": "path", + "description": "The project key.", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "webhookId", + "in": "path", + "description": "ID of the webhook", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A webhook invocation dataset.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestInvocationHistory" + } + } + } + }, + "204": { + "description": "No webhook invocations exist." + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to get webhook statistics summary in the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The project does not exist, or the webhook does not exist in the project.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/repos": { + "get": { + "tags": [ + "Repository" + ], + "summary": "Search for repositories", + "description": "Retrieve a page of repositories based on query parameters that control the search. See the documentation of the parameters for more details. \n\nThis resource is anonymously accessible. \n\nNote on permissions. In absence of the permission query parameter the implicit 'read' permission is assumed. Please note that this permission is lower than the REPO_READ permission rather than being equal to it. The implicit 'read' permission for a given repository is assigned to any user that has any of the higher permissions, such as REPO_READ, as well as to anonymous users if the repository is marked as public. The important implication of the above is that an anonymous request to this resource with a permission level REPO_READ is guaranteed to receive an empty list of repositories as a result. For anonymous requests it is therefore recommended to not specify the permission parameter at all.", + "operationId": "getRepositories_1", + "parameters": [ + { + "name": "archived", + "in": "query", + "description": "(optional) if specified, this will limit the resulting repository list to ones whose are ACTIVE, ARCHIVED or ALL for both. The match performed is case-insensitive. This filter defaults to ACTIVE when not set. Available since 8.0", + "schema": { + "type": "string" + } + }, + { + "name": "projectname", + "in": "query", + "description": "(optional) if specified, this will limit the resulting repository list to ones whose project's name matches this parameter's value. The match performed is case-insensitive and any leading and/or trailing whitespace characters on the projectname parameter will be stripped.", + "schema": { + "type": "string" + } + }, + { + "name": "projectkey", + "in": "query", + "description": "(optional) if specified, this will limit the resulting repository list to ones whose project's key matches this parameter's value. The match performed is case-insensitive and any leading and/or trailing whitespace characters on the projectKey parameter will be stripped. Available since 8.0", + "schema": { + "type": "string" + } + }, + { + "name": "visibility", + "in": "query", + "description": "(optional) if specified, this will limit the resulting repository list based on the repositories visibility. Valid values are public or private.", + "schema": { + "type": "string", + "enum": [ + "public", + "private" + ] + } + }, + { + "name": "name", + "in": "query", + "description": "(optional) if specified, this will limit the resulting repository list to ones whose name matches this parameter's value. The match performed is case-insensitive and any leading and/or trailing whitespace characters on the name parameter will be stripped.", + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "query", + "description": "(optional) if specified, it must be a valid repository permission level name and will limit the resulting repository list to ones that the requesting user has the specified permission level to. If not specified, the default implicit 'read' permission level will be assumed. The currently supported explicit permission values are REPO_READ, REPO_WRITE and REPO_ADMIN.", + "schema": { + "type": "string", + "enum": [ + "REPO_READ", + "REPO_WRITE", + "REPO_ADMIN" + ] + } + }, + { + "name": "state", + "in": "query", + "description": "(optional) if specified, it must be a valid repository state name and will limit the resulting repository list to ones that are in the specified state. The currently supported explicit state values are AVAILABLE, INITIALISING and INITIALISATION_FAILED.
Available since 5.13", + "schema": { + "type": "string", + "enum": [ + "AVAILABLE", + "INITIALISING", + "INITIALISATION_FAILED" + ] + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "A page of repositories.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepository" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The visibility parameter contains an invalid value.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/secret-scanning/exempt": { + "get": { + "tags": [ + "Security" + ], + "summary": "Find all repos exempt from secret scan", + "description": "Find all repositories exempt from secret scanning", + "operationId": "findExemptReposByScope", + "parameters": [ + { + "name": "order", + "in": "query", + "description": "Order by project name followed by repository name either ascending or descending, defaults to ascending.", + "schema": { + "type": "string", + "enum": [ + "NAME_ASC", + "NAME_DESC" + ] + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "Page of repositories", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepository" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to search exempt repositories globally", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Security" + ], + "summary": "Bulk exempt repos from secret scanning", + "description": "Bulk exempt a list of repositories from being scanned for secrets. User must be have global **ADMIN** permissions.", + "operationId": "bulkAddExemptRepositories", + "requestBody": { + "content": { + "*/*": { + "schema": { + "uniqueItems": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/RestRepositorySelector" + } + } + } + } + }, + "responses": { + "204": { + "description": "All requested repositories were made exempt" + }, + "401": { + "description": "The authenticated user is not permitted to exempt a repository from secret scanning. No repositories were made exempt.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "409": { + "description": "At least one of specified repositories have already been previously made exempt.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/secret-scanning/rules": { + "get": { + "tags": [ + "Security" + ], + "summary": "Find global secret scanning rules", + "description": "Find global secret scanning rules by filtering.", + "operationId": "search_4", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "Filter by rule name", + "schema": { + "type": "string" + }, + "example": "Access" + }, + { + "name": "order", + "in": "query", + "description": "Order by", + "schema": { + "type": "string", + "enum": [ + "NAME_ASC", + "NAME_DESC" + ] + } + }, + { + "name": "start", + "in": "query", + "description": "Start number for the page (inclusive). If not passed, first page is assumed.", + "required": false, + "schema": { + "type": "number", + "example": 0 + }, + "example": 0 + }, + { + "name": "limit", + "in": "query", + "description": "Number of items to return. If not passed, a page size of 25 is used.", + "required": false, + "schema": { + "type": "number", + "example": 25 + }, + "example": 25 + } + ], + "responses": { + "200": { + "description": "Page of rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "values": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestSecretScanningRule" + } + }, + "size": { + "type": "number", + "example": 1 + }, + "limit": { + "type": "number", + "example": 25 + }, + "nextPageStart": { + "type": "integer", + "format": "int32" + }, + "isLastPage": { + "type": "boolean" + }, + "start": { + "type": "integer", + "format": "int32" + } + } + } + } + } + }, + "400": { + "description": "The request did not contain a correctly formed search request, see returned error for more details.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to search global rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Security" + ], + "summary": "Create global secret scanning rule", + "description": "Create a new global secret scanning rule. Global rules are used when scanning all non exempt repositories.", + "operationId": "createRule_2", + "requestBody": { + "description": "Rule to create, either the line regular expression or the path regular expression must be present", + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRuleSetRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "The created rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRule" + } + } + } + }, + "400": { + "description": "The request did not contain a correctly formed rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to create global rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/secret-scanning/rules/{id}": { + "get": { + "tags": [ + "Security" + ], + "summary": "Get a global secret scanning rule", + "description": "Get a global secret scanning rule by ID.", + "operationId": "getRule_2", + "parameters": [ + { + "name": "id", + "in": "path", + "description": "The rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + } + ], + "responses": { + "200": { + "description": "The requested rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRule" + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to get global rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The requested rule was not found", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "Security" + ], + "summary": "Edit a global secret scanning rule.", + "description": "Edit an existing global secret scanning rule", + "operationId": "editRule_2", + "parameters": [ + { + "name": "id", + "in": "path", + "description": "The rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + } + ], + "requestBody": { + "content": { + "*/*": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRuleSetRequest" + } + } + }, + "required": true + }, + "responses": { + "200": { + "description": "The updated rule", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSecretScanningRule" + } + } + } + }, + "400": { + "description": "The request did not contain a correctly formed rule. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to update global rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "Security" + ], + "summary": "Delete a global secret scanning rule", + "description": "Delete a global secret scanning rule with the provided ID", + "operationId": "deleteRule_2", + "parameters": [ + { + "name": "id", + "in": "path", + "description": "The rule id.", + "required": true, + "schema": { + "type": "string" + }, + "example": 7 + } + ], + "responses": { + "204": { + "description": "Empty response indicating that the rule was deleted" + }, + "401": { + "description": "The authenticated user is not permitted to delete global rules", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/signing/x509-certificates": { + "get": { + "tags": [ + "Security" + ], + "summary": "Get all X.509 certificates", + "description": "Get all X.509 certificates that have been added to the system.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "getAllCertificates", + "responses": { + "200": { + "description": "A page of X.509 certificates", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestX509Certificate" + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to get X.509 certificates", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "Security" + ], + "summary": "Create an X.509 certificate", + "description": "Create an X.509 certificate. This will add the given X.509 certificate to the system. Existing entries will not be overridden if an X.509 certificate already exists. Once added, an X.509 certificate cannot be updated.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "createCertificate", + "requestBody": { + "description": "The multipart form data containing the certificate in a form-field named 'certificate'", + "content": { + "multipart/form-data": { + "schema": { + "$ref": "#/components/schemas/ExampleCertificateMultipartFormData" + } + } + }, + "required": true + }, + "responses": { + "201": { + "description": "The newly created X.509 certificate", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestX509Certificate" + } + } + } + }, + "400": { + "description": "The request did not contain a valid X.509 certificate request. See returned error for more details", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to create X.509 certificates", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/signing/x509-certificates/crl/{id}": { + "put": { + "tags": [ + "Security" + ], + "summary": "Update X.509 CRL entries", + "description": "Update the certificate revocation list (CRL) entries for an issuer X.509 certificate in the system, identified by id. This will add any new revoked X.509 certificates that were issued by the given issuer X.509 certificate.\n\nThis endpoint will schedule a request to asynchronously perform the task. Please allow time for the task to complete as it will vary depending on how many CRLs there are to retrieve and process.\n\nNote: CRL updates are scheduled to run every 24 hours. You may wish to trigger a refresh manually using this endpoint, otherwise, entries will be updated daily.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "updateCertificateRevocationListEntries", + "parameters": [ + { + "name": "id", + "in": "path", + "description": "The ID of the issuer certificate.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "Successfully started processing CRLs.", + "content": { + "application/json": {} + } + }, + "401": { + "description": "The authenticated user is not permitted to update X.509 CRL entries", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "There is no X.509 certificate with the given ID", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/signing/x509-certificates/{id}": { + "delete": { + "tags": [ + "Security" + ], + "summary": "Delete an X.509 certificate", + "description": "Delete an X.509 certificate specified by the given ID.\n\nThe authenticated user must have the ADMIN permission to call this resource.", + "operationId": "deleteCertificate", + "parameters": [ + { + "name": "id", + "in": "path", + "description": "The ID of the X.509 certificate.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "204": { + "description": "An empty response if the X.509 certificate was successfully deleted", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestX509Certificate" + } + } + } + }, + "401": { + "description": "The authenticated user is not permitted to delete X.509 certificates", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "There is no X.509 certificate with the given ID", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/system-signing/configuration": { + "get": { + "tags": [ + "System Signing" + ], + "summary": "Get system signing configuration", + "description": "Gets the configuration details for system signing Git objects.", + "operationId": "getSystemSigningConfiguration", + "responses": { + "200": { + "description": "The configuration details for system signing Git objects", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSystemSigningConfiguration" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the configuration details for system signing Git objects.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "System Signing" + ], + "summary": "Update system signing configuration", + "description": "Updates the configuration for system signing Git objects.", + "operationId": "updateSystemSigningConfiguration", + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "enabled": { + "type": "boolean", + "example": false + } + } + } + } + } + }, + "responses": { + "200": { + "description": "The updated configuration details for system signing Git objects", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestSystemSigningConfiguration" + } + } + } + }, + "400": { + "description": "The configuration details could not be updated because the provided request was invalid", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to retrieve the configuration details for system signing Git objects.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/tasks": { + "post": { + "tags": [ + "Deprecated" + ], + "summary": "Create task", + "description": "Create a new task. \n\nRemoved in 8.0. Tasks are now managed using Comments with severity BLOCKER. Call POST /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments instead,passing the attribute 'severity' set to 'BLOCKER'.", + "operationId": "createTask", + "responses": { + "404": { + "description": "This endpoint has been removed as tasks are now managed using Comments with severity BLOCKER.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/api/latest/tasks/{taskId}": { + "get": { + "tags": [ + "Deprecated" + ], + "summary": "Get task", + "description": "Retrieve an existing task.\n\nRemoved in 8.0. Tasks are now managed using Comments with BLOCKER severity. Call GET /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId} instead. @deprecated since 7.2, changed to 404 in 8.0, remove in 9.0. Call GET /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId} instead.", + "operationId": "getTask", + "parameters": [ + { + "name": "taskId", + "in": "path", + "description": "the id identifying the task", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "404": { + "description": "This endpoint has been removed as tasks are now managed using Comments with severity BLOCKER.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + }, + "put": { + "tags": [ + "Deprecated" + ], + "summary": "Update task", + "description": "Update an existing task. \n\n Removed in 8.0. Tasks are now managed using Comments with BLOCKER severity. Call PUT /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId} instead. To resolve a task, pass the attribute 'state' set to 'RESOLVED'. @deprecated since 7.2, changed to 404 in 8.0, remove in 9.0. Call PUT /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}\n instead. \n\n As of Stash 3.3, only the state and text of a task can be updated. \n\n Updating the state of a task is allowed for any user having READ access to the repository. However only the task's creator, the context's author or an admin of the context's repository can update the task's text. (For a pull request task, those are the task's creator, the pull request's author or an admin on the repository containing the pull request). Additionally the task's text cannot be updated if it has been resolved.", + "operationId": "updateTask", + "parameters": [ + { + "name": "taskId", + "in": "path", + "description": "the id identifying the task to update", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "404": { + "description": "This endpoint has been removed as tasks are now managed using Comments with severity BLOCKER.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + }, + "delete": { + "tags": [ + "Deprecated" + ], + "summary": "Delete task", + "description": "Delete a task.\n\nRemoved in 8.0. Tasks are now managed using Comments with BLOCKER severity. Call DELETE /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}instead. @deprecated since 7.2, changed to 404 in 8.0, remove in 9.0. Call DELETE /rest/api/1.0/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId} instead.\n\nNote that only the task's creator, the context's author or an admin of the context's repository can delete a task. (For a pull request task, those are the task's creator, the pull request's author or an admin on the repository containing the pull request). Additionally a task cannot be deleted if it has already been resolved.", + "operationId": "deleteTask", + "parameters": [ + { + "name": "taskId", + "in": "path", + "description": "the id identifying the task to delete", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "404": { + "description": "This endpoint has been removed as tasks are now managed using Comments with severity BLOCKER.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + }, + "deprecated": true + } + }, + "/api/latest/users": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get all users", + "description": "Retrieve a page of users, optionally run through provided filters.\n\n\nOnly authenticated users may call this resource.\n### Permission Filters\n\n\nThe following three sub-sections list parameters supported for permission filters (where [root] is\nthe root permission filter name, e.g. permission, permission.1 etc.) depending on the\npermission resource. The system determines which filter to apply (Global, Project or Repository permission)\nbased on the `[root]` permission value. E.g. ADMIN is a global permission,\nPROJECT_ADMIN is a project permission and REPO_ADMIN is a repository permission. Note\nthat the parameters for a given resource will be looked up in the order as they are listed below, that is e.g.\nfor a project resource, if both projectId and projectKey are provided, the system will\nuse projectId for the lookup.\n

Global permissions

\n\n\nThe permission value under [root] is the only required and recognized parameter, as global\npermissions do not apply to a specific resource.\n\n\nExample valid filter: permission=ADMIN.\n

Project permissions

\n\n\n- [root]- specifies the project permission\n- [root].projectId - specifies the project ID to lookup the project by\n- [root].projectKey - specifies the project key to lookup the project by\n\n\nExample valid filter: permission.1=PROJECT_ADMIN&permission.1.projectKey=TEST_PROJECT.\n#### Repository permissions\n\n\n- [root]- specifies the repository permission\n- [root].projectId - specifies the repository ID to lookup the repository by\n- [root].projectKey and [root].repositorySlug- specifies the project key and repository slug to lookup the repository by; both values need to be provided for this look up to be triggered\n\n\nExample valid filter: permission.2=REPO_ADMIN&permission.2.projectKey=TEST_PROJECT&permission.2.repositorySlug=test_repo.", + "operationId": "getUsers_2", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "Return only users, whose username, name or email address contain the filter value", + "schema": { + "type": "string" + } + }, + { + "name": "permission.N", + "in": "query", + "description": "The \"root\" of a single permission filter, similar to the permission parameter, where \"N\" is a natural number starting from 1. This allows clients to specify multiple permission filters, by providing consecutive filters as permission.1, permission.2 etc. Note that the filters numbering has to start with 1 and be continuous for all filters to be processed. The total allowed number of permission filters is 50 and all filters exceeding that limit will be dropped. See the section \"Permission Filters\" above for more details on how the permission filters are processed.", + "schema": { + "type": "string" + } + }, + { + "name": "permission", + "in": "query", + "description": "The \"root\" of a permission filter, whose value must be a valid global, project, or repository permission. Additional filter parameters referring to this filter that specify the resource (project or repository) to apply the filter to must be prefixed with permission.. See the section \"Permission Filters\" above for more details.", + "schema": { + "type": "string" + } + }, + { + "name": "group", + "in": "query", + "description": "return only users who are members of the given group", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "A page of users.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestApplicationUser" + } + } + } + }, + "400": { + "description": "The search request was invalid, which may happen for multiple reasons, among\nothers:\n\n\n- permission filter for project/repository permission with no parameters specifying the project or repository to apply the filter to\n- invalid permission name\n- permission filter for a project/repository permission pointing to a non-existent project or repository\n\n\nThe exact reason for the error and - in most cases - the request parameter name that had invalid value - will be\nprovided in the error message.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "Authentication failed or was not attempted.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Update user details", + "description": "Update the currently authenticated user's details. The update will always be applied to the currently authenticated user.", + "operationId": "updateUserDetails_1", + "requestBody": { + "description": "The user update details", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/UserUpdate" + } + } + } + }, + "responses": { + "200": { + "description": "The updated user.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestApplicationUser" + } + } + } + }, + "400": { + "description": "The request was malformed.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "Authentication failed or was not attempted.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/users/credentials": { + "put": { + "tags": [ + "System Maintenance" + ], + "summary": "Set password", + "description": "Update the currently authenticated user's password.", + "operationId": "updateUserPassword_1", + "requestBody": { + "description": "The password update details", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/UserPasswordUpdate" + } + } + } + }, + "responses": { + "204": { + "description": "The user's password was successfully updated." + }, + "400": { + "description": "The request was malformed or the old password was incorrect.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "401": { + "description": "Authentication failed or was not attempted.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/users/{userSlug}": { + "get": { + "tags": [ + "User" + ], + "summary": "Get user", + "description": "Retrieve the user matching the supplied userSlug.", + "operationId": "getUser", + "parameters": [ + { + "name": "userSlug", + "in": "path", + "description": "The user slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The user matching the supplied userSlug. Note, this may\nnot be the user's username, always use the user.slug property.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestApplicationUser" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to view the user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/users/{userSlug}/avatar.png": { + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Update user avatar", + "description": "Update the avatar for the user with the supplied slug.\n\n\nThis resource accepts POST multipart form data, containing a single image in a form-field named 'avatar'.\n\n\nThere are configurable server limits on both the dimensions (1024x1024 pixels by default) and uploaded\nfile size (1MB by default). Several different image formats are supported, but PNG and\nJPEG are preferred due to the file size limit.\n\n\nThis resource has Cross-Site Request Forgery (XSRF) protection. To allow the request to\npass the XSRF check the caller needs to send an X-Atlassian-Token HTTP header with the\nvalue no-check.\n\n\nAn example curl request to upload an image name 'avatar.png' would be:\n```\ncurl -X POST -u username:password -H \"X-Atlassian-Token: no-check\" http://example.com/rest/api/latest/users/jdoe/avatar.png -F avatar=@avatar.png\n```\n\n\nUsers are always allowed to update their own avatar. To update someone else's avatar the authenticated user must\nhave global ADMIN permission, or global SYS_ADMIN permission to update a\nSYS_ADMIN user's avatar.", + "operationId": "uploadAvatar_1", + "parameters": [ + { + "name": "X-Atlassian-Token", + "in": "header", + "description": "This resource has Cross-Site Request Forgery (XSRF) protection. To allow the request to pass the XSRF check the caller needs to send an X-Atlassian-Token HTTP header with the value no-check.", + "schema": { + "type": "string" + }, + "example": "no-check" + }, + { + "name": "userSlug", + "in": "path", + "description": "The user slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "Multipart form data containing a single image in a form-field named 'avatar'.", + "content": { + "multipart/form-data": { + "schema": { + "$ref": "#/components/schemas/ExampleAvatarMultipartFormData" + } + } + } + }, + "responses": { + "201": { + "description": "The avatar was uploaded successfully.", + "headers": { + "Location": { + "description": "The Location response header which indicates the URL of the avatar.", + "style": "simple", + "schema": { + "type": "string" + } + } + } + }, + "401": { + "description": "The currently authenticated user has insufficient permissions to update the avatar.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "delete": { + "tags": [ + "System Maintenance" + ], + "summary": "Delete user avatar", + "description": "Delete the avatar associated to a user.\n\n\nUsers are always allowed to delete their own avatar. To delete someone else's avatar the authenticated user must\nhave global ADMIN permission, or global SYS_ADMIN permission to update a\nSYS_ADMIN user's avatar.", + "operationId": "deleteAvatar", + "parameters": [ + { + "name": "userSlug", + "in": "path", + "description": "The user slug", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The new avatar URL if the local avatar was successfully deleted or did not exist", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RestNamedLink" + } + } + } + }, + "401": { + "description": "The authenticated user has insufficient permissions to delete the specified avatar.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified user does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + }, + "/api/latest/users/{userSlug}/settings": { + "get": { + "tags": [ + "System Maintenance" + ], + "summary": "Get user settings", + "description": "Retrieve a map of user setting key values for a specific user identified by the user slug.", + "operationId": "getUserSettings", + "parameters": [ + { + "name": "userSlug", + "in": "path", + "description": "The user slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "The user settings for the specified user slug.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ExampleSettingsMap" + } + } + } + }, + "401": { + "description": "The currently authenticated user does not have permission to view the settings of this user.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + }, + "404": { + "description": "The specified project, repository, commit, or report does not exist.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + }, + "post": { + "tags": [ + "System Maintenance" + ], + "summary": "Update user settings", + "description": "Update the entries of a map of user setting key/values for a specific user identified by the user slug.", + "operationId": "updateSettings", + "parameters": [ + { + "name": "userSlug", + "in": "path", + "description": "The user slug.", + "required": true, + "schema": { + "type": "string" + } + } + ], + "requestBody": { + "description": "A map with the UserSettings entries which must be updated.", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ExampleSettingsMap" + } + } + } + }, + "responses": { + "204": { + "description": "The UserSettings were updated successfully" + }, + "401": { + "description": "The currently authenticated user is not a project administrator.", + "content": { + "application/json": { + "schema": { + "type": "object", + "properties": { + "errors": { + "type": "array", + "items": { + "$ref": "#/components/schemas/RestErrorMessage" + } + } + } + } + } + } + } + } + } + } + } +} \ No newline at end of file diff --git a/internal/client/bitbucket/.openapi-generator-ignore b/internal/client/bitbucket/.openapi-generator-ignore new file mode 100644 index 0000000..7484ee5 --- /dev/null +++ b/internal/client/bitbucket/.openapi-generator-ignore @@ -0,0 +1,23 @@ +# OpenAPI Generator Ignore +# Generated by openapi-generator https://github.com/openapitools/openapi-generator + +# Use this file to prevent files from being overwritten by the generator. +# The patterns follow closely to .gitignore or .dockerignore. + +# As an example, the C# client generator defines ApiClient.cs. +# You can make changes and tell OpenAPI Generator to ignore just this file by uncommenting the following line: +#ApiClient.cs + +# You can match any string of characters against a directory, file or extension with a single asterisk (*): +#foo/*/qux +# The above matches foo/bar/qux and foo/baz/qux, but not foo/bar/baz/qux + +# You can recursively match patterns against a directory, file or extension with a double asterisk (**): +#foo/**/qux +# This matches foo/bar/qux, foo/baz/qux, and foo/bar/baz/qux + +# You can also negate patterns with an exclamation (!). +# For example, you can ignore all files in a docs folder with the file extension .md: +#docs/*.md +# Then explicitly reverse the ignore rule for a single file: +#!docs/README.md diff --git a/internal/client/bitbucket/.openapi-generator/FILES b/internal/client/bitbucket/.openapi-generator/FILES new file mode 100644 index 0000000..e01e303 --- /dev/null +++ b/internal/client/bitbucket/.openapi-generator/FILES @@ -0,0 +1,342 @@ +generated_api_builds_and_deployments.go +generated_api_pull_requests.go +generated_api_repository.go +generated_api_user.go +generated_base_client.go +generated_client_error.go +generated_model_add_ssh_key_request.go +generated_model_admin_password_update.go +generated_model_application_user.go +generated_model_context.go +generated_model_credentials.go +generated_model_dismiss_retention_config_review_notification_401_response.go +generated_model_enriched_repository.go +generated_model_enriched_repository_properties.go +generated_model_entity_holder_rest_pull_request_decline_request.go +generated_model_entity_holder_rest_pull_request_decline_request_entity.go +generated_model_entity_holder_rest_pull_request_merge_request.go +generated_model_entity_holder_rest_pull_request_merge_request_entity.go +generated_model_entity_holder_rest_pull_request_reopen_request.go +generated_model_entity_holder_rest_pull_request_reopen_request_entity.go +generated_model_example_files.go +generated_model_example_json_last_modified_callback.go +generated_model_example_multipart_form_data.go +generated_model_example_preview_migration.go +generated_model_example_put_multipart_form_data.go +generated_model_example_requirements.go +generated_model_example_settings.go +generated_model_example_settings_map.go +generated_model_example_socket_address.go +generated_model_example_status.go +generated_model_file_part.go +generated_model_find_by_commit_200_response.go +generated_model_find_users_in_group_200_response.go +generated_model_get_activities_200_response.go +generated_model_get_all_200_response.go +generated_model_get_all_access_tokens_200_response.go +generated_model_get_all_mesh_migration_summaries_200_response.go +generated_model_get_all_rate_limit_settings_200_response.go +generated_model_get_all_repos_for_project_200_response.go +generated_model_get_branches_200_response.go +generated_model_get_build_status_200_response.go +generated_model_get_changes_1_200_response.go +generated_model_get_comments_200_response.go +generated_model_get_commits_200_response.go +generated_model_get_commits_by_issue_key_200_response.go +generated_model_get_configurations_200_response.go +generated_model_get_content_1_200_response.go +generated_model_get_content_1_200_response_lines_inner.go +generated_model_get_export_job_messages_200_response.go +generated_model_get_groups_1_200_response.go +generated_model_get_groups_200_response.go +generated_model_get_groups_with_any_permission_200_response.go +generated_model_get_history_200_response.go +generated_model_get_keys_for_user_200_response.go +generated_model_get_labelables_200_response.go +generated_model_get_labels_200_response.go +generated_model_get_likers_200_response.go +generated_model_get_page_of_required_builds_merge_checks_200_response.go +generated_model_get_projects_200_response.go +generated_model_get_pull_request_suggestions_200_response.go +generated_model_get_pull_requests_1_200_response.go +generated_model_get_ref_change_activity_200_response.go +generated_model_get_repo_sync_status_200_response.go +generated_model_get_reports_200_response.go +generated_model_get_repositories_recently_accessed_200_response.go +generated_model_get_repository_hooks_1_200_response.go +generated_model_get_restrictions_1_200_response.go +generated_model_get_reviewer_groups_1_200_response.go +generated_model_get_ssh_keys_200_response.go +generated_model_get_ssh_keys_for_project_200_response.go +generated_model_get_tags_200_response.go +generated_model_get_users_with_any_permission_1_200_response.go +generated_model_group.go +generated_model_group_and_users.go +generated_model_group_picker_context.go +generated_model_list_mirrors_200_response.go +generated_model_list_participants_200_response.go +generated_model_list_requests_200_response.go +generated_model_list_upstream_servers_200_response.go +generated_model_repository_hook_details.go +generated_model_rest_access_token.go +generated_model_rest_access_token_request.go +generated_model_rest_aggregate_reject_counter.go +generated_model_rest_analytics_settings.go +generated_model_rest_announcement_banner.go +generated_model_rest_application_properties.go +generated_model_rest_application_user.go +generated_model_rest_application_user_with_permissions.go +generated_model_rest_apply_suggestion_request.go +generated_model_rest_apply_suggestion_request_comment_version.go +generated_model_rest_apply_suggestion_request_pull_request_version.go +generated_model_rest_apply_suggestion_request_suggestion_index.go +generated_model_rest_attachment_metadata.go +generated_model_rest_authentication_request.go +generated_model_rest_auto_decline_settings.go +generated_model_rest_auto_decline_settings_request.go +generated_model_rest_auto_decline_settings_scope.go +generated_model_rest_auto_merge_processing_result.go +generated_model_rest_auto_merge_processing_result_pull_request.go +generated_model_rest_auto_merge_project_settings_request.go +generated_model_rest_auto_merge_request.go +generated_model_rest_auto_merge_restricted_settings.go +generated_model_rest_auto_merge_restricted_settings_scope.go +generated_model_rest_auto_merge_settings_request.go +generated_model_rest_bearer_token_credentials.go +generated_model_rest_bitbucket_license.go +generated_model_rest_bitbucket_license_status.go +generated_model_rest_branch.go +generated_model_rest_branch_create_request.go +generated_model_rest_branch_delete_request.go +generated_model_rest_build_capabilities.go +generated_model_rest_build_stats.go +generated_model_rest_build_status.go +generated_model_rest_build_status_set_request.go +generated_model_rest_build_status_set_request_test_results.go +generated_model_rest_build_status_test_results.go +generated_model_rest_bulk_add_insight_annotation_request.go +generated_model_rest_bulk_user_rate_limit_settings_update_request.go +generated_model_rest_bulk_user_rate_limit_settings_update_request_settings.go +generated_model_rest_change.go +generated_model_rest_change_conflict.go +generated_model_rest_change_conflict_our_change.go +generated_model_rest_changeset.go +generated_model_rest_changeset_changes.go +generated_model_rest_changeset_from_commit.go +generated_model_rest_changeset_to_commit.go +generated_model_rest_changeset_to_commit_committer.go +generated_model_rest_cluster_information.go +generated_model_rest_cluster_information_local_node.go +generated_model_rest_cluster_node.go +generated_model_rest_cluster_node_address.go +generated_model_rest_comment.go +generated_model_rest_comment_jira_issue.go +generated_model_rest_comment_thread_diff_anchor.go +generated_model_rest_comment_thread_diff_anchor_path.go +generated_model_rest_comment_thread_diff_anchor_pull_request.go +generated_model_rest_commit.go +generated_model_rest_commit_message_suggestion.go +generated_model_rest_conflict.go +generated_model_rest_conflict_change.go +generated_model_rest_connectivity_summary.go +generated_model_rest_create_branch_request.go +generated_model_rest_create_tag_request.go +generated_model_rest_default_branch.go +generated_model_rest_default_reviewers_request.go +generated_model_rest_deployment.go +generated_model_rest_deployment_environment.go +generated_model_rest_deployment_set_request.go +generated_model_rest_detailed_group.go +generated_model_rest_detailed_invocation.go +generated_model_rest_detailed_invocation_event_scope.go +generated_model_rest_detailed_user.go +generated_model_rest_diff.go +generated_model_rest_diff_hunk.go +generated_model_rest_diff_line.go +generated_model_rest_diff_segment.go +generated_model_rest_emoticon.go +generated_model_rest_enhanced_entity_link.go +generated_model_rest_erased_user.go +generated_model_rest_error_message.go +generated_model_rest_errors.go +generated_model_rest_export_request.go +generated_model_rest_export_request_repositories_request.go +generated_model_rest_farm_synchronization_request.go +generated_model_rest_git_tag_create_request.go +generated_model_rest_gpg_key.go +generated_model_rest_gpg_sub_key.go +generated_model_rest_hook_script.go +generated_model_rest_hook_script_config.go +generated_model_rest_hook_script_config_script.go +generated_model_rest_hook_script_triggers.go +generated_model_rest_import_request.go +generated_model_rest_insight_annotation.go +generated_model_rest_insight_annotations_response.go +generated_model_rest_insight_report.go +generated_model_rest_insight_report_data.go +generated_model_rest_jira_issue.go +generated_model_rest_job.go +generated_model_rest_job_message.go +generated_model_rest_job_progress.go +generated_model_rest_label.go +generated_model_rest_labelable.go +generated_model_rest_log_level.go +generated_model_rest_mail_configuration.go +generated_model_rest_markup.go +generated_model_rest_mesh_connectivity_report.go +generated_model_rest_mesh_migration_request.go +generated_model_rest_mesh_migration_summary.go +generated_model_rest_mesh_node.go +generated_model_rest_migration_repository.go +generated_model_rest_minimal_commit.go +generated_model_rest_minimal_ref.go +generated_model_rest_mirror_hashes.go +generated_model_rest_mirror_repository_synchronization_status.go +generated_model_rest_mirror_repository_synchronization_status_hashes.go +generated_model_rest_mirror_server.go +generated_model_rest_mirror_upgrade_request.go +generated_model_rest_mirrored_repository.go +generated_model_rest_mirrored_repository_descriptor.go +generated_model_rest_mirrored_repository_descriptor_mirror_server.go +generated_model_rest_mirroring_request.go +generated_model_rest_named_link.go +generated_model_rest_node.go +generated_model_rest_node_connectivity_report.go +generated_model_rest_node_connectivity_report_node.go +generated_model_rest_node_connectivity_summary.go +generated_model_rest_node_connectivity_summary_summary.go +generated_model_rest_page_rest_change.go +generated_model_rest_path.go +generated_model_rest_permitted.go +generated_model_rest_permitted_group.go +generated_model_rest_permitted_group_group.go +generated_model_rest_permitted_user.go +generated_model_rest_person.go +generated_model_rest_progress.go +generated_model_rest_project.go +generated_model_rest_project_settings_restriction.go +generated_model_rest_project_settings_restriction_request.go +generated_model_rest_properties.go +generated_model_rest_pull_request.go +generated_model_rest_pull_request_activity.go +generated_model_rest_pull_request_assign_participant_role_request.go +generated_model_rest_pull_request_assign_participant_role_request_user.go +generated_model_rest_pull_request_assign_status_request.go +generated_model_rest_pull_request_commit_message_template.go +generated_model_rest_pull_request_condition.go +generated_model_rest_pull_request_condition_scope.go +generated_model_rest_pull_request_decline_request.go +generated_model_rest_pull_request_delete_request.go +generated_model_rest_pull_request_finish_review_request.go +generated_model_rest_pull_request_from_ref.go +generated_model_rest_pull_request_from_ref_repository.go +generated_model_rest_pull_request_from_ref_repository_origin.go +generated_model_rest_pull_request_from_ref_repository_project.go +generated_model_rest_pull_request_merge_config.go +generated_model_rest_pull_request_merge_config_commit_message_template.go +generated_model_rest_pull_request_merge_config_default_strategy.go +generated_model_rest_pull_request_merge_request.go +generated_model_rest_pull_request_merge_strategy.go +generated_model_rest_pull_request_mergeability.go +generated_model_rest_pull_request_participant.go +generated_model_rest_pull_request_participant_user.go +generated_model_rest_pull_request_rebase_request.go +generated_model_rest_pull_request_rebase_result.go +generated_model_rest_pull_request_rebase_result_ref_change.go +generated_model_rest_pull_request_rebase_result_ref_change_ref.go +generated_model_rest_pull_request_rebaseability.go +generated_model_rest_pull_request_ref.go +generated_model_rest_pull_request_reopen_request.go +generated_model_rest_pull_request_settings.go +generated_model_rest_pull_request_settings_merge_config.go +generated_model_rest_pull_request_suggestion.go +generated_model_rest_push_ref_change.go +generated_model_rest_rate_limit_settings.go +generated_model_rest_raw_access_token.go +generated_model_rest_ref_change.go +generated_model_rest_ref_matcher.go +generated_model_rest_ref_matcher_type.go +generated_model_rest_ref_restriction.go +generated_model_rest_ref_sync_queue.go +generated_model_rest_ref_sync_request.go +generated_model_rest_ref_sync_status.go +generated_model_rest_ref_sync_status_ahead_refs.go +generated_model_rest_rejected_ref.go +generated_model_rest_repositories_export_request.go +generated_model_rest_repository.go +generated_model_rest_repository_hook.go +generated_model_rest_repository_hook_veto.go +generated_model_rest_repository_mirror_event.go +generated_model_rest_repository_policy.go +generated_model_rest_repository_pull_request_settings.go +generated_model_rest_repository_pull_request_settings_required_approvers.go +generated_model_rest_repository_ref_change_activity.go +generated_model_rest_repository_ref_change_activity_ref_change.go +generated_model_rest_repository_selector.go +generated_model_rest_required_build_condition.go +generated_model_rest_required_build_condition_ref_matcher.go +generated_model_rest_required_build_condition_set_request.go +generated_model_rest_restriction_request.go +generated_model_rest_restriction_request_scope.go +generated_model_rest_reviewer_group.go +generated_model_rest_scope.go +generated_model_rest_scopes_example.go +generated_model_rest_secret_scanning_allowlist_rule.go +generated_model_rest_secret_scanning_allowlist_rule_set_request.go +generated_model_rest_secret_scanning_rule.go +generated_model_rest_secret_scanning_rule_scope.go +generated_model_rest_secret_scanning_rule_set_request.go +generated_model_rest_set_insight_report_request.go +generated_model_rest_single_add_insight_annotation_request.go +generated_model_rest_ssh_access_key.go +generated_model_rest_ssh_access_key_key.go +generated_model_rest_ssh_access_key_locations.go +generated_model_rest_ssh_credentials.go +generated_model_rest_ssh_key.go +generated_model_rest_ssh_key_settings.go +generated_model_rest_ssh_key_settings_max_expiry_days.go +generated_model_rest_ssh_key_type_restriction.go +generated_model_rest_ssh_key_type_restriction_min_key_length.go +generated_model_rest_ssh_settings.go +generated_model_rest_sync_progress.go +generated_model_rest_system_signing_configuration.go +generated_model_rest_tag.go +generated_model_rest_test_results.go +generated_model_rest_token_bucket_settings.go +generated_model_rest_upstream_server.go +generated_model_rest_upstream_settings.go +generated_model_rest_user_directory.go +generated_model_rest_user_rate_limit_settings.go +generated_model_rest_user_rate_limit_settings_update_request.go +generated_model_rest_user_reaction.go +generated_model_rest_user_reaction_comment.go +generated_model_rest_user_reaction_comment_parent.go +generated_model_rest_user_reaction_comment_parent_anchor.go +generated_model_rest_user_reaction_comment_parent_thread_resolver.go +generated_model_rest_user_reaction_emoticon.go +generated_model_rest_username_password_credentials.go +generated_model_rest_webhook.go +generated_model_rest_webhook_credentials.go +generated_model_rest_webhook_scope.go +generated_model_rest_x509_certificate.go +generated_model_revoke_many_request.go +generated_model_search_2_200_response.go +generated_model_search_3_200_response.go +generated_model_search_mesh_migration_repos_200_response.go +generated_model_set_banner_request.go +generated_model_set_default_branch_request.go +generated_model_set_mail_config_request.go +generated_model_simple_ssh_key_fingerprint.go +generated_model_start_mesh_migration_request.go +generated_model_start_mesh_migration_request_max_bytes_per_second.go +generated_model_stream_diff_1_200_response.go +generated_model_stream_files_200_response.go +generated_model_update_pull_request_condition_1_request.go +generated_model_update_pull_request_condition_1_request_source_matcher.go +generated_model_update_pull_request_condition_1_request_source_matcher_type.go +generated_model_update_system_signing_configuration_request.go +generated_model_user_and_groups.go +generated_model_user_password_update.go +generated_model_user_picker_context.go +generated_model_user_rename.go +generated_model_user_update.go diff --git a/internal/client/bitbucket/.openapi-generator/VERSION b/internal/client/bitbucket/.openapi-generator/VERSION new file mode 100644 index 0000000..d2e252b --- /dev/null +++ b/internal/client/bitbucket/.openapi-generator/VERSION @@ -0,0 +1 @@ +7.7.1_INTERHYP-SNAPSHOT diff --git a/internal/client/bitbucket/bitbucket.go b/internal/client/bitbucket/bitbucket.go new file mode 100644 index 0000000..ffb722f --- /dev/null +++ b/internal/client/bitbucket/bitbucket.go @@ -0,0 +1,163 @@ +package bitbucketclient + +import ( + "context" + "fmt" + librepo "github.com/Interhyp/go-backend-service-common/acorns/repository" + "github.com/Interhyp/metadata-service/internal/acorn/errors/httperror" + "github.com/Interhyp/metadata-service/internal/acorn/repository" + "github.com/Interhyp/metadata-service/internal/util" + aulogging "github.com/StephanHCB/go-autumn-logging" + aurestclientapi "github.com/StephanHCB/go-autumn-restclient/api" + "net/http" + "strings" +) + +type ExtendedClient interface { + PullRequestsAPI + BuildsAndDeploymentsAPI +} + +type Impl struct { + Logging librepo.Logging + pullRequestsAPI PullRequestsAPI + buildsAndDeploymentsAPI BuildsAndDeploymentsAPI + repositoryApi RepositoryAPI + userApi UserAPI +} + +func New(client *ApiClient, logging librepo.Logging) *Impl { + return &Impl{ + Logging: logging, + pullRequestsAPI: NewPullRequestsAPI(client), + buildsAndDeploymentsAPI: NewBuildsAndDeploymentsAPI(client), + repositoryApi: NewRepositoryAPI(client), + userApi: NewUserAPI(client), + } +} + +func (r *Impl) SetCommitStatusInProgress(ctx context.Context, projectKey, repoSlug, commitID, url string, statusKey string) error { + return r.SetCommitStatus(ctx, projectKey, repoSlug, commitID, url, statusKey, repository.CommitBuildStatusInProgress) +} + +func (r *Impl) SetCommitStatusSucceeded(ctx context.Context, projectKey, repoSlug, commitID, url string, statusKey string) error { + return r.SetCommitStatus(ctx, projectKey, repoSlug, commitID, url, statusKey, repository.CommitBuildStatusSuccess) +} + +func (r *Impl) SetCommitStatusFailed(ctx context.Context, projectKey, repoSlug, commitID, url string, statusKey string) error { + return r.SetCommitStatus(ctx, projectKey, repoSlug, commitID, url, statusKey, repository.CommitBuildStatusFailed) +} + +func (r *Impl) CreatePullRequestComment(ctx context.Context, projectKey, repoSlug, pullRequestID, text string) error { + comment := RestComment{ + Text: &text, + } + _, response, err := r.pullRequestsAPI.CreateComment2(ctx, projectKey, pullRequestID, repoSlug, comment) + if err != nil { + return enrichError(response, err) + } + return nil +} + +func (r *Impl) SetCommitStatus(ctx context.Context, projectKey, repoSlug, commitID, url string, statusKey string, status repository.CommitBuildStatus) error { + buildStatus := RestBuildStatusSetRequest{ + Key: statusKey, + Url: url, + State: string(status), + } + request := r.buildsAndDeploymentsAPI.AddRequest(ctx, projectKey, commitID, repoSlug) + request.RestBuildStatusSetRequest(buildStatus) + _, err := request.Execute() + return err +} + +func enrichError(response aurestclientapi.ParsedResponse, err error) error { + if err != nil { + switch parsed := response.Body.(type) { + case DismissRetentionConfigReviewNotification401Response: + var messages []string + for _, errorsInner := range parsed.Errors { + if errorsInner.Message != nil && *errorsInner.Message != "" { + messages = append(messages, *errorsInner.Message) + } + } + return NewError(fmt.Sprintf("received error with messages: %v", messages), response.Status) + default: + return err + } + } + return nil +} + +func (r *Impl) GetChangedFilesOnPullRequest(ctx context.Context, repoPath, repoName, pullRequestID, toRef string) ([]repository.File, string, error) { + pullRequest, _, err := r.pullRequestsAPI.Get3(ctx, repoPath, pullRequestID, repoName) + if err != nil { + return nil, "", err + } + + prSourceHead := pullRequest.FromRef.LatestCommit + changes, _, err := r.repositoryApi.GetChanges1(ctx, repoPath, repoName, *prSourceHead, *pullRequest.ToRef.LatestCommit, 0, 1000) // TODO pagination? + if err != nil { + return nil, *prSourceHead, err + } + + aulogging.Logger.Ctx(ctx).Info().Printf("pull request had %d changed files", len(changes.Values)) + + result := make([]repository.File, 0) + for _, change := range changes.Values { + path := fmt.Sprintf("%s/%s", *change.Path.Parent, *change.Path.Name) + contents, err := r.getFileContentsAt(ctx, repoPath, repoName, *prSourceHead, path) + if err != nil { + asHttpError, ok := err.(httperror.Error) + if ok && asHttpError.Status() == http.StatusNotFound { + aulogging.Logger.Ctx(ctx).Debug().Printf("path %s not present on PR head - skipping and continuing", path) + continue // expected situation - happens for deleted files, or for files added on mainline after fork (which show up in changes) + } else { + aulogging.Logger.Ctx(ctx).Info().Printf("failed to retrieve change for %s: %s", path, err.Error()) + return nil, *prSourceHead, err + } + } + + result = append(result, repository.File{ + Path: path, + Contents: contents, + }) + } + + aulogging.Logger.Ctx(ctx).Info().Printf("successfully obtained %d changes for pull request %d", len(result), pullRequestID) + return result, *prSourceHead, nil +} + +func (r *Impl) getFileContentsAt(ctx context.Context, repoPath string, repoName string, atHash string, path string) (string, error) { + var contents strings.Builder + var err error + start := 0 + + page := GetContent1200Response{ + IsLastPage: util.Ptr(false), + NextPageStart: util.Ptr(float32(start)), + } + + for !*page.IsLastPage && page.NextPageStart != nil { + req := r.repositoryApi.GetContent1Request(ctx, path, repoPath, repoName) + req.at = &atHash + page, _, err = req.FilePathCompatibleExecute() + + if err != nil { + return contents.String(), err + } + for _, line := range page.Lines { + contents.WriteString(*line.Text + "\n") + } + } + + return contents.String(), nil +} + +func (r *Impl) GetUser(ctx context.Context, username string) (string, error) { + response, _, err := r.userApi.GetUser(ctx, username) + if err != nil { + return "", err + } + return *response.Name, nil +} diff --git a/internal/client/bitbucket/extended_client.go b/internal/client/bitbucket/extended_client.go new file mode 100644 index 0000000..51c2552 --- /dev/null +++ b/internal/client/bitbucket/extended_client.go @@ -0,0 +1,65 @@ +package bitbucketclient + +import ( + "context" + "fmt" + "github.com/Interhyp/go-backend-service-common/web/middleware/requestid" + "github.com/Interhyp/metadata-service/pkg/recorder" + auapmclient "github.com/StephanHCB/go-autumn-restclient-apm/implementation/client" + aurestclientapi "github.com/StephanHCB/go-autumn-restclient/api" + aurestrecorder "github.com/StephanHCB/go-autumn-restclient/implementation/recorder" + "github.com/go-http-utils/headers" + "net/http" + urlUtil "net/url" + "strings" +) + +func NewClient(baseURL string, accessToken string) (*ApiClient, error) { + clientConfig := DefaultApiClientConfig(fmt.Sprintf("%s/rest", baseURL)) + clientConfig.CachingConfigurer = nil + clientConfig.RequestManipulator = func(ctx context.Context, request *http.Request) { + request.Header.Set(headers.Accept, aurestclientapi.ContentTypeApplicationJson) + + request.Header.Set(headers.Authorization, fmt.Sprintf("Bearer %s", accessToken)) + + if reqId := requestid.GetReqID(ctx); reqId != "" { + request.Header.Set(requestid.RequestIDHeader, reqId) + } + auapmclient.AddTraceHeadersRequestManipulator(ctx, request) + } + clientConfig.RecorderConfigurer = func(client aurestclientapi.Client) aurestclientapi.Client { + return aurestrecorder.New(client, aurestrecorder.RecorderOptions{ + ConstructFilenameFunc: recorder.ConstructFilenameV4, + }) + } + + return NewApiClientConfigured(clientConfig) +} + +func (r *RepositoryAPIGetContent1Request) FilePathCompatibleExecute() (GetContent1200Response, aurestclientapi.ParsedResponse, error) { + escapedPath := "" + for _, pathComponent := range strings.Split(r.path, "/") { + escapedPath += "/" + urlUtil.PathEscape(pathComponent) + } + fullUrlValue := r.ApiService.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/browse{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", escapedPath) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.noContent != nil { + withUrlQueryParam(requestURL, "noContent", *r.noContent) + } + if r.at != nil { + withUrlQueryParam(requestURL, "at", *r.at) + } + if r.size != nil { + withUrlQueryParam(requestURL, "size", *r.size) + } + if r.blame != nil { + withUrlQueryParam(requestURL, "blame", *r.blame) + } + if r.type_ != nil { + withUrlQueryParam(requestURL, "type", *r.type_) + } + return r.ApiService.makeGetContent1Call(r.ctx, requestURL, nil) +} diff --git a/internal/client/bitbucket/generated_api_builds_and_deployments.go b/internal/client/bitbucket/generated_api_builds_and_deployments.go new file mode 100644 index 0000000..aaa2e92 --- /dev/null +++ b/internal/client/bitbucket/generated_api_builds_and_deployments.go @@ -0,0 +1,2123 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + +import ( + "context" + "fmt" + aurestclientapi "github.com/StephanHCB/go-autumn-restclient/api" + "net/http" + urlUtil "net/url" + "strings" +) + +type BuildsAndDeploymentsAPI interface { + + /* + Add Store a build status + */ + Add(ctx context.Context, projectKey string, commitId string, repositorySlug string, restBuildStatusSetRequest RestBuildStatusSetRequest) (aurestclientapi.ParsedResponse, error) + + // AddExecutes the request + AddRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIAddRequest + + /* + AddAnnotations Add Code Insights annotations + */ + AddAnnotations(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string, restBulkAddInsightAnnotationRequest RestBulkAddInsightAnnotationRequest) (aurestclientapi.ParsedResponse, error) + + // AddAnnotationsExecutes the request + AddAnnotationsRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPIAddAnnotationsRequest + + /* + CreateOrUpdateDeployment Create or update a deployment + */ + CreateOrUpdateDeployment(ctx context.Context, projectKey string, commitId string, repositorySlug string, restDeploymentSetRequest RestDeploymentSetRequest) (RestDeployment, aurestclientapi.ParsedResponse, error) + + // CreateOrUpdateDeploymentExecutes the request + // @return RestDeployment + CreateOrUpdateDeploymentRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPICreateOrUpdateDeploymentRequest + + /* + CreateRequiredBuildsMergeCheck Create a required builds merge check + */ + CreateRequiredBuildsMergeCheck(ctx context.Context, projectKey string, repositorySlug string, restRequiredBuildConditionSetRequest RestRequiredBuildConditionSetRequest) (RestRequiredBuildCondition, aurestclientapi.ParsedResponse, error) + + // CreateRequiredBuildsMergeCheckExecutes the request + // @return RestRequiredBuildCondition + CreateRequiredBuildsMergeCheckRequest(ctx context.Context, projectKey string, repositorySlug string) BuildsAndDeploymentsAPICreateRequiredBuildsMergeCheckRequest + + /* + Delete Delete a specific build status + */ + Delete(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) (aurestclientapi.ParsedResponse, error) + + // DeleteExecutes the request + DeleteRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIDeleteRequest + + /* + Delete1 Delete a deployment + */ + Delete1(ctx context.Context, projectKey string, commitId string, repositorySlug string, deploymentSequenceNumber string, key string, environmentKey string) (aurestclientapi.ParsedResponse, error) + + // Delete1Executes the request + Delete1Request(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIDelete1Request + + /* + DeleteACodeInsightsReport Delete a Code Insights report + */ + DeleteACodeInsightsReport(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) (aurestclientapi.ParsedResponse, error) + + // DeleteACodeInsightsReportExecutes the request + DeleteACodeInsightsReportRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPIDeleteACodeInsightsReportRequest + + /* + DeleteAnnotations Delete Code Insights annotations + */ + DeleteAnnotations(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string, externalId string) (aurestclientapi.ParsedResponse, error) + + // DeleteAnnotationsExecutes the request + DeleteAnnotationsRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPIDeleteAnnotationsRequest + + /* + DeleteRequiredBuildsMergeCheck Delete a required builds merge check + */ + DeleteRequiredBuildsMergeCheck(ctx context.Context, projectKey string, id int64, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // DeleteRequiredBuildsMergeCheckExecutes the request + DeleteRequiredBuildsMergeCheckRequest(ctx context.Context, projectKey string, id int64, repositorySlug string) BuildsAndDeploymentsAPIDeleteRequiredBuildsMergeCheckRequest + + /* + Get Get a specific build status + */ + Get(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) (RestBuildStatus, aurestclientapi.ParsedResponse, error) + + // GetExecutes the request + // @return RestBuildStatus + GetRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIGetRequest + + /* + Get1 Get a deployment + */ + Get1(ctx context.Context, projectKey string, commitId string, repositorySlug string, deploymentSequenceNumber string, key string, environmentKey string) (RestDeployment, aurestclientapi.ParsedResponse, error) + + // Get1Executes the request + // @return RestDeployment + Get1Request(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIGet1Request + + /* + GetACodeInsightsReport Get a Code Insights report + */ + GetACodeInsightsReport(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) (RestInsightReport, aurestclientapi.ParsedResponse, error) + + // GetACodeInsightsReportExecutes the request + // @return RestInsightReport + GetACodeInsightsReportRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPIGetACodeInsightsReportRequest + + /* + GetAnnotations Get Code Insights annotations for a commit + */ + GetAnnotations(ctx context.Context, projectKey string, commitId string, repositorySlug string, severity string, path string, externalId string, type_ string, key string) (RestInsightAnnotationsResponse, aurestclientapi.ParsedResponse, error) + + // GetAnnotationsExecutes the request + // @return RestInsightAnnotationsResponse + GetAnnotationsRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIGetAnnotationsRequest + + /* + GetAnnotations1 Get Code Insights annotations for a report + */ + GetAnnotations1(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) (RestInsightAnnotationsResponse, aurestclientapi.ParsedResponse, error) + + // GetAnnotations1Executes the request + // @return RestInsightAnnotationsResponse + GetAnnotations1Request(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPIGetAnnotations1Request + + /* + GetBuildStatusStats Get build status statistics for commit + */ + GetBuildStatusStats(ctx context.Context, commitId string, includeUnique bool) (RestBuildStats, aurestclientapi.ParsedResponse, error) + + // GetBuildStatusStatsExecutes the request + // @return RestBuildStats + GetBuildStatusStatsRequest(ctx context.Context, commitId string) BuildsAndDeploymentsAPIGetBuildStatusStatsRequest + + /* + GetMultipleBuildStatusStats Get build status statistics for multiple commits + */ + GetMultipleBuildStatusStats(ctx context.Context, requestBody []string) (interface{}, aurestclientapi.ParsedResponse, error) + + // GetMultipleBuildStatusStatsExecutes the request + // @return interface{} + GetMultipleBuildStatusStatsRequest(ctx context.Context) BuildsAndDeploymentsAPIGetMultipleBuildStatusStatsRequest + + /* + GetPageOfRequiredBuildsMergeChecks Get required builds merge checks + */ + GetPageOfRequiredBuildsMergeChecks(ctx context.Context, projectKey string, repositorySlug string, start float32, limit float32) (GetPageOfRequiredBuildsMergeChecks200Response, aurestclientapi.ParsedResponse, error) + + // GetPageOfRequiredBuildsMergeChecksExecutes the request + // @return GetPageOfRequiredBuildsMergeChecks200Response + GetPageOfRequiredBuildsMergeChecksRequest(ctx context.Context, projectKey string, repositorySlug string) BuildsAndDeploymentsAPIGetPageOfRequiredBuildsMergeChecksRequest + + /* + GetReports Get all Code Insights reports for a commit + */ + GetReports(ctx context.Context, projectKey string, commitId string, repositorySlug string, start float32, limit float32) (GetReports200Response, aurestclientapi.ParsedResponse, error) + + // GetReportsExecutes the request + // @return GetReports200Response + GetReportsRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIGetReportsRequest + + /* + SetACodeInsightsReport Create a Code Insights report + */ + SetACodeInsightsReport(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string, restSetInsightReportRequest RestSetInsightReportRequest) (RestInsightReport, aurestclientapi.ParsedResponse, error) + + // SetACodeInsightsReportExecutes the request + // @return RestInsightReport + SetACodeInsightsReportRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPISetACodeInsightsReportRequest + + /* + SetAnnotation Create or replace a Code Insights annotation + */ + SetAnnotation(ctx context.Context, projectKey string, externalId string, commitId string, repositorySlug string, key string, restSingleAddInsightAnnotationRequest RestSingleAddInsightAnnotationRequest) (aurestclientapi.ParsedResponse, error) + + // SetAnnotationExecutes the request + SetAnnotationRequest(ctx context.Context, projectKey string, externalId string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPISetAnnotationRequest + + /* + UpdateRequiredBuildsMergeCheck Update a required builds merge check + */ + UpdateRequiredBuildsMergeCheck(ctx context.Context, projectKey string, id int64, repositorySlug string, restRequiredBuildConditionSetRequest RestRequiredBuildConditionSetRequest) (RestRequiredBuildCondition, aurestclientapi.ParsedResponse, error) + + // UpdateRequiredBuildsMergeCheckExecutes the request + // @return RestRequiredBuildCondition + UpdateRequiredBuildsMergeCheckRequest(ctx context.Context, projectKey string, id int64, repositorySlug string) BuildsAndDeploymentsAPIUpdateRequiredBuildsMergeCheckRequest +} + + type BuildsAndDeploymentsAPIAddRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + restBuildStatusSetRequest *RestBuildStatusSetRequest +} + + // The contents of the build status request are: These fields are **required**: - **key**: The string referring to this branch plan/job - **state**: The build status state, one of: \"SUCCESSFUL\", \"FAILED\", \"INPROGRESS\", \"CANCELLED\", \"UNKNOWN\" - **url**: URL referring to the build result page in the CI tool. These fields are optional: - **buildNumber** (optional): A unique identifier for this particular run of a plan< - **dateAdded** (optional): milliseconds since epoch. If not provided current date is used. - **description** (optional): Describes the build result - **duration** (optional): Duration of a completed build in milliseconds. - **name** (optional): A short string that describes the build plan - **parent** (optional): The identifier for the plan or job that ran the branch plan that produced this build status. - **ref** (optional): The fully qualified git reference e.g. refs/heads/master. - **testResults** (optional): A summary of the passed, failed and skipped tests. +func (r *BuildsAndDeploymentsAPIAddRequest) RestBuildStatusSetRequest(restBuildStatusSetRequest RestBuildStatusSetRequest) *BuildsAndDeploymentsAPIAddRequest { + r.restBuildStatusSetRequest = &restBuildStatusSetRequest + return r +} + +func (r *BuildsAndDeploymentsAPIAddRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.AddExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) AddRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIAddRequest { + return BuildsAndDeploymentsAPIAddRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) AddExecute(r *BuildsAndDeploymentsAPIAddRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/builds" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeAddCall(r.ctx, requestURL, r.restBuildStatusSetRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) Add(ctx context.Context, projectKey string, commitId string, repositorySlug string, restBuildStatusSetRequest RestBuildStatusSetRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/builds" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeAddCall(ctx, requestURL, restBuildStatusSetRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeAddCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type BuildsAndDeploymentsAPIAddAnnotationsRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + key string + restBulkAddInsightAnnotationRequest *RestBulkAddInsightAnnotationRequest +} + + // The annotations to add. +func (r *BuildsAndDeploymentsAPIAddAnnotationsRequest) RestBulkAddInsightAnnotationRequest(restBulkAddInsightAnnotationRequest RestBulkAddInsightAnnotationRequest) *BuildsAndDeploymentsAPIAddAnnotationsRequest { + r.restBulkAddInsightAnnotationRequest = &restBulkAddInsightAnnotationRequest + return r +} + +func (r *BuildsAndDeploymentsAPIAddAnnotationsRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.AddAnnotationsExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) AddAnnotationsRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPIAddAnnotationsRequest { + return BuildsAndDeploymentsAPIAddAnnotationsRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + key: key, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) AddAnnotationsExecute(r *BuildsAndDeploymentsAPIAddAnnotationsRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}/annotations" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(r.key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeAddAnnotationsCall(r.ctx, requestURL, r.restBulkAddInsightAnnotationRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) AddAnnotations(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string, restBulkAddInsightAnnotationRequest RestBulkAddInsightAnnotationRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}/annotations" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeAddAnnotationsCall(ctx, requestURL, restBulkAddInsightAnnotationRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeAddAnnotationsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type BuildsAndDeploymentsAPICreateOrUpdateDeploymentRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + restDeploymentSetRequest *RestDeploymentSetRequest +} + + // the details of the deployment to create, as detailed by the request body +func (r *BuildsAndDeploymentsAPICreateOrUpdateDeploymentRequest) RestDeploymentSetRequest(restDeploymentSetRequest RestDeploymentSetRequest) *BuildsAndDeploymentsAPICreateOrUpdateDeploymentRequest { + r.restDeploymentSetRequest = &restDeploymentSetRequest + return r +} + +func (r *BuildsAndDeploymentsAPICreateOrUpdateDeploymentRequest) Execute() (RestDeployment, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreateOrUpdateDeploymentExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) CreateOrUpdateDeploymentRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPICreateOrUpdateDeploymentRequest { + return BuildsAndDeploymentsAPICreateOrUpdateDeploymentRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) CreateOrUpdateDeploymentExecute(r *BuildsAndDeploymentsAPICreateOrUpdateDeploymentRequest) (RestDeployment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/deployments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateOrUpdateDeploymentCall(r.ctx, requestURL, r.restDeploymentSetRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) CreateOrUpdateDeployment(ctx context.Context, projectKey string, commitId string, repositorySlug string, restDeploymentSetRequest RestDeploymentSetRequest) (RestDeployment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/deployments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateOrUpdateDeploymentCall(ctx, requestURL, restDeploymentSetRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeCreateOrUpdateDeploymentCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestDeployment, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestDeployment + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestDeployment](&response) + if err == nil { + result = response.Body.(RestDeployment) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type BuildsAndDeploymentsAPICreateRequiredBuildsMergeCheckRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + repositorySlug string + restRequiredBuildConditionSetRequest *RestRequiredBuildConditionSetRequest +} + + // The request specifying the required build parent keys, ref matcher and exemption matcher +func (r *BuildsAndDeploymentsAPICreateRequiredBuildsMergeCheckRequest) RestRequiredBuildConditionSetRequest(restRequiredBuildConditionSetRequest RestRequiredBuildConditionSetRequest) *BuildsAndDeploymentsAPICreateRequiredBuildsMergeCheckRequest { + r.restRequiredBuildConditionSetRequest = &restRequiredBuildConditionSetRequest + return r +} + +func (r *BuildsAndDeploymentsAPICreateRequiredBuildsMergeCheckRequest) Execute() (RestRequiredBuildCondition, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreateRequiredBuildsMergeCheckExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) CreateRequiredBuildsMergeCheckRequest(ctx context.Context, projectKey string, repositorySlug string) BuildsAndDeploymentsAPICreateRequiredBuildsMergeCheckRequest { + return BuildsAndDeploymentsAPICreateRequiredBuildsMergeCheckRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) CreateRequiredBuildsMergeCheckExecute(r *BuildsAndDeploymentsAPICreateRequiredBuildsMergeCheckRequest) (RestRequiredBuildCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/required-builds/latest/projects/{projectKey}/repos/{repositorySlug}/condition" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateRequiredBuildsMergeCheckCall(r.ctx, requestURL, r.restRequiredBuildConditionSetRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) CreateRequiredBuildsMergeCheck(ctx context.Context, projectKey string, repositorySlug string, restRequiredBuildConditionSetRequest RestRequiredBuildConditionSetRequest) (RestRequiredBuildCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/required-builds/latest/projects/{projectKey}/repos/{repositorySlug}/condition" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateRequiredBuildsMergeCheckCall(ctx, requestURL, restRequiredBuildConditionSetRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeCreateRequiredBuildsMergeCheckCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestRequiredBuildCondition, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestRequiredBuildCondition + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestRequiredBuildCondition](&response) + if err == nil { + result = response.Body.(RestRequiredBuildCondition) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type BuildsAndDeploymentsAPIDeleteRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + key *string +} + + // the key of the build status +func (r *BuildsAndDeploymentsAPIDeleteRequest) Key(key string) *BuildsAndDeploymentsAPIDeleteRequest { + r.key = &key + return r +} + +func (r *BuildsAndDeploymentsAPIDeleteRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) DeleteRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIDeleteRequest { + return BuildsAndDeploymentsAPIDeleteRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) DeleteExecute(r *BuildsAndDeploymentsAPIDeleteRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/builds" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.key!=nil { + withUrlQueryParam(requestURL, "key", *r.key) + } + return a.makeDeleteCall(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) Delete(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/builds" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "key", key) + return a.makeDeleteCall(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeDeleteCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type BuildsAndDeploymentsAPIDelete1Request struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + deploymentSequenceNumber *string + key *string + environmentKey *string +} + + // the sequence number of the deployment, as detailed by the query parameter +func (r *BuildsAndDeploymentsAPIDelete1Request) DeploymentSequenceNumber(deploymentSequenceNumber string) *BuildsAndDeploymentsAPIDelete1Request { + r.deploymentSequenceNumber = &deploymentSequenceNumber + return r +} + + // the key of the deployment, as detailed by the query parameter +func (r *BuildsAndDeploymentsAPIDelete1Request) Key(key string) *BuildsAndDeploymentsAPIDelete1Request { + r.key = &key + return r +} + + // the key of the environment, as detailed by the query parameter +func (r *BuildsAndDeploymentsAPIDelete1Request) EnvironmentKey(environmentKey string) *BuildsAndDeploymentsAPIDelete1Request { + r.environmentKey = &environmentKey + return r +} + +func (r *BuildsAndDeploymentsAPIDelete1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.Delete1Execute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) Delete1Request(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIDelete1Request { + return BuildsAndDeploymentsAPIDelete1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) Delete1Execute(r *BuildsAndDeploymentsAPIDelete1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/deployments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.deploymentSequenceNumber!=nil { + withUrlQueryParam(requestURL, "deploymentSequenceNumber", *r.deploymentSequenceNumber) + } + if r.key!=nil { + withUrlQueryParam(requestURL, "key", *r.key) + } + if r.environmentKey!=nil { + withUrlQueryParam(requestURL, "environmentKey", *r.environmentKey) + } + return a.makeDelete1Call(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) Delete1(ctx context.Context, projectKey string, commitId string, repositorySlug string, deploymentSequenceNumber string, key string, environmentKey string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/deployments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "deploymentSequenceNumber", deploymentSequenceNumber) + withUrlQueryParam(requestURL, "key", key) + withUrlQueryParam(requestURL, "environmentKey", environmentKey) + return a.makeDelete1Call(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeDelete1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type BuildsAndDeploymentsAPIDeleteACodeInsightsReportRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + key string +} + +func (r *BuildsAndDeploymentsAPIDeleteACodeInsightsReportRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteACodeInsightsReportExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) DeleteACodeInsightsReportRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPIDeleteACodeInsightsReportRequest { + return BuildsAndDeploymentsAPIDeleteACodeInsightsReportRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + key: key, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) DeleteACodeInsightsReportExecute(r *BuildsAndDeploymentsAPIDeleteACodeInsightsReportRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(r.key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteACodeInsightsReportCall(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) DeleteACodeInsightsReport(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteACodeInsightsReportCall(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeDeleteACodeInsightsReportCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type BuildsAndDeploymentsAPIDeleteAnnotationsRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + key string + externalId *string +} + + // The external IDs for the annotations that are to be deleted. Can be specified more than once to delete by more than one external ID, or can be unspecified to delete all annotations. +func (r *BuildsAndDeploymentsAPIDeleteAnnotationsRequest) ExternalId(externalId string) *BuildsAndDeploymentsAPIDeleteAnnotationsRequest { + r.externalId = &externalId + return r +} + +func (r *BuildsAndDeploymentsAPIDeleteAnnotationsRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteAnnotationsExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) DeleteAnnotationsRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPIDeleteAnnotationsRequest { + return BuildsAndDeploymentsAPIDeleteAnnotationsRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + key: key, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) DeleteAnnotationsExecute(r *BuildsAndDeploymentsAPIDeleteAnnotationsRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}/annotations" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(r.key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.externalId!=nil { + withUrlQueryParam(requestURL, "externalId", *r.externalId) + } + return a.makeDeleteAnnotationsCall(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) DeleteAnnotations(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string, externalId string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}/annotations" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "externalId", externalId) + return a.makeDeleteAnnotationsCall(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeDeleteAnnotationsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type BuildsAndDeploymentsAPIDeleteRequiredBuildsMergeCheckRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + id int64 + repositorySlug string +} + +func (r *BuildsAndDeploymentsAPIDeleteRequiredBuildsMergeCheckRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteRequiredBuildsMergeCheckExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) DeleteRequiredBuildsMergeCheckRequest(ctx context.Context, projectKey string, id int64, repositorySlug string) BuildsAndDeploymentsAPIDeleteRequiredBuildsMergeCheckRequest { + return BuildsAndDeploymentsAPIDeleteRequiredBuildsMergeCheckRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + repositorySlug: repositorySlug, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) DeleteRequiredBuildsMergeCheckExecute(r *BuildsAndDeploymentsAPIDeleteRequiredBuildsMergeCheckRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/required-builds/latest/projects/{projectKey}/repos/{repositorySlug}/condition/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(parameterValueToString(r.id))) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteRequiredBuildsMergeCheckCall(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) DeleteRequiredBuildsMergeCheck(ctx context.Context, projectKey string, id int64, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/required-builds/latest/projects/{projectKey}/repos/{repositorySlug}/condition/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(parameterValueToString(id))) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteRequiredBuildsMergeCheckCall(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeDeleteRequiredBuildsMergeCheckCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type BuildsAndDeploymentsAPIGetRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + key *string +} + + // the key of the build status +func (r *BuildsAndDeploymentsAPIGetRequest) Key(key string) *BuildsAndDeploymentsAPIGetRequest { + r.key = &key + return r +} + +func (r *BuildsAndDeploymentsAPIGetRequest) Execute() (RestBuildStatus, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIGetRequest { + return BuildsAndDeploymentsAPIGetRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) GetExecute(r *BuildsAndDeploymentsAPIGetRequest) (RestBuildStatus, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/builds" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.key!=nil { + withUrlQueryParam(requestURL, "key", *r.key) + } + return a.makeGetCall(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) Get(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) (RestBuildStatus, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/builds" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "key", key) + return a.makeGetCall(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeGetCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestBuildStatus, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestBuildStatus + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestBuildStatus](&response) + if err == nil { + result = response.Body.(RestBuildStatus) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type BuildsAndDeploymentsAPIGet1Request struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + deploymentSequenceNumber *string + key *string + environmentKey *string +} + + // the sequence number of the deployment, as detailed by the query param +func (r *BuildsAndDeploymentsAPIGet1Request) DeploymentSequenceNumber(deploymentSequenceNumber string) *BuildsAndDeploymentsAPIGet1Request { + r.deploymentSequenceNumber = &deploymentSequenceNumber + return r +} + + // the key of the deployment, as detailed by the query parameter +func (r *BuildsAndDeploymentsAPIGet1Request) Key(key string) *BuildsAndDeploymentsAPIGet1Request { + r.key = &key + return r +} + + // the key of the environment, as detailed by the query parameter +func (r *BuildsAndDeploymentsAPIGet1Request) EnvironmentKey(environmentKey string) *BuildsAndDeploymentsAPIGet1Request { + r.environmentKey = &environmentKey + return r +} + +func (r *BuildsAndDeploymentsAPIGet1Request) Execute() (RestDeployment, aurestclientapi.ParsedResponse, error) { + return r.ApiService.Get1Execute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) Get1Request(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIGet1Request { + return BuildsAndDeploymentsAPIGet1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) Get1Execute(r *BuildsAndDeploymentsAPIGet1Request) (RestDeployment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/deployments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.deploymentSequenceNumber!=nil { + withUrlQueryParam(requestURL, "deploymentSequenceNumber", *r.deploymentSequenceNumber) + } + if r.key!=nil { + withUrlQueryParam(requestURL, "key", *r.key) + } + if r.environmentKey!=nil { + withUrlQueryParam(requestURL, "environmentKey", *r.environmentKey) + } + return a.makeGet1Call(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) Get1(ctx context.Context, projectKey string, commitId string, repositorySlug string, deploymentSequenceNumber string, key string, environmentKey string) (RestDeployment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/deployments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "deploymentSequenceNumber", deploymentSequenceNumber) + withUrlQueryParam(requestURL, "key", key) + withUrlQueryParam(requestURL, "environmentKey", environmentKey) + return a.makeGet1Call(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeGet1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestDeployment, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestDeployment + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestDeployment](&response) + if err == nil { + result = response.Body.(RestDeployment) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type BuildsAndDeploymentsAPIGetACodeInsightsReportRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + key string +} + +func (r *BuildsAndDeploymentsAPIGetACodeInsightsReportRequest) Execute() (RestInsightReport, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetACodeInsightsReportExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetACodeInsightsReportRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPIGetACodeInsightsReportRequest { + return BuildsAndDeploymentsAPIGetACodeInsightsReportRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + key: key, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) GetACodeInsightsReportExecute(r *BuildsAndDeploymentsAPIGetACodeInsightsReportRequest) (RestInsightReport, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(r.key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetACodeInsightsReportCall(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetACodeInsightsReport(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) (RestInsightReport, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetACodeInsightsReportCall(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeGetACodeInsightsReportCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestInsightReport, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestInsightReport + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestInsightReport](&response) + if err == nil { + result = response.Body.(RestInsightReport) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type BuildsAndDeploymentsAPIGetAnnotationsRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + severity *string + path *string + externalId *string + type_ *string + key *string +} + + // Return only annotations that have one of the given severities. Can be specified more than once to filter by more than one severity. Valid severities are <code>LOW</code>, <code>MEDIUM</code> and <code>HIGH</code>. +func (r *BuildsAndDeploymentsAPIGetAnnotationsRequest) Severity(severity string) *BuildsAndDeploymentsAPIGetAnnotationsRequest { + r.severity = &severity + return r +} + + // Return only annotations that appear on one of the provided paths. Can be specified more than once to filter by more than one path. +func (r *BuildsAndDeploymentsAPIGetAnnotationsRequest) Path(path string) *BuildsAndDeploymentsAPIGetAnnotationsRequest { + r.path = &path + return r +} + + // Return only annotations that have one of the provided external IDs. Can be specified more than once to filter by more than one external ID. +func (r *BuildsAndDeploymentsAPIGetAnnotationsRequest) ExternalId(externalId string) *BuildsAndDeploymentsAPIGetAnnotationsRequest { + r.externalId = &externalId + return r +} + + // Return only annotations that have one of the given types. Can be specified more than once to filter by multiple types. Valid types are <code>BUG</code>, <code>CODE_SMELL</code>, and <code>VULNERABILITY</code>. +func (r *BuildsAndDeploymentsAPIGetAnnotationsRequest) Type_(type_ string) *BuildsAndDeploymentsAPIGetAnnotationsRequest { + r.type_ = &type_ + return r +} + + // Return only annotations that belong to one of the provided report keys. Can be specified more than once to filter by more than one report +func (r *BuildsAndDeploymentsAPIGetAnnotationsRequest) Key(key string) *BuildsAndDeploymentsAPIGetAnnotationsRequest { + r.key = &key + return r +} + +func (r *BuildsAndDeploymentsAPIGetAnnotationsRequest) Execute() (RestInsightAnnotationsResponse, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetAnnotationsExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetAnnotationsRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIGetAnnotationsRequest { + return BuildsAndDeploymentsAPIGetAnnotationsRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) GetAnnotationsExecute(r *BuildsAndDeploymentsAPIGetAnnotationsRequest) (RestInsightAnnotationsResponse, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/annotations" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.severity!=nil { + withUrlQueryParam(requestURL, "severity", *r.severity) + } + if r.path!=nil { + withUrlQueryParam(requestURL, "path", *r.path) + } + if r.externalId!=nil { + withUrlQueryParam(requestURL, "externalId", *r.externalId) + } + if r.type_!=nil { + withUrlQueryParam(requestURL, "type", *r.type_) + } + if r.key!=nil { + withUrlQueryParam(requestURL, "key", *r.key) + } + return a.makeGetAnnotationsCall(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetAnnotations(ctx context.Context, projectKey string, commitId string, repositorySlug string, severity string, path string, externalId string, type_ string, key string) (RestInsightAnnotationsResponse, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/annotations" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "severity", severity) + withUrlQueryParam(requestURL, "path", path) + withUrlQueryParam(requestURL, "externalId", externalId) + withUrlQueryParam(requestURL, "type", type_) + withUrlQueryParam(requestURL, "key", key) + return a.makeGetAnnotationsCall(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeGetAnnotationsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestInsightAnnotationsResponse, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestInsightAnnotationsResponse + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestInsightAnnotationsResponse](&response) + if err == nil { + result = response.Body.(RestInsightAnnotationsResponse) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type BuildsAndDeploymentsAPIGetAnnotations1Request struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + key string +} + +func (r *BuildsAndDeploymentsAPIGetAnnotations1Request) Execute() (RestInsightAnnotationsResponse, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetAnnotations1Execute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetAnnotations1Request(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPIGetAnnotations1Request { + return BuildsAndDeploymentsAPIGetAnnotations1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + key: key, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) GetAnnotations1Execute(r *BuildsAndDeploymentsAPIGetAnnotations1Request) (RestInsightAnnotationsResponse, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}/annotations" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(r.key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetAnnotations1Call(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetAnnotations1(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) (RestInsightAnnotationsResponse, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}/annotations" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetAnnotations1Call(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeGetAnnotations1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestInsightAnnotationsResponse, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestInsightAnnotationsResponse + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestInsightAnnotationsResponse](&response) + if err == nil { + result = response.Body.(RestInsightAnnotationsResponse) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type BuildsAndDeploymentsAPIGetBuildStatusStatsRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + commitId string + includeUnique *bool +} + + // include a unique build result if there is either only one failed build, only one in-progress build or only one successful build +func (r *BuildsAndDeploymentsAPIGetBuildStatusStatsRequest) IncludeUnique(includeUnique bool) *BuildsAndDeploymentsAPIGetBuildStatusStatsRequest { + r.includeUnique = &includeUnique + return r +} + +func (r *BuildsAndDeploymentsAPIGetBuildStatusStatsRequest) Execute() (RestBuildStats, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetBuildStatusStatsExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetBuildStatusStatsRequest(ctx context.Context, commitId string) BuildsAndDeploymentsAPIGetBuildStatusStatsRequest { + return BuildsAndDeploymentsAPIGetBuildStatusStatsRequest{ + ApiService: a, + ctx: ctx, + commitId: commitId, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) GetBuildStatusStatsExecute(r *BuildsAndDeploymentsAPIGetBuildStatusStatsRequest) (RestBuildStats, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/build-status/latest/commits/stats/{commitId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.includeUnique!=nil { + withUrlQueryParam(requestURL, "includeUnique", parameterValueToString(*r.includeUnique)) + } + return a.makeGetBuildStatusStatsCall(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetBuildStatusStats(ctx context.Context, commitId string, includeUnique bool) (RestBuildStats, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/build-status/latest/commits/stats/{commitId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "includeUnique", parameterValueToString(includeUnique)) + return a.makeGetBuildStatusStatsCall(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeGetBuildStatusStatsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestBuildStats, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestBuildStats + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestBuildStats](&response) + if err == nil { + result = response.Body.(RestBuildStats) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type BuildsAndDeploymentsAPIGetMultipleBuildStatusStatsRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + requestBody *[]string +} + + // full SHA1 of each commit +func (r *BuildsAndDeploymentsAPIGetMultipleBuildStatusStatsRequest) RequestBody(requestBody []string) *BuildsAndDeploymentsAPIGetMultipleBuildStatusStatsRequest { + r.requestBody = &requestBody + return r +} + +func (r *BuildsAndDeploymentsAPIGetMultipleBuildStatusStatsRequest) Execute() (interface{}, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetMultipleBuildStatusStatsExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetMultipleBuildStatusStatsRequest(ctx context.Context) BuildsAndDeploymentsAPIGetMultipleBuildStatusStatsRequest { + return BuildsAndDeploymentsAPIGetMultipleBuildStatusStatsRequest{ + ApiService: a, + ctx: ctx, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) GetMultipleBuildStatusStatsExecute(r *BuildsAndDeploymentsAPIGetMultipleBuildStatusStatsRequest) (interface{}, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/build-status/latest/commits/stats" + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetMultipleBuildStatusStatsCall(r.ctx, requestURL, r.requestBody) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetMultipleBuildStatusStats(ctx context.Context, requestBody []string) (interface{}, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/build-status/latest/commits/stats" + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetMultipleBuildStatusStatsCall(ctx, requestURL, requestBody) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeGetMultipleBuildStatusStatsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (interface{}, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result interface{} + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[interface{}](&response) + if err == nil { + result = response.Body.(interface{}) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type BuildsAndDeploymentsAPIGetPageOfRequiredBuildsMergeChecksRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + repositorySlug string + start *float32 + limit *float32 +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *BuildsAndDeploymentsAPIGetPageOfRequiredBuildsMergeChecksRequest) Start(start float32) *BuildsAndDeploymentsAPIGetPageOfRequiredBuildsMergeChecksRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *BuildsAndDeploymentsAPIGetPageOfRequiredBuildsMergeChecksRequest) Limit(limit float32) *BuildsAndDeploymentsAPIGetPageOfRequiredBuildsMergeChecksRequest { + r.limit = &limit + return r +} + +func (r *BuildsAndDeploymentsAPIGetPageOfRequiredBuildsMergeChecksRequest) Execute() (GetPageOfRequiredBuildsMergeChecks200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetPageOfRequiredBuildsMergeChecksExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetPageOfRequiredBuildsMergeChecksRequest(ctx context.Context, projectKey string, repositorySlug string) BuildsAndDeploymentsAPIGetPageOfRequiredBuildsMergeChecksRequest { + return BuildsAndDeploymentsAPIGetPageOfRequiredBuildsMergeChecksRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) GetPageOfRequiredBuildsMergeChecksExecute(r *BuildsAndDeploymentsAPIGetPageOfRequiredBuildsMergeChecksRequest) (GetPageOfRequiredBuildsMergeChecks200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/required-builds/latest/projects/{projectKey}/repos/{repositorySlug}/conditions" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetPageOfRequiredBuildsMergeChecksCall(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetPageOfRequiredBuildsMergeChecks(ctx context.Context, projectKey string, repositorySlug string, start float32, limit float32) (GetPageOfRequiredBuildsMergeChecks200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/required-builds/latest/projects/{projectKey}/repos/{repositorySlug}/conditions" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetPageOfRequiredBuildsMergeChecksCall(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeGetPageOfRequiredBuildsMergeChecksCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetPageOfRequiredBuildsMergeChecks200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetPageOfRequiredBuildsMergeChecks200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetPageOfRequiredBuildsMergeChecks200Response](&response) + if err == nil { + result = response.Body.(GetPageOfRequiredBuildsMergeChecks200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type BuildsAndDeploymentsAPIGetReportsRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + start *float32 + limit *float32 +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *BuildsAndDeploymentsAPIGetReportsRequest) Start(start float32) *BuildsAndDeploymentsAPIGetReportsRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *BuildsAndDeploymentsAPIGetReportsRequest) Limit(limit float32) *BuildsAndDeploymentsAPIGetReportsRequest { + r.limit = &limit + return r +} + +func (r *BuildsAndDeploymentsAPIGetReportsRequest) Execute() (GetReports200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetReportsExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetReportsRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) BuildsAndDeploymentsAPIGetReportsRequest { + return BuildsAndDeploymentsAPIGetReportsRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) GetReportsExecute(r *BuildsAndDeploymentsAPIGetReportsRequest) (GetReports200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetReportsCall(r.ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) GetReports(ctx context.Context, projectKey string, commitId string, repositorySlug string, start float32, limit float32) (GetReports200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetReportsCall(ctx, requestURL, nil) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeGetReportsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetReports200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetReports200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetReports200Response](&response) + if err == nil { + result = response.Body.(GetReports200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type BuildsAndDeploymentsAPISetACodeInsightsReportRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + commitId string + repositorySlug string + key string + restSetInsightReportRequest *RestSetInsightReportRequest +} + + // The request object containing the details of the report to create (see example). +func (r *BuildsAndDeploymentsAPISetACodeInsightsReportRequest) RestSetInsightReportRequest(restSetInsightReportRequest RestSetInsightReportRequest) *BuildsAndDeploymentsAPISetACodeInsightsReportRequest { + r.restSetInsightReportRequest = &restSetInsightReportRequest + return r +} + +func (r *BuildsAndDeploymentsAPISetACodeInsightsReportRequest) Execute() (RestInsightReport, aurestclientapi.ParsedResponse, error) { + return r.ApiService.SetACodeInsightsReportExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) SetACodeInsightsReportRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPISetACodeInsightsReportRequest { + return BuildsAndDeploymentsAPISetACodeInsightsReportRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + key: key, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) SetACodeInsightsReportExecute(r *BuildsAndDeploymentsAPISetACodeInsightsReportRequest) (RestInsightReport, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(r.key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetACodeInsightsReportCall(r.ctx, requestURL, r.restSetInsightReportRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) SetACodeInsightsReport(ctx context.Context, projectKey string, commitId string, repositorySlug string, key string, restSetInsightReportRequest RestSetInsightReportRequest) (RestInsightReport, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetACodeInsightsReportCall(ctx, requestURL, restSetInsightReportRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeSetACodeInsightsReportCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestInsightReport, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestInsightReport + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestInsightReport](&response) + if err == nil { + result = response.Body.(RestInsightReport) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type BuildsAndDeploymentsAPISetAnnotationRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + externalId string + commitId string + repositorySlug string + key string + restSingleAddInsightAnnotationRequest *RestSingleAddInsightAnnotationRequest +} + + // The new annotation that is to replace the existing one. +func (r *BuildsAndDeploymentsAPISetAnnotationRequest) RestSingleAddInsightAnnotationRequest(restSingleAddInsightAnnotationRequest RestSingleAddInsightAnnotationRequest) *BuildsAndDeploymentsAPISetAnnotationRequest { + r.restSingleAddInsightAnnotationRequest = &restSingleAddInsightAnnotationRequest + return r +} + +func (r *BuildsAndDeploymentsAPISetAnnotationRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.SetAnnotationExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) SetAnnotationRequest(ctx context.Context, projectKey string, externalId string, commitId string, repositorySlug string, key string) BuildsAndDeploymentsAPISetAnnotationRequest { + return BuildsAndDeploymentsAPISetAnnotationRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + externalId: externalId, + commitId: commitId, + repositorySlug: repositorySlug, + key: key, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) SetAnnotationExecute(r *BuildsAndDeploymentsAPISetAnnotationRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}/annotations/{externalId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{externalId}", urlUtil.PathEscape(r.externalId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(r.key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetAnnotationCall(r.ctx, requestURL, r.restSingleAddInsightAnnotationRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) SetAnnotation(ctx context.Context, projectKey string, externalId string, commitId string, repositorySlug string, key string, restSingleAddInsightAnnotationRequest RestSingleAddInsightAnnotationRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/insights/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/reports/{key}/annotations/{externalId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{externalId}", urlUtil.PathEscape(externalId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{key}", urlUtil.PathEscape(key)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetAnnotationCall(ctx, requestURL, restSingleAddInsightAnnotationRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeSetAnnotationCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type BuildsAndDeploymentsAPIUpdateRequiredBuildsMergeCheckRequest struct { + ctx context.Context + ApiService *BuildsAndDeploymentsAPIRepository + projectKey string + id int64 + repositorySlug string + restRequiredBuildConditionSetRequest *RestRequiredBuildConditionSetRequest +} + + // The request specifying the required build parent keys, ref matcher and exemption matcher +func (r *BuildsAndDeploymentsAPIUpdateRequiredBuildsMergeCheckRequest) RestRequiredBuildConditionSetRequest(restRequiredBuildConditionSetRequest RestRequiredBuildConditionSetRequest) *BuildsAndDeploymentsAPIUpdateRequiredBuildsMergeCheckRequest { + r.restRequiredBuildConditionSetRequest = &restRequiredBuildConditionSetRequest + return r +} + +func (r *BuildsAndDeploymentsAPIUpdateRequiredBuildsMergeCheckRequest) Execute() (RestRequiredBuildCondition, aurestclientapi.ParsedResponse, error) { + return r.ApiService.UpdateRequiredBuildsMergeCheckExecute(r) +} + +func (a *BuildsAndDeploymentsAPIRepository) UpdateRequiredBuildsMergeCheckRequest(ctx context.Context, projectKey string, id int64, repositorySlug string) BuildsAndDeploymentsAPIUpdateRequiredBuildsMergeCheckRequest { + return BuildsAndDeploymentsAPIUpdateRequiredBuildsMergeCheckRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + repositorySlug: repositorySlug, + } +} + +func (a *BuildsAndDeploymentsAPIRepository) UpdateRequiredBuildsMergeCheckExecute(r *BuildsAndDeploymentsAPIUpdateRequiredBuildsMergeCheckRequest) (RestRequiredBuildCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/required-builds/latest/projects/{projectKey}/repos/{repositorySlug}/condition/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(parameterValueToString(r.id))) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdateRequiredBuildsMergeCheckCall(r.ctx, requestURL, r.restRequiredBuildConditionSetRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) UpdateRequiredBuildsMergeCheck(ctx context.Context, projectKey string, id int64, repositorySlug string, restRequiredBuildConditionSetRequest RestRequiredBuildConditionSetRequest) (RestRequiredBuildCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/required-builds/latest/projects/{projectKey}/repos/{repositorySlug}/condition/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(parameterValueToString(id))) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdateRequiredBuildsMergeCheckCall(ctx, requestURL, restRequiredBuildConditionSetRequest) +} + +func (a *BuildsAndDeploymentsAPIRepository) makeUpdateRequiredBuildsMergeCheckCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestRequiredBuildCondition, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestRequiredBuildCondition + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestRequiredBuildCondition](&response) + if err == nil { + result = response.Body.(RestRequiredBuildCondition) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + +type BuildsAndDeploymentsAPIRepository struct { + ApiClient *ApiClient +} + +func (c *BuildsAndDeploymentsAPIRepository) baseUrl() string { + return c.ApiClient.BaseUrl +} + +func (c *BuildsAndDeploymentsAPIRepository) httpClient() aurestclientapi.Client { + return c.ApiClient.Client +} + +func NewBuildsAndDeploymentsAPI(client *ApiClient) BuildsAndDeploymentsAPI { + return &BuildsAndDeploymentsAPIRepository{ApiClient: client} +} diff --git a/internal/client/bitbucket/generated_api_pull_requests.go b/internal/client/bitbucket/generated_api_pull_requests.go new file mode 100644 index 0000000..5e63821 --- /dev/null +++ b/internal/client/bitbucket/generated_api_pull_requests.go @@ -0,0 +1,7437 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + +import ( + "context" + "fmt" + aurestclientapi "github.com/StephanHCB/go-autumn-restclient/api" + "net/http" + urlUtil "net/url" + "strings" +) + +type PullRequestsAPI interface { + + /* + ApplySuggestion Apply pull request suggestion + */ + ApplySuggestion(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string, restApplySuggestionRequest RestApplySuggestionRequest) (aurestclientapi.ParsedResponse, error) + + // ApplySuggestionExecutes the request + ApplySuggestionRequest(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIApplySuggestionRequest + + /* + Approve Approve pull request + Deprecated + */ + Approve(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) + + // ApproveExecutes the request + // @return RestPullRequestParticipant + // Deprecated + ApproveRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIApproveRequest + + /* + AssignParticipantRole Assign pull request participant role + */ + AssignParticipantRole(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestAssignParticipantRoleRequest RestPullRequestAssignParticipantRoleRequest) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) + + // AssignParticipantRoleExecutes the request + // @return RestPullRequestParticipant + AssignParticipantRoleRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIAssignParticipantRoleRequest + + /* + CanMerge Test if pull request can be merged + */ + CanMerge(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestPullRequestMergeability, aurestclientapi.ParsedResponse, error) + + // CanMergeExecutes the request + // @return RestPullRequestMergeability + CanMergeRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPICanMergeRequest + + /* + CanRebase Check PR rebase precondition + */ + CanRebase(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestPullRequestRebaseability, aurestclientapi.ParsedResponse, error) + + // CanRebaseExecutes the request + // @return RestPullRequestRebaseability + CanRebaseRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPICanRebaseRequest + + /* + CancelAutoMerge Cancel auto-merge for pull request + */ + CancelAutoMerge(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // CancelAutoMergeExecutes the request + CancelAutoMergeRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPICancelAutoMergeRequest + + /* + Create Create pull request + */ + Create(ctx context.Context, projectKey string, repositorySlug string, restPullRequest RestPullRequest) (RestPullRequest, aurestclientapi.ParsedResponse, error) + + // CreateExecutes the request + // @return RestPullRequest + CreateRequest(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPICreateRequest + + /* + Create1 Create reviewer group + */ + Create1(ctx context.Context, projectKey string, restReviewerGroup RestReviewerGroup) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) + + // Create1Executes the request + // @return RestReviewerGroup + Create1Request(ctx context.Context, projectKey string) PullRequestsAPICreate1Request + + /* + Create2 Create reviewer group + */ + Create2(ctx context.Context, projectKey string, repositorySlug string, restReviewerGroup RestReviewerGroup) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) + + // Create2Executes the request + // @return RestReviewerGroup + Create2Request(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPICreate2Request + + /* + CreateComment1 Add new blocker comment + */ + CreateComment1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restComment RestComment) (RestComment, aurestclientapi.ParsedResponse, error) + + // CreateComment1Executes the request + // @return RestComment + CreateComment1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPICreateComment1Request + + /* + CreateComment2 Add pull request comment + */ + CreateComment2(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restComment RestComment) (RestComment, aurestclientapi.ParsedResponse, error) + + // CreateComment2Executes the request + // @return RestComment + CreateComment2Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPICreateComment2Request + + /* + CreatePullRequestCondition Create default reviewer + */ + CreatePullRequestCondition(ctx context.Context, projectKey string, restDefaultReviewersRequest RestDefaultReviewersRequest) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) + + // CreatePullRequestConditionExecutes the request + // @return RestPullRequestCondition + CreatePullRequestConditionRequest(ctx context.Context, projectKey string) PullRequestsAPICreatePullRequestConditionRequest + + /* + CreatePullRequestCondition1 Create default reviewers condition + */ + CreatePullRequestCondition1(ctx context.Context, projectKey string, repositorySlug string, restDefaultReviewersRequest RestDefaultReviewersRequest) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) + + // CreatePullRequestCondition1Executes the request + // @return RestPullRequestCondition + CreatePullRequestCondition1Request(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPICreatePullRequestCondition1Request + + /* + Decline Decline pull request + */ + Decline(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestDeclineRequest RestPullRequestDeclineRequest, version string) (RestPullRequest, aurestclientapi.ParsedResponse, error) + + // DeclineExecutes the request + // @return RestPullRequest + DeclineRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIDeclineRequest + + /* + Delete3 Delete pull request + */ + Delete3(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestDeleteRequest RestPullRequestDeleteRequest) (aurestclientapi.ParsedResponse, error) + + // Delete3Executes the request + Delete3Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIDelete3Request + + /* + Delete6 Delete reviewer group + */ + Delete6(ctx context.Context, projectKey string, id string) (aurestclientapi.ParsedResponse, error) + + // Delete6Executes the request + Delete6Request(ctx context.Context, projectKey string, id string) PullRequestsAPIDelete6Request + + /* + Delete7 Delete reviewer group + */ + Delete7(ctx context.Context, projectKey string, id string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // Delete7Executes the request + Delete7Request(ctx context.Context, projectKey string, id string, repositorySlug string) PullRequestsAPIDelete7Request + + /* + DeleteComment1 Delete pull request comment + */ + DeleteComment1(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string, version string) (aurestclientapi.ParsedResponse, error) + + // DeleteComment1Executes the request + DeleteComment1Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIDeleteComment1Request + + /* + DeleteComment2 Delete a pull request comment + */ + DeleteComment2(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string, version string) (aurestclientapi.ParsedResponse, error) + + // DeleteComment2Executes the request + DeleteComment2Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIDeleteComment2Request + + /* + DeletePullRequestCondition Remove default reviewer + */ + DeletePullRequestCondition(ctx context.Context, projectKey string, id string) (aurestclientapi.ParsedResponse, error) + + // DeletePullRequestConditionExecutes the request + DeletePullRequestConditionRequest(ctx context.Context, projectKey string, id string) PullRequestsAPIDeletePullRequestConditionRequest + + /* + DeletePullRequestCondition1 Delete a default reviewer condition + */ + DeletePullRequestCondition1(ctx context.Context, projectKey string, id int32, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // DeletePullRequestCondition1Executes the request + DeletePullRequestCondition1Request(ctx context.Context, projectKey string, id int32, repositorySlug string) PullRequestsAPIDeletePullRequestCondition1Request + + /* + DiscardReview Discard pull request review + */ + DiscardReview(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // DiscardReviewExecutes the request + DiscardReviewRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIDiscardReviewRequest + + /* + FinishReview Complete pull request review + */ + FinishReview(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestFinishReviewRequest RestPullRequestFinishReviewRequest, version string) (aurestclientapi.ParsedResponse, error) + + // FinishReviewExecutes the request + FinishReviewRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIFinishReviewRequest + + /* + Get3 Get pull request + */ + Get3(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestPullRequest, aurestclientapi.ParsedResponse, error) + + // Get3Executes the request + // @return RestPullRequest + Get3Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGet3Request + + /* + GetActivities Get pull request activity + */ + GetActivities(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, fromType string, fromId string, start float32, limit float32) (GetActivities200Response, aurestclientapi.ParsedResponse, error) + + // GetActivitiesExecutes the request + // @return GetActivities200Response + GetActivitiesRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetActivitiesRequest + + /* + GetAutoMergeRequest Get auto-merge request for pull request + */ + GetAutoMergeRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestAutoMergeRequest, aurestclientapi.ParsedResponse, error) + + // GetAutoMergeRequestExecutes the request + // @return RestAutoMergeRequest + GetAutoMergeRequestRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetAutoMergeRequestRequest + + /* + GetComment1 Get pull request comment + */ + GetComment1(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) (RestComment, aurestclientapi.ParsedResponse, error) + + // GetComment1Executes the request + // @return RestComment + GetComment1Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIGetComment1Request + + /* + GetComment2 Get a pull request comment + */ + GetComment2(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) (RestComment, aurestclientapi.ParsedResponse, error) + + // GetComment2Executes the request + // @return RestComment + GetComment2Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIGetComment2Request + + /* + GetComments1 Search pull request comments + */ + GetComments1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, count string, state []string, states string, start float32, limit float32) (GetComments200Response, aurestclientapi.ParsedResponse, error) + + // GetComments1Executes the request + // @return GetComments200Response + GetComments1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetComments1Request + + /* + GetComments2 Get pull request comments for path + */ + GetComments2(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, path string, fromHash string, anchorState string, diffType []string, toHash string, state []string, diffTypes string, states string, start float32, limit float32) (GetComments200Response, aurestclientapi.ParsedResponse, error) + + // GetComments2Executes the request + // @return GetComments200Response + GetComments2Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetComments2Request + + /* + GetCommitMessageSuggestion Get commit message suggestion + */ + GetCommitMessageSuggestion(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestCommitMessageSuggestion, aurestclientapi.ParsedResponse, error) + + // GetCommitMessageSuggestionExecutes the request + // @return RestCommitMessageSuggestion + GetCommitMessageSuggestionRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetCommitMessageSuggestionRequest + + /* + GetCommits1 Get pull request commits + */ + GetCommits1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, avatarScheme string, withCounts string, avatarSize string, start float32, limit float32) (GetCommits200Response, aurestclientapi.ParsedResponse, error) + + // GetCommits1Executes the request + // @return GetCommits200Response + GetCommits1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetCommits1Request + + /* + GetMergeBase1 Get the common ancestor between the latest commits of the source and target branches of the pull request + */ + GetMergeBase1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestCommit, aurestclientapi.ParsedResponse, error) + + // GetMergeBase1Executes the request + // @return RestCommit + GetMergeBase1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetMergeBase1Request + + /* + GetMergeConfig Get merge strategies + */ + GetMergeConfig(ctx context.Context, scmId string) (RestPullRequestMergeConfig, aurestclientapi.ParsedResponse, error) + + // GetMergeConfigExecutes the request + // @return RestPullRequestMergeConfig + GetMergeConfigRequest(ctx context.Context, scmId string) PullRequestsAPIGetMergeConfigRequest + + /* + GetPage Get pull requests for repository + */ + GetPage(ctx context.Context, projectKey string, repositorySlug string, withAttributes string, at string, withProperties string, draft string, filterText string, state string, order string, direction string, start float32, limit float32) (GetPullRequests1200Response, aurestclientapi.ParsedResponse, error) + + // GetPageExecutes the request + // @return GetPullRequests1200Response + GetPageRequest(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPIGetPageRequest + + /* + GetPullRequestConditions Get default reviewers + */ + GetPullRequestConditions(ctx context.Context, projectKey string) ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) + + // GetPullRequestConditionsExecutes the request + // @return []RestPullRequestCondition + GetPullRequestConditionsRequest(ctx context.Context, projectKey string) PullRequestsAPIGetPullRequestConditionsRequest + + /* + GetPullRequestConditions1 Get configured default reviewers + */ + GetPullRequestConditions1(ctx context.Context, projectKey string, repositorySlug string) ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) + + // GetPullRequestConditions1Executes the request + // @return []RestPullRequestCondition + GetPullRequestConditions1Request(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPIGetPullRequestConditions1Request + + /* + GetPullRequests Get repository pull requests containing commit + */ + GetPullRequests(ctx context.Context, projectKey string, commitId string, repositorySlug string, start float32, limit float32) (GetPullRequests1200Response, aurestclientapi.ParsedResponse, error) + + // GetPullRequestsExecutes the request + // @return GetPullRequests1200Response + GetPullRequestsRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) PullRequestsAPIGetPullRequestsRequest + + /* + GetReview Get pull request comment thread + */ + GetReview(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, start float32, limit float32) (GetComments200Response, aurestclientapi.ParsedResponse, error) + + // GetReviewExecutes the request + // @return GetComments200Response + GetReviewRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetReviewRequest + + /* + GetReviewerGroup Get reviewer group + */ + GetReviewerGroup(ctx context.Context, projectKey string, id string) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) + + // GetReviewerGroupExecutes the request + // @return RestReviewerGroup + GetReviewerGroupRequest(ctx context.Context, projectKey string, id string) PullRequestsAPIGetReviewerGroupRequest + + /* + GetReviewerGroup1 Get reviewer group + */ + GetReviewerGroup1(ctx context.Context, projectKey string, id string, repositorySlug string) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) + + // GetReviewerGroup1Executes the request + // @return RestReviewerGroup + GetReviewerGroup1Request(ctx context.Context, projectKey string, id string, repositorySlug string) PullRequestsAPIGetReviewerGroup1Request + + /* + GetReviewerGroups Get all reviewer groups + */ + GetReviewerGroups(ctx context.Context, projectKey string, start float32, limit float32) (GetReviewerGroups1200Response, aurestclientapi.ParsedResponse, error) + + // GetReviewerGroupsExecutes the request + // @return GetReviewerGroups1200Response + GetReviewerGroupsRequest(ctx context.Context, projectKey string) PullRequestsAPIGetReviewerGroupsRequest + + /* + GetReviewerGroups1 Get all reviewer groups + */ + GetReviewerGroups1(ctx context.Context, projectKey string, repositorySlug string, start float32, limit float32) (GetReviewerGroups1200Response, aurestclientapi.ParsedResponse, error) + + // GetReviewerGroups1Executes the request + // @return GetReviewerGroups1200Response + GetReviewerGroups1Request(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPIGetReviewerGroups1Request + + /* + GetReviewers Get required reviewers for PR creation + */ + GetReviewers(ctx context.Context, projectKey string, repositorySlug string, targetRepoId string, sourceRepoId string, sourceRefId string, targetRefId string) ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) + + // GetReviewersExecutes the request + // @return []RestPullRequestCondition + GetReviewersRequest(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPIGetReviewersRequest + + /* + GetUsers Get reviewer group users + */ + GetUsers(ctx context.Context, projectKey string, id string, repositorySlug string) ([]RestApplicationUser, aurestclientapi.ParsedResponse, error) + + // GetUsersExecutes the request + // @return []RestApplicationUser + GetUsersRequest(ctx context.Context, projectKey string, id string, repositorySlug string) PullRequestsAPIGetUsersRequest + + /* + ListParticipants Get pull request participants + */ + ListParticipants(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, start float32, limit float32) (ListParticipants200Response, aurestclientapi.ParsedResponse, error) + + // ListParticipantsExecutes the request + // @return ListParticipants200Response + ListParticipantsRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIListParticipantsRequest + + /* + Merge Merge pull request + */ + Merge(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestMergeRequest RestPullRequestMergeRequest, version string) (RestPullRequest, aurestclientapi.ParsedResponse, error) + + // MergeExecutes the request + // @return RestPullRequest + MergeRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIMergeRequest + + /* + React1 React to a PR comment + */ + React1(ctx context.Context, projectKey string, commentId string, pullRequestId string, emoticon string, repositorySlug string) (RestUserReaction, aurestclientapi.ParsedResponse, error) + + // React1Executes the request + // @return RestUserReaction + React1Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, emoticon string, repositorySlug string) PullRequestsAPIReact1Request + + /* + Rebase Rebase pull request + */ + Rebase(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestRebaseRequest RestPullRequestRebaseRequest) (RestPullRequestRebaseResult, aurestclientapi.ParsedResponse, error) + + // RebaseExecutes the request + // @return RestPullRequestRebaseResult + RebaseRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIRebaseRequest + + /* + Reopen Re-open pull request + */ + Reopen(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestReopenRequest RestPullRequestReopenRequest, version string) (RestPullRequest, aurestclientapi.ParsedResponse, error) + + // ReopenExecutes the request + // @return RestPullRequest + ReopenRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIReopenRequest + + /* + Search Search pull request participants + */ + Search(ctx context.Context, projectKey string, repositorySlug string, filter string, role string, direction string, start float32, limit float32) (GetLikers200Response, aurestclientapi.ParsedResponse, error) + + // SearchExecutes the request + // @return GetLikers200Response + SearchRequest(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPISearchRequest + + /* + SetMergeConfig Update merge strategies + */ + SetMergeConfig(ctx context.Context, scmId string, restPullRequestSettings RestPullRequestSettings) (RestPullRequestMergeConfig, aurestclientapi.ParsedResponse, error) + + // SetMergeConfigExecutes the request + // @return RestPullRequestMergeConfig + SetMergeConfigRequest(ctx context.Context, scmId string) PullRequestsAPISetMergeConfigRequest + + /* + StreamChanges1 Gets pull request changes + */ + StreamChanges1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, sinceId string, changeScope string, untilId string, withComments string, start float32, limit float32) (RestChange, aurestclientapi.ParsedResponse, error) + + // StreamChanges1Executes the request + // @return RestChange + StreamChanges1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIStreamChanges1Request + + /* + StreamDiff2 Stream a diff within a pull request + */ + StreamDiff2(ctx context.Context, path string, projectKey string, pullRequestId string, repositorySlug string, avatarScheme string, contextLines string, sinceId string, srcPath string, diffType string, untilId string, whitespace string, withComments string, avatarSize string, start float32, limit float32) (StreamDiff1200Response, aurestclientapi.ParsedResponse, error) + + // StreamDiff2Executes the request + // @return StreamDiff1200Response + StreamDiff2Request(ctx context.Context, path string, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIStreamDiff2Request + + /* + StreamPatch1 Stream pull request as patch + */ + StreamPatch1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // StreamPatch1Executes the request + StreamPatch1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIStreamPatch1Request + + /* + StreamRawDiff2 Stream raw pull request diff + */ + StreamRawDiff2(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, contextLines string, whitespace string) (aurestclientapi.ParsedResponse, error) + + // StreamRawDiff2Executes the request + StreamRawDiff2Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIStreamRawDiff2Request + + /* + TryAutoMerge Auto-merge pull request + */ + TryAutoMerge(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestAutoMergeProcessingResult, aurestclientapi.ParsedResponse, error) + + // TryAutoMergeExecutes the request + // @return RestAutoMergeProcessingResult + TryAutoMergeRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPITryAutoMergeRequest + + /* + UnReact1 Remove a reaction from a PR comment + */ + UnReact1(ctx context.Context, projectKey string, commentId string, pullRequestId string, emoticon string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // UnReact1Executes the request + UnReact1Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, emoticon string, repositorySlug string) PullRequestsAPIUnReact1Request + + /* + UnassignParticipantRole Unassign pull request participant + */ + UnassignParticipantRole(ctx context.Context, projectKey string, userSlug string, pullRequestId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // UnassignParticipantRoleExecutes the request + UnassignParticipantRoleRequest(ctx context.Context, projectKey string, userSlug string, pullRequestId string, repositorySlug string) PullRequestsAPIUnassignParticipantRoleRequest + + /* + UnassignParticipantRole1 Unassign pull request participant + Deprecated + */ + UnassignParticipantRole1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, username string) (aurestclientapi.ParsedResponse, error) + + // UnassignParticipantRole1Executes the request + // Deprecated + UnassignParticipantRole1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIUnassignParticipantRole1Request + + /* + Unwatch1 Stop watching pull request + */ + Unwatch1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // Unwatch1Executes the request + Unwatch1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIUnwatch1Request + + /* + Update Update pull request metadata + */ + Update(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequest RestPullRequest) (RestPullRequest, aurestclientapi.ParsedResponse, error) + + // UpdateExecutes the request + // @return RestPullRequest + UpdateRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIUpdateRequest + + /* + Update1 Update reviewer group attributes + */ + Update1(ctx context.Context, projectKey string, id string, restReviewerGroup RestReviewerGroup) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) + + // Update1Executes the request + // @return RestReviewerGroup + Update1Request(ctx context.Context, projectKey string, id string) PullRequestsAPIUpdate1Request + + /* + Update2 Update reviewer group attributes + */ + Update2(ctx context.Context, projectKey string, id string, repositorySlug string, restReviewerGroup RestReviewerGroup) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) + + // Update2Executes the request + // @return RestReviewerGroup + Update2Request(ctx context.Context, projectKey string, id string, repositorySlug string) PullRequestsAPIUpdate2Request + + /* + UpdateComment1 Update pull request comment + */ + UpdateComment1(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string, restComment RestComment) (RestComment, aurestclientapi.ParsedResponse, error) + + // UpdateComment1Executes the request + // @return RestComment + UpdateComment1Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIUpdateComment1Request + + /* + UpdateComment2 Update pull request comment + */ + UpdateComment2(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string, restComment RestComment) (RestComment, aurestclientapi.ParsedResponse, error) + + // UpdateComment2Executes the request + // @return RestComment + UpdateComment2Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIUpdateComment2Request + + /* + UpdatePullRequestCondition Update the default reviewer + */ + UpdatePullRequestCondition(ctx context.Context, projectKey string, id string, restDefaultReviewersRequest RestDefaultReviewersRequest) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) + + // UpdatePullRequestConditionExecutes the request + // @return RestPullRequestCondition + UpdatePullRequestConditionRequest(ctx context.Context, projectKey string, id string) PullRequestsAPIUpdatePullRequestConditionRequest + + /* + UpdatePullRequestCondition1 Update a default reviewer condition + */ + UpdatePullRequestCondition1(ctx context.Context, projectKey string, id string, repositorySlug string, updatePullRequestCondition1Request UpdatePullRequestCondition1Request) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) + + // UpdatePullRequestCondition1Executes the request + // @return RestPullRequestCondition + UpdatePullRequestCondition1Request(ctx context.Context, projectKey string, id string, repositorySlug string) PullRequestsAPIUpdatePullRequestCondition1Request + + /* + UpdateStatus Change pull request status + */ + UpdateStatus(ctx context.Context, projectKey string, userSlug string, pullRequestId string, repositorySlug string, restPullRequestAssignStatusRequest RestPullRequestAssignStatusRequest, version string) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) + + // UpdateStatusExecutes the request + // @return RestPullRequestParticipant + UpdateStatusRequest(ctx context.Context, projectKey string, userSlug string, pullRequestId string, repositorySlug string) PullRequestsAPIUpdateStatusRequest + + /* + Watch1 Watch pull request + */ + Watch1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // Watch1Executes the request + Watch1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIWatch1Request + + /* + WithdrawApproval Unapprove pull request + Deprecated + */ + WithdrawApproval(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) + + // WithdrawApprovalExecutes the request + // @return RestPullRequestParticipant + // Deprecated + WithdrawApprovalRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIWithdrawApprovalRequest +} + + type PullRequestsAPIApplySuggestionRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + commentId string + pullRequestId string + repositorySlug string + restApplySuggestionRequest *RestApplySuggestionRequest +} + + // A request containing other parameters required to apply a suggestion - The given versions/hashes must match the server's version/hashes or the suggestion application will fail (in order to avoid applying the suggestion to the wrong place +func (r *PullRequestsAPIApplySuggestionRequest) RestApplySuggestionRequest(restApplySuggestionRequest RestApplySuggestionRequest) *PullRequestsAPIApplySuggestionRequest { + r.restApplySuggestionRequest = &restApplySuggestionRequest + return r +} + +func (r *PullRequestsAPIApplySuggestionRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.ApplySuggestionExecute(r) +} + +func (a *PullRequestsAPIRepository) ApplySuggestionRequest(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIApplySuggestionRequest { + return PullRequestsAPIApplySuggestionRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) ApplySuggestionExecute(r *PullRequestsAPIApplySuggestionRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}/apply-suggestion" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeApplySuggestionCall(r.ctx, requestURL, r.restApplySuggestionRequest) +} + +func (a *PullRequestsAPIRepository) ApplySuggestion(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string, restApplySuggestionRequest RestApplySuggestionRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}/apply-suggestion" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeApplySuggestionCall(ctx, requestURL, restApplySuggestionRequest) +} + +func (a *PullRequestsAPIRepository) makeApplySuggestionCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIApproveRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIApproveRequest) Execute() (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + return r.ApiService.ApproveExecute(r) +} + +func (a *PullRequestsAPIRepository) ApproveRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIApproveRequest { + return PullRequestsAPIApproveRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +// Deprecated +func (a *PullRequestsAPIRepository) ApproveExecute(r *PullRequestsAPIApproveRequest) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/approve" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeApproveCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) Approve(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/approve" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeApproveCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeApproveCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestPullRequestParticipant + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestParticipant](&response) + if err == nil { + result = response.Body.(RestPullRequestParticipant) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIAssignParticipantRoleRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + restPullRequestAssignParticipantRoleRequest *RestPullRequestAssignParticipantRoleRequest +} + + // The participant to be added to the pull request, includes the user and their role +func (r *PullRequestsAPIAssignParticipantRoleRequest) RestPullRequestAssignParticipantRoleRequest(restPullRequestAssignParticipantRoleRequest RestPullRequestAssignParticipantRoleRequest) *PullRequestsAPIAssignParticipantRoleRequest { + r.restPullRequestAssignParticipantRoleRequest = &restPullRequestAssignParticipantRoleRequest + return r +} + +func (r *PullRequestsAPIAssignParticipantRoleRequest) Execute() (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + return r.ApiService.AssignParticipantRoleExecute(r) +} + +func (a *PullRequestsAPIRepository) AssignParticipantRoleRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIAssignParticipantRoleRequest { + return PullRequestsAPIAssignParticipantRoleRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) AssignParticipantRoleExecute(r *PullRequestsAPIAssignParticipantRoleRequest) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeAssignParticipantRoleCall(r.ctx, requestURL, r.restPullRequestAssignParticipantRoleRequest) +} + +func (a *PullRequestsAPIRepository) AssignParticipantRole(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestAssignParticipantRoleRequest RestPullRequestAssignParticipantRoleRequest) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeAssignParticipantRoleCall(ctx, requestURL, restPullRequestAssignParticipantRoleRequest) +} + +func (a *PullRequestsAPIRepository) makeAssignParticipantRoleCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestPullRequestParticipant + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestParticipant](&response) + if err == nil { + result = response.Body.(RestPullRequestParticipant) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPICanMergeRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPICanMergeRequest) Execute() (RestPullRequestMergeability, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CanMergeExecute(r) +} + +func (a *PullRequestsAPIRepository) CanMergeRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPICanMergeRequest { + return PullRequestsAPICanMergeRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) CanMergeExecute(r *PullRequestsAPICanMergeRequest) (RestPullRequestMergeability, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCanMergeCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) CanMerge(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestPullRequestMergeability, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCanMergeCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeCanMergeCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestMergeability, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestPullRequestMergeability + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestMergeability](&response) + if err == nil { + result = response.Body.(RestPullRequestMergeability) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPICanRebaseRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPICanRebaseRequest) Execute() (RestPullRequestRebaseability, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CanRebaseExecute(r) +} + +func (a *PullRequestsAPIRepository) CanRebaseRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPICanRebaseRequest { + return PullRequestsAPICanRebaseRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) CanRebaseExecute(r *PullRequestsAPICanRebaseRequest) (RestPullRequestRebaseability, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/git/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/rebase" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCanRebaseCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) CanRebase(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestPullRequestRebaseability, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/git/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/rebase" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCanRebaseCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeCanRebaseCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestRebaseability, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestPullRequestRebaseability + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestRebaseability](&response) + if err == nil { + result = response.Body.(RestPullRequestRebaseability) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPICancelAutoMergeRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPICancelAutoMergeRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.CancelAutoMergeExecute(r) +} + +func (a *PullRequestsAPIRepository) CancelAutoMergeRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPICancelAutoMergeRequest { + return PullRequestsAPICancelAutoMergeRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) CancelAutoMergeExecute(r *PullRequestsAPICancelAutoMergeRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/auto-merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCancelAutoMergeCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) CancelAutoMerge(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/auto-merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCancelAutoMergeCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeCancelAutoMergeCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPICreateRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + repositorySlug string + restPullRequest *RestPullRequest +} + + // The pull request data +func (r *PullRequestsAPICreateRequest) RestPullRequest(restPullRequest RestPullRequest) *PullRequestsAPICreateRequest { + r.restPullRequest = &restPullRequest + return r +} + +func (r *PullRequestsAPICreateRequest) Execute() (RestPullRequest, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreateExecute(r) +} + +func (a *PullRequestsAPIRepository) CreateRequest(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPICreateRequest { + return PullRequestsAPICreateRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) CreateExecute(r *PullRequestsAPICreateRequest) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateCall(r.ctx, requestURL, r.restPullRequest) +} + +func (a *PullRequestsAPIRepository) Create(ctx context.Context, projectKey string, repositorySlug string, restPullRequest RestPullRequest) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateCall(ctx, requestURL, restPullRequest) +} + +func (a *PullRequestsAPIRepository) makeCreateCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestPullRequest + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequest](&response) + if err == nil { + result = response.Body.(RestPullRequest) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPICreate1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + restReviewerGroup *RestReviewerGroup +} + + // The reviewer group to be create +func (r *PullRequestsAPICreate1Request) RestReviewerGroup(restReviewerGroup RestReviewerGroup) *PullRequestsAPICreate1Request { + r.restReviewerGroup = &restReviewerGroup + return r +} + +func (r *PullRequestsAPICreate1Request) Execute() (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + return r.ApiService.Create1Execute(r) +} + +func (a *PullRequestsAPIRepository) Create1Request(ctx context.Context, projectKey string) PullRequestsAPICreate1Request { + return PullRequestsAPICreate1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + } +} + +func (a *PullRequestsAPIRepository) Create1Execute(r *PullRequestsAPICreate1Request) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/settings/reviewer-groups" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreate1Call(r.ctx, requestURL, r.restReviewerGroup) +} + +func (a *PullRequestsAPIRepository) Create1(ctx context.Context, projectKey string, restReviewerGroup RestReviewerGroup) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/settings/reviewer-groups" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreate1Call(ctx, requestURL, restReviewerGroup) +} + +func (a *PullRequestsAPIRepository) makeCreate1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestReviewerGroup + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestReviewerGroup](&response) + if err == nil { + result = response.Body.(RestReviewerGroup) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPICreate2Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + repositorySlug string + restReviewerGroup *RestReviewerGroup +} + + // The request containing the details of the reviewer group. +func (r *PullRequestsAPICreate2Request) RestReviewerGroup(restReviewerGroup RestReviewerGroup) *PullRequestsAPICreate2Request { + r.restReviewerGroup = &restReviewerGroup + return r +} + +func (r *PullRequestsAPICreate2Request) Execute() (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + return r.ApiService.Create2Execute(r) +} + +func (a *PullRequestsAPIRepository) Create2Request(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPICreate2Request { + return PullRequestsAPICreate2Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) Create2Execute(r *PullRequestsAPICreate2Request) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreate2Call(r.ctx, requestURL, r.restReviewerGroup) +} + +func (a *PullRequestsAPIRepository) Create2(ctx context.Context, projectKey string, repositorySlug string, restReviewerGroup RestReviewerGroup) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreate2Call(ctx, requestURL, restReviewerGroup) +} + +func (a *PullRequestsAPIRepository) makeCreate2Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestReviewerGroup + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestReviewerGroup](&response) + if err == nil { + result = response.Body.(RestReviewerGroup) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPICreateComment1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + restComment *RestComment +} + + // The comment to add. +func (r *PullRequestsAPICreateComment1Request) RestComment(restComment RestComment) *PullRequestsAPICreateComment1Request { + r.restComment = &restComment + return r +} + +func (r *PullRequestsAPICreateComment1Request) Execute() (RestComment, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreateComment1Execute(r) +} + +func (a *PullRequestsAPIRepository) CreateComment1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPICreateComment1Request { + return PullRequestsAPICreateComment1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) CreateComment1Execute(r *PullRequestsAPICreateComment1Request) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateComment1Call(r.ctx, requestURL, r.restComment) +} + +func (a *PullRequestsAPIRepository) CreateComment1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restComment RestComment) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateComment1Call(ctx, requestURL, restComment) +} + +func (a *PullRequestsAPIRepository) makeCreateComment1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestComment, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestComment + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestComment](&response) + if err == nil { + result = response.Body.(RestComment) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPICreateComment2Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + restComment *RestComment +} + + // The comment to add +func (r *PullRequestsAPICreateComment2Request) RestComment(restComment RestComment) *PullRequestsAPICreateComment2Request { + r.restComment = &restComment + return r +} + +func (r *PullRequestsAPICreateComment2Request) Execute() (RestComment, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreateComment2Execute(r) +} + +func (a *PullRequestsAPIRepository) CreateComment2Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPICreateComment2Request { + return PullRequestsAPICreateComment2Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) CreateComment2Execute(r *PullRequestsAPICreateComment2Request) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateComment2Call(r.ctx, requestURL, r.restComment) +} + +func (a *PullRequestsAPIRepository) CreateComment2(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restComment RestComment) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateComment2Call(ctx, requestURL, restComment) +} + +func (a *PullRequestsAPIRepository) makeCreateComment2Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestComment, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestComment + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestComment](&response) + if err == nil { + result = response.Body.(RestComment) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPICreatePullRequestConditionRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + restDefaultReviewersRequest *RestDefaultReviewersRequest +} + + // The details needed to create a default reviewer pull request condition. +func (r *PullRequestsAPICreatePullRequestConditionRequest) RestDefaultReviewersRequest(restDefaultReviewersRequest RestDefaultReviewersRequest) *PullRequestsAPICreatePullRequestConditionRequest { + r.restDefaultReviewersRequest = &restDefaultReviewersRequest + return r +} + +func (r *PullRequestsAPICreatePullRequestConditionRequest) Execute() (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreatePullRequestConditionExecute(r) +} + +func (a *PullRequestsAPIRepository) CreatePullRequestConditionRequest(ctx context.Context, projectKey string) PullRequestsAPICreatePullRequestConditionRequest { + return PullRequestsAPICreatePullRequestConditionRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + } +} + +func (a *PullRequestsAPIRepository) CreatePullRequestConditionExecute(r *PullRequestsAPICreatePullRequestConditionRequest) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/condition" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreatePullRequestConditionCall(r.ctx, requestURL, r.restDefaultReviewersRequest) +} + +func (a *PullRequestsAPIRepository) CreatePullRequestCondition(ctx context.Context, projectKey string, restDefaultReviewersRequest RestDefaultReviewersRequest) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/condition" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreatePullRequestConditionCall(ctx, requestURL, restDefaultReviewersRequest) +} + +func (a *PullRequestsAPIRepository) makeCreatePullRequestConditionCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestPullRequestCondition + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestCondition](&response) + if err == nil { + result = response.Body.(RestPullRequestCondition) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPICreatePullRequestCondition1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + repositorySlug string + restDefaultReviewersRequest *RestDefaultReviewersRequest +} + + // The details needed to create a default reviewer pull request condition. +func (r *PullRequestsAPICreatePullRequestCondition1Request) RestDefaultReviewersRequest(restDefaultReviewersRequest RestDefaultReviewersRequest) *PullRequestsAPICreatePullRequestCondition1Request { + r.restDefaultReviewersRequest = &restDefaultReviewersRequest + return r +} + +func (r *PullRequestsAPICreatePullRequestCondition1Request) Execute() (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreatePullRequestCondition1Execute(r) +} + +func (a *PullRequestsAPIRepository) CreatePullRequestCondition1Request(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPICreatePullRequestCondition1Request { + return PullRequestsAPICreatePullRequestCondition1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) CreatePullRequestCondition1Execute(r *PullRequestsAPICreatePullRequestCondition1Request) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/condition" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreatePullRequestCondition1Call(r.ctx, requestURL, r.restDefaultReviewersRequest) +} + +func (a *PullRequestsAPIRepository) CreatePullRequestCondition1(ctx context.Context, projectKey string, repositorySlug string, restDefaultReviewersRequest RestDefaultReviewersRequest) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/condition" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreatePullRequestCondition1Call(ctx, requestURL, restDefaultReviewersRequest) +} + +func (a *PullRequestsAPIRepository) makeCreatePullRequestCondition1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestPullRequestCondition + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestCondition](&response) + if err == nil { + result = response.Body.(RestPullRequestCondition) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIDeclineRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + version *string + restPullRequestDeclineRequest *RestPullRequestDeclineRequest +} + + // The current version of the pull request. If the server's version isn't the same as the specified version the operation will fail. To determine the current version of the pull request it should be fetched from the server prior to this operation. Look for the 'version' attribute in the returned JSON structure. +func (r *PullRequestsAPIDeclineRequest) Version(version string) *PullRequestsAPIDeclineRequest { + r.version = &version + return r +} + + // The body holder +func (r *PullRequestsAPIDeclineRequest) RestPullRequestDeclineRequest(restPullRequestDeclineRequest RestPullRequestDeclineRequest) *PullRequestsAPIDeclineRequest { + r.restPullRequestDeclineRequest = &restPullRequestDeclineRequest + return r +} + +func (r *PullRequestsAPIDeclineRequest) Execute() (RestPullRequest, aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeclineExecute(r) +} + +func (a *PullRequestsAPIRepository) DeclineRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIDeclineRequest { + return PullRequestsAPIDeclineRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) DeclineExecute(r *PullRequestsAPIDeclineRequest) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/decline" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.version!=nil { + withUrlQueryParam(requestURL, "version", *r.version) + } + return a.makeDeclineCall(r.ctx, requestURL, r.restPullRequestDeclineRequest) +} + +func (a *PullRequestsAPIRepository) Decline(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestDeclineRequest RestPullRequestDeclineRequest, version string) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/decline" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "version", version) + return a.makeDeclineCall(ctx, requestURL, restPullRequestDeclineRequest) +} + +func (a *PullRequestsAPIRepository) makeDeclineCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestPullRequest + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequest](&response) + if err == nil { + result = response.Body.(RestPullRequest) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIDelete3Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + restPullRequestDeleteRequest *RestPullRequestDeleteRequest +} + + // A body containing the version of the pull request +func (r *PullRequestsAPIDelete3Request) RestPullRequestDeleteRequest(restPullRequestDeleteRequest RestPullRequestDeleteRequest) *PullRequestsAPIDelete3Request { + r.restPullRequestDeleteRequest = &restPullRequestDeleteRequest + return r +} + +func (r *PullRequestsAPIDelete3Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.Delete3Execute(r) +} + +func (a *PullRequestsAPIRepository) Delete3Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIDelete3Request { + return PullRequestsAPIDelete3Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) Delete3Execute(r *PullRequestsAPIDelete3Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDelete3Call(r.ctx, requestURL, r.restPullRequestDeleteRequest) +} + +func (a *PullRequestsAPIRepository) Delete3(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestDeleteRequest RestPullRequestDeleteRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDelete3Call(ctx, requestURL, restPullRequestDeleteRequest) +} + +func (a *PullRequestsAPIRepository) makeDelete3Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIDelete6Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + id string +} + +func (r *PullRequestsAPIDelete6Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.Delete6Execute(r) +} + +func (a *PullRequestsAPIRepository) Delete6Request(ctx context.Context, projectKey string, id string) PullRequestsAPIDelete6Request { + return PullRequestsAPIDelete6Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + } +} + +func (a *PullRequestsAPIRepository) Delete6Execute(r *PullRequestsAPIDelete6Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/settings/reviewer-groups/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(r.id)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDelete6Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) Delete6(ctx context.Context, projectKey string, id string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/settings/reviewer-groups/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(id)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDelete6Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeDelete6Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIDelete7Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + id string + repositorySlug string +} + +func (r *PullRequestsAPIDelete7Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.Delete7Execute(r) +} + +func (a *PullRequestsAPIRepository) Delete7Request(ctx context.Context, projectKey string, id string, repositorySlug string) PullRequestsAPIDelete7Request { + return PullRequestsAPIDelete7Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) Delete7Execute(r *PullRequestsAPIDelete7Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(r.id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDelete7Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) Delete7(ctx context.Context, projectKey string, id string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDelete7Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeDelete7Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIDeleteComment1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + commentId string + pullRequestId string + repositorySlug string + version *string +} + + // The expected version of the comment. This must match the server's version of the comment or the delete will fail. To determine the current version of the comment, the comment should be fetched from the server prior to the delete. Look for the 'version' attribute in the returned JSON structure. +func (r *PullRequestsAPIDeleteComment1Request) Version(version string) *PullRequestsAPIDeleteComment1Request { + r.version = &version + return r +} + +func (r *PullRequestsAPIDeleteComment1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteComment1Execute(r) +} + +func (a *PullRequestsAPIRepository) DeleteComment1Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIDeleteComment1Request { + return PullRequestsAPIDeleteComment1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) DeleteComment1Execute(r *PullRequestsAPIDeleteComment1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.version!=nil { + withUrlQueryParam(requestURL, "version", *r.version) + } + return a.makeDeleteComment1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) DeleteComment1(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string, version string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "version", version) + return a.makeDeleteComment1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeDeleteComment1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIDeleteComment2Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + commentId string + pullRequestId string + repositorySlug string + version *string +} + + // The expected version of the comment. This must match the server's version of the comment or the delete will fail. To determine the current version of the comment, the comment should be fetched from the server prior to the delete. Look for the 'version' attribute in the returned JSON structure. +func (r *PullRequestsAPIDeleteComment2Request) Version(version string) *PullRequestsAPIDeleteComment2Request { + r.version = &version + return r +} + +func (r *PullRequestsAPIDeleteComment2Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteComment2Execute(r) +} + +func (a *PullRequestsAPIRepository) DeleteComment2Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIDeleteComment2Request { + return PullRequestsAPIDeleteComment2Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) DeleteComment2Execute(r *PullRequestsAPIDeleteComment2Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.version!=nil { + withUrlQueryParam(requestURL, "version", *r.version) + } + return a.makeDeleteComment2Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) DeleteComment2(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string, version string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "version", version) + return a.makeDeleteComment2Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeDeleteComment2Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIDeletePullRequestConditionRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + id string +} + +func (r *PullRequestsAPIDeletePullRequestConditionRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeletePullRequestConditionExecute(r) +} + +func (a *PullRequestsAPIRepository) DeletePullRequestConditionRequest(ctx context.Context, projectKey string, id string) PullRequestsAPIDeletePullRequestConditionRequest { + return PullRequestsAPIDeletePullRequestConditionRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + } +} + +func (a *PullRequestsAPIRepository) DeletePullRequestConditionExecute(r *PullRequestsAPIDeletePullRequestConditionRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/condition/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(r.id)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeletePullRequestConditionCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) DeletePullRequestCondition(ctx context.Context, projectKey string, id string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/condition/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(id)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeletePullRequestConditionCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeDeletePullRequestConditionCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIDeletePullRequestCondition1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + id int32 + repositorySlug string +} + +func (r *PullRequestsAPIDeletePullRequestCondition1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeletePullRequestCondition1Execute(r) +} + +func (a *PullRequestsAPIRepository) DeletePullRequestCondition1Request(ctx context.Context, projectKey string, id int32, repositorySlug string) PullRequestsAPIDeletePullRequestCondition1Request { + return PullRequestsAPIDeletePullRequestCondition1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) DeletePullRequestCondition1Execute(r *PullRequestsAPIDeletePullRequestCondition1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/condition/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(parameterValueToString(r.id))) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeletePullRequestCondition1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) DeletePullRequestCondition1(ctx context.Context, projectKey string, id int32, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/condition/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(parameterValueToString(id))) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeletePullRequestCondition1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeDeletePullRequestCondition1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIDiscardReviewRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIDiscardReviewRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DiscardReviewExecute(r) +} + +func (a *PullRequestsAPIRepository) DiscardReviewRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIDiscardReviewRequest { + return PullRequestsAPIDiscardReviewRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) DiscardReviewExecute(r *PullRequestsAPIDiscardReviewRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/review" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDiscardReviewCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) DiscardReview(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/review" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDiscardReviewCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeDiscardReviewCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIFinishReviewRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + version *string + restPullRequestFinishReviewRequest *RestPullRequestFinishReviewRequest +} + + // The current version of the pull request. If the server's version isn't the same as the specified version the operation will fail. To determine the current version of the pull request it should be fetched from the server prior to this operation. Look for the 'version' attribute in the returned JSON structure. +func (r *PullRequestsAPIFinishReviewRequest) Version(version string) *PullRequestsAPIFinishReviewRequest { + r.version = &version + return r +} + + // The REST request which contains comment text and participant status +func (r *PullRequestsAPIFinishReviewRequest) RestPullRequestFinishReviewRequest(restPullRequestFinishReviewRequest RestPullRequestFinishReviewRequest) *PullRequestsAPIFinishReviewRequest { + r.restPullRequestFinishReviewRequest = &restPullRequestFinishReviewRequest + return r +} + +func (r *PullRequestsAPIFinishReviewRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.FinishReviewExecute(r) +} + +func (a *PullRequestsAPIRepository) FinishReviewRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIFinishReviewRequest { + return PullRequestsAPIFinishReviewRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) FinishReviewExecute(r *PullRequestsAPIFinishReviewRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/review" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.version!=nil { + withUrlQueryParam(requestURL, "version", *r.version) + } + return a.makeFinishReviewCall(r.ctx, requestURL, r.restPullRequestFinishReviewRequest) +} + +func (a *PullRequestsAPIRepository) FinishReview(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestFinishReviewRequest RestPullRequestFinishReviewRequest, version string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/review" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "version", version) + return a.makeFinishReviewCall(ctx, requestURL, restPullRequestFinishReviewRequest) +} + +func (a *PullRequestsAPIRepository) makeFinishReviewCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIGet3Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIGet3Request) Execute() (RestPullRequest, aurestclientapi.ParsedResponse, error) { + return r.ApiService.Get3Execute(r) +} + +func (a *PullRequestsAPIRepository) Get3Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGet3Request { + return PullRequestsAPIGet3Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) Get3Execute(r *PullRequestsAPIGet3Request) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGet3Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) Get3(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGet3Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGet3Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestPullRequest + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequest](&response) + if err == nil { + result = response.Body.(RestPullRequest) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetActivitiesRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + fromType *string + fromId *string + start *float32 + limit *float32 +} + + // (required if <strong>fromId</strong> is present) the type of the activity item specified by <strong>fromId</strong> (either <strong>COMMENT</strong> or <strong>ACTIVITY</strong>) +func (r *PullRequestsAPIGetActivitiesRequest) FromType(fromType string) *PullRequestsAPIGetActivitiesRequest { + r.fromType = &fromType + return r +} + + // (optional) the ID of the activity item to use as the first item in the returned page +func (r *PullRequestsAPIGetActivitiesRequest) FromId(fromId string) *PullRequestsAPIGetActivitiesRequest { + r.fromId = &fromId + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPIGetActivitiesRequest) Start(start float32) *PullRequestsAPIGetActivitiesRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPIGetActivitiesRequest) Limit(limit float32) *PullRequestsAPIGetActivitiesRequest { + r.limit = &limit + return r +} + +func (r *PullRequestsAPIGetActivitiesRequest) Execute() (GetActivities200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetActivitiesExecute(r) +} + +func (a *PullRequestsAPIRepository) GetActivitiesRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetActivitiesRequest { + return PullRequestsAPIGetActivitiesRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetActivitiesExecute(r *PullRequestsAPIGetActivitiesRequest) (GetActivities200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/activities" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.fromType!=nil { + withUrlQueryParam(requestURL, "fromType", *r.fromType) + } + if r.fromId!=nil { + withUrlQueryParam(requestURL, "fromId", *r.fromId) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetActivitiesCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetActivities(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, fromType string, fromId string, start float32, limit float32) (GetActivities200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/activities" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "fromType", fromType) + withUrlQueryParam(requestURL, "fromId", fromId) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetActivitiesCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetActivitiesCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetActivities200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetActivities200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetActivities200Response](&response) + if err == nil { + result = response.Body.(GetActivities200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetAutoMergeRequestRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIGetAutoMergeRequestRequest) Execute() (RestAutoMergeRequest, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetAutoMergeRequestExecute(r) +} + +func (a *PullRequestsAPIRepository) GetAutoMergeRequestRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetAutoMergeRequestRequest { + return PullRequestsAPIGetAutoMergeRequestRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetAutoMergeRequestExecute(r *PullRequestsAPIGetAutoMergeRequestRequest) (RestAutoMergeRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/auto-merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetAutoMergeRequestCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetAutoMergeRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestAutoMergeRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/auto-merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetAutoMergeRequestCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetAutoMergeRequestCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestAutoMergeRequest, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestAutoMergeRequest + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestAutoMergeRequest](&response) + if err == nil { + result = response.Body.(RestAutoMergeRequest) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetComment1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + commentId string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIGetComment1Request) Execute() (RestComment, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetComment1Execute(r) +} + +func (a *PullRequestsAPIRepository) GetComment1Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIGetComment1Request { + return PullRequestsAPIGetComment1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetComment1Execute(r *PullRequestsAPIGetComment1Request) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetComment1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetComment1(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetComment1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetComment1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestComment, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestComment + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestComment](&response) + if err == nil { + result = response.Body.(RestComment) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetComment2Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + commentId string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIGetComment2Request) Execute() (RestComment, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetComment2Execute(r) +} + +func (a *PullRequestsAPIRepository) GetComment2Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIGetComment2Request { + return PullRequestsAPIGetComment2Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetComment2Execute(r *PullRequestsAPIGetComment2Request) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetComment2Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetComment2(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetComment2Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetComment2Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestComment, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestComment + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestComment](&response) + if err == nil { + result = response.Body.(RestComment) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetComments1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + count *string + state *[]string + states *string + start *float32 + limit *float32 +} + + // If true only the count of the comments by state will be returned (and not the body of the comments). +func (r *PullRequestsAPIGetComments1Request) Count(count string) *PullRequestsAPIGetComments1Request { + r.count = &count + return r +} + +func (r *PullRequestsAPIGetComments1Request) State(state []string) *PullRequestsAPIGetComments1Request { + r.state = &state + return r +} + + // (optional). If supplied, only comments with a state in the given list will be returned. The state can be OPEN or RESOLVED. +func (r *PullRequestsAPIGetComments1Request) States(states string) *PullRequestsAPIGetComments1Request { + r.states = &states + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPIGetComments1Request) Start(start float32) *PullRequestsAPIGetComments1Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPIGetComments1Request) Limit(limit float32) *PullRequestsAPIGetComments1Request { + r.limit = &limit + return r +} + +func (r *PullRequestsAPIGetComments1Request) Execute() (GetComments200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetComments1Execute(r) +} + +func (a *PullRequestsAPIRepository) GetComments1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetComments1Request { + return PullRequestsAPIGetComments1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetComments1Execute(r *PullRequestsAPIGetComments1Request) (GetComments200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.count!=nil { + withUrlQueryParam(requestURL, "count", *r.count) + } + if r.state!=nil { + for _, ___element := range *r.state { + withUrlQueryParam(requestURL, "state", ___element) + } + } + if r.states!=nil { + withUrlQueryParam(requestURL, "states", *r.states) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetComments1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetComments1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, count string, state []string, states string, start float32, limit float32) (GetComments200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "count", count) + for _, ___element := range state { + withUrlQueryParam(requestURL, "state", ___element) + } + withUrlQueryParam(requestURL, "states", states) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetComments1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetComments1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetComments200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetComments200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetComments200Response](&response) + if err == nil { + result = response.Body.(GetComments200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetComments2Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + path *string + projectKey string + pullRequestId string + repositorySlug string + fromHash *string + anchorState *string + diffType *[]string + toHash *string + state *[]string + diffTypes *string + states *string + start *float32 + limit *float32 +} + + // The path to stream comments for a given path +func (r *PullRequestsAPIGetComments2Request) Path(path string) *PullRequestsAPIGetComments2Request { + r.path = &path + return r +} + + // The from commit hash to stream comments for a RANGE or COMMIT arbitrary change scope +func (r *PullRequestsAPIGetComments2Request) FromHash(fromHash string) *PullRequestsAPIGetComments2Request { + r.fromHash = &fromHash + return r +} + + // ACTIVE to stream the active comments; ORPHANED to stream the orphaned comments; ALL to stream both the active and the orphaned comments; +func (r *PullRequestsAPIGetComments2Request) AnchorState(anchorState string) *PullRequestsAPIGetComments2Request { + r.anchorState = &anchorState + return r +} + +func (r *PullRequestsAPIGetComments2Request) DiffType(diffType []string) *PullRequestsAPIGetComments2Request { + r.diffType = &diffType + return r +} + + // The to commit hash to stream comments for a RANGE or COMMIT arbitrary change scope +func (r *PullRequestsAPIGetComments2Request) ToHash(toHash string) *PullRequestsAPIGetComments2Request { + r.toHash = &toHash + return r +} + +func (r *PullRequestsAPIGetComments2Request) State(state []string) *PullRequestsAPIGetComments2Request { + r.state = &state + return r +} + + // EFFECTIVE to stream the comments related to the effective diff of the pull request; RANGE to stream comments related to a commit range between two arbitrary commits (requires 'fromHash' and 'toHash'); COMMIT to stream comments related to a commit between two arbitrary commits (requires 'fromHash' and 'toHash') +func (r *PullRequestsAPIGetComments2Request) DiffTypes(diffTypes string) *PullRequestsAPIGetComments2Request { + r.diffTypes = &diffTypes + return r +} + + // (optional). If supplied, only comments with a state in the given list will be returned. The state can be OPEN or RESOLVED. +func (r *PullRequestsAPIGetComments2Request) States(states string) *PullRequestsAPIGetComments2Request { + r.states = &states + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPIGetComments2Request) Start(start float32) *PullRequestsAPIGetComments2Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPIGetComments2Request) Limit(limit float32) *PullRequestsAPIGetComments2Request { + r.limit = &limit + return r +} + +func (r *PullRequestsAPIGetComments2Request) Execute() (GetComments200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetComments2Execute(r) +} + +func (a *PullRequestsAPIRepository) GetComments2Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetComments2Request { + return PullRequestsAPIGetComments2Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetComments2Execute(r *PullRequestsAPIGetComments2Request) (GetComments200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.path!=nil { + withUrlQueryParam(requestURL, "path", *r.path) + } + if r.fromHash!=nil { + withUrlQueryParam(requestURL, "fromHash", *r.fromHash) + } + if r.anchorState!=nil { + withUrlQueryParam(requestURL, "anchorState", *r.anchorState) + } + if r.diffType!=nil { + for _, ___element := range *r.diffType { + withUrlQueryParam(requestURL, "diffType", ___element) + } + } + if r.toHash!=nil { + withUrlQueryParam(requestURL, "toHash", *r.toHash) + } + if r.state!=nil { + for _, ___element := range *r.state { + withUrlQueryParam(requestURL, "state", ___element) + } + } + if r.diffTypes!=nil { + withUrlQueryParam(requestURL, "diffTypes", *r.diffTypes) + } + if r.states!=nil { + withUrlQueryParam(requestURL, "states", *r.states) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetComments2Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetComments2(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, path string, fromHash string, anchorState string, diffType []string, toHash string, state []string, diffTypes string, states string, start float32, limit float32) (GetComments200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "path", path) + withUrlQueryParam(requestURL, "fromHash", fromHash) + withUrlQueryParam(requestURL, "anchorState", anchorState) + for _, ___element := range diffType { + withUrlQueryParam(requestURL, "diffType", ___element) + } + withUrlQueryParam(requestURL, "toHash", toHash) + for _, ___element := range state { + withUrlQueryParam(requestURL, "state", ___element) + } + withUrlQueryParam(requestURL, "diffTypes", diffTypes) + withUrlQueryParam(requestURL, "states", states) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetComments2Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetComments2Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetComments200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetComments200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetComments200Response](&response) + if err == nil { + result = response.Body.(GetComments200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetCommitMessageSuggestionRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIGetCommitMessageSuggestionRequest) Execute() (RestCommitMessageSuggestion, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetCommitMessageSuggestionExecute(r) +} + +func (a *PullRequestsAPIRepository) GetCommitMessageSuggestionRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetCommitMessageSuggestionRequest { + return PullRequestsAPIGetCommitMessageSuggestionRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetCommitMessageSuggestionExecute(r *PullRequestsAPIGetCommitMessageSuggestionRequest) (RestCommitMessageSuggestion, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/commit-message-suggestion" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetCommitMessageSuggestionCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetCommitMessageSuggestion(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestCommitMessageSuggestion, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/commit-message-suggestion" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetCommitMessageSuggestionCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetCommitMessageSuggestionCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestCommitMessageSuggestion, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestCommitMessageSuggestion + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestCommitMessageSuggestion](&response) + if err == nil { + result = response.Body.(RestCommitMessageSuggestion) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetCommits1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + avatarScheme *string + withCounts *string + avatarSize *string + start *float32 + limit *float32 +} + + // The desired scheme for the avatar URL. If the parameter is not present URLs will use the same scheme as this request +func (r *PullRequestsAPIGetCommits1Request) AvatarScheme(avatarScheme string) *PullRequestsAPIGetCommits1Request { + r.avatarScheme = &avatarScheme + return r +} + + // If set to true, the service will add \"authorCount\" and \"totalCount\" at the end of the page. \"authorCount\" is the number of different authors and \"totalCount\" is the total number of commits. +func (r *PullRequestsAPIGetCommits1Request) WithCounts(withCounts string) *PullRequestsAPIGetCommits1Request { + r.withCounts = &withCounts + return r +} + + // If present the service adds avatar URLs for commit authors. Should be an integer specifying the desired size in pixels. If the parameter is not present, avatar URLs will not be setCOMMIT to stream comments related to a commit between two arbitrary commits (requires 'fromHash' and 'toHash') +func (r *PullRequestsAPIGetCommits1Request) AvatarSize(avatarSize string) *PullRequestsAPIGetCommits1Request { + r.avatarSize = &avatarSize + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPIGetCommits1Request) Start(start float32) *PullRequestsAPIGetCommits1Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPIGetCommits1Request) Limit(limit float32) *PullRequestsAPIGetCommits1Request { + r.limit = &limit + return r +} + +func (r *PullRequestsAPIGetCommits1Request) Execute() (GetCommits200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetCommits1Execute(r) +} + +func (a *PullRequestsAPIRepository) GetCommits1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetCommits1Request { + return PullRequestsAPIGetCommits1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetCommits1Execute(r *PullRequestsAPIGetCommits1Request) (GetCommits200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/commits" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.avatarScheme!=nil { + withUrlQueryParam(requestURL, "avatarScheme", *r.avatarScheme) + } + if r.withCounts!=nil { + withUrlQueryParam(requestURL, "withCounts", *r.withCounts) + } + if r.avatarSize!=nil { + withUrlQueryParam(requestURL, "avatarSize", *r.avatarSize) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetCommits1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetCommits1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, avatarScheme string, withCounts string, avatarSize string, start float32, limit float32) (GetCommits200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/commits" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "avatarScheme", avatarScheme) + withUrlQueryParam(requestURL, "withCounts", withCounts) + withUrlQueryParam(requestURL, "avatarSize", avatarSize) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetCommits1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetCommits1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetCommits200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetCommits200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetCommits200Response](&response) + if err == nil { + result = response.Body.(GetCommits200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetMergeBase1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIGetMergeBase1Request) Execute() (RestCommit, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetMergeBase1Execute(r) +} + +func (a *PullRequestsAPIRepository) GetMergeBase1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetMergeBase1Request { + return PullRequestsAPIGetMergeBase1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetMergeBase1Execute(r *PullRequestsAPIGetMergeBase1Request) (RestCommit, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/merge-base" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetMergeBase1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetMergeBase1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestCommit, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/merge-base" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetMergeBase1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetMergeBase1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestCommit, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestCommit + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestCommit](&response) + if err == nil { + result = response.Body.(RestCommit) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetMergeConfigRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + scmId string +} + +func (r *PullRequestsAPIGetMergeConfigRequest) Execute() (RestPullRequestMergeConfig, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetMergeConfigExecute(r) +} + +func (a *PullRequestsAPIRepository) GetMergeConfigRequest(ctx context.Context, scmId string) PullRequestsAPIGetMergeConfigRequest { + return PullRequestsAPIGetMergeConfigRequest{ + ApiService: a, + ctx: ctx, + scmId: scmId, + } +} + +func (a *PullRequestsAPIRepository) GetMergeConfigExecute(r *PullRequestsAPIGetMergeConfigRequest) (RestPullRequestMergeConfig, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/admin/pull-requests/{scmId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{scmId}", urlUtil.PathEscape(r.scmId)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetMergeConfigCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetMergeConfig(ctx context.Context, scmId string) (RestPullRequestMergeConfig, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/admin/pull-requests/{scmId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{scmId}", urlUtil.PathEscape(scmId)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetMergeConfigCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetMergeConfigCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestMergeConfig, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestPullRequestMergeConfig + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestMergeConfig](&response) + if err == nil { + result = response.Body.(RestPullRequestMergeConfig) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetPageRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + repositorySlug string + withAttributes *string + at *string + withProperties *string + draft *string + filterText *string + state *string + order *string + direction *string + start *float32 + limit *float32 +} + + // (optional) defaults to true, whether to return additional pull request attributes +func (r *PullRequestsAPIGetPageRequest) WithAttributes(withAttributes string) *PullRequestsAPIGetPageRequest { + r.withAttributes = &withAttributes + return r +} + + // (optional) a <i>fully-qualified</i> branch ID to find pull requests to or from, such as refs/heads/master +func (r *PullRequestsAPIGetPageRequest) At(at string) *PullRequestsAPIGetPageRequest { + r.at = &at + return r +} + + // (optional) defaults to true, whether to return additional pull request properties +func (r *PullRequestsAPIGetPageRequest) WithProperties(withProperties string) *PullRequestsAPIGetPageRequest { + r.withProperties = &withProperties + return r +} + + // (optional) If specified, only pull requests matching the supplied draft status will be returned. +func (r *PullRequestsAPIGetPageRequest) Draft(draft string) *PullRequestsAPIGetPageRequest { + r.draft = &draft + return r +} + + // (optional) If specified, only pull requests where the title or description contains the supplied string will be returned. +func (r *PullRequestsAPIGetPageRequest) FilterText(filterText string) *PullRequestsAPIGetPageRequest { + r.filterText = &filterText + return r +} + + // (optional, defaults to <strong>OPEN</strong>). Supply <strong>ALL</strong> to return pull request in any state. If a state is supplied only pull requests in the specified state will be returned. Either <strong>OPEN</strong>, <strong>DECLINED</strong> or <strong>MERGED</strong>. +func (r *PullRequestsAPIGetPageRequest) State(state string) *PullRequestsAPIGetPageRequest { + r.state = &state + return r +} + + // (optional, defaults to <strong>NEWEST</strong>) the order to return pull requests in, either <strong>OLDEST</strong> (as in: \"oldest first\") or <strong>NEWEST</strong>. +func (r *PullRequestsAPIGetPageRequest) Order(order string) *PullRequestsAPIGetPageRequest { + r.order = &order + return r +} + + // (optional, defaults to <strong>INCOMING</strong>) the direction relative to the specified repository. Either <strong>INCOMING</strong> or <strong>OUTGOING</strong>. +func (r *PullRequestsAPIGetPageRequest) Direction(direction string) *PullRequestsAPIGetPageRequest { + r.direction = &direction + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPIGetPageRequest) Start(start float32) *PullRequestsAPIGetPageRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPIGetPageRequest) Limit(limit float32) *PullRequestsAPIGetPageRequest { + r.limit = &limit + return r +} + +func (r *PullRequestsAPIGetPageRequest) Execute() (GetPullRequests1200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetPageExecute(r) +} + +func (a *PullRequestsAPIRepository) GetPageRequest(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPIGetPageRequest { + return PullRequestsAPIGetPageRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetPageExecute(r *PullRequestsAPIGetPageRequest) (GetPullRequests1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.withAttributes!=nil { + withUrlQueryParam(requestURL, "withAttributes", *r.withAttributes) + } + if r.at!=nil { + withUrlQueryParam(requestURL, "at", *r.at) + } + if r.withProperties!=nil { + withUrlQueryParam(requestURL, "withProperties", *r.withProperties) + } + if r.draft!=nil { + withUrlQueryParam(requestURL, "draft", *r.draft) + } + if r.filterText!=nil { + withUrlQueryParam(requestURL, "filterText", *r.filterText) + } + if r.state!=nil { + withUrlQueryParam(requestURL, "state", *r.state) + } + if r.order!=nil { + withUrlQueryParam(requestURL, "order", *r.order) + } + if r.direction!=nil { + withUrlQueryParam(requestURL, "direction", *r.direction) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetPageCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetPage(ctx context.Context, projectKey string, repositorySlug string, withAttributes string, at string, withProperties string, draft string, filterText string, state string, order string, direction string, start float32, limit float32) (GetPullRequests1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "withAttributes", withAttributes) + withUrlQueryParam(requestURL, "at", at) + withUrlQueryParam(requestURL, "withProperties", withProperties) + withUrlQueryParam(requestURL, "draft", draft) + withUrlQueryParam(requestURL, "filterText", filterText) + withUrlQueryParam(requestURL, "state", state) + withUrlQueryParam(requestURL, "order", order) + withUrlQueryParam(requestURL, "direction", direction) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetPageCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetPageCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetPullRequests1200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetPullRequests1200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetPullRequests1200Response](&response) + if err == nil { + result = response.Body.(GetPullRequests1200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetPullRequestConditionsRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string +} + +func (r *PullRequestsAPIGetPullRequestConditionsRequest) Execute() ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetPullRequestConditionsExecute(r) +} + +func (a *PullRequestsAPIRepository) GetPullRequestConditionsRequest(ctx context.Context, projectKey string) PullRequestsAPIGetPullRequestConditionsRequest { + return PullRequestsAPIGetPullRequestConditionsRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + } +} + +func (a *PullRequestsAPIRepository) GetPullRequestConditionsExecute(r *PullRequestsAPIGetPullRequestConditionsRequest) ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/conditions" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetPullRequestConditionsCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetPullRequestConditions(ctx context.Context, projectKey string) ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/conditions" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetPullRequestConditionsCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetPullRequestConditionsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result []RestPullRequestCondition + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + + if response.Status < 400 { + err = safeUnmarshal[[]RestPullRequestCondition](&response) + if err == nil { + result = response.Body.([]RestPullRequestCondition) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetPullRequestConditions1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + repositorySlug string +} + +func (r *PullRequestsAPIGetPullRequestConditions1Request) Execute() ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetPullRequestConditions1Execute(r) +} + +func (a *PullRequestsAPIRepository) GetPullRequestConditions1Request(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPIGetPullRequestConditions1Request { + return PullRequestsAPIGetPullRequestConditions1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetPullRequestConditions1Execute(r *PullRequestsAPIGetPullRequestConditions1Request) ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/conditions" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetPullRequestConditions1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetPullRequestConditions1(ctx context.Context, projectKey string, repositorySlug string) ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/conditions" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetPullRequestConditions1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetPullRequestConditions1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result []RestPullRequestCondition + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + + if response.Status < 400 { + err = safeUnmarshal[[]RestPullRequestCondition](&response) + if err == nil { + result = response.Body.([]RestPullRequestCondition) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetPullRequestsRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + commitId string + repositorySlug string + start *float32 + limit *float32 +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPIGetPullRequestsRequest) Start(start float32) *PullRequestsAPIGetPullRequestsRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPIGetPullRequestsRequest) Limit(limit float32) *PullRequestsAPIGetPullRequestsRequest { + r.limit = &limit + return r +} + +func (r *PullRequestsAPIGetPullRequestsRequest) Execute() (GetPullRequests1200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetPullRequestsExecute(r) +} + +func (a *PullRequestsAPIRepository) GetPullRequestsRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) PullRequestsAPIGetPullRequestsRequest { + return PullRequestsAPIGetPullRequestsRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetPullRequestsExecute(r *PullRequestsAPIGetPullRequestsRequest) (GetPullRequests1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/pull-requests" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetPullRequestsCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetPullRequests(ctx context.Context, projectKey string, commitId string, repositorySlug string, start float32, limit float32) (GetPullRequests1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/pull-requests" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetPullRequestsCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetPullRequestsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetPullRequests1200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetPullRequests1200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetPullRequests1200Response](&response) + if err == nil { + result = response.Body.(GetPullRequests1200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetReviewRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + start *float32 + limit *float32 +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPIGetReviewRequest) Start(start float32) *PullRequestsAPIGetReviewRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPIGetReviewRequest) Limit(limit float32) *PullRequestsAPIGetReviewRequest { + r.limit = &limit + return r +} + +func (r *PullRequestsAPIGetReviewRequest) Execute() (GetComments200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetReviewExecute(r) +} + +func (a *PullRequestsAPIRepository) GetReviewRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIGetReviewRequest { + return PullRequestsAPIGetReviewRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetReviewExecute(r *PullRequestsAPIGetReviewRequest) (GetComments200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/review" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetReviewCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetReview(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, start float32, limit float32) (GetComments200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/review" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetReviewCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetReviewCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetComments200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetComments200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetComments200Response](&response) + if err == nil { + result = response.Body.(GetComments200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetReviewerGroupRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + id string +} + +func (r *PullRequestsAPIGetReviewerGroupRequest) Execute() (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetReviewerGroupExecute(r) +} + +func (a *PullRequestsAPIRepository) GetReviewerGroupRequest(ctx context.Context, projectKey string, id string) PullRequestsAPIGetReviewerGroupRequest { + return PullRequestsAPIGetReviewerGroupRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + } +} + +func (a *PullRequestsAPIRepository) GetReviewerGroupExecute(r *PullRequestsAPIGetReviewerGroupRequest) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/settings/reviewer-groups/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(r.id)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetReviewerGroupCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetReviewerGroup(ctx context.Context, projectKey string, id string) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/settings/reviewer-groups/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(id)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetReviewerGroupCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetReviewerGroupCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestReviewerGroup + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestReviewerGroup](&response) + if err == nil { + result = response.Body.(RestReviewerGroup) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetReviewerGroup1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + id string + repositorySlug string +} + +func (r *PullRequestsAPIGetReviewerGroup1Request) Execute() (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetReviewerGroup1Execute(r) +} + +func (a *PullRequestsAPIRepository) GetReviewerGroup1Request(ctx context.Context, projectKey string, id string, repositorySlug string) PullRequestsAPIGetReviewerGroup1Request { + return PullRequestsAPIGetReviewerGroup1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetReviewerGroup1Execute(r *PullRequestsAPIGetReviewerGroup1Request) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(r.id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetReviewerGroup1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetReviewerGroup1(ctx context.Context, projectKey string, id string, repositorySlug string) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetReviewerGroup1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetReviewerGroup1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestReviewerGroup + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestReviewerGroup](&response) + if err == nil { + result = response.Body.(RestReviewerGroup) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetReviewerGroupsRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + start *float32 + limit *float32 +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPIGetReviewerGroupsRequest) Start(start float32) *PullRequestsAPIGetReviewerGroupsRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPIGetReviewerGroupsRequest) Limit(limit float32) *PullRequestsAPIGetReviewerGroupsRequest { + r.limit = &limit + return r +} + +func (r *PullRequestsAPIGetReviewerGroupsRequest) Execute() (GetReviewerGroups1200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetReviewerGroupsExecute(r) +} + +func (a *PullRequestsAPIRepository) GetReviewerGroupsRequest(ctx context.Context, projectKey string) PullRequestsAPIGetReviewerGroupsRequest { + return PullRequestsAPIGetReviewerGroupsRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + } +} + +func (a *PullRequestsAPIRepository) GetReviewerGroupsExecute(r *PullRequestsAPIGetReviewerGroupsRequest) (GetReviewerGroups1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/settings/reviewer-groups" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetReviewerGroupsCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetReviewerGroups(ctx context.Context, projectKey string, start float32, limit float32) (GetReviewerGroups1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/settings/reviewer-groups" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetReviewerGroupsCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetReviewerGroupsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetReviewerGroups1200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetReviewerGroups1200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetReviewerGroups1200Response](&response) + if err == nil { + result = response.Body.(GetReviewerGroups1200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetReviewerGroups1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + repositorySlug string + start *float32 + limit *float32 +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPIGetReviewerGroups1Request) Start(start float32) *PullRequestsAPIGetReviewerGroups1Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPIGetReviewerGroups1Request) Limit(limit float32) *PullRequestsAPIGetReviewerGroups1Request { + r.limit = &limit + return r +} + +func (r *PullRequestsAPIGetReviewerGroups1Request) Execute() (GetReviewerGroups1200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetReviewerGroups1Execute(r) +} + +func (a *PullRequestsAPIRepository) GetReviewerGroups1Request(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPIGetReviewerGroups1Request { + return PullRequestsAPIGetReviewerGroups1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetReviewerGroups1Execute(r *PullRequestsAPIGetReviewerGroups1Request) (GetReviewerGroups1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetReviewerGroups1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetReviewerGroups1(ctx context.Context, projectKey string, repositorySlug string, start float32, limit float32) (GetReviewerGroups1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetReviewerGroups1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetReviewerGroups1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetReviewerGroups1200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetReviewerGroups1200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetReviewerGroups1200Response](&response) + if err == nil { + result = response.Body.(GetReviewerGroups1200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetReviewersRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + repositorySlug string + targetRepoId *string + sourceRepoId *string + sourceRefId *string + targetRefId *string +} + + // The ID of the repository in which the target ref exists +func (r *PullRequestsAPIGetReviewersRequest) TargetRepoId(targetRepoId string) *PullRequestsAPIGetReviewersRequest { + r.targetRepoId = &targetRepoId + return r +} + + // The ID of the repository in which the source ref exists +func (r *PullRequestsAPIGetReviewersRequest) SourceRepoId(sourceRepoId string) *PullRequestsAPIGetReviewersRequest { + r.sourceRepoId = &sourceRepoId + return r +} + + // The ID of the source ref +func (r *PullRequestsAPIGetReviewersRequest) SourceRefId(sourceRefId string) *PullRequestsAPIGetReviewersRequest { + r.sourceRefId = &sourceRefId + return r +} + + // The ID of the target ref +func (r *PullRequestsAPIGetReviewersRequest) TargetRefId(targetRefId string) *PullRequestsAPIGetReviewersRequest { + r.targetRefId = &targetRefId + return r +} + +func (r *PullRequestsAPIGetReviewersRequest) Execute() ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetReviewersExecute(r) +} + +func (a *PullRequestsAPIRepository) GetReviewersRequest(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPIGetReviewersRequest { + return PullRequestsAPIGetReviewersRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetReviewersExecute(r *PullRequestsAPIGetReviewersRequest) ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/reviewers" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.targetRepoId!=nil { + withUrlQueryParam(requestURL, "targetRepoId", *r.targetRepoId) + } + if r.sourceRepoId!=nil { + withUrlQueryParam(requestURL, "sourceRepoId", *r.sourceRepoId) + } + if r.sourceRefId!=nil { + withUrlQueryParam(requestURL, "sourceRefId", *r.sourceRefId) + } + if r.targetRefId!=nil { + withUrlQueryParam(requestURL, "targetRefId", *r.targetRefId) + } + return a.makeGetReviewersCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetReviewers(ctx context.Context, projectKey string, repositorySlug string, targetRepoId string, sourceRepoId string, sourceRefId string, targetRefId string) ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/reviewers" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "targetRepoId", targetRepoId) + withUrlQueryParam(requestURL, "sourceRepoId", sourceRepoId) + withUrlQueryParam(requestURL, "sourceRefId", sourceRefId) + withUrlQueryParam(requestURL, "targetRefId", targetRefId) + return a.makeGetReviewersCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetReviewersCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) ([]RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result []RestPullRequestCondition + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[RestErrors](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[[]RestPullRequestCondition](&response) + if err == nil { + result = response.Body.([]RestPullRequestCondition) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIGetUsersRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + id string + repositorySlug string +} + +func (r *PullRequestsAPIGetUsersRequest) Execute() ([]RestApplicationUser, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetUsersExecute(r) +} + +func (a *PullRequestsAPIRepository) GetUsersRequest(ctx context.Context, projectKey string, id string, repositorySlug string) PullRequestsAPIGetUsersRequest { + return PullRequestsAPIGetUsersRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) GetUsersExecute(r *PullRequestsAPIGetUsersRequest) ([]RestApplicationUser, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups/{id}/users" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(r.id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetUsersCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) GetUsers(ctx context.Context, projectKey string, id string, repositorySlug string) ([]RestApplicationUser, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups/{id}/users" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetUsersCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeGetUsersCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) ([]RestApplicationUser, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result []RestApplicationUser + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[RestErrors](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[RestErrors](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[[]RestApplicationUser](&response) + if err == nil { + result = response.Body.([]RestApplicationUser) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIListParticipantsRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + start *float32 + limit *float32 +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPIListParticipantsRequest) Start(start float32) *PullRequestsAPIListParticipantsRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPIListParticipantsRequest) Limit(limit float32) *PullRequestsAPIListParticipantsRequest { + r.limit = &limit + return r +} + +func (r *PullRequestsAPIListParticipantsRequest) Execute() (ListParticipants200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.ListParticipantsExecute(r) +} + +func (a *PullRequestsAPIRepository) ListParticipantsRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIListParticipantsRequest { + return PullRequestsAPIListParticipantsRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) ListParticipantsExecute(r *PullRequestsAPIListParticipantsRequest) (ListParticipants200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeListParticipantsCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) ListParticipants(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, start float32, limit float32) (ListParticipants200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeListParticipantsCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeListParticipantsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (ListParticipants200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result ListParticipants200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[ListParticipants200Response](&response) + if err == nil { + result = response.Body.(ListParticipants200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIMergeRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + version *string + restPullRequestMergeRequest *RestPullRequestMergeRequest +} + + // The current version of the pull request. If the server's version isn't the same as the specified version the operation will fail. To determine the current version of the pull request it should be fetched from the server prior to this operation. Look for the 'version' attribute in the returned JSON structure. +func (r *PullRequestsAPIMergeRequest) Version(version string) *PullRequestsAPIMergeRequest { + r.version = &version + return r +} + + // The body holder +func (r *PullRequestsAPIMergeRequest) RestPullRequestMergeRequest(restPullRequestMergeRequest RestPullRequestMergeRequest) *PullRequestsAPIMergeRequest { + r.restPullRequestMergeRequest = &restPullRequestMergeRequest + return r +} + +func (r *PullRequestsAPIMergeRequest) Execute() (RestPullRequest, aurestclientapi.ParsedResponse, error) { + return r.ApiService.MergeExecute(r) +} + +func (a *PullRequestsAPIRepository) MergeRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIMergeRequest { + return PullRequestsAPIMergeRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) MergeExecute(r *PullRequestsAPIMergeRequest) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.version!=nil { + withUrlQueryParam(requestURL, "version", *r.version) + } + return a.makeMergeCall(r.ctx, requestURL, r.restPullRequestMergeRequest) +} + +func (a *PullRequestsAPIRepository) Merge(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestMergeRequest RestPullRequestMergeRequest, version string) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "version", version) + return a.makeMergeCall(ctx, requestURL, restPullRequestMergeRequest) +} + +func (a *PullRequestsAPIRepository) makeMergeCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestPullRequest + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 403 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequest](&response) + if err == nil { + result = response.Body.(RestPullRequest) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIReact1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + commentId string + pullRequestId string + emoticon string + repositorySlug string +} + +func (r *PullRequestsAPIReact1Request) Execute() (RestUserReaction, aurestclientapi.ParsedResponse, error) { + return r.ApiService.React1Execute(r) +} + +func (a *PullRequestsAPIRepository) React1Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, emoticon string, repositorySlug string) PullRequestsAPIReact1Request { + return PullRequestsAPIReact1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + pullRequestId: pullRequestId, + emoticon: emoticon, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) React1Execute(r *PullRequestsAPIReact1Request) (RestUserReaction, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/comment-likes/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}/reactions/{emoticon}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{emoticon}", urlUtil.PathEscape(r.emoticon)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeReact1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) React1(ctx context.Context, projectKey string, commentId string, pullRequestId string, emoticon string, repositorySlug string) (RestUserReaction, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/comment-likes/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}/reactions/{emoticon}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{emoticon}", urlUtil.PathEscape(emoticon)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeReact1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeReact1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestUserReaction, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestUserReaction + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestUserReaction](&response) + if err == nil { + result = response.Body.(RestUserReaction) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIRebaseRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + restPullRequestRebaseRequest *RestPullRequestRebaseRequest +} + + // The pull request rebase request. +func (r *PullRequestsAPIRebaseRequest) RestPullRequestRebaseRequest(restPullRequestRebaseRequest RestPullRequestRebaseRequest) *PullRequestsAPIRebaseRequest { + r.restPullRequestRebaseRequest = &restPullRequestRebaseRequest + return r +} + +func (r *PullRequestsAPIRebaseRequest) Execute() (RestPullRequestRebaseResult, aurestclientapi.ParsedResponse, error) { + return r.ApiService.RebaseExecute(r) +} + +func (a *PullRequestsAPIRepository) RebaseRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIRebaseRequest { + return PullRequestsAPIRebaseRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) RebaseExecute(r *PullRequestsAPIRebaseRequest) (RestPullRequestRebaseResult, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/git/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/rebase" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeRebaseCall(r.ctx, requestURL, r.restPullRequestRebaseRequest) +} + +func (a *PullRequestsAPIRepository) Rebase(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestRebaseRequest RestPullRequestRebaseRequest) (RestPullRequestRebaseResult, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/git/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/rebase" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeRebaseCall(ctx, requestURL, restPullRequestRebaseRequest) +} + +func (a *PullRequestsAPIRepository) makeRebaseCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestRebaseResult, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestPullRequestRebaseResult + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestRebaseResult](&response) + if err == nil { + result = response.Body.(RestPullRequestRebaseResult) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIReopenRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + version *string + restPullRequestReopenRequest *RestPullRequestReopenRequest +} + + // The current version of the pull request. If the server's version isn't the same as the specified version the operation will fail. To determine the current version of the pull request it should be fetched from the server prior to this operation. Look for the 'version' attribute in the returned JSON structure. +func (r *PullRequestsAPIReopenRequest) Version(version string) *PullRequestsAPIReopenRequest { + r.version = &version + return r +} + + // The body holder +func (r *PullRequestsAPIReopenRequest) RestPullRequestReopenRequest(restPullRequestReopenRequest RestPullRequestReopenRequest) *PullRequestsAPIReopenRequest { + r.restPullRequestReopenRequest = &restPullRequestReopenRequest + return r +} + +func (r *PullRequestsAPIReopenRequest) Execute() (RestPullRequest, aurestclientapi.ParsedResponse, error) { + return r.ApiService.ReopenExecute(r) +} + +func (a *PullRequestsAPIRepository) ReopenRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIReopenRequest { + return PullRequestsAPIReopenRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) ReopenExecute(r *PullRequestsAPIReopenRequest) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/reopen" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.version!=nil { + withUrlQueryParam(requestURL, "version", *r.version) + } + return a.makeReopenCall(r.ctx, requestURL, r.restPullRequestReopenRequest) +} + +func (a *PullRequestsAPIRepository) Reopen(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequestReopenRequest RestPullRequestReopenRequest, version string) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/reopen" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "version", version) + return a.makeReopenCall(ctx, requestURL, restPullRequestReopenRequest) +} + +func (a *PullRequestsAPIRepository) makeReopenCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestPullRequest + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequest](&response) + if err == nil { + result = response.Body.(RestPullRequest) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPISearchRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + repositorySlug string + filter *string + role *string + direction *string + start *float32 + limit *float32 +} + + // (optional) Return only users, whose username, name or email address <i>contain</i> the filter value +func (r *PullRequestsAPISearchRequest) Filter(filter string) *PullRequestsAPISearchRequest { + r.filter = &filter + return r +} + + // (optional) The role associated with the pull request participant. This must be one of AUTHOR, REVIEWER, or PARTICIPANT +func (r *PullRequestsAPISearchRequest) Role(role string) *PullRequestsAPISearchRequest { + r.role = &role + return r +} + + // (optional), Defaults to <strong>INCOMING</strong>) the direction relative to the specified repository. Either <strong>INCOMING</strong> or <strong>OUTGOING</strong>. +func (r *PullRequestsAPISearchRequest) Direction(direction string) *PullRequestsAPISearchRequest { + r.direction = &direction + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPISearchRequest) Start(start float32) *PullRequestsAPISearchRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPISearchRequest) Limit(limit float32) *PullRequestsAPISearchRequest { + r.limit = &limit + return r +} + +func (r *PullRequestsAPISearchRequest) Execute() (GetLikers200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.SearchExecute(r) +} + +func (a *PullRequestsAPIRepository) SearchRequest(ctx context.Context, projectKey string, repositorySlug string) PullRequestsAPISearchRequest { + return PullRequestsAPISearchRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) SearchExecute(r *PullRequestsAPISearchRequest) (GetLikers200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/participants" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.filter!=nil { + withUrlQueryParam(requestURL, "filter", *r.filter) + } + if r.role!=nil { + withUrlQueryParam(requestURL, "role", *r.role) + } + if r.direction!=nil { + withUrlQueryParam(requestURL, "direction", *r.direction) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeSearchCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) Search(ctx context.Context, projectKey string, repositorySlug string, filter string, role string, direction string, start float32, limit float32) (GetLikers200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/participants" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "filter", filter) + withUrlQueryParam(requestURL, "role", role) + withUrlQueryParam(requestURL, "direction", direction) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeSearchCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeSearchCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetLikers200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetLikers200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetLikers200Response](&response) + if err == nil { + result = response.Body.(GetLikers200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPISetMergeConfigRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + scmId string + restPullRequestSettings *RestPullRequestSettings +} + + // the settings +func (r *PullRequestsAPISetMergeConfigRequest) RestPullRequestSettings(restPullRequestSettings RestPullRequestSettings) *PullRequestsAPISetMergeConfigRequest { + r.restPullRequestSettings = &restPullRequestSettings + return r +} + +func (r *PullRequestsAPISetMergeConfigRequest) Execute() (RestPullRequestMergeConfig, aurestclientapi.ParsedResponse, error) { + return r.ApiService.SetMergeConfigExecute(r) +} + +func (a *PullRequestsAPIRepository) SetMergeConfigRequest(ctx context.Context, scmId string) PullRequestsAPISetMergeConfigRequest { + return PullRequestsAPISetMergeConfigRequest{ + ApiService: a, + ctx: ctx, + scmId: scmId, + } +} + +func (a *PullRequestsAPIRepository) SetMergeConfigExecute(r *PullRequestsAPISetMergeConfigRequest) (RestPullRequestMergeConfig, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/admin/pull-requests/{scmId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{scmId}", urlUtil.PathEscape(r.scmId)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetMergeConfigCall(r.ctx, requestURL, r.restPullRequestSettings) +} + +func (a *PullRequestsAPIRepository) SetMergeConfig(ctx context.Context, scmId string, restPullRequestSettings RestPullRequestSettings) (RestPullRequestMergeConfig, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/admin/pull-requests/{scmId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{scmId}", urlUtil.PathEscape(scmId)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetMergeConfigCall(ctx, requestURL, restPullRequestSettings) +} + +func (a *PullRequestsAPIRepository) makeSetMergeConfigCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestMergeConfig, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestPullRequestMergeConfig + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestMergeConfig](&response) + if err == nil { + result = response.Body.(RestPullRequestMergeConfig) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIStreamChanges1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + sinceId *string + changeScope *string + untilId *string + withComments *string + start *float32 + limit *float32 +} + + // The since commit hash to stream changes for a RANGE arbitrary change scope +func (r *PullRequestsAPIStreamChanges1Request) SinceId(sinceId string) *PullRequestsAPIStreamChanges1Request { + r.sinceId = &sinceId + return r +} + + // UNREVIEWED to stream the unreviewed changes for the current user (if they exist); RANGE to stream changes between two arbitrary commits (requires 'sinceId' and 'untilId'); otherwise ALL to stream all changes (the default) +func (r *PullRequestsAPIStreamChanges1Request) ChangeScope(changeScope string) *PullRequestsAPIStreamChanges1Request { + r.changeScope = &changeScope + return r +} + + // The until commit hash to stream changes for a RANGE arbitrary change scope +func (r *PullRequestsAPIStreamChanges1Request) UntilId(untilId string) *PullRequestsAPIStreamChanges1Request { + r.untilId = &untilId + return r +} + + // true to apply comment counts in the changes (the default); otherwise, false to stream changes without comment counts +func (r *PullRequestsAPIStreamChanges1Request) WithComments(withComments string) *PullRequestsAPIStreamChanges1Request { + r.withComments = &withComments + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPIStreamChanges1Request) Start(start float32) *PullRequestsAPIStreamChanges1Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPIStreamChanges1Request) Limit(limit float32) *PullRequestsAPIStreamChanges1Request { + r.limit = &limit + return r +} + +func (r *PullRequestsAPIStreamChanges1Request) Execute() (RestChange, aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamChanges1Execute(r) +} + +func (a *PullRequestsAPIRepository) StreamChanges1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIStreamChanges1Request { + return PullRequestsAPIStreamChanges1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) StreamChanges1Execute(r *PullRequestsAPIStreamChanges1Request) (RestChange, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/changes" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.sinceId!=nil { + withUrlQueryParam(requestURL, "sinceId", *r.sinceId) + } + if r.changeScope!=nil { + withUrlQueryParam(requestURL, "changeScope", *r.changeScope) + } + if r.untilId!=nil { + withUrlQueryParam(requestURL, "untilId", *r.untilId) + } + if r.withComments!=nil { + withUrlQueryParam(requestURL, "withComments", *r.withComments) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeStreamChanges1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) StreamChanges1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, sinceId string, changeScope string, untilId string, withComments string, start float32, limit float32) (RestChange, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/changes" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "sinceId", sinceId) + withUrlQueryParam(requestURL, "changeScope", changeScope) + withUrlQueryParam(requestURL, "untilId", untilId) + withUrlQueryParam(requestURL, "withComments", withComments) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeStreamChanges1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeStreamChanges1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestChange, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestChange + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestChange](&response) + if err == nil { + result = response.Body.(RestChange) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIStreamDiff2Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + path string + projectKey string + pullRequestId string + repositorySlug string + avatarScheme *string + contextLines *string + sinceId *string + srcPath *string + diffType *string + untilId *string + whitespace *string + withComments *string + avatarSize *string + start *float32 + limit *float32 +} + + // The security scheme for avatar URLs. If the scheme is not present then it is inherited from the request. It can be set to \"https\" to force the use of secure URLs. Not applicable if streaming raw diff +func (r *PullRequestsAPIStreamDiff2Request) AvatarScheme(avatarScheme string) *PullRequestsAPIStreamDiff2Request { + r.avatarScheme = &avatarScheme + return r +} + + // The number of context lines to include around added/removed lines in the diff +func (r *PullRequestsAPIStreamDiff2Request) ContextLines(contextLines string) *PullRequestsAPIStreamDiff2Request { + r.contextLines = &contextLines + return r +} + + // The since commit hash to stream a diff between two arbitrary hashes +func (r *PullRequestsAPIStreamDiff2Request) SinceId(sinceId string) *PullRequestsAPIStreamDiff2Request { + r.sinceId = &sinceId + return r +} + + // The previous path to the file, if the file has been copied, moved or renamed +func (r *PullRequestsAPIStreamDiff2Request) SrcPath(srcPath string) *PullRequestsAPIStreamDiff2Request { + r.srcPath = &srcPath + return r +} + + // The type of diff being requested. When withComments is true this works as a hint to the system to attach the correct set of comments to the diff. Not applicable if streaming raw diff +func (r *PullRequestsAPIStreamDiff2Request) DiffType(diffType string) *PullRequestsAPIStreamDiff2Request { + r.diffType = &diffType + return r +} + + // The until commit hash to stream a diff between two arbitrary hashes +func (r *PullRequestsAPIStreamDiff2Request) UntilId(untilId string) *PullRequestsAPIStreamDiff2Request { + r.untilId = &untilId + return r +} + + // Optional whitespace flag which can be set to <code>ignore-all</code> +func (r *PullRequestsAPIStreamDiff2Request) Whitespace(whitespace string) *PullRequestsAPIStreamDiff2Request { + r.whitespace = &whitespace + return r +} + + // <code>true</code> to embed comments in the diff (the default); otherwise, <code>false</code> to stream the diff without comments. Not applicable if streaming raw diff +func (r *PullRequestsAPIStreamDiff2Request) WithComments(withComments string) *PullRequestsAPIStreamDiff2Request { + r.withComments = &withComments + return r +} + + // If present the service adds avatar URLs for comment authors where the provided value specifies the desired avatar size in pixels. Not applicable if streaming raw diff +func (r *PullRequestsAPIStreamDiff2Request) AvatarSize(avatarSize string) *PullRequestsAPIStreamDiff2Request { + r.avatarSize = &avatarSize + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *PullRequestsAPIStreamDiff2Request) Start(start float32) *PullRequestsAPIStreamDiff2Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *PullRequestsAPIStreamDiff2Request) Limit(limit float32) *PullRequestsAPIStreamDiff2Request { + r.limit = &limit + return r +} + +func (r *PullRequestsAPIStreamDiff2Request) Execute() (StreamDiff1200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamDiff2Execute(r) +} + +func (a *PullRequestsAPIRepository) StreamDiff2Request(ctx context.Context, path string, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIStreamDiff2Request { + return PullRequestsAPIStreamDiff2Request{ + ApiService: a, + ctx: ctx, + path: path, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) StreamDiff2Execute(r *PullRequestsAPIStreamDiff2Request) (StreamDiff1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/diff/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(r.path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.avatarScheme!=nil { + withUrlQueryParam(requestURL, "avatarScheme", *r.avatarScheme) + } + if r.contextLines!=nil { + withUrlQueryParam(requestURL, "contextLines", *r.contextLines) + } + if r.sinceId!=nil { + withUrlQueryParam(requestURL, "sinceId", *r.sinceId) + } + if r.srcPath!=nil { + withUrlQueryParam(requestURL, "srcPath", *r.srcPath) + } + if r.diffType!=nil { + withUrlQueryParam(requestURL, "diffType", *r.diffType) + } + if r.untilId!=nil { + withUrlQueryParam(requestURL, "untilId", *r.untilId) + } + if r.whitespace!=nil { + withUrlQueryParam(requestURL, "whitespace", *r.whitespace) + } + if r.withComments!=nil { + withUrlQueryParam(requestURL, "withComments", *r.withComments) + } + if r.avatarSize!=nil { + withUrlQueryParam(requestURL, "avatarSize", *r.avatarSize) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeStreamDiff2Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) StreamDiff2(ctx context.Context, path string, projectKey string, pullRequestId string, repositorySlug string, avatarScheme string, contextLines string, sinceId string, srcPath string, diffType string, untilId string, whitespace string, withComments string, avatarSize string, start float32, limit float32) (StreamDiff1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/diff/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "avatarScheme", avatarScheme) + withUrlQueryParam(requestURL, "contextLines", contextLines) + withUrlQueryParam(requestURL, "sinceId", sinceId) + withUrlQueryParam(requestURL, "srcPath", srcPath) + withUrlQueryParam(requestURL, "diffType", diffType) + withUrlQueryParam(requestURL, "untilId", untilId) + withUrlQueryParam(requestURL, "whitespace", whitespace) + withUrlQueryParam(requestURL, "withComments", withComments) + withUrlQueryParam(requestURL, "avatarSize", avatarSize) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeStreamDiff2Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeStreamDiff2Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (StreamDiff1200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result StreamDiff1200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[StreamDiff1200Response](&response) + if err == nil { + result = response.Body.(StreamDiff1200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIStreamPatch1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIStreamPatch1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamPatch1Execute(r) +} + +func (a *PullRequestsAPIRepository) StreamPatch1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIStreamPatch1Request { + return PullRequestsAPIStreamPatch1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) StreamPatch1Execute(r *PullRequestsAPIStreamPatch1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}.patch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeStreamPatch1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) StreamPatch1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}.patch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeStreamPatch1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeStreamPatch1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIStreamRawDiff2Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + contextLines *string + whitespace *string +} + + // The number of context lines to include around added/removed lines in the diff +func (r *PullRequestsAPIStreamRawDiff2Request) ContextLines(contextLines string) *PullRequestsAPIStreamRawDiff2Request { + r.contextLines = &contextLines + return r +} + + // optional whitespace flag which can be set to <code>ignore-all</code> +func (r *PullRequestsAPIStreamRawDiff2Request) Whitespace(whitespace string) *PullRequestsAPIStreamRawDiff2Request { + r.whitespace = &whitespace + return r +} + +func (r *PullRequestsAPIStreamRawDiff2Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamRawDiff2Execute(r) +} + +func (a *PullRequestsAPIRepository) StreamRawDiff2Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIStreamRawDiff2Request { + return PullRequestsAPIStreamRawDiff2Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) StreamRawDiff2Execute(r *PullRequestsAPIStreamRawDiff2Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}.diff" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.contextLines!=nil { + withUrlQueryParam(requestURL, "contextLines", *r.contextLines) + } + if r.whitespace!=nil { + withUrlQueryParam(requestURL, "whitespace", *r.whitespace) + } + return a.makeStreamRawDiff2Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) StreamRawDiff2(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, contextLines string, whitespace string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}.diff" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "contextLines", contextLines) + withUrlQueryParam(requestURL, "whitespace", whitespace) + return a.makeStreamRawDiff2Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeStreamRawDiff2Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + return response, nil + } + if response.Status == 404 { + return response, nil + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPITryAutoMergeRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPITryAutoMergeRequest) Execute() (RestAutoMergeProcessingResult, aurestclientapi.ParsedResponse, error) { + return r.ApiService.TryAutoMergeExecute(r) +} + +func (a *PullRequestsAPIRepository) TryAutoMergeRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPITryAutoMergeRequest { + return PullRequestsAPITryAutoMergeRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) TryAutoMergeExecute(r *PullRequestsAPITryAutoMergeRequest) (RestAutoMergeProcessingResult, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/auto-merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeTryAutoMergeCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) TryAutoMerge(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestAutoMergeProcessingResult, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/auto-merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeTryAutoMergeCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeTryAutoMergeCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestAutoMergeProcessingResult, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestAutoMergeProcessingResult + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 403 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestAutoMergeProcessingResult](&response) + if err == nil { + result = response.Body.(RestAutoMergeProcessingResult) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIUnReact1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + commentId string + pullRequestId string + emoticon string + repositorySlug string +} + +func (r *PullRequestsAPIUnReact1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.UnReact1Execute(r) +} + +func (a *PullRequestsAPIRepository) UnReact1Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, emoticon string, repositorySlug string) PullRequestsAPIUnReact1Request { + return PullRequestsAPIUnReact1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + pullRequestId: pullRequestId, + emoticon: emoticon, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) UnReact1Execute(r *PullRequestsAPIUnReact1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/comment-likes/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}/reactions/{emoticon}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{emoticon}", urlUtil.PathEscape(r.emoticon)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUnReact1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) UnReact1(ctx context.Context, projectKey string, commentId string, pullRequestId string, emoticon string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/comment-likes/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}/reactions/{emoticon}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{emoticon}", urlUtil.PathEscape(emoticon)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUnReact1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeUnReact1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIUnassignParticipantRoleRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + userSlug string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIUnassignParticipantRoleRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.UnassignParticipantRoleExecute(r) +} + +func (a *PullRequestsAPIRepository) UnassignParticipantRoleRequest(ctx context.Context, projectKey string, userSlug string, pullRequestId string, repositorySlug string) PullRequestsAPIUnassignParticipantRoleRequest { + return PullRequestsAPIUnassignParticipantRoleRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + userSlug: userSlug, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) UnassignParticipantRoleExecute(r *PullRequestsAPIUnassignParticipantRoleRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants/{userSlug}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{userSlug}", urlUtil.PathEscape(r.userSlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUnassignParticipantRoleCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) UnassignParticipantRole(ctx context.Context, projectKey string, userSlug string, pullRequestId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants/{userSlug}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{userSlug}", urlUtil.PathEscape(userSlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUnassignParticipantRoleCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeUnassignParticipantRoleCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIUnassignParticipantRole1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + username *string +} + +func (r *PullRequestsAPIUnassignParticipantRole1Request) Username(username string) *PullRequestsAPIUnassignParticipantRole1Request { + r.username = &username + return r +} + +func (r *PullRequestsAPIUnassignParticipantRole1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.UnassignParticipantRole1Execute(r) +} + +func (a *PullRequestsAPIRepository) UnassignParticipantRole1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIUnassignParticipantRole1Request { + return PullRequestsAPIUnassignParticipantRole1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +// Deprecated +func (a *PullRequestsAPIRepository) UnassignParticipantRole1Execute(r *PullRequestsAPIUnassignParticipantRole1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.username!=nil { + withUrlQueryParam(requestURL, "username", *r.username) + } + return a.makeUnassignParticipantRole1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) UnassignParticipantRole1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, username string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "username", username) + return a.makeUnassignParticipantRole1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeUnassignParticipantRole1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIUnwatch1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIUnwatch1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.Unwatch1Execute(r) +} + +func (a *PullRequestsAPIRepository) Unwatch1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIUnwatch1Request { + return PullRequestsAPIUnwatch1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) Unwatch1Execute(r *PullRequestsAPIUnwatch1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/watch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUnwatch1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) Unwatch1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/watch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUnwatch1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeUnwatch1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIUpdateRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string + restPullRequest *RestPullRequest +} + + // The updated pull request +func (r *PullRequestsAPIUpdateRequest) RestPullRequest(restPullRequest RestPullRequest) *PullRequestsAPIUpdateRequest { + r.restPullRequest = &restPullRequest + return r +} + +func (r *PullRequestsAPIUpdateRequest) Execute() (RestPullRequest, aurestclientapi.ParsedResponse, error) { + return r.ApiService.UpdateExecute(r) +} + +func (a *PullRequestsAPIRepository) UpdateRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIUpdateRequest { + return PullRequestsAPIUpdateRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) UpdateExecute(r *PullRequestsAPIUpdateRequest) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdateCall(r.ctx, requestURL, r.restPullRequest) +} + +func (a *PullRequestsAPIRepository) Update(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string, restPullRequest RestPullRequest) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdateCall(ctx, requestURL, restPullRequest) +} + +func (a *PullRequestsAPIRepository) makeUpdateCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequest, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestPullRequest + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequest](&response) + if err == nil { + result = response.Body.(RestPullRequest) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIUpdate1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + id string + restReviewerGroup *RestReviewerGroup +} + + // The request containing the attributes of the reviewer group to be updated. Only the attributes to be updated need to be present in this object. +func (r *PullRequestsAPIUpdate1Request) RestReviewerGroup(restReviewerGroup RestReviewerGroup) *PullRequestsAPIUpdate1Request { + r.restReviewerGroup = &restReviewerGroup + return r +} + +func (r *PullRequestsAPIUpdate1Request) Execute() (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + return r.ApiService.Update1Execute(r) +} + +func (a *PullRequestsAPIRepository) Update1Request(ctx context.Context, projectKey string, id string) PullRequestsAPIUpdate1Request { + return PullRequestsAPIUpdate1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + } +} + +func (a *PullRequestsAPIRepository) Update1Execute(r *PullRequestsAPIUpdate1Request) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/settings/reviewer-groups/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(r.id)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdate1Call(r.ctx, requestURL, r.restReviewerGroup) +} + +func (a *PullRequestsAPIRepository) Update1(ctx context.Context, projectKey string, id string, restReviewerGroup RestReviewerGroup) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/settings/reviewer-groups/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(id)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdate1Call(ctx, requestURL, restReviewerGroup) +} + +func (a *PullRequestsAPIRepository) makeUpdate1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestReviewerGroup + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestReviewerGroup](&response) + if err == nil { + result = response.Body.(RestReviewerGroup) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIUpdate2Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + id string + repositorySlug string + restReviewerGroup *RestReviewerGroup +} + + // The request containing the attributes of the reviewer group to be updated. Only the attributes to be updated need to be present in this object. +func (r *PullRequestsAPIUpdate2Request) RestReviewerGroup(restReviewerGroup RestReviewerGroup) *PullRequestsAPIUpdate2Request { + r.restReviewerGroup = &restReviewerGroup + return r +} + +func (r *PullRequestsAPIUpdate2Request) Execute() (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + return r.ApiService.Update2Execute(r) +} + +func (a *PullRequestsAPIRepository) Update2Request(ctx context.Context, projectKey string, id string, repositorySlug string) PullRequestsAPIUpdate2Request { + return PullRequestsAPIUpdate2Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) Update2Execute(r *PullRequestsAPIUpdate2Request) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(r.id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdate2Call(r.ctx, requestURL, r.restReviewerGroup) +} + +func (a *PullRequestsAPIRepository) Update2(ctx context.Context, projectKey string, id string, repositorySlug string, restReviewerGroup RestReviewerGroup) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/reviewer-groups/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdate2Call(ctx, requestURL, restReviewerGroup) +} + +func (a *PullRequestsAPIRepository) makeUpdate2Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestReviewerGroup, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestReviewerGroup + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestReviewerGroup](&response) + if err == nil { + result = response.Body.(RestReviewerGroup) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIUpdateComment1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + commentId string + pullRequestId string + repositorySlug string + restComment *RestComment +} + + // The comment to add. +func (r *PullRequestsAPIUpdateComment1Request) RestComment(restComment RestComment) *PullRequestsAPIUpdateComment1Request { + r.restComment = &restComment + return r +} + +func (r *PullRequestsAPIUpdateComment1Request) Execute() (RestComment, aurestclientapi.ParsedResponse, error) { + return r.ApiService.UpdateComment1Execute(r) +} + +func (a *PullRequestsAPIRepository) UpdateComment1Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIUpdateComment1Request { + return PullRequestsAPIUpdateComment1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) UpdateComment1Execute(r *PullRequestsAPIUpdateComment1Request) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdateComment1Call(r.ctx, requestURL, r.restComment) +} + +func (a *PullRequestsAPIRepository) UpdateComment1(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string, restComment RestComment) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/blocker-comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdateComment1Call(ctx, requestURL, restComment) +} + +func (a *PullRequestsAPIRepository) makeUpdateComment1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestComment, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestComment + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestComment](&response) + if err == nil { + result = response.Body.(RestComment) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIUpdateComment2Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + commentId string + pullRequestId string + repositorySlug string + restComment *RestComment +} + + // The updated comment +func (r *PullRequestsAPIUpdateComment2Request) RestComment(restComment RestComment) *PullRequestsAPIUpdateComment2Request { + r.restComment = &restComment + return r +} + +func (r *PullRequestsAPIUpdateComment2Request) Execute() (RestComment, aurestclientapi.ParsedResponse, error) { + return r.ApiService.UpdateComment2Execute(r) +} + +func (a *PullRequestsAPIRepository) UpdateComment2Request(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string) PullRequestsAPIUpdateComment2Request { + return PullRequestsAPIUpdateComment2Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) UpdateComment2Execute(r *PullRequestsAPIUpdateComment2Request) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdateComment2Call(r.ctx, requestURL, r.restComment) +} + +func (a *PullRequestsAPIRepository) UpdateComment2(ctx context.Context, projectKey string, commentId string, pullRequestId string, repositorySlug string, restComment RestComment) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdateComment2Call(ctx, requestURL, restComment) +} + +func (a *PullRequestsAPIRepository) makeUpdateComment2Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestComment, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestComment + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestComment](&response) + if err == nil { + result = response.Body.(RestComment) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIUpdatePullRequestConditionRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + id string + restDefaultReviewersRequest *RestDefaultReviewersRequest +} + + // The new details for the default reviewer pull request condition. +func (r *PullRequestsAPIUpdatePullRequestConditionRequest) RestDefaultReviewersRequest(restDefaultReviewersRequest RestDefaultReviewersRequest) *PullRequestsAPIUpdatePullRequestConditionRequest { + r.restDefaultReviewersRequest = &restDefaultReviewersRequest + return r +} + +func (r *PullRequestsAPIUpdatePullRequestConditionRequest) Execute() (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + return r.ApiService.UpdatePullRequestConditionExecute(r) +} + +func (a *PullRequestsAPIRepository) UpdatePullRequestConditionRequest(ctx context.Context, projectKey string, id string) PullRequestsAPIUpdatePullRequestConditionRequest { + return PullRequestsAPIUpdatePullRequestConditionRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + } +} + +func (a *PullRequestsAPIRepository) UpdatePullRequestConditionExecute(r *PullRequestsAPIUpdatePullRequestConditionRequest) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/condition/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(r.id)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdatePullRequestConditionCall(r.ctx, requestURL, r.restDefaultReviewersRequest) +} + +func (a *PullRequestsAPIRepository) UpdatePullRequestCondition(ctx context.Context, projectKey string, id string, restDefaultReviewersRequest RestDefaultReviewersRequest) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/condition/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(id)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdatePullRequestConditionCall(ctx, requestURL, restDefaultReviewersRequest) +} + +func (a *PullRequestsAPIRepository) makeUpdatePullRequestConditionCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestPullRequestCondition + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestCondition](&response) + if err == nil { + result = response.Body.(RestPullRequestCondition) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIUpdatePullRequestCondition1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + id string + repositorySlug string + updatePullRequestCondition1Request *UpdatePullRequestCondition1Request +} + +func (r *PullRequestsAPIUpdatePullRequestCondition1Request) UpdatePullRequestCondition1Request(updatePullRequestCondition1Request UpdatePullRequestCondition1Request) *PullRequestsAPIUpdatePullRequestCondition1Request { + r.updatePullRequestCondition1Request = &updatePullRequestCondition1Request + return r +} + +func (r *PullRequestsAPIUpdatePullRequestCondition1Request) Execute() (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + return r.ApiService.UpdatePullRequestCondition1Execute(r) +} + +func (a *PullRequestsAPIRepository) UpdatePullRequestCondition1Request(ctx context.Context, projectKey string, id string, repositorySlug string) PullRequestsAPIUpdatePullRequestCondition1Request { + return PullRequestsAPIUpdatePullRequestCondition1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) UpdatePullRequestCondition1Execute(r *PullRequestsAPIUpdatePullRequestCondition1Request) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/condition/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(r.id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdatePullRequestCondition1Call(r.ctx, requestURL, r.updatePullRequestCondition1Request) +} + +func (a *PullRequestsAPIRepository) UpdatePullRequestCondition1(ctx context.Context, projectKey string, id string, repositorySlug string, updatePullRequestCondition1Request UpdatePullRequestCondition1Request) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/default-reviewers/latest/projects/{projectKey}/repos/{repositorySlug}/condition/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdatePullRequestCondition1Call(ctx, requestURL, updatePullRequestCondition1Request) +} + +func (a *PullRequestsAPIRepository) makeUpdatePullRequestCondition1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestCondition, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestPullRequestCondition + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestCondition](&response) + if err == nil { + result = response.Body.(RestPullRequestCondition) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIUpdateStatusRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + userSlug string + pullRequestId string + repositorySlug string + restPullRequestAssignStatusRequest *RestPullRequestAssignStatusRequest + version *string +} + + // The participant representing the status to set, includes the status of the participant +func (r *PullRequestsAPIUpdateStatusRequest) RestPullRequestAssignStatusRequest(restPullRequestAssignStatusRequest RestPullRequestAssignStatusRequest) *PullRequestsAPIUpdateStatusRequest { + r.restPullRequestAssignStatusRequest = &restPullRequestAssignStatusRequest + return r +} + + // The current version of the pull request. If the server's version isn't the same as the specified version the operation will fail. To determine the current version of the pull request it should be fetched from the server prior to this operation. Look for the 'version' attribute in the returned JSON structure. +func (r *PullRequestsAPIUpdateStatusRequest) Version(version string) *PullRequestsAPIUpdateStatusRequest { + r.version = &version + return r +} + +func (r *PullRequestsAPIUpdateStatusRequest) Execute() (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + return r.ApiService.UpdateStatusExecute(r) +} + +func (a *PullRequestsAPIRepository) UpdateStatusRequest(ctx context.Context, projectKey string, userSlug string, pullRequestId string, repositorySlug string) PullRequestsAPIUpdateStatusRequest { + return PullRequestsAPIUpdateStatusRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + userSlug: userSlug, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) UpdateStatusExecute(r *PullRequestsAPIUpdateStatusRequest) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants/{userSlug}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{userSlug}", urlUtil.PathEscape(r.userSlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.version!=nil { + withUrlQueryParam(requestURL, "version", *r.version) + } + return a.makeUpdateStatusCall(r.ctx, requestURL, r.restPullRequestAssignStatusRequest) +} + +func (a *PullRequestsAPIRepository) UpdateStatus(ctx context.Context, projectKey string, userSlug string, pullRequestId string, repositorySlug string, restPullRequestAssignStatusRequest RestPullRequestAssignStatusRequest, version string) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/participants/{userSlug}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{userSlug}", urlUtil.PathEscape(userSlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "version", version) + return a.makeUpdateStatusCall(ctx, requestURL, restPullRequestAssignStatusRequest) +} + +func (a *PullRequestsAPIRepository) makeUpdateStatusCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestPullRequestParticipant + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestParticipant](&response) + if err == nil { + result = response.Body.(RestPullRequestParticipant) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type PullRequestsAPIWatch1Request struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIWatch1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.Watch1Execute(r) +} + +func (a *PullRequestsAPIRepository) Watch1Request(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIWatch1Request { + return PullRequestsAPIWatch1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +func (a *PullRequestsAPIRepository) Watch1Execute(r *PullRequestsAPIWatch1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/watch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeWatch1Call(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) Watch1(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/watch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeWatch1Call(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeWatch1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type PullRequestsAPIWithdrawApprovalRequest struct { + ctx context.Context + ApiService *PullRequestsAPIRepository + projectKey string + pullRequestId string + repositorySlug string +} + +func (r *PullRequestsAPIWithdrawApprovalRequest) Execute() (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + return r.ApiService.WithdrawApprovalExecute(r) +} + +func (a *PullRequestsAPIRepository) WithdrawApprovalRequest(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) PullRequestsAPIWithdrawApprovalRequest { + return PullRequestsAPIWithdrawApprovalRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + pullRequestId: pullRequestId, + repositorySlug: repositorySlug, + } +} + +// Deprecated +func (a *PullRequestsAPIRepository) WithdrawApprovalExecute(r *PullRequestsAPIWithdrawApprovalRequest) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/approve" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(r.pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeWithdrawApprovalCall(r.ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) WithdrawApproval(ctx context.Context, projectKey string, pullRequestId string, repositorySlug string) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/pull-requests/{pullRequestId}/approve" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{pullRequestId}", urlUtil.PathEscape(pullRequestId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeWithdrawApprovalCall(ctx, requestURL, nil) +} + +func (a *PullRequestsAPIRepository) makeWithdrawApprovalCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestPullRequestParticipant, aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + var result RestPullRequestParticipant + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestPullRequestParticipant](&response) + if err == nil { + result = response.Body.(RestPullRequestParticipant) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + +type PullRequestsAPIRepository struct { + ApiClient *ApiClient +} + +func (c *PullRequestsAPIRepository) baseUrl() string { + return c.ApiClient.BaseUrl +} + +func (c *PullRequestsAPIRepository) httpClient() aurestclientapi.Client { + return c.ApiClient.Client +} + +func NewPullRequestsAPI(client *ApiClient) PullRequestsAPI { + return &PullRequestsAPIRepository{ApiClient: client} +} diff --git a/internal/client/bitbucket/generated_api_repository.go b/internal/client/bitbucket/generated_api_repository.go new file mode 100644 index 0000000..9ea6e0e --- /dev/null +++ b/internal/client/bitbucket/generated_api_repository.go @@ -0,0 +1,9771 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + +import ( + "context" + "fmt" + aurestclientapi "github.com/StephanHCB/go-autumn-restclient/api" + "net/http" + urlUtil "net/url" + "strings" +) + +type RepositoryAPI interface { + + /* + AddLabel Add repository label + */ + AddLabel(ctx context.Context, projectKey string, repositorySlug string, restLabel RestLabel) (RestLabel, aurestclientapi.ParsedResponse, error) + + // AddLabelExecutes the request + // @return RestLabel + AddLabelRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIAddLabelRequest + + /* + CreateBranch Create branch + */ + CreateBranch(ctx context.Context, projectKey string, repositorySlug string, restBranchCreateRequest RestBranchCreateRequest) (RestBranch, aurestclientapi.ParsedResponse, error) + + // CreateBranchExecutes the request + // @return RestBranch + CreateBranchRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPICreateBranchRequest + + /* + CreateBranchForRepository Create branch + */ + CreateBranchForRepository(ctx context.Context, projectKey string, repositorySlug string, restCreateBranchRequest RestCreateBranchRequest) (RestBranch, aurestclientapi.ParsedResponse, error) + + // CreateBranchForRepositoryExecutes the request + // @return RestBranch + CreateBranchForRepositoryRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPICreateBranchForRepositoryRequest + + /* + CreateComment Add a new commit comment + */ + CreateComment(ctx context.Context, projectKey string, commitId string, repositorySlug string, restComment RestComment, since string) (RestComment, aurestclientapi.ParsedResponse, error) + + // CreateCommentExecutes the request + // @return RestComment + CreateCommentRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPICreateCommentRequest + + /* + CreateRestrictions1 Create multiple ref restrictions + */ + CreateRestrictions1(ctx context.Context, projectKey string, repositorySlug string, restRestrictionRequest []RestRestrictionRequest) (RestRefRestriction, aurestclientapi.ParsedResponse, error) + + // CreateRestrictions1Executes the request + // @return RestRefRestriction + CreateRestrictions1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPICreateRestrictions1Request + + /* + CreateTag Create tag + */ + CreateTag(ctx context.Context, projectKey string, repositorySlug string, restGitTagCreateRequest RestGitTagCreateRequest) (RestTag, aurestclientapi.ParsedResponse, error) + + // CreateTagExecutes the request + // @return RestTag + CreateTagRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPICreateTagRequest + + /* + CreateTagForRepository Create tag + */ + CreateTagForRepository(ctx context.Context, projectKey string, repositorySlug string, restCreateTagRequest RestCreateTagRequest) (RestTag, aurestclientapi.ParsedResponse, error) + + // CreateTagForRepositoryExecutes the request + // @return RestTag + CreateTagForRepositoryRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPICreateTagForRepositoryRequest + + /* + CreateWebhook1 Create webhook + */ + CreateWebhook1(ctx context.Context, projectKey string, repositorySlug string, restWebhook RestWebhook) (RestWebhook, aurestclientapi.ParsedResponse, error) + + // CreateWebhook1Executes the request + // @return RestWebhook + CreateWebhook1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPICreateWebhook1Request + + /* + Delete5 Delete pull request auto-merge settings + */ + Delete5(ctx context.Context, projectKey string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // Delete5Executes the request + Delete5Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIDelete5Request + + /* + DeleteAttachment Delete an attachment + */ + DeleteAttachment(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // DeleteAttachmentExecutes the request + DeleteAttachmentRequest(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) RepositoryAPIDeleteAttachmentRequest + + /* + DeleteAttachmentMetadata Delete attachment metadata + */ + DeleteAttachmentMetadata(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // DeleteAttachmentMetadataExecutes the request + DeleteAttachmentMetadataRequest(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) RepositoryAPIDeleteAttachmentMetadataRequest + + /* + DeleteAutoDeclineSettings1 Delete auto decline settings + */ + DeleteAutoDeclineSettings1(ctx context.Context, projectKey string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // DeleteAutoDeclineSettings1Executes the request + DeleteAutoDeclineSettings1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIDeleteAutoDeclineSettings1Request + + /* + DeleteBranch Delete branch + */ + DeleteBranch(ctx context.Context, projectKey string, repositorySlug string, restBranchDeleteRequest RestBranchDeleteRequest) (aurestclientapi.ParsedResponse, error) + + // DeleteBranchExecutes the request + DeleteBranchRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIDeleteBranchRequest + + /* + DeleteComment Delete a commit comment + */ + DeleteComment(ctx context.Context, projectKey string, commentId string, commitId string, repositorySlug string, version string) (aurestclientapi.ParsedResponse, error) + + // DeleteCommentExecutes the request + DeleteCommentRequest(ctx context.Context, projectKey string, commentId string, commitId string, repositorySlug string) RepositoryAPIDeleteCommentRequest + + /* + DeleteRepositoryHook Delete repository hook + */ + DeleteRepositoryHook(ctx context.Context, projectKey string, hookKey string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // DeleteRepositoryHookExecutes the request + DeleteRepositoryHookRequest(ctx context.Context, projectKey string, hookKey string, repositorySlug string) RepositoryAPIDeleteRepositoryHookRequest + + /* + DeleteRestriction1 Delete a ref restriction + */ + DeleteRestriction1(ctx context.Context, projectKey string, id string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // DeleteRestriction1Executes the request + DeleteRestriction1Request(ctx context.Context, projectKey string, id string, repositorySlug string) RepositoryAPIDeleteRestriction1Request + + /* + DeleteTag Delete tag + */ + DeleteTag(ctx context.Context, projectKey string, name string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // DeleteTagExecutes the request + DeleteTagRequest(ctx context.Context, projectKey string, name string, repositorySlug string) RepositoryAPIDeleteTagRequest + + /* + DeleteWebhook1 Delete webhook + */ + DeleteWebhook1(ctx context.Context, projectKey string, webhookId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // DeleteWebhook1Executes the request + DeleteWebhook1Request(ctx context.Context, projectKey string, webhookId string, repositorySlug string) RepositoryAPIDeleteWebhook1Request + + /* + DisableHook1 Disable repository hook + */ + DisableHook1(ctx context.Context, projectKey string, hookKey string, repositorySlug string) (RestRepositoryHook, aurestclientapi.ParsedResponse, error) + + // DisableHook1Executes the request + // @return RestRepositoryHook + DisableHook1Request(ctx context.Context, projectKey string, hookKey string, repositorySlug string) RepositoryAPIDisableHook1Request + + /* + EditFile Edit file + */ + EditFile(ctx context.Context, path string, projectKey string, repositorySlug string, exampleMultipartFormData ExampleMultipartFormData) (RestCommit, aurestclientapi.ParsedResponse, error) + + // EditFileExecutes the request + // @return RestCommit + EditFileRequest(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIEditFileRequest + + /* + EnableHook1 Enable repository hook + */ + EnableHook1(ctx context.Context, projectKey string, hookKey string, repositorySlug string) (RestRepositoryHook, aurestclientapi.ParsedResponse, error) + + // EnableHook1Executes the request + // @return RestRepositoryHook + EnableHook1Request(ctx context.Context, projectKey string, hookKey string, repositorySlug string) RepositoryAPIEnableHook1Request + + /* + FindBranches Get branches with ref change activities for repository + */ + FindBranches(ctx context.Context, projectKey string, repositorySlug string, filterText string, start float32, limit float32) (FindByCommit200Response, aurestclientapi.ParsedResponse, error) + + // FindBranchesExecutes the request + // @return FindByCommit200Response + FindBranchesRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIFindBranchesRequest + + /* + FindByCommit Get branch + */ + FindByCommit(ctx context.Context, projectKey string, commitId string, repositorySlug string, start float32, limit float32) (FindByCommit200Response, aurestclientapi.ParsedResponse, error) + + // FindByCommitExecutes the request + // @return FindByCommit200Response + FindByCommitRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIFindByCommitRequest + + /* + FindWebhooks1 Find webhooks + */ + FindWebhooks1(ctx context.Context, projectKey string, repositorySlug string, event string, statistics bool) (aurestclientapi.ParsedResponse, error) + + // FindWebhooks1Executes the request + FindWebhooks1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIFindWebhooks1Request + + /* + Get5 Get pull request auto-merge settings + */ + Get5(ctx context.Context, projectKey string, repositorySlug string) (RestAutoMergeRestrictedSettings, aurestclientapi.ParsedResponse, error) + + // Get5Executes the request + // @return RestAutoMergeRestrictedSettings + Get5Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGet5Request + + /* + GetAllLabelsForRepository Get repository labels + */ + GetAllLabelsForRepository(ctx context.Context, projectKey string, repositorySlug string) (RestLabel, aurestclientapi.ParsedResponse, error) + + // GetAllLabelsForRepositoryExecutes the request + // @return RestLabel + GetAllLabelsForRepositoryRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetAllLabelsForRepositoryRequest + + /* + GetArchive Stream archive of repository + */ + GetArchive(ctx context.Context, projectKey string, repositorySlug string, path string, filename string, at string, prefix string, format string) (aurestclientapi.ParsedResponse, error) + + // GetArchiveExecutes the request + GetArchiveRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetArchiveRequest + + /* + GetAttachment Get an attachment + */ + GetAttachment(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // GetAttachmentExecutes the request + GetAttachmentRequest(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) RepositoryAPIGetAttachmentRequest + + /* + GetAttachmentMetadata Get attachment metadata + */ + GetAttachmentMetadata(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) (RestAttachmentMetadata, aurestclientapi.ParsedResponse, error) + + // GetAttachmentMetadataExecutes the request + // @return RestAttachmentMetadata + GetAttachmentMetadataRequest(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) RepositoryAPIGetAttachmentMetadataRequest + + /* + GetAutoDeclineSettings1 Get auto decline settings + */ + GetAutoDeclineSettings1(ctx context.Context, projectKey string, repositorySlug string) (RestAutoDeclineSettings, aurestclientapi.ParsedResponse, error) + + // GetAutoDeclineSettings1Executes the request + // @return RestAutoDeclineSettings + GetAutoDeclineSettings1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetAutoDeclineSettings1Request + + /* + GetBranches Find branches + */ + GetBranches(ctx context.Context, projectKey string, repositorySlug string, boostMatches bool, orderBy string, details bool, filterText string, base string, start float32, limit float32) (GetBranches200Response, aurestclientapi.ParsedResponse, error) + + // GetBranchesExecutes the request + // @return GetBranches200Response + GetBranchesRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetBranchesRequest + + /* + GetChanges Get changes in commit + */ + GetChanges(ctx context.Context, projectKey string, commitId string, repositorySlug string, withComments string, since string, start float32, limit float32) (GetChanges1200Response, aurestclientapi.ParsedResponse, error) + + // GetChangesExecutes the request + // @return GetChanges1200Response + GetChangesRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIGetChangesRequest + + /* + GetChanges1 Get changes made in commit + */ + GetChanges1(ctx context.Context, projectKey string, repositorySlug string, until string, since string, start float32, limit float32) (GetChanges1200Response, aurestclientapi.ParsedResponse, error) + + // GetChanges1Executes the request + // @return GetChanges1200Response + GetChanges1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetChanges1Request + + /* + GetComment Get a commit comment + */ + GetComment(ctx context.Context, projectKey string, commentId string, commitId string, repositorySlug string) (RestComment, aurestclientapi.ParsedResponse, error) + + // GetCommentExecutes the request + // @return RestComment + GetCommentRequest(ctx context.Context, projectKey string, commentId string, commitId string, repositorySlug string) RepositoryAPIGetCommentRequest + + /* + GetComments Search for commit comments + */ + GetComments(ctx context.Context, projectKey string, commitId string, repositorySlug string, path string, since string, start float32, limit float32) (GetComments200Response, aurestclientapi.ParsedResponse, error) + + // GetCommentsExecutes the request + // @return GetComments200Response + GetCommentsRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIGetCommentsRequest + + /* + GetCommit Get commit by ID + */ + GetCommit(ctx context.Context, projectKey string, commitId string, repositorySlug string, path string) (RestCommit, aurestclientapi.ParsedResponse, error) + + // GetCommitExecutes the request + // @return RestCommit + GetCommitRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIGetCommitRequest + + /* + GetCommits Get commits + */ + GetCommits(ctx context.Context, projectKey string, repositorySlug string, avatarScheme string, path string, withCounts string, followRenames string, until string, avatarSize string, since string, merges string, ignoreMissing string, start float32, limit float32) (GetCommits200Response, aurestclientapi.ParsedResponse, error) + + // GetCommitsExecutes the request + // @return GetCommits200Response + GetCommitsRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetCommitsRequest + + /* + GetConfigurations1 Get hook scripts + */ + GetConfigurations1(ctx context.Context, projectKey string, repositorySlug string, start float32, limit float32) (GetConfigurations200Response, aurestclientapi.ParsedResponse, error) + + // GetConfigurations1Executes the request + // @return GetConfigurations200Response + GetConfigurations1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetConfigurations1Request + + /* + GetContent Get file content at revision + */ + GetContent(ctx context.Context, projectKey string, repositorySlug string, noContent string, at string, size string, blame string, type_ string) (aurestclientapi.ParsedResponse, error) + + // GetContentExecutes the request + GetContentRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetContentRequest + + /* + GetContent1 Get file content + */ + GetContent1(ctx context.Context, path string, projectKey string, repositorySlug string, noContent string, at string, size string, blame string, type_ string) (GetContent1200Response, aurestclientapi.ParsedResponse, error) + + // GetContent1Executes the request + // @return GetContent1200Response + GetContent1Request(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIGetContent1Request + + /* + GetDefaultBranch1 Get default branch + Deprecated + */ + GetDefaultBranch1(ctx context.Context, projectKey string, repositorySlug string) (RestBranch, aurestclientapi.ParsedResponse, error) + + // GetDefaultBranch1Executes the request + // @return RestBranch + // Deprecated + GetDefaultBranch1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetDefaultBranch1Request + + /* + GetLatestInvocation1 Get last webhook invocation details + */ + GetLatestInvocation1(ctx context.Context, projectKey string, webhookId string, repositorySlug string, event string, outcome string) (RestDetailedInvocation, aurestclientapi.ParsedResponse, error) + + // GetLatestInvocation1Executes the request + // @return RestDetailedInvocation + GetLatestInvocation1Request(ctx context.Context, projectKey string, webhookId string, repositorySlug string) RepositoryAPIGetLatestInvocation1Request + + /* + GetMergeBase Get the common ancestor between two commits + */ + GetMergeBase(ctx context.Context, projectKey string, commitId string, repositorySlug string, otherCommitId string) (RestCommit, aurestclientapi.ParsedResponse, error) + + // GetMergeBaseExecutes the request + // @return RestCommit + GetMergeBaseRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIGetMergeBaseRequest + + /* + GetPullRequestSettings1 Get pull request settings + */ + GetPullRequestSettings1(ctx context.Context, projectKey string, repositorySlug string) (RestRepositoryPullRequestSettings, aurestclientapi.ParsedResponse, error) + + // GetPullRequestSettings1Executes the request + // @return RestRepositoryPullRequestSettings + GetPullRequestSettings1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetPullRequestSettings1Request + + /* + GetRefChangeActivity Get ref change activity + */ + GetRefChangeActivity(ctx context.Context, projectKey string, repositorySlug string, ref string, start float32, limit float32) (GetRefChangeActivity200Response, aurestclientapi.ParsedResponse, error) + + // GetRefChangeActivityExecutes the request + // @return GetRefChangeActivity200Response + GetRefChangeActivityRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetRefChangeActivityRequest + + /* + GetRepositories1 Search for repositories + */ + GetRepositories1(ctx context.Context, archived string, projectname string, projectkey string, visibility string, name string, permission string, state string, start float32, limit float32) (GetRepositoriesRecentlyAccessed200Response, aurestclientapi.ParsedResponse, error) + + // GetRepositories1Executes the request + // @return GetRepositoriesRecentlyAccessed200Response + GetRepositories1Request(ctx context.Context) RepositoryAPIGetRepositories1Request + + /* + GetRepositoriesRecentlyAccessed Get recently accessed repositories + */ + GetRepositoriesRecentlyAccessed(ctx context.Context, permission string, start float32, limit float32) (GetRepositoriesRecentlyAccessed200Response, aurestclientapi.ParsedResponse, error) + + // GetRepositoriesRecentlyAccessedExecutes the request + // @return GetRepositoriesRecentlyAccessed200Response + GetRepositoriesRecentlyAccessedRequest(ctx context.Context) RepositoryAPIGetRepositoriesRecentlyAccessedRequest + + /* + GetRepositoryHook1 Get repository hook + */ + GetRepositoryHook1(ctx context.Context, projectKey string, hookKey string, repositorySlug string) (RestRepositoryHook, aurestclientapi.ParsedResponse, error) + + // GetRepositoryHook1Executes the request + // @return RestRepositoryHook + GetRepositoryHook1Request(ctx context.Context, projectKey string, hookKey string, repositorySlug string) RepositoryAPIGetRepositoryHook1Request + + /* + GetRepositoryHooks1 Get repository hooks + */ + GetRepositoryHooks1(ctx context.Context, projectKey string, repositorySlug string, type_ string, start float32, limit float32) (GetRepositoryHooks1200Response, aurestclientapi.ParsedResponse, error) + + // GetRepositoryHooks1Executes the request + // @return GetRepositoryHooks1200Response + GetRepositoryHooks1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetRepositoryHooks1Request + + /* + GetRestriction1 Get a ref restriction + */ + GetRestriction1(ctx context.Context, projectKey string, id string, repositorySlug string) (RestRefRestriction, aurestclientapi.ParsedResponse, error) + + // GetRestriction1Executes the request + // @return RestRefRestriction + GetRestriction1Request(ctx context.Context, projectKey string, id string, repositorySlug string) RepositoryAPIGetRestriction1Request + + /* + GetRestrictions1 Search for ref restrictions + */ + GetRestrictions1(ctx context.Context, projectKey string, repositorySlug string, matcherType string, matcherId string, type_ string, start float32, limit float32) (GetRestrictions1200Response, aurestclientapi.ParsedResponse, error) + + // GetRestrictions1Executes the request + // @return GetRestrictions1200Response + GetRestrictions1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetRestrictions1Request + + /* + GetSettings1 Get repository hook settings + */ + GetSettings1(ctx context.Context, projectKey string, hookKey string, repositorySlug string) (ExampleSettings, aurestclientapi.ParsedResponse, error) + + // GetSettings1Executes the request + // @return ExampleSettings + GetSettings1Request(ctx context.Context, projectKey string, hookKey string, repositorySlug string) RepositoryAPIGetSettings1Request + + /* + GetStatistics1 Get webhook statistics + */ + GetStatistics1(ctx context.Context, projectKey string, webhookId string, repositorySlug string, event string) (interface{}, aurestclientapi.ParsedResponse, error) + + // GetStatistics1Executes the request + // @return interface{} + GetStatistics1Request(ctx context.Context, projectKey string, webhookId string, repositorySlug string) RepositoryAPIGetStatistics1Request + + /* + GetStatisticsSummary1 Get webhook statistics summary + */ + GetStatisticsSummary1(ctx context.Context, projectKey string, webhookId string, repositorySlug string) (interface{}, aurestclientapi.ParsedResponse, error) + + // GetStatisticsSummary1Executes the request + // @return interface{} + GetStatisticsSummary1Request(ctx context.Context, projectKey string, webhookId string, repositorySlug string) RepositoryAPIGetStatisticsSummary1Request + + /* + GetStatus Get synchronization status + */ + GetStatus(ctx context.Context, projectKey string, repositorySlug string, at string) (RestRefSyncStatus, aurestclientapi.ParsedResponse, error) + + // GetStatusExecutes the request + // @return RestRefSyncStatus + GetStatusRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetStatusRequest + + /* + GetTag Get tag + */ + GetTag(ctx context.Context, projectKey string, name string, repositorySlug string) (RestTag, aurestclientapi.ParsedResponse, error) + + // GetTagExecutes the request + // @return RestTag + GetTagRequest(ctx context.Context, projectKey string, name string, repositorySlug string) RepositoryAPIGetTagRequest + + /* + GetTags Find tag + */ + GetTags(ctx context.Context, projectKey string, repositorySlug string, orderBy string, filterText string, start float32, limit float32) (GetTags200Response, aurestclientapi.ParsedResponse, error) + + // GetTagsExecutes the request + // @return GetTags200Response + GetTagsRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetTagsRequest + + /* + GetWebhook1 Get webhook + */ + GetWebhook1(ctx context.Context, projectKey string, webhookId string, repositorySlug string, statistics string) (RestWebhook, aurestclientapi.ParsedResponse, error) + + // GetWebhook1Executes the request + // @return RestWebhook + GetWebhook1Request(ctx context.Context, projectKey string, webhookId string, repositorySlug string) RepositoryAPIGetWebhook1Request + + /* + React React to a comment + */ + React(ctx context.Context, projectKey string, commentId string, commitId string, emoticon string, repositorySlug string) (RestUserReaction, aurestclientapi.ParsedResponse, error) + + // ReactExecutes the request + // @return RestUserReaction + ReactRequest(ctx context.Context, projectKey string, commentId string, commitId string, emoticon string, repositorySlug string) RepositoryAPIReactRequest + + /* + RemoveConfiguration1 Remove a hook script + */ + RemoveConfiguration1(ctx context.Context, projectKey string, scriptId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // RemoveConfiguration1Executes the request + RemoveConfiguration1Request(ctx context.Context, projectKey string, scriptId string, repositorySlug string) RepositoryAPIRemoveConfiguration1Request + + /* + RemoveLabel Remove repository label + */ + RemoveLabel(ctx context.Context, projectKey string, labelName string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // RemoveLabelExecutes the request + RemoveLabelRequest(ctx context.Context, projectKey string, labelName string, repositorySlug string) RepositoryAPIRemoveLabelRequest + + /* + SaveAttachmentMetadata Save attachment metadata + */ + SaveAttachmentMetadata(ctx context.Context, projectKey string, attachmentId string, repositorySlug string, body string) (aurestclientapi.ParsedResponse, error) + + // SaveAttachmentMetadataExecutes the request + SaveAttachmentMetadataRequest(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) RepositoryAPISaveAttachmentMetadataRequest + + /* + SearchWebhooks Search webhooks + */ + SearchWebhooks(ctx context.Context, projectKey string, repositorySlug string, scopeType string, event string, statistics bool) (aurestclientapi.ParsedResponse, error) + + // SearchWebhooksExecutes the request + SearchWebhooksRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPISearchWebhooksRequest + + /* + Set1 Create or update the pull request auto-merge settings + */ + Set1(ctx context.Context, projectKey string, repositorySlug string, restAutoMergeSettingsRequest RestAutoMergeSettingsRequest) (RestAutoMergeRestrictedSettings, aurestclientapi.ParsedResponse, error) + + // Set1Executes the request + // @return RestAutoMergeRestrictedSettings + Set1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPISet1Request + + /* + SetAutoDeclineSettings1 Create auto decline settings + */ + SetAutoDeclineSettings1(ctx context.Context, projectKey string, repositorySlug string, restAutoDeclineSettingsRequest RestAutoDeclineSettingsRequest) (RestAutoDeclineSettings, aurestclientapi.ParsedResponse, error) + + // SetAutoDeclineSettings1Executes the request + // @return RestAutoDeclineSettings + SetAutoDeclineSettings1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPISetAutoDeclineSettings1Request + + /* + SetConfiguration1 Create/update a hook script + */ + SetConfiguration1(ctx context.Context, projectKey string, scriptId string, repositorySlug string, restHookScriptTriggers RestHookScriptTriggers) (RestHookScriptConfig, aurestclientapi.ParsedResponse, error) + + // SetConfiguration1Executes the request + // @return RestHookScriptConfig + SetConfiguration1Request(ctx context.Context, projectKey string, scriptId string, repositorySlug string) RepositoryAPISetConfiguration1Request + + /* + SetDefaultBranch1 Update default branch + Deprecated + */ + SetDefaultBranch1(ctx context.Context, projectKey string, repositorySlug string, restBranch RestBranch) (aurestclientapi.ParsedResponse, error) + + // SetDefaultBranch1Executes the request + // Deprecated + SetDefaultBranch1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPISetDefaultBranch1Request + + /* + SetEnabled Disable synchronization + */ + SetEnabled(ctx context.Context, projectKey string, repositorySlug string, restRefSyncStatus RestRefSyncStatus) (RestRefSyncStatus, aurestclientapi.ParsedResponse, error) + + // SetEnabledExecutes the request + // @return RestRefSyncStatus + SetEnabledRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPISetEnabledRequest + + /* + SetSettings1 Update repository hook settings + */ + SetSettings1(ctx context.Context, projectKey string, hookKey string, repositorySlug string, exampleSettings ExampleSettings) (ExampleSettings, aurestclientapi.ParsedResponse, error) + + // SetSettings1Executes the request + // @return ExampleSettings + SetSettings1Request(ctx context.Context, projectKey string, hookKey string, repositorySlug string) RepositoryAPISetSettings1Request + + /* + Stream Stream files + */ + Stream(ctx context.Context, projectKey string, repositorySlug string, at string) (ExampleFiles, aurestclientapi.ParsedResponse, error) + + // StreamExecutes the request + // @return ExampleFiles + StreamRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIStreamRequest + + /* + Stream1 Stream files with last modified commit in path + */ + Stream1(ctx context.Context, path string, projectKey string, repositorySlug string, at string) (ExampleFiles, aurestclientapi.ParsedResponse, error) + + // Stream1Executes the request + // @return ExampleFiles + Stream1Request(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIStream1Request + + /* + StreamChanges Compare commits + */ + StreamChanges(ctx context.Context, projectKey string, repositorySlug string, fromRepo string, from string, to string, start float32, limit float32) (GetChanges1200Response, aurestclientapi.ParsedResponse, error) + + // StreamChangesExecutes the request + // @return GetChanges1200Response + StreamChangesRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIStreamChangesRequest + + /* + StreamCommits Get accessible commits + */ + StreamCommits(ctx context.Context, projectKey string, repositorySlug string, fromRepo string, from string, to string, start float32, limit float32) (GetCommits200Response, aurestclientapi.ParsedResponse, error) + + // StreamCommitsExecutes the request + // @return GetCommits200Response + StreamCommitsRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIStreamCommitsRequest + + /* + StreamDiff Get diff between revisions + */ + StreamDiff(ctx context.Context, commitId string, repositorySlug string, path string, projectKey string, srcPath string, avatarSize string, filter string, avatarScheme string, contextLines string, autoSrcPath string, whitespace string, withComments string, since string) (RestDiff, aurestclientapi.ParsedResponse, error) + + // StreamDiffExecutes the request + // @return RestDiff + StreamDiffRequest(ctx context.Context, commitId string, repositorySlug string, path string, projectKey string) RepositoryAPIStreamDiffRequest + + /* + StreamDiff1 Get diff between commits + */ + StreamDiff1(ctx context.Context, path string, projectKey string, repositorySlug string, contextLines string, fromRepo string, srcPath string, from string, to string, whitespace string, start float32, limit float32) (StreamDiff1200Response, aurestclientapi.ParsedResponse, error) + + // StreamDiff1Executes the request + // @return StreamDiff1200Response + StreamDiff1Request(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIStreamDiff1Request + + /* + StreamFiles Get files in directory + */ + StreamFiles(ctx context.Context, projectKey string, repositorySlug string, at string, start float32, limit float32) (StreamFiles200Response, aurestclientapi.ParsedResponse, error) + + // StreamFilesExecutes the request + // @return StreamFiles200Response + StreamFilesRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIStreamFilesRequest + + /* + StreamFiles1 Get files in directory + */ + StreamFiles1(ctx context.Context, path string, projectKey string, repositorySlug string, at string, start float32, limit float32) (StreamFiles200Response, aurestclientapi.ParsedResponse, error) + + // StreamFiles1Executes the request + // @return StreamFiles200Response + StreamFiles1Request(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIStreamFiles1Request + + /* + StreamPatch Get patch content at revision + */ + StreamPatch(ctx context.Context, projectKey string, repositorySlug string, until string, allAncestors string, since string) (aurestclientapi.ParsedResponse, error) + + // StreamPatchExecutes the request + StreamPatchRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIStreamPatchRequest + + /* + StreamRaw Get raw content of a file at revision + */ + StreamRaw(ctx context.Context, path string, projectKey string, repositorySlug string, at string, markup string, htmlEscape string, includeHeadingId string, hardwrap string) (aurestclientapi.ParsedResponse, error) + + // StreamRawExecutes the request + StreamRawRequest(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIStreamRawRequest + + /* + StreamRawDiff Get raw diff for path + */ + StreamRawDiff(ctx context.Context, projectKey string, repositorySlug string, contextLines string, srcPath string, until string, whitespace string, since string) (aurestclientapi.ParsedResponse, error) + + // StreamRawDiffExecutes the request + StreamRawDiffRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIStreamRawDiffRequest + + /* + StreamRawDiff1 Get raw diff for path + */ + StreamRawDiff1(ctx context.Context, path string, projectKey string, repositorySlug string, contextLines string, srcPath string, until string, whitespace string, since string) (aurestclientapi.ParsedResponse, error) + + // StreamRawDiff1Executes the request + StreamRawDiff1Request(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIStreamRawDiff1Request + + /* + Synchronize Manual synchronization + */ + Synchronize(ctx context.Context, projectKey string, repositorySlug string, restRefSyncRequest RestRefSyncRequest) (RestRejectedRef, aurestclientapi.ParsedResponse, error) + + // SynchronizeExecutes the request + // @return RestRejectedRef + SynchronizeRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPISynchronizeRequest + + /* + TestWebhook1 Test webhook + */ + TestWebhook1(ctx context.Context, projectKey string, repositorySlug string, restWebhookCredentials RestWebhookCredentials, webhookId int32, sslVerificationRequired string, url string) (interface{}, aurestclientapi.ParsedResponse, error) + + // TestWebhook1Executes the request + // @return interface{} + TestWebhook1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPITestWebhook1Request + + /* + UnReact Remove a reaction from comment + */ + UnReact(ctx context.Context, projectKey string, commentId string, commitId string, emoticon string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // UnReactExecutes the request + UnReactRequest(ctx context.Context, projectKey string, commentId string, commitId string, emoticon string, repositorySlug string) RepositoryAPIUnReactRequest + + /* + Unwatch Stop watching commit + */ + Unwatch(ctx context.Context, projectKey string, commitId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // UnwatchExecutes the request + UnwatchRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIUnwatchRequest + + /* + Unwatch2 Stop watching repository + */ + Unwatch2(ctx context.Context, projectKey string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // Unwatch2Executes the request + Unwatch2Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIUnwatch2Request + + /* + UpdateComment Update a commit comment + */ + UpdateComment(ctx context.Context, projectKey string, commentId string, commitId string, repositorySlug string, restComment RestComment) (RestComment, aurestclientapi.ParsedResponse, error) + + // UpdateCommentExecutes the request + // @return RestComment + UpdateCommentRequest(ctx context.Context, projectKey string, commentId string, commitId string, repositorySlug string) RepositoryAPIUpdateCommentRequest + + /* + UpdatePullRequestSettings1 Update pull request settings + */ + UpdatePullRequestSettings1(ctx context.Context, projectKey string, repositorySlug string, restRepositoryPullRequestSettings RestRepositoryPullRequestSettings) (RestRepositoryPullRequestSettings, aurestclientapi.ParsedResponse, error) + + // UpdatePullRequestSettings1Executes the request + // @return RestRepositoryPullRequestSettings + UpdatePullRequestSettings1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIUpdatePullRequestSettings1Request + + /* + UpdateWebhook1 Update webhook + */ + UpdateWebhook1(ctx context.Context, projectKey string, webhookId string, repositorySlug string, restWebhook RestWebhook) (RestWebhook, aurestclientapi.ParsedResponse, error) + + // UpdateWebhook1Executes the request + // @return RestWebhook + UpdateWebhook1Request(ctx context.Context, projectKey string, webhookId string, repositorySlug string) RepositoryAPIUpdateWebhook1Request + + /* + Watch Watch commit + */ + Watch(ctx context.Context, projectKey string, commitId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) + + // WatchExecutes the request + WatchRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIWatchRequest + + /* + Watch2 Watch repository + */ + Watch2(ctx context.Context, projectKey string, repositorySlug string, restRepository RestRepository) (aurestclientapi.ParsedResponse, error) + + // Watch2Executes the request + Watch2Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIWatch2Request +} + + type RepositoryAPIAddLabelRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restLabel *RestLabel +} + + // The label to apply +func (r *RepositoryAPIAddLabelRequest) RestLabel(restLabel RestLabel) *RepositoryAPIAddLabelRequest { + r.restLabel = &restLabel + return r +} + +func (r *RepositoryAPIAddLabelRequest) Execute() (RestLabel, aurestclientapi.ParsedResponse, error) { + return r.ApiService.AddLabelExecute(r) +} + +func (a *RepositoryAPIRepository) AddLabelRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIAddLabelRequest { + return RepositoryAPIAddLabelRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) AddLabelExecute(r *RepositoryAPIAddLabelRequest) (RestLabel, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/labels" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeAddLabelCall(r.ctx, requestURL, r.restLabel) +} + +func (a *RepositoryAPIRepository) AddLabel(ctx context.Context, projectKey string, repositorySlug string, restLabel RestLabel) (RestLabel, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/labels" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeAddLabelCall(ctx, requestURL, restLabel) +} + +func (a *RepositoryAPIRepository) makeAddLabelCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestLabel, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestLabel + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestLabel](&response) + if err == nil { + result = response.Body.(RestLabel) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPICreateBranchRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restBranchCreateRequest *RestBranchCreateRequest +} + +func (r *RepositoryAPICreateBranchRequest) RestBranchCreateRequest(restBranchCreateRequest RestBranchCreateRequest) *RepositoryAPICreateBranchRequest { + r.restBranchCreateRequest = &restBranchCreateRequest + return r +} + +func (r *RepositoryAPICreateBranchRequest) Execute() (RestBranch, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreateBranchExecute(r) +} + +func (a *RepositoryAPIRepository) CreateBranchRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPICreateBranchRequest { + return RepositoryAPICreateBranchRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) CreateBranchExecute(r *RepositoryAPICreateBranchRequest) (RestBranch, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-utils/latest/projects/{projectKey}/repos/{repositorySlug}/branches" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateBranchCall(r.ctx, requestURL, r.restBranchCreateRequest) +} + +func (a *RepositoryAPIRepository) CreateBranch(ctx context.Context, projectKey string, repositorySlug string, restBranchCreateRequest RestBranchCreateRequest) (RestBranch, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-utils/latest/projects/{projectKey}/repos/{repositorySlug}/branches" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateBranchCall(ctx, requestURL, restBranchCreateRequest) +} + +func (a *RepositoryAPIRepository) makeCreateBranchCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestBranch, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestBranch + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestBranch](&response) + if err == nil { + result = response.Body.(RestBranch) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPICreateBranchForRepositoryRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restCreateBranchRequest *RestCreateBranchRequest +} + + // The request to create a branch containing a <strong>name</strong>, <strong>startPoint</strong>, and optionally a <strong>message</strong> +func (r *RepositoryAPICreateBranchForRepositoryRequest) RestCreateBranchRequest(restCreateBranchRequest RestCreateBranchRequest) *RepositoryAPICreateBranchForRepositoryRequest { + r.restCreateBranchRequest = &restCreateBranchRequest + return r +} + +func (r *RepositoryAPICreateBranchForRepositoryRequest) Execute() (RestBranch, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreateBranchForRepositoryExecute(r) +} + +func (a *RepositoryAPIRepository) CreateBranchForRepositoryRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPICreateBranchForRepositoryRequest { + return RepositoryAPICreateBranchForRepositoryRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) CreateBranchForRepositoryExecute(r *RepositoryAPICreateBranchForRepositoryRequest) (RestBranch, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/branches" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateBranchForRepositoryCall(r.ctx, requestURL, r.restCreateBranchRequest) +} + +func (a *RepositoryAPIRepository) CreateBranchForRepository(ctx context.Context, projectKey string, repositorySlug string, restCreateBranchRequest RestCreateBranchRequest) (RestBranch, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/branches" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateBranchForRepositoryCall(ctx, requestURL, restCreateBranchRequest) +} + +func (a *RepositoryAPIRepository) makeCreateBranchForRepositoryCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestBranch, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestBranch + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestBranch](&response) + if err == nil { + result = response.Body.(RestBranch) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPICreateCommentRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commitId string + repositorySlug string + since *string + restComment *RestComment +} + + // For a merge commit, a parent can be provided to specify which diff the comments should be on. For a commit range, a sinceId can be provided to specify where the comments should be anchored from. +func (r *RepositoryAPICreateCommentRequest) Since(since string) *RepositoryAPICreateCommentRequest { + r.since = &since + return r +} + + // the comment +func (r *RepositoryAPICreateCommentRequest) RestComment(restComment RestComment) *RepositoryAPICreateCommentRequest { + r.restComment = &restComment + return r +} + +func (r *RepositoryAPICreateCommentRequest) Execute() (RestComment, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreateCommentExecute(r) +} + +func (a *RepositoryAPIRepository) CreateCommentRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPICreateCommentRequest { + return RepositoryAPICreateCommentRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) CreateCommentExecute(r *RepositoryAPICreateCommentRequest) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.since!=nil { + withUrlQueryParam(requestURL, "since", *r.since) + } + return a.makeCreateCommentCall(r.ctx, requestURL, r.restComment) +} + +func (a *RepositoryAPIRepository) CreateComment(ctx context.Context, projectKey string, commitId string, repositorySlug string, restComment RestComment, since string) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "since", since) + return a.makeCreateCommentCall(ctx, requestURL, restComment) +} + +func (a *RepositoryAPIRepository) makeCreateCommentCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestComment, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestComment + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestComment](&response) + if err == nil { + result = response.Body.(RestComment) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPICreateRestrictions1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restRestrictionRequest *[]RestRestrictionRequest +} + + // The request containing a list of the details of the restrictions to create. +func (r *RepositoryAPICreateRestrictions1Request) RestRestrictionRequest(restRestrictionRequest []RestRestrictionRequest) *RepositoryAPICreateRestrictions1Request { + r.restRestrictionRequest = &restRestrictionRequest + return r +} + +func (r *RepositoryAPICreateRestrictions1Request) Execute() (RestRefRestriction, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreateRestrictions1Execute(r) +} + +func (a *RepositoryAPIRepository) CreateRestrictions1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPICreateRestrictions1Request { + return RepositoryAPICreateRestrictions1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) CreateRestrictions1Execute(r *RepositoryAPICreateRestrictions1Request) (RestRefRestriction, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-permissions/latest/projects/{projectKey}/repos/{repositorySlug}/restrictions" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateRestrictions1Call(r.ctx, requestURL, r.restRestrictionRequest) +} + +func (a *RepositoryAPIRepository) CreateRestrictions1(ctx context.Context, projectKey string, repositorySlug string, restRestrictionRequest []RestRestrictionRequest) (RestRefRestriction, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-permissions/latest/projects/{projectKey}/repos/{repositorySlug}/restrictions" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateRestrictions1Call(ctx, requestURL, restRestrictionRequest) +} + +func (a *RepositoryAPIRepository) makeCreateRestrictions1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestRefRestriction, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestRefRestriction + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestRefRestriction](&response) + if err == nil { + result = response.Body.(RestRefRestriction) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPICreateTagRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restGitTagCreateRequest *RestGitTagCreateRequest +} + + // The create git tag request. +func (r *RepositoryAPICreateTagRequest) RestGitTagCreateRequest(restGitTagCreateRequest RestGitTagCreateRequest) *RepositoryAPICreateTagRequest { + r.restGitTagCreateRequest = &restGitTagCreateRequest + return r +} + +func (r *RepositoryAPICreateTagRequest) Execute() (RestTag, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreateTagExecute(r) +} + +func (a *RepositoryAPIRepository) CreateTagRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPICreateTagRequest { + return RepositoryAPICreateTagRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) CreateTagExecute(r *RepositoryAPICreateTagRequest) (RestTag, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/git/latest/projects/{projectKey}/repos/{repositorySlug}/tags" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateTagCall(r.ctx, requestURL, r.restGitTagCreateRequest) +} + +func (a *RepositoryAPIRepository) CreateTag(ctx context.Context, projectKey string, repositorySlug string, restGitTagCreateRequest RestGitTagCreateRequest) (RestTag, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/git/latest/projects/{projectKey}/repos/{repositorySlug}/tags" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateTagCall(ctx, requestURL, restGitTagCreateRequest) +} + +func (a *RepositoryAPIRepository) makeCreateTagCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestTag, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestTag + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestTag](&response) + if err == nil { + result = response.Body.(RestTag) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPICreateTagForRepositoryRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restCreateTagRequest *RestCreateTagRequest +} + + // The request to create a tag containing a <strong>name</strong>, <strong>startPoint</strong>, and optionally a <strong>message</strong> +func (r *RepositoryAPICreateTagForRepositoryRequest) RestCreateTagRequest(restCreateTagRequest RestCreateTagRequest) *RepositoryAPICreateTagForRepositoryRequest { + r.restCreateTagRequest = &restCreateTagRequest + return r +} + +func (r *RepositoryAPICreateTagForRepositoryRequest) Execute() (RestTag, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreateTagForRepositoryExecute(r) +} + +func (a *RepositoryAPIRepository) CreateTagForRepositoryRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPICreateTagForRepositoryRequest { + return RepositoryAPICreateTagForRepositoryRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) CreateTagForRepositoryExecute(r *RepositoryAPICreateTagForRepositoryRequest) (RestTag, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/tags" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateTagForRepositoryCall(r.ctx, requestURL, r.restCreateTagRequest) +} + +func (a *RepositoryAPIRepository) CreateTagForRepository(ctx context.Context, projectKey string, repositorySlug string, restCreateTagRequest RestCreateTagRequest) (RestTag, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/tags" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateTagForRepositoryCall(ctx, requestURL, restCreateTagRequest) +} + +func (a *RepositoryAPIRepository) makeCreateTagForRepositoryCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestTag, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestTag + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestTag](&response) + if err == nil { + result = response.Body.(RestTag) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPICreateWebhook1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restWebhook *RestWebhook +} + + // The webhook to be created for this repository. +func (r *RepositoryAPICreateWebhook1Request) RestWebhook(restWebhook RestWebhook) *RepositoryAPICreateWebhook1Request { + r.restWebhook = &restWebhook + return r +} + +func (r *RepositoryAPICreateWebhook1Request) Execute() (RestWebhook, aurestclientapi.ParsedResponse, error) { + return r.ApiService.CreateWebhook1Execute(r) +} + +func (a *RepositoryAPIRepository) CreateWebhook1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPICreateWebhook1Request { + return RepositoryAPICreateWebhook1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) CreateWebhook1Execute(r *RepositoryAPICreateWebhook1Request) (RestWebhook, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateWebhook1Call(r.ctx, requestURL, r.restWebhook) +} + +func (a *RepositoryAPIRepository) CreateWebhook1(ctx context.Context, projectKey string, repositorySlug string, restWebhook RestWebhook) (RestWebhook, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeCreateWebhook1Call(ctx, requestURL, restWebhook) +} + +func (a *RepositoryAPIRepository) makeCreateWebhook1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestWebhook, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestWebhook + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestWebhook](&response) + if err == nil { + result = response.Body.(RestWebhook) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIDelete5Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string +} + +func (r *RepositoryAPIDelete5Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.Delete5Execute(r) +} + +func (a *RepositoryAPIRepository) Delete5Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIDelete5Request { + return RepositoryAPIDelete5Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) Delete5Execute(r *RepositoryAPIDelete5Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDelete5Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) Delete5(ctx context.Context, projectKey string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDelete5Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeDelete5Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 403 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIDeleteAttachmentRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + attachmentId string + repositorySlug string +} + +func (r *RepositoryAPIDeleteAttachmentRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteAttachmentExecute(r) +} + +func (a *RepositoryAPIRepository) DeleteAttachmentRequest(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) RepositoryAPIDeleteAttachmentRequest { + return RepositoryAPIDeleteAttachmentRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + attachmentId: attachmentId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) DeleteAttachmentExecute(r *RepositoryAPIDeleteAttachmentRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/attachments/{attachmentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{attachmentId}", urlUtil.PathEscape(r.attachmentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteAttachmentCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) DeleteAttachment(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/attachments/{attachmentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{attachmentId}", urlUtil.PathEscape(attachmentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteAttachmentCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeDeleteAttachmentCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIDeleteAttachmentMetadataRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + attachmentId string + repositorySlug string +} + +func (r *RepositoryAPIDeleteAttachmentMetadataRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteAttachmentMetadataExecute(r) +} + +func (a *RepositoryAPIRepository) DeleteAttachmentMetadataRequest(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) RepositoryAPIDeleteAttachmentMetadataRequest { + return RepositoryAPIDeleteAttachmentMetadataRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + attachmentId: attachmentId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) DeleteAttachmentMetadataExecute(r *RepositoryAPIDeleteAttachmentMetadataRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/attachments/{attachmentId}/metadata" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{attachmentId}", urlUtil.PathEscape(r.attachmentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteAttachmentMetadataCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) DeleteAttachmentMetadata(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/attachments/{attachmentId}/metadata" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{attachmentId}", urlUtil.PathEscape(attachmentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteAttachmentMetadataCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeDeleteAttachmentMetadataCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIDeleteAutoDeclineSettings1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string +} + +func (r *RepositoryAPIDeleteAutoDeclineSettings1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteAutoDeclineSettings1Execute(r) +} + +func (a *RepositoryAPIRepository) DeleteAutoDeclineSettings1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIDeleteAutoDeclineSettings1Request { + return RepositoryAPIDeleteAutoDeclineSettings1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) DeleteAutoDeclineSettings1Execute(r *RepositoryAPIDeleteAutoDeclineSettings1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-decline" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteAutoDeclineSettings1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) DeleteAutoDeclineSettings1(ctx context.Context, projectKey string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-decline" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteAutoDeclineSettings1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeDeleteAutoDeclineSettings1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIDeleteBranchRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restBranchDeleteRequest *RestBranchDeleteRequest +} + + // Branch delete request +func (r *RepositoryAPIDeleteBranchRequest) RestBranchDeleteRequest(restBranchDeleteRequest RestBranchDeleteRequest) *RepositoryAPIDeleteBranchRequest { + r.restBranchDeleteRequest = &restBranchDeleteRequest + return r +} + +func (r *RepositoryAPIDeleteBranchRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteBranchExecute(r) +} + +func (a *RepositoryAPIRepository) DeleteBranchRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIDeleteBranchRequest { + return RepositoryAPIDeleteBranchRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) DeleteBranchExecute(r *RepositoryAPIDeleteBranchRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-utils/latest/projects/{projectKey}/repos/{repositorySlug}/branches" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteBranchCall(r.ctx, requestURL, r.restBranchDeleteRequest) +} + +func (a *RepositoryAPIRepository) DeleteBranch(ctx context.Context, projectKey string, repositorySlug string, restBranchDeleteRequest RestBranchDeleteRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-utils/latest/projects/{projectKey}/repos/{repositorySlug}/branches" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteBranchCall(ctx, requestURL, restBranchDeleteRequest) +} + +func (a *RepositoryAPIRepository) makeDeleteBranchCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIDeleteCommentRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commentId string + commitId string + repositorySlug string + version *string +} + + // The expected version of the comment. This must match the server's version of the comment or the delete will fail. To determine the current version of the comment, the comment should be fetched from the server prior to the delete. Look for the 'version' attribute in the returned JSON structure. +func (r *RepositoryAPIDeleteCommentRequest) Version(version string) *RepositoryAPIDeleteCommentRequest { + r.version = &version + return r +} + +func (r *RepositoryAPIDeleteCommentRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteCommentExecute(r) +} + +func (a *RepositoryAPIRepository) DeleteCommentRequest(ctx context.Context, projectKey string, commentId string, commitId string, repositorySlug string) RepositoryAPIDeleteCommentRequest { + return RepositoryAPIDeleteCommentRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) DeleteCommentExecute(r *RepositoryAPIDeleteCommentRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.version!=nil { + withUrlQueryParam(requestURL, "version", *r.version) + } + return a.makeDeleteCommentCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) DeleteComment(ctx context.Context, projectKey string, commentId string, commitId string, repositorySlug string, version string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "version", version) + return a.makeDeleteCommentCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeDeleteCommentCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIDeleteRepositoryHookRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + hookKey string + repositorySlug string +} + +func (r *RepositoryAPIDeleteRepositoryHookRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteRepositoryHookExecute(r) +} + +func (a *RepositoryAPIRepository) DeleteRepositoryHookRequest(ctx context.Context, projectKey string, hookKey string, repositorySlug string) RepositoryAPIDeleteRepositoryHookRequest { + return RepositoryAPIDeleteRepositoryHookRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + hookKey: hookKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) DeleteRepositoryHookExecute(r *RepositoryAPIDeleteRepositoryHookRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{hookKey}", urlUtil.PathEscape(r.hookKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteRepositoryHookCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) DeleteRepositoryHook(ctx context.Context, projectKey string, hookKey string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{hookKey}", urlUtil.PathEscape(hookKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteRepositoryHookCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeDeleteRepositoryHookCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIDeleteRestriction1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + id string + repositorySlug string +} + +func (r *RepositoryAPIDeleteRestriction1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteRestriction1Execute(r) +} + +func (a *RepositoryAPIRepository) DeleteRestriction1Request(ctx context.Context, projectKey string, id string, repositorySlug string) RepositoryAPIDeleteRestriction1Request { + return RepositoryAPIDeleteRestriction1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) DeleteRestriction1Execute(r *RepositoryAPIDeleteRestriction1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-permissions/latest/projects/{projectKey}/repos/{repositorySlug}/restrictions/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(r.id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteRestriction1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) DeleteRestriction1(ctx context.Context, projectKey string, id string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-permissions/latest/projects/{projectKey}/repos/{repositorySlug}/restrictions/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteRestriction1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeDeleteRestriction1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIDeleteTagRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + name string + repositorySlug string +} + +func (r *RepositoryAPIDeleteTagRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteTagExecute(r) +} + +func (a *RepositoryAPIRepository) DeleteTagRequest(ctx context.Context, projectKey string, name string, repositorySlug string) RepositoryAPIDeleteTagRequest { + return RepositoryAPIDeleteTagRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + name: name, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) DeleteTagExecute(r *RepositoryAPIDeleteTagRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/git/latest/projects/{projectKey}/repos/{repositorySlug}/tags/{name}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{name}", urlUtil.PathEscape(r.name)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteTagCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) DeleteTag(ctx context.Context, projectKey string, name string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/git/latest/projects/{projectKey}/repos/{repositorySlug}/tags/{name}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{name}", urlUtil.PathEscape(name)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteTagCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeDeleteTagCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIDeleteWebhook1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + webhookId string + repositorySlug string +} + +func (r *RepositoryAPIDeleteWebhook1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.DeleteWebhook1Execute(r) +} + +func (a *RepositoryAPIRepository) DeleteWebhook1Request(ctx context.Context, projectKey string, webhookId string, repositorySlug string) RepositoryAPIDeleteWebhook1Request { + return RepositoryAPIDeleteWebhook1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + webhookId: webhookId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) DeleteWebhook1Execute(r *RepositoryAPIDeleteWebhook1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{webhookId}", urlUtil.PathEscape(r.webhookId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteWebhook1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) DeleteWebhook1(ctx context.Context, projectKey string, webhookId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{webhookId}", urlUtil.PathEscape(webhookId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDeleteWebhook1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeDeleteWebhook1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIDisableHook1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + hookKey string + repositorySlug string +} + +func (r *RepositoryAPIDisableHook1Request) Execute() (RestRepositoryHook, aurestclientapi.ParsedResponse, error) { + return r.ApiService.DisableHook1Execute(r) +} + +func (a *RepositoryAPIRepository) DisableHook1Request(ctx context.Context, projectKey string, hookKey string, repositorySlug string) RepositoryAPIDisableHook1Request { + return RepositoryAPIDisableHook1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + hookKey: hookKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) DisableHook1Execute(r *RepositoryAPIDisableHook1Request) (RestRepositoryHook, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}/enabled" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{hookKey}", urlUtil.PathEscape(r.hookKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDisableHook1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) DisableHook1(ctx context.Context, projectKey string, hookKey string, repositorySlug string) (RestRepositoryHook, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}/enabled" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{hookKey}", urlUtil.PathEscape(hookKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeDisableHook1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeDisableHook1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestRepositoryHook, aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + var result RestRepositoryHook + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestRepositoryHook](&response) + if err == nil { + result = response.Body.(RestRepositoryHook) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIEditFileRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + path string + projectKey string + repositorySlug string + exampleMultipartFormData *ExampleMultipartFormData +} + + // The multipart form data containing the file +func (r *RepositoryAPIEditFileRequest) ExampleMultipartFormData(exampleMultipartFormData ExampleMultipartFormData) *RepositoryAPIEditFileRequest { + r.exampleMultipartFormData = &exampleMultipartFormData + return r +} + +func (r *RepositoryAPIEditFileRequest) Execute() (RestCommit, aurestclientapi.ParsedResponse, error) { + return r.ApiService.EditFileExecute(r) +} + +func (a *RepositoryAPIRepository) EditFileRequest(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIEditFileRequest { + return RepositoryAPIEditFileRequest{ + ApiService: a, + ctx: ctx, + path: path, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) EditFileExecute(r *RepositoryAPIEditFileRequest) (RestCommit, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/browse/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(r.path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeEditFileCall(r.ctx, requestURL, r.exampleMultipartFormData) +} + +func (a *RepositoryAPIRepository) EditFile(ctx context.Context, path string, projectKey string, repositorySlug string, exampleMultipartFormData ExampleMultipartFormData) (RestCommit, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/browse/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeEditFileCall(ctx, requestURL, exampleMultipartFormData) +} + +func (a *RepositoryAPIRepository) makeEditFileCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestCommit, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestCommit + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 403 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestCommit](&response) + if err == nil { + result = response.Body.(RestCommit) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIEnableHook1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + hookKey string + repositorySlug string + contentLength *string +} + + // The content length. +func (r *RepositoryAPIEnableHook1Request) ContentLength(contentLength string) *RepositoryAPIEnableHook1Request { + r.contentLength = &contentLength + return r +} + +func (r *RepositoryAPIEnableHook1Request) Execute() (RestRepositoryHook, aurestclientapi.ParsedResponse, error) { + return r.ApiService.EnableHook1Execute(r) +} + +func (a *RepositoryAPIRepository) EnableHook1Request(ctx context.Context, projectKey string, hookKey string, repositorySlug string) RepositoryAPIEnableHook1Request { + return RepositoryAPIEnableHook1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + hookKey: hookKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) EnableHook1Execute(r *RepositoryAPIEnableHook1Request) (RestRepositoryHook, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}/enabled" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{hookKey}", urlUtil.PathEscape(r.hookKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeEnableHook1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) EnableHook1(ctx context.Context, projectKey string, hookKey string, repositorySlug string) (RestRepositoryHook, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}/enabled" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{hookKey}", urlUtil.PathEscape(hookKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeEnableHook1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeEnableHook1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestRepositoryHook, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestRepositoryHook + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestRepositoryHook](&response) + if err == nil { + result = response.Body.(RestRepositoryHook) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIFindBranchesRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + filterText *string + start *float32 + limit *float32 +} + + // (optional) Partial match for a ref ID to filter minimal refs for +func (r *RepositoryAPIFindBranchesRequest) FilterText(filterText string) *RepositoryAPIFindBranchesRequest { + r.filterText = &filterText + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIFindBranchesRequest) Start(start float32) *RepositoryAPIFindBranchesRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIFindBranchesRequest) Limit(limit float32) *RepositoryAPIFindBranchesRequest { + r.limit = &limit + return r +} + +func (r *RepositoryAPIFindBranchesRequest) Execute() (FindByCommit200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.FindBranchesExecute(r) +} + +func (a *RepositoryAPIRepository) FindBranchesRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIFindBranchesRequest { + return RepositoryAPIFindBranchesRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) FindBranchesExecute(r *RepositoryAPIFindBranchesRequest) (FindByCommit200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/ref-change-activities/branches" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.filterText!=nil { + withUrlQueryParam(requestURL, "filterText", *r.filterText) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeFindBranchesCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) FindBranches(ctx context.Context, projectKey string, repositorySlug string, filterText string, start float32, limit float32) (FindByCommit200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/ref-change-activities/branches" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "filterText", filterText) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeFindBranchesCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeFindBranchesCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (FindByCommit200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result FindByCommit200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[FindByCommit200Response](&response) + if err == nil { + result = response.Body.(FindByCommit200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIFindByCommitRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commitId string + repositorySlug string + start *float32 + limit *float32 +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIFindByCommitRequest) Start(start float32) *RepositoryAPIFindByCommitRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIFindByCommitRequest) Limit(limit float32) *RepositoryAPIFindByCommitRequest { + r.limit = &limit + return r +} + +func (r *RepositoryAPIFindByCommitRequest) Execute() (FindByCommit200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.FindByCommitExecute(r) +} + +func (a *RepositoryAPIRepository) FindByCommitRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIFindByCommitRequest { + return RepositoryAPIFindByCommitRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) FindByCommitExecute(r *RepositoryAPIFindByCommitRequest) (FindByCommit200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-utils/latest/projects/{projectKey}/repos/{repositorySlug}/branches/info/{commitId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeFindByCommitCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) FindByCommit(ctx context.Context, projectKey string, commitId string, repositorySlug string, start float32, limit float32) (FindByCommit200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-utils/latest/projects/{projectKey}/repos/{repositorySlug}/branches/info/{commitId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeFindByCommitCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeFindByCommitCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (FindByCommit200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result FindByCommit200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 500 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[FindByCommit200Response](&response) + if err == nil { + result = response.Body.(FindByCommit200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIFindWebhooks1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + event *string + statistics *bool +} + + // List of <code>com.atlassian.webhooks.WebhookEvent</code> IDs to filter for +func (r *RepositoryAPIFindWebhooks1Request) Event(event string) *RepositoryAPIFindWebhooks1Request { + r.event = &event + return r +} + + // <code>true</code> if statistics should be provided for all found webhooks +func (r *RepositoryAPIFindWebhooks1Request) Statistics(statistics bool) *RepositoryAPIFindWebhooks1Request { + r.statistics = &statistics + return r +} + +func (r *RepositoryAPIFindWebhooks1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.FindWebhooks1Execute(r) +} + +func (a *RepositoryAPIRepository) FindWebhooks1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIFindWebhooks1Request { + return RepositoryAPIFindWebhooks1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) FindWebhooks1Execute(r *RepositoryAPIFindWebhooks1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.event!=nil { + withUrlQueryParam(requestURL, "event", *r.event) + } + if r.statistics!=nil { + withUrlQueryParam(requestURL, "statistics", parameterValueToString(*r.statistics)) + } + return a.makeFindWebhooks1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) FindWebhooks1(ctx context.Context, projectKey string, repositorySlug string, event string, statistics bool) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "event", event) + withUrlQueryParam(requestURL, "statistics", parameterValueToString(statistics)) + return a.makeFindWebhooks1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeFindWebhooks1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIGet5Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string +} + +func (r *RepositoryAPIGet5Request) Execute() (RestAutoMergeRestrictedSettings, aurestclientapi.ParsedResponse, error) { + return r.ApiService.Get5Execute(r) +} + +func (a *RepositoryAPIRepository) Get5Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGet5Request { + return RepositoryAPIGet5Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) Get5Execute(r *RepositoryAPIGet5Request) (RestAutoMergeRestrictedSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGet5Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) Get5(ctx context.Context, projectKey string, repositorySlug string) (RestAutoMergeRestrictedSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGet5Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGet5Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestAutoMergeRestrictedSettings, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestAutoMergeRestrictedSettings + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestAutoMergeRestrictedSettings](&response) + if err == nil { + result = response.Body.(RestAutoMergeRestrictedSettings) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetAllLabelsForRepositoryRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string +} + +func (r *RepositoryAPIGetAllLabelsForRepositoryRequest) Execute() (RestLabel, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetAllLabelsForRepositoryExecute(r) +} + +func (a *RepositoryAPIRepository) GetAllLabelsForRepositoryRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetAllLabelsForRepositoryRequest { + return RepositoryAPIGetAllLabelsForRepositoryRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetAllLabelsForRepositoryExecute(r *RepositoryAPIGetAllLabelsForRepositoryRequest) (RestLabel, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/labels" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetAllLabelsForRepositoryCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetAllLabelsForRepository(ctx context.Context, projectKey string, repositorySlug string) (RestLabel, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/labels" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetAllLabelsForRepositoryCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetAllLabelsForRepositoryCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestLabel, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestLabel + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestLabel](&response) + if err == nil { + result = response.Body.(RestLabel) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetArchiveRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + path *string + filename *string + at *string + prefix *string + format *string +} + + // Paths to include in the streamed archive; may be repeated to include multiple paths +func (r *RepositoryAPIGetArchiveRequest) Path(path string) *RepositoryAPIGetArchiveRequest { + r.path = &path + return r +} + + // A filename to include the \"Content-Disposition\" header +func (r *RepositoryAPIGetArchiveRequest) Filename(filename string) *RepositoryAPIGetArchiveRequest { + r.filename = &filename + return r +} + + // The commit to stream an archive of; if not supplied, an archive of the default branch is streamed +func (r *RepositoryAPIGetArchiveRequest) At(at string) *RepositoryAPIGetArchiveRequest { + r.at = &at + return r +} + + // A prefix to apply to all entries in the streamed archive; if the supplied prefix does not end with a trailing /, one will be added automatically +func (r *RepositoryAPIGetArchiveRequest) Prefix(prefix string) *RepositoryAPIGetArchiveRequest { + r.prefix = &prefix + return r +} + + // The format to stream the archive in; must be one of: zip, tar, tar.gz or tgz +func (r *RepositoryAPIGetArchiveRequest) Format(format string) *RepositoryAPIGetArchiveRequest { + r.format = &format + return r +} + +func (r *RepositoryAPIGetArchiveRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetArchiveExecute(r) +} + +func (a *RepositoryAPIRepository) GetArchiveRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetArchiveRequest { + return RepositoryAPIGetArchiveRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetArchiveExecute(r *RepositoryAPIGetArchiveRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/archive" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.path!=nil { + withUrlQueryParam(requestURL, "path", *r.path) + } + if r.filename!=nil { + withUrlQueryParam(requestURL, "filename", *r.filename) + } + if r.at!=nil { + withUrlQueryParam(requestURL, "at", *r.at) + } + if r.prefix!=nil { + withUrlQueryParam(requestURL, "prefix", *r.prefix) + } + if r.format!=nil { + withUrlQueryParam(requestURL, "format", *r.format) + } + return a.makeGetArchiveCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetArchive(ctx context.Context, projectKey string, repositorySlug string, path string, filename string, at string, prefix string, format string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/archive" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "path", path) + withUrlQueryParam(requestURL, "filename", filename) + withUrlQueryParam(requestURL, "at", at) + withUrlQueryParam(requestURL, "prefix", prefix) + withUrlQueryParam(requestURL, "format", format) + return a.makeGetArchiveCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetArchiveCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIGetAttachmentRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + attachmentId string + repositorySlug string + userAgent *string + range_ *string +} + +func (r *RepositoryAPIGetAttachmentRequest) UserAgent(userAgent string) *RepositoryAPIGetAttachmentRequest { + r.userAgent = &userAgent + return r +} + +func (r *RepositoryAPIGetAttachmentRequest) Range_(range_ string) *RepositoryAPIGetAttachmentRequest { + r.range_ = &range_ + return r +} + +func (r *RepositoryAPIGetAttachmentRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetAttachmentExecute(r) +} + +func (a *RepositoryAPIRepository) GetAttachmentRequest(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) RepositoryAPIGetAttachmentRequest { + return RepositoryAPIGetAttachmentRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + attachmentId: attachmentId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetAttachmentExecute(r *RepositoryAPIGetAttachmentRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/attachments/{attachmentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{attachmentId}", urlUtil.PathEscape(r.attachmentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetAttachmentCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetAttachment(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/attachments/{attachmentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{attachmentId}", urlUtil.PathEscape(attachmentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetAttachmentCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetAttachmentCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIGetAttachmentMetadataRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + attachmentId string + repositorySlug string +} + +func (r *RepositoryAPIGetAttachmentMetadataRequest) Execute() (RestAttachmentMetadata, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetAttachmentMetadataExecute(r) +} + +func (a *RepositoryAPIRepository) GetAttachmentMetadataRequest(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) RepositoryAPIGetAttachmentMetadataRequest { + return RepositoryAPIGetAttachmentMetadataRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + attachmentId: attachmentId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetAttachmentMetadataExecute(r *RepositoryAPIGetAttachmentMetadataRequest) (RestAttachmentMetadata, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/attachments/{attachmentId}/metadata" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{attachmentId}", urlUtil.PathEscape(r.attachmentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetAttachmentMetadataCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetAttachmentMetadata(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) (RestAttachmentMetadata, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/attachments/{attachmentId}/metadata" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{attachmentId}", urlUtil.PathEscape(attachmentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetAttachmentMetadataCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetAttachmentMetadataCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestAttachmentMetadata, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestAttachmentMetadata + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestAttachmentMetadata](&response) + if err == nil { + result = response.Body.(RestAttachmentMetadata) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetAutoDeclineSettings1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string +} + +func (r *RepositoryAPIGetAutoDeclineSettings1Request) Execute() (RestAutoDeclineSettings, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetAutoDeclineSettings1Execute(r) +} + +func (a *RepositoryAPIRepository) GetAutoDeclineSettings1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetAutoDeclineSettings1Request { + return RepositoryAPIGetAutoDeclineSettings1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetAutoDeclineSettings1Execute(r *RepositoryAPIGetAutoDeclineSettings1Request) (RestAutoDeclineSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-decline" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetAutoDeclineSettings1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetAutoDeclineSettings1(ctx context.Context, projectKey string, repositorySlug string) (RestAutoDeclineSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-decline" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetAutoDeclineSettings1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetAutoDeclineSettings1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestAutoDeclineSettings, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestAutoDeclineSettings + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestAutoDeclineSettings](&response) + if err == nil { + result = response.Body.(RestAutoDeclineSettings) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetBranchesRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + boostMatches *bool + orderBy *string + details *bool + filterText *string + base *string + start *float32 + limit *float32 +} + + // Controls whether exact and prefix matches will be boosted to the top +func (r *RepositoryAPIGetBranchesRequest) BoostMatches(boostMatches bool) *RepositoryAPIGetBranchesRequest { + r.boostMatches = &boostMatches + return r +} + + // Ordering of refs either ALPHABETICAL (by name) or MODIFICATION (last updated) +func (r *RepositoryAPIGetBranchesRequest) OrderBy(orderBy string) *RepositoryAPIGetBranchesRequest { + r.orderBy = &orderBy + return r +} + + // Whether to retrieve plugin-provided metadata about each branch +func (r *RepositoryAPIGetBranchesRequest) Details(details bool) *RepositoryAPIGetBranchesRequest { + r.details = &details + return r +} + + // The text to match on +func (r *RepositoryAPIGetBranchesRequest) FilterText(filterText string) *RepositoryAPIGetBranchesRequest { + r.filterText = &filterText + return r +} + + // Base branch or tag to compare each branch to (for the metadata providers that uses that information +func (r *RepositoryAPIGetBranchesRequest) Base(base string) *RepositoryAPIGetBranchesRequest { + r.base = &base + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIGetBranchesRequest) Start(start float32) *RepositoryAPIGetBranchesRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIGetBranchesRequest) Limit(limit float32) *RepositoryAPIGetBranchesRequest { + r.limit = &limit + return r +} + +func (r *RepositoryAPIGetBranchesRequest) Execute() (GetBranches200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetBranchesExecute(r) +} + +func (a *RepositoryAPIRepository) GetBranchesRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetBranchesRequest { + return RepositoryAPIGetBranchesRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetBranchesExecute(r *RepositoryAPIGetBranchesRequest) (GetBranches200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/branches" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.boostMatches!=nil { + withUrlQueryParam(requestURL, "boostMatches", parameterValueToString(*r.boostMatches)) + } + if r.orderBy!=nil { + withUrlQueryParam(requestURL, "orderBy", *r.orderBy) + } + if r.details!=nil { + withUrlQueryParam(requestURL, "details", parameterValueToString(*r.details)) + } + if r.filterText!=nil { + withUrlQueryParam(requestURL, "filterText", *r.filterText) + } + if r.base!=nil { + withUrlQueryParam(requestURL, "base", *r.base) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetBranchesCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetBranches(ctx context.Context, projectKey string, repositorySlug string, boostMatches bool, orderBy string, details bool, filterText string, base string, start float32, limit float32) (GetBranches200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/branches" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "boostMatches", parameterValueToString(boostMatches)) + withUrlQueryParam(requestURL, "orderBy", orderBy) + withUrlQueryParam(requestURL, "details", parameterValueToString(details)) + withUrlQueryParam(requestURL, "filterText", filterText) + withUrlQueryParam(requestURL, "base", base) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetBranchesCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetBranchesCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetBranches200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetBranches200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetBranches200Response](&response) + if err == nil { + result = response.Body.(GetBranches200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetChangesRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commitId string + repositorySlug string + withComments *string + since *string + start *float32 + limit *float32 +} + + // <code>true</code> to apply comment counts in the changes (the default); otherwise, <code>false</code> to stream changes without comment counts +func (r *RepositoryAPIGetChangesRequest) WithComments(withComments string) *RepositoryAPIGetChangesRequest { + r.withComments = &withComments + return r +} + + // The commit to which <code>until</code> should be compared to produce a page of changes. If not specified the commit's first parent is assumed (if one exists) +func (r *RepositoryAPIGetChangesRequest) Since(since string) *RepositoryAPIGetChangesRequest { + r.since = &since + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIGetChangesRequest) Start(start float32) *RepositoryAPIGetChangesRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIGetChangesRequest) Limit(limit float32) *RepositoryAPIGetChangesRequest { + r.limit = &limit + return r +} + +func (r *RepositoryAPIGetChangesRequest) Execute() (GetChanges1200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetChangesExecute(r) +} + +func (a *RepositoryAPIRepository) GetChangesRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIGetChangesRequest { + return RepositoryAPIGetChangesRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetChangesExecute(r *RepositoryAPIGetChangesRequest) (GetChanges1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/changes" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.withComments!=nil { + withUrlQueryParam(requestURL, "withComments", *r.withComments) + } + if r.since!=nil { + withUrlQueryParam(requestURL, "since", *r.since) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetChangesCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetChanges(ctx context.Context, projectKey string, commitId string, repositorySlug string, withComments string, since string, start float32, limit float32) (GetChanges1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/changes" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "withComments", withComments) + withUrlQueryParam(requestURL, "since", since) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetChangesCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetChangesCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetChanges1200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetChanges1200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetChanges1200Response](&response) + if err == nil { + result = response.Body.(GetChanges1200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetChanges1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + until *string + since *string + start *float32 + limit *float32 +} + + // The commit to retrieve changes for +func (r *RepositoryAPIGetChanges1Request) Until(until string) *RepositoryAPIGetChanges1Request { + r.until = &until + return r +} + + // The commit to which <code>until</code> should be compared to produce a page of changes. If not specified the commit's first parent is assumed (if one exists) +func (r *RepositoryAPIGetChanges1Request) Since(since string) *RepositoryAPIGetChanges1Request { + r.since = &since + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIGetChanges1Request) Start(start float32) *RepositoryAPIGetChanges1Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIGetChanges1Request) Limit(limit float32) *RepositoryAPIGetChanges1Request { + r.limit = &limit + return r +} + +func (r *RepositoryAPIGetChanges1Request) Execute() (GetChanges1200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetChanges1Execute(r) +} + +func (a *RepositoryAPIRepository) GetChanges1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetChanges1Request { + return RepositoryAPIGetChanges1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetChanges1Execute(r *RepositoryAPIGetChanges1Request) (GetChanges1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/changes" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.until!=nil { + withUrlQueryParam(requestURL, "until", *r.until) + } + if r.since!=nil { + withUrlQueryParam(requestURL, "since", *r.since) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetChanges1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetChanges1(ctx context.Context, projectKey string, repositorySlug string, until string, since string, start float32, limit float32) (GetChanges1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/changes" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "until", until) + withUrlQueryParam(requestURL, "since", since) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetChanges1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetChanges1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetChanges1200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetChanges1200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetChanges1200Response](&response) + if err == nil { + result = response.Body.(GetChanges1200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetCommentRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commentId string + commitId string + repositorySlug string +} + +func (r *RepositoryAPIGetCommentRequest) Execute() (RestComment, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetCommentExecute(r) +} + +func (a *RepositoryAPIRepository) GetCommentRequest(ctx context.Context, projectKey string, commentId string, commitId string, repositorySlug string) RepositoryAPIGetCommentRequest { + return RepositoryAPIGetCommentRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetCommentExecute(r *RepositoryAPIGetCommentRequest) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetCommentCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetComment(ctx context.Context, projectKey string, commentId string, commitId string, repositorySlug string) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetCommentCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetCommentCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestComment, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestComment + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestComment](&response) + if err == nil { + result = response.Body.(RestComment) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetCommentsRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commitId string + repositorySlug string + path *string + since *string + start *float32 + limit *float32 +} + + // The path to the file on which comments were made +func (r *RepositoryAPIGetCommentsRequest) Path(path string) *RepositoryAPIGetCommentsRequest { + r.path = &path + return r +} + + // For a merge commit, a parent can be provided to specify which diff the comments are on. For a commit range, a sinceId can be provided to specify where the comments are anchored from. +func (r *RepositoryAPIGetCommentsRequest) Since(since string) *RepositoryAPIGetCommentsRequest { + r.since = &since + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIGetCommentsRequest) Start(start float32) *RepositoryAPIGetCommentsRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIGetCommentsRequest) Limit(limit float32) *RepositoryAPIGetCommentsRequest { + r.limit = &limit + return r +} + +func (r *RepositoryAPIGetCommentsRequest) Execute() (GetComments200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetCommentsExecute(r) +} + +func (a *RepositoryAPIRepository) GetCommentsRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIGetCommentsRequest { + return RepositoryAPIGetCommentsRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetCommentsExecute(r *RepositoryAPIGetCommentsRequest) (GetComments200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.path!=nil { + withUrlQueryParam(requestURL, "path", *r.path) + } + if r.since!=nil { + withUrlQueryParam(requestURL, "since", *r.since) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetCommentsCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetComments(ctx context.Context, projectKey string, commitId string, repositorySlug string, path string, since string, start float32, limit float32) (GetComments200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "path", path) + withUrlQueryParam(requestURL, "since", since) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetCommentsCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetCommentsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetComments200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetComments200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetComments200Response](&response) + if err == nil { + result = response.Body.(GetComments200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetCommitRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commitId string + repositorySlug string + path *string +} + + // An optional path to filter the commit by. If supplied the details returned <i>may not</i> be for the specified commit. Instead, starting from the specified commit, they will be the details for the first commit affecting the specified path. +func (r *RepositoryAPIGetCommitRequest) Path(path string) *RepositoryAPIGetCommitRequest { + r.path = &path + return r +} + +func (r *RepositoryAPIGetCommitRequest) Execute() (RestCommit, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetCommitExecute(r) +} + +func (a *RepositoryAPIRepository) GetCommitRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIGetCommitRequest { + return RepositoryAPIGetCommitRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetCommitExecute(r *RepositoryAPIGetCommitRequest) (RestCommit, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.path!=nil { + withUrlQueryParam(requestURL, "path", *r.path) + } + return a.makeGetCommitCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetCommit(ctx context.Context, projectKey string, commitId string, repositorySlug string, path string) (RestCommit, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "path", path) + return a.makeGetCommitCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetCommitCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestCommit, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestCommit + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestCommit](&response) + if err == nil { + result = response.Body.(RestCommit) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetCommitsRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + avatarScheme *string + path *string + withCounts *string + followRenames *string + until *string + avatarSize *string + since *string + merges *string + ignoreMissing *string + start *float32 + limit *float32 +} + + // The desired scheme for the avatar URL. If the parameter is not present URLs will use the same scheme as this request +func (r *RepositoryAPIGetCommitsRequest) AvatarScheme(avatarScheme string) *RepositoryAPIGetCommitsRequest { + r.avatarScheme = &avatarScheme + return r +} + + // An optional path to filter commits by +func (r *RepositoryAPIGetCommitsRequest) Path(path string) *RepositoryAPIGetCommitsRequest { + r.path = &path + return r +} + + // Optionally include the total number of commits and total number of unique authors +func (r *RepositoryAPIGetCommitsRequest) WithCounts(withCounts string) *RepositoryAPIGetCommitsRequest { + r.withCounts = &withCounts + return r +} + + // If <code>true</code>, the commit history of the specified file will be followed past renames. Only valid for a path to a single file. +func (r *RepositoryAPIGetCommitsRequest) FollowRenames(followRenames string) *RepositoryAPIGetCommitsRequest { + r.followRenames = &followRenames + return r +} + + // The commit ID (SHA1) or ref (inclusively) to retrieve commits before +func (r *RepositoryAPIGetCommitsRequest) Until(until string) *RepositoryAPIGetCommitsRequest { + r.until = &until + return r +} + + // If present the service adds avatar URLs for commit authors. Should be an integer specifying the desired size in pixels. If the parameter is not present, avatar URLs will not be set +func (r *RepositoryAPIGetCommitsRequest) AvatarSize(avatarSize string) *RepositoryAPIGetCommitsRequest { + r.avatarSize = &avatarSize + return r +} + + // The commit ID or ref (exclusively) to retrieve commits after +func (r *RepositoryAPIGetCommitsRequest) Since(since string) *RepositoryAPIGetCommitsRequest { + r.since = &since + return r +} + + // If present, controls how merge commits should be filtered. Can be either <code>exclude</code>, to exclude merge commits, <code>include</code>, to include both merge commits and non-merge commits or <code>only</code>, to only return merge commits. +func (r *RepositoryAPIGetCommitsRequest) Merges(merges string) *RepositoryAPIGetCommitsRequest { + r.merges = &merges + return r +} + + // <code>true</code> to ignore missing commits, <code>false</code> otherwise +func (r *RepositoryAPIGetCommitsRequest) IgnoreMissing(ignoreMissing string) *RepositoryAPIGetCommitsRequest { + r.ignoreMissing = &ignoreMissing + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIGetCommitsRequest) Start(start float32) *RepositoryAPIGetCommitsRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIGetCommitsRequest) Limit(limit float32) *RepositoryAPIGetCommitsRequest { + r.limit = &limit + return r +} + +func (r *RepositoryAPIGetCommitsRequest) Execute() (GetCommits200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetCommitsExecute(r) +} + +func (a *RepositoryAPIRepository) GetCommitsRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetCommitsRequest { + return RepositoryAPIGetCommitsRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetCommitsExecute(r *RepositoryAPIGetCommitsRequest) (GetCommits200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.avatarScheme!=nil { + withUrlQueryParam(requestURL, "avatarScheme", *r.avatarScheme) + } + if r.path!=nil { + withUrlQueryParam(requestURL, "path", *r.path) + } + if r.withCounts!=nil { + withUrlQueryParam(requestURL, "withCounts", *r.withCounts) + } + if r.followRenames!=nil { + withUrlQueryParam(requestURL, "followRenames", *r.followRenames) + } + if r.until!=nil { + withUrlQueryParam(requestURL, "until", *r.until) + } + if r.avatarSize!=nil { + withUrlQueryParam(requestURL, "avatarSize", *r.avatarSize) + } + if r.since!=nil { + withUrlQueryParam(requestURL, "since", *r.since) + } + if r.merges!=nil { + withUrlQueryParam(requestURL, "merges", *r.merges) + } + if r.ignoreMissing!=nil { + withUrlQueryParam(requestURL, "ignoreMissing", *r.ignoreMissing) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetCommitsCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetCommits(ctx context.Context, projectKey string, repositorySlug string, avatarScheme string, path string, withCounts string, followRenames string, until string, avatarSize string, since string, merges string, ignoreMissing string, start float32, limit float32) (GetCommits200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "avatarScheme", avatarScheme) + withUrlQueryParam(requestURL, "path", path) + withUrlQueryParam(requestURL, "withCounts", withCounts) + withUrlQueryParam(requestURL, "followRenames", followRenames) + withUrlQueryParam(requestURL, "until", until) + withUrlQueryParam(requestURL, "avatarSize", avatarSize) + withUrlQueryParam(requestURL, "since", since) + withUrlQueryParam(requestURL, "merges", merges) + withUrlQueryParam(requestURL, "ignoreMissing", ignoreMissing) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetCommitsCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetCommitsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetCommits200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetCommits200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetCommits200Response](&response) + if err == nil { + result = response.Body.(GetCommits200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetConfigurations1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + start *float32 + limit *float32 +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIGetConfigurations1Request) Start(start float32) *RepositoryAPIGetConfigurations1Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIGetConfigurations1Request) Limit(limit float32) *RepositoryAPIGetConfigurations1Request { + r.limit = &limit + return r +} + +func (r *RepositoryAPIGetConfigurations1Request) Execute() (GetConfigurations200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetConfigurations1Execute(r) +} + +func (a *RepositoryAPIRepository) GetConfigurations1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetConfigurations1Request { + return RepositoryAPIGetConfigurations1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetConfigurations1Execute(r *RepositoryAPIGetConfigurations1Request) (GetConfigurations200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/hook-scripts" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetConfigurations1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetConfigurations1(ctx context.Context, projectKey string, repositorySlug string, start float32, limit float32) (GetConfigurations200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/hook-scripts" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetConfigurations1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetConfigurations1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetConfigurations200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetConfigurations200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetConfigurations200Response](&response) + if err == nil { + result = response.Body.(GetConfigurations200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetContentRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + noContent *string + at *string + size *string + blame *string + type_ *string +} + + // If blame&amp;noContent only the blame is retrieved instead of the contents +func (r *RepositoryAPIGetContentRequest) NoContent(noContent string) *RepositoryAPIGetContentRequest { + r.noContent = &noContent + return r +} + + // The commit ID or ref to retrieve the content for +func (r *RepositoryAPIGetContentRequest) At(at string) *RepositoryAPIGetContentRequest { + r.at = &at + return r +} + + // If true only the size will be returned for the file path instead of the contents +func (r *RepositoryAPIGetContentRequest) Size(size string) *RepositoryAPIGetContentRequest { + r.size = &size + return r +} + + // If present and not equal to 'false', the blame will be returned for the file as well +func (r *RepositoryAPIGetContentRequest) Blame(blame string) *RepositoryAPIGetContentRequest { + r.blame = &blame + return r +} + + // If true only the type will be returned for the file path instead of the contents +func (r *RepositoryAPIGetContentRequest) Type_(type_ string) *RepositoryAPIGetContentRequest { + r.type_ = &type_ + return r +} + +func (r *RepositoryAPIGetContentRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetContentExecute(r) +} + +func (a *RepositoryAPIRepository) GetContentRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetContentRequest { + return RepositoryAPIGetContentRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetContentExecute(r *RepositoryAPIGetContentRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/browse" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.noContent!=nil { + withUrlQueryParam(requestURL, "noContent", *r.noContent) + } + if r.at!=nil { + withUrlQueryParam(requestURL, "at", *r.at) + } + if r.size!=nil { + withUrlQueryParam(requestURL, "size", *r.size) + } + if r.blame!=nil { + withUrlQueryParam(requestURL, "blame", *r.blame) + } + if r.type_!=nil { + withUrlQueryParam(requestURL, "type", *r.type_) + } + return a.makeGetContentCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetContent(ctx context.Context, projectKey string, repositorySlug string, noContent string, at string, size string, blame string, type_ string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/browse" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "noContent", noContent) + withUrlQueryParam(requestURL, "at", at) + withUrlQueryParam(requestURL, "size", size) + withUrlQueryParam(requestURL, "blame", blame) + withUrlQueryParam(requestURL, "type", type_) + return a.makeGetContentCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetContentCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIGetContent1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + path string + projectKey string + repositorySlug string + noContent *string + at *string + size *string + blame *string + type_ *string +} + + // If blame&amp;noContent only the blame is retrieved instead of the contents +func (r *RepositoryAPIGetContent1Request) NoContent(noContent string) *RepositoryAPIGetContent1Request { + r.noContent = &noContent + return r +} + + // The commit ID or ref to retrieve the content for +func (r *RepositoryAPIGetContent1Request) At(at string) *RepositoryAPIGetContent1Request { + r.at = &at + return r +} + + // If true only the size will be returned for the file path instead of the contents +func (r *RepositoryAPIGetContent1Request) Size(size string) *RepositoryAPIGetContent1Request { + r.size = &size + return r +} + + // If present and not equal to 'false', the blame will be returned for the file as well +func (r *RepositoryAPIGetContent1Request) Blame(blame string) *RepositoryAPIGetContent1Request { + r.blame = &blame + return r +} + + // If true only the type will be returned for the file path instead of the contents +func (r *RepositoryAPIGetContent1Request) Type_(type_ string) *RepositoryAPIGetContent1Request { + r.type_ = &type_ + return r +} + +func (r *RepositoryAPIGetContent1Request) Execute() (GetContent1200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetContent1Execute(r) +} + +func (a *RepositoryAPIRepository) GetContent1Request(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIGetContent1Request { + return RepositoryAPIGetContent1Request{ + ApiService: a, + ctx: ctx, + path: path, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetContent1Execute(r *RepositoryAPIGetContent1Request) (GetContent1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/browse/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(r.path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.noContent!=nil { + withUrlQueryParam(requestURL, "noContent", *r.noContent) + } + if r.at!=nil { + withUrlQueryParam(requestURL, "at", *r.at) + } + if r.size!=nil { + withUrlQueryParam(requestURL, "size", *r.size) + } + if r.blame!=nil { + withUrlQueryParam(requestURL, "blame", *r.blame) + } + if r.type_!=nil { + withUrlQueryParam(requestURL, "type", *r.type_) + } + return a.makeGetContent1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetContent1(ctx context.Context, path string, projectKey string, repositorySlug string, noContent string, at string, size string, blame string, type_ string) (GetContent1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/browse/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "noContent", noContent) + withUrlQueryParam(requestURL, "at", at) + withUrlQueryParam(requestURL, "size", size) + withUrlQueryParam(requestURL, "blame", blame) + withUrlQueryParam(requestURL, "type", type_) + return a.makeGetContent1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetContent1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetContent1200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetContent1200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetContent1200Response](&response) + if err == nil { + result = response.Body.(GetContent1200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetDefaultBranch1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string +} + +func (r *RepositoryAPIGetDefaultBranch1Request) Execute() (RestBranch, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetDefaultBranch1Execute(r) +} + +func (a *RepositoryAPIRepository) GetDefaultBranch1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetDefaultBranch1Request { + return RepositoryAPIGetDefaultBranch1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +// Deprecated +func (a *RepositoryAPIRepository) GetDefaultBranch1Execute(r *RepositoryAPIGetDefaultBranch1Request) (RestBranch, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/branches/default" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetDefaultBranch1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetDefaultBranch1(ctx context.Context, projectKey string, repositorySlug string) (RestBranch, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/branches/default" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetDefaultBranch1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetDefaultBranch1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestBranch, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestBranch + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestBranch](&response) + if err == nil { + result = response.Body.(RestBranch) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetLatestInvocation1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + webhookId string + repositorySlug string + event *string + outcome *string +} + + // The string ID of a specific event to retrieve the last invocation for. +func (r *RepositoryAPIGetLatestInvocation1Request) Event(event string) *RepositoryAPIGetLatestInvocation1Request { + r.event = &event + return r +} + + // The outcome to filter for. Can be SUCCESS, FAILURE, ERROR. None specified means that the all will be considered +func (r *RepositoryAPIGetLatestInvocation1Request) Outcome(outcome string) *RepositoryAPIGetLatestInvocation1Request { + r.outcome = &outcome + return r +} + +func (r *RepositoryAPIGetLatestInvocation1Request) Execute() (RestDetailedInvocation, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetLatestInvocation1Execute(r) +} + +func (a *RepositoryAPIRepository) GetLatestInvocation1Request(ctx context.Context, projectKey string, webhookId string, repositorySlug string) RepositoryAPIGetLatestInvocation1Request { + return RepositoryAPIGetLatestInvocation1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + webhookId: webhookId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetLatestInvocation1Execute(r *RepositoryAPIGetLatestInvocation1Request) (RestDetailedInvocation, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}/latest" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{webhookId}", urlUtil.PathEscape(r.webhookId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.event!=nil { + withUrlQueryParam(requestURL, "event", *r.event) + } + if r.outcome!=nil { + withUrlQueryParam(requestURL, "outcome", *r.outcome) + } + return a.makeGetLatestInvocation1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetLatestInvocation1(ctx context.Context, projectKey string, webhookId string, repositorySlug string, event string, outcome string) (RestDetailedInvocation, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}/latest" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{webhookId}", urlUtil.PathEscape(webhookId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "event", event) + withUrlQueryParam(requestURL, "outcome", outcome) + return a.makeGetLatestInvocation1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetLatestInvocation1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestDetailedInvocation, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestDetailedInvocation + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestDetailedInvocation](&response) + if err == nil { + result = response.Body.(RestDetailedInvocation) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetMergeBaseRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commitId string + repositorySlug string + otherCommitId *string +} + + // The other commit id to calculate the merge-base on +func (r *RepositoryAPIGetMergeBaseRequest) OtherCommitId(otherCommitId string) *RepositoryAPIGetMergeBaseRequest { + r.otherCommitId = &otherCommitId + return r +} + +func (r *RepositoryAPIGetMergeBaseRequest) Execute() (RestCommit, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetMergeBaseExecute(r) +} + +func (a *RepositoryAPIRepository) GetMergeBaseRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIGetMergeBaseRequest { + return RepositoryAPIGetMergeBaseRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetMergeBaseExecute(r *RepositoryAPIGetMergeBaseRequest) (RestCommit, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/merge-base" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.otherCommitId!=nil { + withUrlQueryParam(requestURL, "otherCommitId", *r.otherCommitId) + } + return a.makeGetMergeBaseCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetMergeBase(ctx context.Context, projectKey string, commitId string, repositorySlug string, otherCommitId string) (RestCommit, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/merge-base" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "otherCommitId", otherCommitId) + return a.makeGetMergeBaseCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetMergeBaseCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestCommit, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestCommit + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestCommit](&response) + if err == nil { + result = response.Body.(RestCommit) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetPullRequestSettings1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string +} + +func (r *RepositoryAPIGetPullRequestSettings1Request) Execute() (RestRepositoryPullRequestSettings, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetPullRequestSettings1Execute(r) +} + +func (a *RepositoryAPIRepository) GetPullRequestSettings1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetPullRequestSettings1Request { + return RepositoryAPIGetPullRequestSettings1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetPullRequestSettings1Execute(r *RepositoryAPIGetPullRequestSettings1Request) (RestRepositoryPullRequestSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/pull-requests" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetPullRequestSettings1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetPullRequestSettings1(ctx context.Context, projectKey string, repositorySlug string) (RestRepositoryPullRequestSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/pull-requests" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetPullRequestSettings1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetPullRequestSettings1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestRepositoryPullRequestSettings, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestRepositoryPullRequestSettings + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestRepositoryPullRequestSettings](&response) + if err == nil { + result = response.Body.(RestRepositoryPullRequestSettings) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetRefChangeActivityRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + ref *string + start *float32 + limit *float32 +} + + // (optional) exact match for a ref ID to filter ref change activity for +func (r *RepositoryAPIGetRefChangeActivityRequest) Ref(ref string) *RepositoryAPIGetRefChangeActivityRequest { + r.ref = &ref + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIGetRefChangeActivityRequest) Start(start float32) *RepositoryAPIGetRefChangeActivityRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIGetRefChangeActivityRequest) Limit(limit float32) *RepositoryAPIGetRefChangeActivityRequest { + r.limit = &limit + return r +} + +func (r *RepositoryAPIGetRefChangeActivityRequest) Execute() (GetRefChangeActivity200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetRefChangeActivityExecute(r) +} + +func (a *RepositoryAPIRepository) GetRefChangeActivityRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetRefChangeActivityRequest { + return RepositoryAPIGetRefChangeActivityRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetRefChangeActivityExecute(r *RepositoryAPIGetRefChangeActivityRequest) (GetRefChangeActivity200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/ref-change-activities" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.ref!=nil { + withUrlQueryParam(requestURL, "ref", *r.ref) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetRefChangeActivityCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetRefChangeActivity(ctx context.Context, projectKey string, repositorySlug string, ref string, start float32, limit float32) (GetRefChangeActivity200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/ref-change-activities" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "ref", ref) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetRefChangeActivityCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetRefChangeActivityCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetRefChangeActivity200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetRefChangeActivity200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetRefChangeActivity200Response](&response) + if err == nil { + result = response.Body.(GetRefChangeActivity200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetRepositories1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + archived *string + projectname *string + projectkey *string + visibility *string + name *string + permission *string + state *string + start *float32 + limit *float32 +} + + // (optional) if specified, this will limit the resulting repository list to ones whose are <tt>ACTIVE</tt>, <tt>ARCHIVED</tt> or <tt>ALL</tt> for both. The match performed is case-insensitive. This filter defaults to <tt>ACTIVE</tt> when not set. <em>Available since 8.0</em> +func (r *RepositoryAPIGetRepositories1Request) Archived(archived string) *RepositoryAPIGetRepositories1Request { + r.archived = &archived + return r +} + + // (optional) if specified, this will limit the resulting repository list to ones whose project's name matches this parameter's value. The match performed is case-insensitive and any leading and/or trailing whitespace characters on the <code>projectname</code> parameter will be stripped. +func (r *RepositoryAPIGetRepositories1Request) Projectname(projectname string) *RepositoryAPIGetRepositories1Request { + r.projectname = &projectname + return r +} + + // (optional) if specified, this will limit the resulting repository list to ones whose project's key matches this parameter's value. The match performed is case-insensitive and any leading and/or trailing whitespace characters on the <code>projectKey</code> parameter will be stripped. <em>Available since 8.0</em> +func (r *RepositoryAPIGetRepositories1Request) Projectkey(projectkey string) *RepositoryAPIGetRepositories1Request { + r.projectkey = &projectkey + return r +} + + // (optional) if specified, this will limit the resulting repository list based on the repositories visibility. Valid values are <em>public</em> or <em>private</em>. +func (r *RepositoryAPIGetRepositories1Request) Visibility(visibility string) *RepositoryAPIGetRepositories1Request { + r.visibility = &visibility + return r +} + + // (optional) if specified, this will limit the resulting repository list to ones whose name matches this parameter's value. The match performed is case-insensitive and any leading and/or trailing whitespace characters on the <code>name</code> parameter will be stripped. +func (r *RepositoryAPIGetRepositories1Request) Name(name string) *RepositoryAPIGetRepositories1Request { + r.name = &name + return r +} + + // (optional) if specified, it must be a valid repository permission level name and will limit the resulting repository list to ones that the requesting user has the specified permission level to. If not specified, the default implicit 'read' permission level will be assumed. The currently supported explicit permission values are <tt>REPO_READ</tt>, <tt>REPO_WRITE</tt> and <tt>REPO_ADMIN</tt>. +func (r *RepositoryAPIGetRepositories1Request) Permission(permission string) *RepositoryAPIGetRepositories1Request { + r.permission = &permission + return r +} + + // (optional) if specified, it must be a valid repository state name and will limit the resulting repository list to ones that are in the specified state. The currently supported explicit state values are <tt>AVAILABLE</tt>, <tt>INITIALISING</tt> and <tt>INITIALISATION_FAILED</tt>.<br> <em>Available since 5.13</em> +func (r *RepositoryAPIGetRepositories1Request) State(state string) *RepositoryAPIGetRepositories1Request { + r.state = &state + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIGetRepositories1Request) Start(start float32) *RepositoryAPIGetRepositories1Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIGetRepositories1Request) Limit(limit float32) *RepositoryAPIGetRepositories1Request { + r.limit = &limit + return r +} + +func (r *RepositoryAPIGetRepositories1Request) Execute() (GetRepositoriesRecentlyAccessed200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetRepositories1Execute(r) +} + +func (a *RepositoryAPIRepository) GetRepositories1Request(ctx context.Context) RepositoryAPIGetRepositories1Request { + return RepositoryAPIGetRepositories1Request{ + ApiService: a, + ctx: ctx, + } +} + +func (a *RepositoryAPIRepository) GetRepositories1Execute(r *RepositoryAPIGetRepositories1Request) (GetRepositoriesRecentlyAccessed200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/repos" + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.archived!=nil { + withUrlQueryParam(requestURL, "archived", *r.archived) + } + if r.projectname!=nil { + withUrlQueryParam(requestURL, "projectname", *r.projectname) + } + if r.projectkey!=nil { + withUrlQueryParam(requestURL, "projectkey", *r.projectkey) + } + if r.visibility!=nil { + withUrlQueryParam(requestURL, "visibility", *r.visibility) + } + if r.name!=nil { + withUrlQueryParam(requestURL, "name", *r.name) + } + if r.permission!=nil { + withUrlQueryParam(requestURL, "permission", *r.permission) + } + if r.state!=nil { + withUrlQueryParam(requestURL, "state", *r.state) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetRepositories1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetRepositories1(ctx context.Context, archived string, projectname string, projectkey string, visibility string, name string, permission string, state string, start float32, limit float32) (GetRepositoriesRecentlyAccessed200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/repos" + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "archived", archived) + withUrlQueryParam(requestURL, "projectname", projectname) + withUrlQueryParam(requestURL, "projectkey", projectkey) + withUrlQueryParam(requestURL, "visibility", visibility) + withUrlQueryParam(requestURL, "name", name) + withUrlQueryParam(requestURL, "permission", permission) + withUrlQueryParam(requestURL, "state", state) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetRepositories1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetRepositories1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetRepositoriesRecentlyAccessed200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetRepositoriesRecentlyAccessed200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetRepositoriesRecentlyAccessed200Response](&response) + if err == nil { + result = response.Body.(GetRepositoriesRecentlyAccessed200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetRepositoriesRecentlyAccessedRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + permission *string + start *float32 + limit *float32 +} + + // (optional) If specified, it must be a valid repository permission level name and will limit the resulting repository list to ones that the requesting user has the specified permission level to. If not specified, the default <code>REPO_READ</code> permission level will be assumed. +func (r *RepositoryAPIGetRepositoriesRecentlyAccessedRequest) Permission(permission string) *RepositoryAPIGetRepositoriesRecentlyAccessedRequest { + r.permission = &permission + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIGetRepositoriesRecentlyAccessedRequest) Start(start float32) *RepositoryAPIGetRepositoriesRecentlyAccessedRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIGetRepositoriesRecentlyAccessedRequest) Limit(limit float32) *RepositoryAPIGetRepositoriesRecentlyAccessedRequest { + r.limit = &limit + return r +} + +func (r *RepositoryAPIGetRepositoriesRecentlyAccessedRequest) Execute() (GetRepositoriesRecentlyAccessed200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetRepositoriesRecentlyAccessedExecute(r) +} + +func (a *RepositoryAPIRepository) GetRepositoriesRecentlyAccessedRequest(ctx context.Context) RepositoryAPIGetRepositoriesRecentlyAccessedRequest { + return RepositoryAPIGetRepositoriesRecentlyAccessedRequest{ + ApiService: a, + ctx: ctx, + } +} + +func (a *RepositoryAPIRepository) GetRepositoriesRecentlyAccessedExecute(r *RepositoryAPIGetRepositoriesRecentlyAccessedRequest) (GetRepositoriesRecentlyAccessed200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/profile/recent/repos" + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.permission!=nil { + withUrlQueryParam(requestURL, "permission", *r.permission) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetRepositoriesRecentlyAccessedCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetRepositoriesRecentlyAccessed(ctx context.Context, permission string, start float32, limit float32) (GetRepositoriesRecentlyAccessed200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/profile/recent/repos" + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "permission", permission) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetRepositoriesRecentlyAccessedCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetRepositoriesRecentlyAccessedCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetRepositoriesRecentlyAccessed200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetRepositoriesRecentlyAccessed200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetRepositoriesRecentlyAccessed200Response](&response) + if err == nil { + result = response.Body.(GetRepositoriesRecentlyAccessed200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetRepositoryHook1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + hookKey string + repositorySlug string +} + +func (r *RepositoryAPIGetRepositoryHook1Request) Execute() (RestRepositoryHook, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetRepositoryHook1Execute(r) +} + +func (a *RepositoryAPIRepository) GetRepositoryHook1Request(ctx context.Context, projectKey string, hookKey string, repositorySlug string) RepositoryAPIGetRepositoryHook1Request { + return RepositoryAPIGetRepositoryHook1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + hookKey: hookKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetRepositoryHook1Execute(r *RepositoryAPIGetRepositoryHook1Request) (RestRepositoryHook, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{hookKey}", urlUtil.PathEscape(r.hookKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetRepositoryHook1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetRepositoryHook1(ctx context.Context, projectKey string, hookKey string, repositorySlug string) (RestRepositoryHook, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{hookKey}", urlUtil.PathEscape(hookKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetRepositoryHook1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetRepositoryHook1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestRepositoryHook, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestRepositoryHook + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestRepositoryHook](&response) + if err == nil { + result = response.Body.(RestRepositoryHook) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetRepositoryHooks1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + type_ *string + start *float32 + limit *float32 +} + + // The optional type to filter by. +func (r *RepositoryAPIGetRepositoryHooks1Request) Type_(type_ string) *RepositoryAPIGetRepositoryHooks1Request { + r.type_ = &type_ + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIGetRepositoryHooks1Request) Start(start float32) *RepositoryAPIGetRepositoryHooks1Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIGetRepositoryHooks1Request) Limit(limit float32) *RepositoryAPIGetRepositoryHooks1Request { + r.limit = &limit + return r +} + +func (r *RepositoryAPIGetRepositoryHooks1Request) Execute() (GetRepositoryHooks1200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetRepositoryHooks1Execute(r) +} + +func (a *RepositoryAPIRepository) GetRepositoryHooks1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetRepositoryHooks1Request { + return RepositoryAPIGetRepositoryHooks1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetRepositoryHooks1Execute(r *RepositoryAPIGetRepositoryHooks1Request) (GetRepositoryHooks1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.type_!=nil { + withUrlQueryParam(requestURL, "type", *r.type_) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetRepositoryHooks1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetRepositoryHooks1(ctx context.Context, projectKey string, repositorySlug string, type_ string, start float32, limit float32) (GetRepositoryHooks1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "type", type_) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetRepositoryHooks1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetRepositoryHooks1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetRepositoryHooks1200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetRepositoryHooks1200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetRepositoryHooks1200Response](&response) + if err == nil { + result = response.Body.(GetRepositoryHooks1200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetRestriction1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + id string + repositorySlug string +} + +func (r *RepositoryAPIGetRestriction1Request) Execute() (RestRefRestriction, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetRestriction1Execute(r) +} + +func (a *RepositoryAPIRepository) GetRestriction1Request(ctx context.Context, projectKey string, id string, repositorySlug string) RepositoryAPIGetRestriction1Request { + return RepositoryAPIGetRestriction1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + id: id, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetRestriction1Execute(r *RepositoryAPIGetRestriction1Request) (RestRefRestriction, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-permissions/latest/projects/{projectKey}/repos/{repositorySlug}/restrictions/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(r.id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetRestriction1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetRestriction1(ctx context.Context, projectKey string, id string, repositorySlug string) (RestRefRestriction, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-permissions/latest/projects/{projectKey}/repos/{repositorySlug}/restrictions/{id}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{id}", urlUtil.PathEscape(id)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetRestriction1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetRestriction1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestRefRestriction, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestRefRestriction + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestRefRestriction](&response) + if err == nil { + result = response.Body.(RestRefRestriction) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetRestrictions1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + matcherType *string + matcherId *string + type_ *string + start *float32 + limit *float32 +} + + // Matcher type to filter on +func (r *RepositoryAPIGetRestrictions1Request) MatcherType(matcherType string) *RepositoryAPIGetRestrictions1Request { + r.matcherType = &matcherType + return r +} + + // Matcher id to filter on. Requires the matcherType parameter to be specified also. +func (r *RepositoryAPIGetRestrictions1Request) MatcherId(matcherId string) *RepositoryAPIGetRestrictions1Request { + r.matcherId = &matcherId + return r +} + + // Types of restrictions to filter on. +func (r *RepositoryAPIGetRestrictions1Request) Type_(type_ string) *RepositoryAPIGetRestrictions1Request { + r.type_ = &type_ + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIGetRestrictions1Request) Start(start float32) *RepositoryAPIGetRestrictions1Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIGetRestrictions1Request) Limit(limit float32) *RepositoryAPIGetRestrictions1Request { + r.limit = &limit + return r +} + +func (r *RepositoryAPIGetRestrictions1Request) Execute() (GetRestrictions1200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetRestrictions1Execute(r) +} + +func (a *RepositoryAPIRepository) GetRestrictions1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetRestrictions1Request { + return RepositoryAPIGetRestrictions1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetRestrictions1Execute(r *RepositoryAPIGetRestrictions1Request) (GetRestrictions1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-permissions/latest/projects/{projectKey}/repos/{repositorySlug}/restrictions" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.matcherType!=nil { + withUrlQueryParam(requestURL, "matcherType", *r.matcherType) + } + if r.matcherId!=nil { + withUrlQueryParam(requestURL, "matcherId", *r.matcherId) + } + if r.type_!=nil { + withUrlQueryParam(requestURL, "type", *r.type_) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetRestrictions1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetRestrictions1(ctx context.Context, projectKey string, repositorySlug string, matcherType string, matcherId string, type_ string, start float32, limit float32) (GetRestrictions1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/branch-permissions/latest/projects/{projectKey}/repos/{repositorySlug}/restrictions" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "matcherType", matcherType) + withUrlQueryParam(requestURL, "matcherId", matcherId) + withUrlQueryParam(requestURL, "type", type_) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetRestrictions1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetRestrictions1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetRestrictions1200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetRestrictions1200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetRestrictions1200Response](&response) + if err == nil { + result = response.Body.(GetRestrictions1200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetSettings1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + hookKey string + repositorySlug string +} + +func (r *RepositoryAPIGetSettings1Request) Execute() (ExampleSettings, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetSettings1Execute(r) +} + +func (a *RepositoryAPIRepository) GetSettings1Request(ctx context.Context, projectKey string, hookKey string, repositorySlug string) RepositoryAPIGetSettings1Request { + return RepositoryAPIGetSettings1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + hookKey: hookKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetSettings1Execute(r *RepositoryAPIGetSettings1Request) (ExampleSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}/settings" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{hookKey}", urlUtil.PathEscape(r.hookKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetSettings1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetSettings1(ctx context.Context, projectKey string, hookKey string, repositorySlug string) (ExampleSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}/settings" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{hookKey}", urlUtil.PathEscape(hookKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetSettings1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetSettings1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (ExampleSettings, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result ExampleSettings + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[ExampleSettings](&response) + if err == nil { + result = response.Body.(ExampleSettings) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetStatistics1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + webhookId string + repositorySlug string + event *string +} + + // The string ID of a specific event to retrieve the last invocation for. May be empty, in which case all events are considered +func (r *RepositoryAPIGetStatistics1Request) Event(event string) *RepositoryAPIGetStatistics1Request { + r.event = &event + return r +} + +func (r *RepositoryAPIGetStatistics1Request) Execute() (interface{}, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetStatistics1Execute(r) +} + +func (a *RepositoryAPIRepository) GetStatistics1Request(ctx context.Context, projectKey string, webhookId string, repositorySlug string) RepositoryAPIGetStatistics1Request { + return RepositoryAPIGetStatistics1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + webhookId: webhookId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetStatistics1Execute(r *RepositoryAPIGetStatistics1Request) (interface{}, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}/statistics" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{webhookId}", urlUtil.PathEscape(r.webhookId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.event!=nil { + withUrlQueryParam(requestURL, "event", *r.event) + } + return a.makeGetStatistics1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetStatistics1(ctx context.Context, projectKey string, webhookId string, repositorySlug string, event string) (interface{}, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}/statistics" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{webhookId}", urlUtil.PathEscape(webhookId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "event", event) + return a.makeGetStatistics1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetStatistics1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (interface{}, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result interface{} + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[interface{}](&response) + if err == nil { + result = response.Body.(interface{}) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetStatisticsSummary1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + webhookId string + repositorySlug string +} + +func (r *RepositoryAPIGetStatisticsSummary1Request) Execute() (interface{}, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetStatisticsSummary1Execute(r) +} + +func (a *RepositoryAPIRepository) GetStatisticsSummary1Request(ctx context.Context, projectKey string, webhookId string, repositorySlug string) RepositoryAPIGetStatisticsSummary1Request { + return RepositoryAPIGetStatisticsSummary1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + webhookId: webhookId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetStatisticsSummary1Execute(r *RepositoryAPIGetStatisticsSummary1Request) (interface{}, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}/statistics/summary" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{webhookId}", urlUtil.PathEscape(r.webhookId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetStatisticsSummary1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetStatisticsSummary1(ctx context.Context, projectKey string, webhookId string, repositorySlug string) (interface{}, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}/statistics/summary" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{webhookId}", urlUtil.PathEscape(webhookId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetStatisticsSummary1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetStatisticsSummary1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (interface{}, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result interface{} + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[interface{}](&response) + if err == nil { + result = response.Body.(interface{}) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetStatusRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + at *string +} + + // Retrieves the synchronization status for the specified ref within the repository, rather than for the entire repository +func (r *RepositoryAPIGetStatusRequest) At(at string) *RepositoryAPIGetStatusRequest { + r.at = &at + return r +} + +func (r *RepositoryAPIGetStatusRequest) Execute() (RestRefSyncStatus, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetStatusExecute(r) +} + +func (a *RepositoryAPIRepository) GetStatusRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetStatusRequest { + return RepositoryAPIGetStatusRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetStatusExecute(r *RepositoryAPIGetStatusRequest) (RestRefSyncStatus, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/sync/latest/projects/{projectKey}/repos/{repositorySlug}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.at!=nil { + withUrlQueryParam(requestURL, "at", *r.at) + } + return a.makeGetStatusCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetStatus(ctx context.Context, projectKey string, repositorySlug string, at string) (RestRefSyncStatus, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/sync/latest/projects/{projectKey}/repos/{repositorySlug}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "at", at) + return a.makeGetStatusCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetStatusCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestRefSyncStatus, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestRefSyncStatus + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestRefSyncStatus](&response) + if err == nil { + result = response.Body.(RestRefSyncStatus) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetTagRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + name string + repositorySlug string +} + +func (r *RepositoryAPIGetTagRequest) Execute() (RestTag, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetTagExecute(r) +} + +func (a *RepositoryAPIRepository) GetTagRequest(ctx context.Context, projectKey string, name string, repositorySlug string) RepositoryAPIGetTagRequest { + return RepositoryAPIGetTagRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + name: name, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetTagExecute(r *RepositoryAPIGetTagRequest) (RestTag, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/tags/{name}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{name}", urlUtil.PathEscape(r.name)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetTagCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetTag(ctx context.Context, projectKey string, name string, repositorySlug string) (RestTag, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/tags/{name}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{name}", urlUtil.PathEscape(name)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetTagCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetTagCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestTag, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestTag + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestTag](&response) + if err == nil { + result = response.Body.(RestTag) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetTagsRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + orderBy *string + filterText *string + start *float32 + limit *float32 +} + + // Ordering of refs either ALPHABETICAL (by name) or MODIFICATION (last updated) +func (r *RepositoryAPIGetTagsRequest) OrderBy(orderBy string) *RepositoryAPIGetTagsRequest { + r.orderBy = &orderBy + return r +} + + // The text to match on. +func (r *RepositoryAPIGetTagsRequest) FilterText(filterText string) *RepositoryAPIGetTagsRequest { + r.filterText = &filterText + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIGetTagsRequest) Start(start float32) *RepositoryAPIGetTagsRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIGetTagsRequest) Limit(limit float32) *RepositoryAPIGetTagsRequest { + r.limit = &limit + return r +} + +func (r *RepositoryAPIGetTagsRequest) Execute() (GetTags200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetTagsExecute(r) +} + +func (a *RepositoryAPIRepository) GetTagsRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIGetTagsRequest { + return RepositoryAPIGetTagsRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetTagsExecute(r *RepositoryAPIGetTagsRequest) (GetTags200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/tags" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.orderBy!=nil { + withUrlQueryParam(requestURL, "orderBy", *r.orderBy) + } + if r.filterText!=nil { + withUrlQueryParam(requestURL, "filterText", *r.filterText) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeGetTagsCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetTags(ctx context.Context, projectKey string, repositorySlug string, orderBy string, filterText string, start float32, limit float32) (GetTags200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/tags" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "orderBy", orderBy) + withUrlQueryParam(requestURL, "filterText", filterText) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeGetTagsCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetTagsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetTags200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetTags200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetTags200Response](&response) + if err == nil { + result = response.Body.(GetTags200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIGetWebhook1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + webhookId string + repositorySlug string + statistics *string +} + + // <code>true</code> if statistics should be provided for the webhook +func (r *RepositoryAPIGetWebhook1Request) Statistics(statistics string) *RepositoryAPIGetWebhook1Request { + r.statistics = &statistics + return r +} + +func (r *RepositoryAPIGetWebhook1Request) Execute() (RestWebhook, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetWebhook1Execute(r) +} + +func (a *RepositoryAPIRepository) GetWebhook1Request(ctx context.Context, projectKey string, webhookId string, repositorySlug string) RepositoryAPIGetWebhook1Request { + return RepositoryAPIGetWebhook1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + webhookId: webhookId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) GetWebhook1Execute(r *RepositoryAPIGetWebhook1Request) (RestWebhook, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{webhookId}", urlUtil.PathEscape(r.webhookId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.statistics!=nil { + withUrlQueryParam(requestURL, "statistics", *r.statistics) + } + return a.makeGetWebhook1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) GetWebhook1(ctx context.Context, projectKey string, webhookId string, repositorySlug string, statistics string) (RestWebhook, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{webhookId}", urlUtil.PathEscape(webhookId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "statistics", statistics) + return a.makeGetWebhook1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeGetWebhook1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestWebhook, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestWebhook + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestWebhook](&response) + if err == nil { + result = response.Body.(RestWebhook) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIReactRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commentId string + commitId string + emoticon string + repositorySlug string +} + +func (r *RepositoryAPIReactRequest) Execute() (RestUserReaction, aurestclientapi.ParsedResponse, error) { + return r.ApiService.ReactExecute(r) +} + +func (a *RepositoryAPIRepository) ReactRequest(ctx context.Context, projectKey string, commentId string, commitId string, emoticon string, repositorySlug string) RepositoryAPIReactRequest { + return RepositoryAPIReactRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + commitId: commitId, + emoticon: emoticon, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) ReactExecute(r *RepositoryAPIReactRequest) (RestUserReaction, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/comment-likes/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}/reactions/{emoticon}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{emoticon}", urlUtil.PathEscape(r.emoticon)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeReactCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) React(ctx context.Context, projectKey string, commentId string, commitId string, emoticon string, repositorySlug string) (RestUserReaction, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/comment-likes/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}/reactions/{emoticon}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{emoticon}", urlUtil.PathEscape(emoticon)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeReactCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeReactCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestUserReaction, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestUserReaction + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestUserReaction](&response) + if err == nil { + result = response.Body.(RestUserReaction) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIRemoveConfiguration1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + scriptId string + repositorySlug string +} + +func (r *RepositoryAPIRemoveConfiguration1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.RemoveConfiguration1Execute(r) +} + +func (a *RepositoryAPIRepository) RemoveConfiguration1Request(ctx context.Context, projectKey string, scriptId string, repositorySlug string) RepositoryAPIRemoveConfiguration1Request { + return RepositoryAPIRemoveConfiguration1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + scriptId: scriptId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) RemoveConfiguration1Execute(r *RepositoryAPIRemoveConfiguration1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/hook-scripts/{scriptId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{scriptId}", urlUtil.PathEscape(r.scriptId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeRemoveConfiguration1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) RemoveConfiguration1(ctx context.Context, projectKey string, scriptId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/hook-scripts/{scriptId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{scriptId}", urlUtil.PathEscape(scriptId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeRemoveConfiguration1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeRemoveConfiguration1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIRemoveLabelRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + labelName string + repositorySlug string +} + +func (r *RepositoryAPIRemoveLabelRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.RemoveLabelExecute(r) +} + +func (a *RepositoryAPIRepository) RemoveLabelRequest(ctx context.Context, projectKey string, labelName string, repositorySlug string) RepositoryAPIRemoveLabelRequest { + return RepositoryAPIRemoveLabelRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + labelName: labelName, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) RemoveLabelExecute(r *RepositoryAPIRemoveLabelRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/labels/{labelName}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{labelName}", urlUtil.PathEscape(r.labelName)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeRemoveLabelCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) RemoveLabel(ctx context.Context, projectKey string, labelName string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/labels/{labelName}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{labelName}", urlUtil.PathEscape(labelName)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeRemoveLabelCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeRemoveLabelCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPISaveAttachmentMetadataRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + attachmentId string + repositorySlug string + body *string +} + + // The attachment metadata can be any valid JSON content +func (r *RepositoryAPISaveAttachmentMetadataRequest) Body(body string) *RepositoryAPISaveAttachmentMetadataRequest { + r.body = &body + return r +} + +func (r *RepositoryAPISaveAttachmentMetadataRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.SaveAttachmentMetadataExecute(r) +} + +func (a *RepositoryAPIRepository) SaveAttachmentMetadataRequest(ctx context.Context, projectKey string, attachmentId string, repositorySlug string) RepositoryAPISaveAttachmentMetadataRequest { + return RepositoryAPISaveAttachmentMetadataRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + attachmentId: attachmentId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) SaveAttachmentMetadataExecute(r *RepositoryAPISaveAttachmentMetadataRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/attachments/{attachmentId}/metadata" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{attachmentId}", urlUtil.PathEscape(r.attachmentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSaveAttachmentMetadataCall(r.ctx, requestURL, r.body) +} + +func (a *RepositoryAPIRepository) SaveAttachmentMetadata(ctx context.Context, projectKey string, attachmentId string, repositorySlug string, body string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/attachments/{attachmentId}/metadata" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{attachmentId}", urlUtil.PathEscape(attachmentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSaveAttachmentMetadataCall(ctx, requestURL, body) +} + +func (a *RepositoryAPIRepository) makeSaveAttachmentMetadataCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPISearchWebhooksRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + scopeType *string + event *string + statistics *bool +} + + // Scopes to filter by. This parameter can be specified once e.g. \"scopeType=repository\", or twice e.g. \"scopeType=repository&scopeType=project\", to filter by more than one scope level. +func (r *RepositoryAPISearchWebhooksRequest) ScopeType(scopeType string) *RepositoryAPISearchWebhooksRequest { + r.scopeType = &scopeType + return r +} + + // List of <code>com.atlassian.webhooks.WebhookEvent</code> ids to filter for +func (r *RepositoryAPISearchWebhooksRequest) Event(event string) *RepositoryAPISearchWebhooksRequest { + r.event = &event + return r +} + + // <code>true</code> if statistics should be provided for all found webhooks +func (r *RepositoryAPISearchWebhooksRequest) Statistics(statistics bool) *RepositoryAPISearchWebhooksRequest { + r.statistics = &statistics + return r +} + +func (r *RepositoryAPISearchWebhooksRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.SearchWebhooksExecute(r) +} + +func (a *RepositoryAPIRepository) SearchWebhooksRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPISearchWebhooksRequest { + return RepositoryAPISearchWebhooksRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) SearchWebhooksExecute(r *RepositoryAPISearchWebhooksRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/search" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.scopeType!=nil { + withUrlQueryParam(requestURL, "scopeType", *r.scopeType) + } + if r.event!=nil { + withUrlQueryParam(requestURL, "event", *r.event) + } + if r.statistics!=nil { + withUrlQueryParam(requestURL, "statistics", parameterValueToString(*r.statistics)) + } + return a.makeSearchWebhooksCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) SearchWebhooks(ctx context.Context, projectKey string, repositorySlug string, scopeType string, event string, statistics bool) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/search" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "scopeType", scopeType) + withUrlQueryParam(requestURL, "event", event) + withUrlQueryParam(requestURL, "statistics", parameterValueToString(statistics)) + return a.makeSearchWebhooksCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeSearchWebhooksCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPISet1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restAutoMergeSettingsRequest *RestAutoMergeSettingsRequest +} + + // The settings to create or update +func (r *RepositoryAPISet1Request) RestAutoMergeSettingsRequest(restAutoMergeSettingsRequest RestAutoMergeSettingsRequest) *RepositoryAPISet1Request { + r.restAutoMergeSettingsRequest = &restAutoMergeSettingsRequest + return r +} + +func (r *RepositoryAPISet1Request) Execute() (RestAutoMergeRestrictedSettings, aurestclientapi.ParsedResponse, error) { + return r.ApiService.Set1Execute(r) +} + +func (a *RepositoryAPIRepository) Set1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPISet1Request { + return RepositoryAPISet1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) Set1Execute(r *RepositoryAPISet1Request) (RestAutoMergeRestrictedSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSet1Call(r.ctx, requestURL, r.restAutoMergeSettingsRequest) +} + +func (a *RepositoryAPIRepository) Set1(ctx context.Context, projectKey string, repositorySlug string, restAutoMergeSettingsRequest RestAutoMergeSettingsRequest) (RestAutoMergeRestrictedSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-merge" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSet1Call(ctx, requestURL, restAutoMergeSettingsRequest) +} + +func (a *RepositoryAPIRepository) makeSet1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestAutoMergeRestrictedSettings, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestAutoMergeRestrictedSettings + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 403 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestAutoMergeRestrictedSettings](&response) + if err == nil { + result = response.Body.(RestAutoMergeRestrictedSettings) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPISetAutoDeclineSettings1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restAutoDeclineSettingsRequest *RestAutoDeclineSettingsRequest +} + + // The settings to create or update +func (r *RepositoryAPISetAutoDeclineSettings1Request) RestAutoDeclineSettingsRequest(restAutoDeclineSettingsRequest RestAutoDeclineSettingsRequest) *RepositoryAPISetAutoDeclineSettings1Request { + r.restAutoDeclineSettingsRequest = &restAutoDeclineSettingsRequest + return r +} + +func (r *RepositoryAPISetAutoDeclineSettings1Request) Execute() (RestAutoDeclineSettings, aurestclientapi.ParsedResponse, error) { + return r.ApiService.SetAutoDeclineSettings1Execute(r) +} + +func (a *RepositoryAPIRepository) SetAutoDeclineSettings1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPISetAutoDeclineSettings1Request { + return RepositoryAPISetAutoDeclineSettings1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) SetAutoDeclineSettings1Execute(r *RepositoryAPISetAutoDeclineSettings1Request) (RestAutoDeclineSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-decline" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetAutoDeclineSettings1Call(r.ctx, requestURL, r.restAutoDeclineSettingsRequest) +} + +func (a *RepositoryAPIRepository) SetAutoDeclineSettings1(ctx context.Context, projectKey string, repositorySlug string, restAutoDeclineSettingsRequest RestAutoDeclineSettingsRequest) (RestAutoDeclineSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/auto-decline" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetAutoDeclineSettings1Call(ctx, requestURL, restAutoDeclineSettingsRequest) +} + +func (a *RepositoryAPIRepository) makeSetAutoDeclineSettings1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestAutoDeclineSettings, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestAutoDeclineSettings + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestAutoDeclineSettings](&response) + if err == nil { + result = response.Body.(RestAutoDeclineSettings) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPISetConfiguration1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + scriptId string + repositorySlug string + restHookScriptTriggers *RestHookScriptTriggers +} + + // The hook triggers for which the hook script should be run +func (r *RepositoryAPISetConfiguration1Request) RestHookScriptTriggers(restHookScriptTriggers RestHookScriptTriggers) *RepositoryAPISetConfiguration1Request { + r.restHookScriptTriggers = &restHookScriptTriggers + return r +} + +func (r *RepositoryAPISetConfiguration1Request) Execute() (RestHookScriptConfig, aurestclientapi.ParsedResponse, error) { + return r.ApiService.SetConfiguration1Execute(r) +} + +func (a *RepositoryAPIRepository) SetConfiguration1Request(ctx context.Context, projectKey string, scriptId string, repositorySlug string) RepositoryAPISetConfiguration1Request { + return RepositoryAPISetConfiguration1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + scriptId: scriptId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) SetConfiguration1Execute(r *RepositoryAPISetConfiguration1Request) (RestHookScriptConfig, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/hook-scripts/{scriptId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{scriptId}", urlUtil.PathEscape(r.scriptId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetConfiguration1Call(r.ctx, requestURL, r.restHookScriptTriggers) +} + +func (a *RepositoryAPIRepository) SetConfiguration1(ctx context.Context, projectKey string, scriptId string, repositorySlug string, restHookScriptTriggers RestHookScriptTriggers) (RestHookScriptConfig, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/hook-scripts/{scriptId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{scriptId}", urlUtil.PathEscape(scriptId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetConfiguration1Call(ctx, requestURL, restHookScriptTriggers) +} + +func (a *RepositoryAPIRepository) makeSetConfiguration1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestHookScriptConfig, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestHookScriptConfig + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestHookScriptConfig](&response) + if err == nil { + result = response.Body.(RestHookScriptConfig) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPISetDefaultBranch1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restBranch *RestBranch +} + + // The branch to set as default +func (r *RepositoryAPISetDefaultBranch1Request) RestBranch(restBranch RestBranch) *RepositoryAPISetDefaultBranch1Request { + r.restBranch = &restBranch + return r +} + +func (r *RepositoryAPISetDefaultBranch1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.SetDefaultBranch1Execute(r) +} + +func (a *RepositoryAPIRepository) SetDefaultBranch1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPISetDefaultBranch1Request { + return RepositoryAPISetDefaultBranch1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +// Deprecated +func (a *RepositoryAPIRepository) SetDefaultBranch1Execute(r *RepositoryAPISetDefaultBranch1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/branches/default" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetDefaultBranch1Call(r.ctx, requestURL, r.restBranch) +} + +func (a *RepositoryAPIRepository) SetDefaultBranch1(ctx context.Context, projectKey string, repositorySlug string, restBranch RestBranch) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/branches/default" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetDefaultBranch1Call(ctx, requestURL, restBranch) +} + +func (a *RepositoryAPIRepository) makeSetDefaultBranch1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPISetEnabledRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restRefSyncStatus *RestRefSyncStatus +} + +func (r *RepositoryAPISetEnabledRequest) RestRefSyncStatus(restRefSyncStatus RestRefSyncStatus) *RepositoryAPISetEnabledRequest { + r.restRefSyncStatus = &restRefSyncStatus + return r +} + +func (r *RepositoryAPISetEnabledRequest) Execute() (RestRefSyncStatus, aurestclientapi.ParsedResponse, error) { + return r.ApiService.SetEnabledExecute(r) +} + +func (a *RepositoryAPIRepository) SetEnabledRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPISetEnabledRequest { + return RepositoryAPISetEnabledRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) SetEnabledExecute(r *RepositoryAPISetEnabledRequest) (RestRefSyncStatus, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/sync/latest/projects/{projectKey}/repos/{repositorySlug}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetEnabledCall(r.ctx, requestURL, r.restRefSyncStatus) +} + +func (a *RepositoryAPIRepository) SetEnabled(ctx context.Context, projectKey string, repositorySlug string, restRefSyncStatus RestRefSyncStatus) (RestRefSyncStatus, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/sync/latest/projects/{projectKey}/repos/{repositorySlug}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetEnabledCall(ctx, requestURL, restRefSyncStatus) +} + +func (a *RepositoryAPIRepository) makeSetEnabledCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestRefSyncStatus, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestRefSyncStatus + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestRefSyncStatus](&response) + if err == nil { + result = response.Body.(RestRefSyncStatus) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPISetSettings1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + hookKey string + repositorySlug string + exampleSettings *ExampleSettings +} + + // The raw settings. +func (r *RepositoryAPISetSettings1Request) ExampleSettings(exampleSettings ExampleSettings) *RepositoryAPISetSettings1Request { + r.exampleSettings = &exampleSettings + return r +} + +func (r *RepositoryAPISetSettings1Request) Execute() (ExampleSettings, aurestclientapi.ParsedResponse, error) { + return r.ApiService.SetSettings1Execute(r) +} + +func (a *RepositoryAPIRepository) SetSettings1Request(ctx context.Context, projectKey string, hookKey string, repositorySlug string) RepositoryAPISetSettings1Request { + return RepositoryAPISetSettings1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + hookKey: hookKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) SetSettings1Execute(r *RepositoryAPISetSettings1Request) (ExampleSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}/settings" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{hookKey}", urlUtil.PathEscape(r.hookKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetSettings1Call(r.ctx, requestURL, r.exampleSettings) +} + +func (a *RepositoryAPIRepository) SetSettings1(ctx context.Context, projectKey string, hookKey string, repositorySlug string, exampleSettings ExampleSettings) (ExampleSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/hooks/{hookKey}/settings" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{hookKey}", urlUtil.PathEscape(hookKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSetSettings1Call(ctx, requestURL, exampleSettings) +} + +func (a *RepositoryAPIRepository) makeSetSettings1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (ExampleSettings, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result ExampleSettings + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[ExampleSettings](&response) + if err == nil { + result = response.Body.(ExampleSettings) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIStreamRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + at *string +} + + // The commit to use as the starting point when listing files and calculating modifications +func (r *RepositoryAPIStreamRequest) At(at string) *RepositoryAPIStreamRequest { + r.at = &at + return r +} + +func (r *RepositoryAPIStreamRequest) Execute() (ExampleFiles, aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamExecute(r) +} + +func (a *RepositoryAPIRepository) StreamRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIStreamRequest { + return RepositoryAPIStreamRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) StreamExecute(r *RepositoryAPIStreamRequest) (ExampleFiles, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/last-modified" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.at!=nil { + withUrlQueryParam(requestURL, "at", *r.at) + } + return a.makeStreamCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) Stream(ctx context.Context, projectKey string, repositorySlug string, at string) (ExampleFiles, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/last-modified" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "at", at) + return a.makeStreamCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeStreamCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (ExampleFiles, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result ExampleFiles + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[ExampleFiles](&response) + if err == nil { + result = response.Body.(ExampleFiles) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIStream1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + path string + projectKey string + repositorySlug string + at *string +} + + // The commit to use as the starting point when listing files and calculating modifications +func (r *RepositoryAPIStream1Request) At(at string) *RepositoryAPIStream1Request { + r.at = &at + return r +} + +func (r *RepositoryAPIStream1Request) Execute() (ExampleFiles, aurestclientapi.ParsedResponse, error) { + return r.ApiService.Stream1Execute(r) +} + +func (a *RepositoryAPIRepository) Stream1Request(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIStream1Request { + return RepositoryAPIStream1Request{ + ApiService: a, + ctx: ctx, + path: path, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) Stream1Execute(r *RepositoryAPIStream1Request) (ExampleFiles, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/last-modified/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(r.path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.at!=nil { + withUrlQueryParam(requestURL, "at", *r.at) + } + return a.makeStream1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) Stream1(ctx context.Context, path string, projectKey string, repositorySlug string, at string) (ExampleFiles, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/last-modified/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "at", at) + return a.makeStream1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeStream1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (ExampleFiles, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result ExampleFiles + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[ExampleFiles](&response) + if err == nil { + result = response.Body.(ExampleFiles) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIStreamChangesRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + fromRepo *string + from *string + to *string + start *float32 + limit *float32 +} + + // an optional parameter specifying the source repository containing the source commit if that commit is not present in the current repository; the repository can be specified by either its ID <em>fromRepo=42</em> or by its project key plus its repo slug separated by a slash: <em>fromRepo=projectKey/repoSlug</em> +func (r *RepositoryAPIStreamChangesRequest) FromRepo(fromRepo string) *RepositoryAPIStreamChangesRequest { + r.fromRepo = &fromRepo + return r +} + + // the source commit (can be a partial/full commit ID or qualified/unqualified ref name) +func (r *RepositoryAPIStreamChangesRequest) From(from string) *RepositoryAPIStreamChangesRequest { + r.from = &from + return r +} + + // the target commit (can be a partial/full commit ID or qualified/unqualified ref name) +func (r *RepositoryAPIStreamChangesRequest) To(to string) *RepositoryAPIStreamChangesRequest { + r.to = &to + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIStreamChangesRequest) Start(start float32) *RepositoryAPIStreamChangesRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIStreamChangesRequest) Limit(limit float32) *RepositoryAPIStreamChangesRequest { + r.limit = &limit + return r +} + +func (r *RepositoryAPIStreamChangesRequest) Execute() (GetChanges1200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamChangesExecute(r) +} + +func (a *RepositoryAPIRepository) StreamChangesRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIStreamChangesRequest { + return RepositoryAPIStreamChangesRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) StreamChangesExecute(r *RepositoryAPIStreamChangesRequest) (GetChanges1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/compare/changes" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.fromRepo!=nil { + withUrlQueryParam(requestURL, "fromRepo", *r.fromRepo) + } + if r.from!=nil { + withUrlQueryParam(requestURL, "from", *r.from) + } + if r.to!=nil { + withUrlQueryParam(requestURL, "to", *r.to) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeStreamChangesCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) StreamChanges(ctx context.Context, projectKey string, repositorySlug string, fromRepo string, from string, to string, start float32, limit float32) (GetChanges1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/compare/changes" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "fromRepo", fromRepo) + withUrlQueryParam(requestURL, "from", from) + withUrlQueryParam(requestURL, "to", to) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeStreamChangesCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeStreamChangesCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetChanges1200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetChanges1200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetChanges1200Response](&response) + if err == nil { + result = response.Body.(GetChanges1200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIStreamCommitsRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + fromRepo *string + from *string + to *string + start *float32 + limit *float32 +} + + // an optional parameter specifying the source repository containing the source commit if that commit is not present in the current repository; the repository can be specified by either its ID <em>fromRepo=42</em> or by its project key plus its repo slug separated by a slash: <em>fromRepo=projectKey/repoSlug</em> +func (r *RepositoryAPIStreamCommitsRequest) FromRepo(fromRepo string) *RepositoryAPIStreamCommitsRequest { + r.fromRepo = &fromRepo + return r +} + + // the source commit (can be a partial/full commit ID or qualified/unqualified ref name) +func (r *RepositoryAPIStreamCommitsRequest) From(from string) *RepositoryAPIStreamCommitsRequest { + r.from = &from + return r +} + + // the target commit (can be a partial/full commit ID or qualified/unqualified ref name) +func (r *RepositoryAPIStreamCommitsRequest) To(to string) *RepositoryAPIStreamCommitsRequest { + r.to = &to + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIStreamCommitsRequest) Start(start float32) *RepositoryAPIStreamCommitsRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIStreamCommitsRequest) Limit(limit float32) *RepositoryAPIStreamCommitsRequest { + r.limit = &limit + return r +} + +func (r *RepositoryAPIStreamCommitsRequest) Execute() (GetCommits200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamCommitsExecute(r) +} + +func (a *RepositoryAPIRepository) StreamCommitsRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIStreamCommitsRequest { + return RepositoryAPIStreamCommitsRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) StreamCommitsExecute(r *RepositoryAPIStreamCommitsRequest) (GetCommits200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/compare/commits" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.fromRepo!=nil { + withUrlQueryParam(requestURL, "fromRepo", *r.fromRepo) + } + if r.from!=nil { + withUrlQueryParam(requestURL, "from", *r.from) + } + if r.to!=nil { + withUrlQueryParam(requestURL, "to", *r.to) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeStreamCommitsCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) StreamCommits(ctx context.Context, projectKey string, repositorySlug string, fromRepo string, from string, to string, start float32, limit float32) (GetCommits200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/compare/commits" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "fromRepo", fromRepo) + withUrlQueryParam(requestURL, "from", from) + withUrlQueryParam(requestURL, "to", to) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeStreamCommitsCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeStreamCommitsCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (GetCommits200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result GetCommits200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[GetCommits200Response](&response) + if err == nil { + result = response.Body.(GetCommits200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIStreamDiffRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + commitId string + repositorySlug string + path string + projectKey string + srcPath *string + avatarSize *string + filter *string + avatarScheme *string + contextLines *string + autoSrcPath *string + whitespace *string + withComments *string + since *string +} + + // The source path for the file, if it was copied, moved or renamed +func (r *RepositoryAPIStreamDiffRequest) SrcPath(srcPath string) *RepositoryAPIStreamDiffRequest { + r.srcPath = &srcPath + return r +} + + // If present the service adds avatar URLs for comment authors where the provided value specifies the desired avatar size in pixels. Not applicable if streaming raw diff +func (r *RepositoryAPIStreamDiffRequest) AvatarSize(avatarSize string) *RepositoryAPIStreamDiffRequest { + r.avatarSize = &avatarSize + return r +} + + // Text used to filter files and lines (optional). Not applicable if streaming raw diff +func (r *RepositoryAPIStreamDiffRequest) Filter(filter string) *RepositoryAPIStreamDiffRequest { + r.filter = &filter + return r +} + + // The security scheme for avatar URLs. If the scheme is not present then it is inherited from the request. It can be set to \"https\" to force the use of secure URLs. Not applicable if streaming raw diff +func (r *RepositoryAPIStreamDiffRequest) AvatarScheme(avatarScheme string) *RepositoryAPIStreamDiffRequest { + r.avatarScheme = &avatarScheme + return r +} + + // The number of context lines to include around added/removed lines in the diff.Not applicable if streaming raw diff +func (r *RepositoryAPIStreamDiffRequest) ContextLines(contextLines string) *RepositoryAPIStreamDiffRequest { + r.contextLines = &contextLines + return r +} + + // <code>true</code> to automatically try to find the source path when it's not provided, <code>false</code> otherwise. Requires the path to be provided. +func (r *RepositoryAPIStreamDiffRequest) AutoSrcPath(autoSrcPath string) *RepositoryAPIStreamDiffRequest { + r.autoSrcPath = &autoSrcPath + return r +} + + // Optional whitespace flag which can be set to ignore-all +func (r *RepositoryAPIStreamDiffRequest) Whitespace(whitespace string) *RepositoryAPIStreamDiffRequest { + r.whitespace = &whitespace + return r +} + + // <code>true</code> to embed comments in the diff (the default); otherwise <code>false</code> to stream the diff without comments. Not applicable if streaming raw diff +func (r *RepositoryAPIStreamDiffRequest) WithComments(withComments string) *RepositoryAPIStreamDiffRequest { + r.withComments = &withComments + return r +} + + // The base revision to diff from. If omitted the parent revision of the until revision is used +func (r *RepositoryAPIStreamDiffRequest) Since(since string) *RepositoryAPIStreamDiffRequest { + r.since = &since + return r +} + +func (r *RepositoryAPIStreamDiffRequest) Execute() (RestDiff, aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamDiffExecute(r) +} + +func (a *RepositoryAPIRepository) StreamDiffRequest(ctx context.Context, commitId string, repositorySlug string, path string, projectKey string) RepositoryAPIStreamDiffRequest { + return RepositoryAPIStreamDiffRequest{ + ApiService: a, + ctx: ctx, + commitId: commitId, + repositorySlug: repositorySlug, + path: path, + projectKey: projectKey, + } +} + +func (a *RepositoryAPIRepository) StreamDiffExecute(r *RepositoryAPIStreamDiffRequest) (RestDiff, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/diff/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(r.path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.srcPath!=nil { + withUrlQueryParam(requestURL, "srcPath", *r.srcPath) + } + if r.avatarSize!=nil { + withUrlQueryParam(requestURL, "avatarSize", *r.avatarSize) + } + if r.filter!=nil { + withUrlQueryParam(requestURL, "filter", *r.filter) + } + if r.avatarScheme!=nil { + withUrlQueryParam(requestURL, "avatarScheme", *r.avatarScheme) + } + if r.contextLines!=nil { + withUrlQueryParam(requestURL, "contextLines", *r.contextLines) + } + if r.autoSrcPath!=nil { + withUrlQueryParam(requestURL, "autoSrcPath", *r.autoSrcPath) + } + if r.whitespace!=nil { + withUrlQueryParam(requestURL, "whitespace", *r.whitespace) + } + if r.withComments!=nil { + withUrlQueryParam(requestURL, "withComments", *r.withComments) + } + if r.since!=nil { + withUrlQueryParam(requestURL, "since", *r.since) + } + return a.makeStreamDiffCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) StreamDiff(ctx context.Context, commitId string, repositorySlug string, path string, projectKey string, srcPath string, avatarSize string, filter string, avatarScheme string, contextLines string, autoSrcPath string, whitespace string, withComments string, since string) (RestDiff, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/diff/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "srcPath", srcPath) + withUrlQueryParam(requestURL, "avatarSize", avatarSize) + withUrlQueryParam(requestURL, "filter", filter) + withUrlQueryParam(requestURL, "avatarScheme", avatarScheme) + withUrlQueryParam(requestURL, "contextLines", contextLines) + withUrlQueryParam(requestURL, "autoSrcPath", autoSrcPath) + withUrlQueryParam(requestURL, "whitespace", whitespace) + withUrlQueryParam(requestURL, "withComments", withComments) + withUrlQueryParam(requestURL, "since", since) + return a.makeStreamDiffCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeStreamDiffCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestDiff, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestDiff + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestDiff](&response) + if err == nil { + result = response.Body.(RestDiff) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIStreamDiff1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + path string + projectKey string + repositorySlug string + contextLines *string + fromRepo *string + srcPath *string + from *string + to *string + whitespace *string + start *float32 + limit *float32 +} + + // an optional number of context lines to include around each added or removed lines in the diff +func (r *RepositoryAPIStreamDiff1Request) ContextLines(contextLines string) *RepositoryAPIStreamDiff1Request { + r.contextLines = &contextLines + return r +} + + // an optional parameter specifying the source repository containing the source commit if that commit is not present in the current repository; the repository can be specified by either its ID <em>fromRepo=42</em> or by its project key plus its repo slug separated by a slash: <em>fromRepo=projectKey/repoSlug</em> +func (r *RepositoryAPIStreamDiff1Request) FromRepo(fromRepo string) *RepositoryAPIStreamDiff1Request { + r.fromRepo = &fromRepo + return r +} + + // source path +func (r *RepositoryAPIStreamDiff1Request) SrcPath(srcPath string) *RepositoryAPIStreamDiff1Request { + r.srcPath = &srcPath + return r +} + + // the source commit (can be a partial/full commit ID or qualified/unqualified ref name) +func (r *RepositoryAPIStreamDiff1Request) From(from string) *RepositoryAPIStreamDiff1Request { + r.from = &from + return r +} + + // the target commit (can be a partial/full commit ID or qualified/unqualified ref name) +func (r *RepositoryAPIStreamDiff1Request) To(to string) *RepositoryAPIStreamDiff1Request { + r.to = &to + return r +} + + // an optional whitespace flag which can be set to <code>ignore-all</code> +func (r *RepositoryAPIStreamDiff1Request) Whitespace(whitespace string) *RepositoryAPIStreamDiff1Request { + r.whitespace = &whitespace + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIStreamDiff1Request) Start(start float32) *RepositoryAPIStreamDiff1Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIStreamDiff1Request) Limit(limit float32) *RepositoryAPIStreamDiff1Request { + r.limit = &limit + return r +} + +func (r *RepositoryAPIStreamDiff1Request) Execute() (StreamDiff1200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamDiff1Execute(r) +} + +func (a *RepositoryAPIRepository) StreamDiff1Request(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIStreamDiff1Request { + return RepositoryAPIStreamDiff1Request{ + ApiService: a, + ctx: ctx, + path: path, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) StreamDiff1Execute(r *RepositoryAPIStreamDiff1Request) (StreamDiff1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/compare/diff{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(r.path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.contextLines!=nil { + withUrlQueryParam(requestURL, "contextLines", *r.contextLines) + } + if r.fromRepo!=nil { + withUrlQueryParam(requestURL, "fromRepo", *r.fromRepo) + } + if r.srcPath!=nil { + withUrlQueryParam(requestURL, "srcPath", *r.srcPath) + } + if r.from!=nil { + withUrlQueryParam(requestURL, "from", *r.from) + } + if r.to!=nil { + withUrlQueryParam(requestURL, "to", *r.to) + } + if r.whitespace!=nil { + withUrlQueryParam(requestURL, "whitespace", *r.whitespace) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeStreamDiff1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) StreamDiff1(ctx context.Context, path string, projectKey string, repositorySlug string, contextLines string, fromRepo string, srcPath string, from string, to string, whitespace string, start float32, limit float32) (StreamDiff1200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/compare/diff{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "contextLines", contextLines) + withUrlQueryParam(requestURL, "fromRepo", fromRepo) + withUrlQueryParam(requestURL, "srcPath", srcPath) + withUrlQueryParam(requestURL, "from", from) + withUrlQueryParam(requestURL, "to", to) + withUrlQueryParam(requestURL, "whitespace", whitespace) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeStreamDiff1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeStreamDiff1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (StreamDiff1200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result StreamDiff1200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[StreamDiff1200Response](&response) + if err == nil { + result = response.Body.(StreamDiff1200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIStreamFilesRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + at *string + start *float32 + limit *float32 +} + + // The commit ID or ref (e.g. a branch or tag) to list the files at. If not specified the default branch will be used instead. +func (r *RepositoryAPIStreamFilesRequest) At(at string) *RepositoryAPIStreamFilesRequest { + r.at = &at + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIStreamFilesRequest) Start(start float32) *RepositoryAPIStreamFilesRequest { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIStreamFilesRequest) Limit(limit float32) *RepositoryAPIStreamFilesRequest { + r.limit = &limit + return r +} + +func (r *RepositoryAPIStreamFilesRequest) Execute() (StreamFiles200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamFilesExecute(r) +} + +func (a *RepositoryAPIRepository) StreamFilesRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIStreamFilesRequest { + return RepositoryAPIStreamFilesRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) StreamFilesExecute(r *RepositoryAPIStreamFilesRequest) (StreamFiles200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/files" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.at!=nil { + withUrlQueryParam(requestURL, "at", *r.at) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeStreamFilesCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) StreamFiles(ctx context.Context, projectKey string, repositorySlug string, at string, start float32, limit float32) (StreamFiles200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/files" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "at", at) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeStreamFilesCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeStreamFilesCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (StreamFiles200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result StreamFiles200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[StreamFiles200Response](&response) + if err == nil { + result = response.Body.(StreamFiles200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIStreamFiles1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + path string + projectKey string + repositorySlug string + at *string + start *float32 + limit *float32 +} + + // The commit ID or ref (e.g. a branch or tag) to list the files at. If not specified the default branch will be used instead. +func (r *RepositoryAPIStreamFiles1Request) At(at string) *RepositoryAPIStreamFiles1Request { + r.at = &at + return r +} + + // Start number for the page (inclusive). If not passed, first page is assumed. +func (r *RepositoryAPIStreamFiles1Request) Start(start float32) *RepositoryAPIStreamFiles1Request { + r.start = &start + return r +} + + // Number of items to return. If not passed, a page size of 25 is used. +func (r *RepositoryAPIStreamFiles1Request) Limit(limit float32) *RepositoryAPIStreamFiles1Request { + r.limit = &limit + return r +} + +func (r *RepositoryAPIStreamFiles1Request) Execute() (StreamFiles200Response, aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamFiles1Execute(r) +} + +func (a *RepositoryAPIRepository) StreamFiles1Request(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIStreamFiles1Request { + return RepositoryAPIStreamFiles1Request{ + ApiService: a, + ctx: ctx, + path: path, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) StreamFiles1Execute(r *RepositoryAPIStreamFiles1Request) (StreamFiles200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/files/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(r.path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.at!=nil { + withUrlQueryParam(requestURL, "at", *r.at) + } + if r.start!=nil { + withUrlQueryParam(requestURL, "start", parameterValueToString(*r.start)) + } + if r.limit!=nil { + withUrlQueryParam(requestURL, "limit", parameterValueToString(*r.limit)) + } + return a.makeStreamFiles1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) StreamFiles1(ctx context.Context, path string, projectKey string, repositorySlug string, at string, start float32, limit float32) (StreamFiles200Response, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/files/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "at", at) + withUrlQueryParam(requestURL, "start", parameterValueToString(start)) + withUrlQueryParam(requestURL, "limit", parameterValueToString(limit)) + return a.makeStreamFiles1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeStreamFiles1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (StreamFiles200Response, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result StreamFiles200Response + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[StreamFiles200Response](&response) + if err == nil { + result = response.Body.(StreamFiles200Response) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIStreamPatchRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + until *string + allAncestors *string + since *string +} + + // The target revision from which to generate the patch (required) +func (r *RepositoryAPIStreamPatchRequest) Until(until string) *RepositoryAPIStreamPatchRequest { + r.until = &until + return r +} + + // indicates whether or not to generate a patch which includes all the ancestors of the 'until' revision. If true, the value provided by 'since' is ignored. +func (r *RepositoryAPIStreamPatchRequest) AllAncestors(allAncestors string) *RepositoryAPIStreamPatchRequest { + r.allAncestors = &allAncestors + return r +} + + // The base revision from which to generate the patch. This is only applicable when 'allAncestors' is false. If omitted the patch will represent one single commit, the 'until'. +func (r *RepositoryAPIStreamPatchRequest) Since(since string) *RepositoryAPIStreamPatchRequest { + r.since = &since + return r +} + +func (r *RepositoryAPIStreamPatchRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamPatchExecute(r) +} + +func (a *RepositoryAPIRepository) StreamPatchRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIStreamPatchRequest { + return RepositoryAPIStreamPatchRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) StreamPatchExecute(r *RepositoryAPIStreamPatchRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/patch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.until!=nil { + withUrlQueryParam(requestURL, "until", *r.until) + } + if r.allAncestors!=nil { + withUrlQueryParam(requestURL, "allAncestors", *r.allAncestors) + } + if r.since!=nil { + withUrlQueryParam(requestURL, "since", *r.since) + } + return a.makeStreamPatchCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) StreamPatch(ctx context.Context, projectKey string, repositorySlug string, until string, allAncestors string, since string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/patch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "until", until) + withUrlQueryParam(requestURL, "allAncestors", allAncestors) + withUrlQueryParam(requestURL, "since", since) + return a.makeStreamPatchCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeStreamPatchCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIStreamRawRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + path string + projectKey string + repositorySlug string + at *string + markup *string + htmlEscape *string + includeHeadingId *string + hardwrap *string +} + + // A specific commit or ref to retrieve the raw content at, or the default branch if not specified +func (r *RepositoryAPIStreamRawRequest) At(at string) *RepositoryAPIStreamRawRequest { + r.at = &at + return r +} + + // If present or \"true\", triggers the raw content to be markup-rendered and returned as HTML; otherwise, if not specified, or any value other than \"true\", the content is streamed without markup +func (r *RepositoryAPIStreamRawRequest) Markup(markup string) *RepositoryAPIStreamRawRequest { + r.markup = &markup + return r +} + + // (Optional) true if HTML should be escaped in the input markup, false otherwise. If not specified, the value of the markup.render.html.escape property, which is true by default, will be used +func (r *RepositoryAPIStreamRawRequest) HtmlEscape(htmlEscape string) *RepositoryAPIStreamRawRequest { + r.htmlEscape = &htmlEscape + return r +} + + // (Optional) true if headings should contain an ID based on the heading content. If not specified, the value of the markup.render.headerids property, which is false by default, will be used +func (r *RepositoryAPIStreamRawRequest) IncludeHeadingId(includeHeadingId string) *RepositoryAPIStreamRawRequest { + r.includeHeadingId = &includeHeadingId + return r +} + + // (Optional) Whether the markup implementation should convert newlines to breaks. If not specified, the value of the markup.render.hardwrap property, which is true by default, will be used +func (r *RepositoryAPIStreamRawRequest) Hardwrap(hardwrap string) *RepositoryAPIStreamRawRequest { + r.hardwrap = &hardwrap + return r +} + +func (r *RepositoryAPIStreamRawRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamRawExecute(r) +} + +func (a *RepositoryAPIRepository) StreamRawRequest(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIStreamRawRequest { + return RepositoryAPIStreamRawRequest{ + ApiService: a, + ctx: ctx, + path: path, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) StreamRawExecute(r *RepositoryAPIStreamRawRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/raw/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(r.path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.at!=nil { + withUrlQueryParam(requestURL, "at", *r.at) + } + if r.markup!=nil { + withUrlQueryParam(requestURL, "markup", *r.markup) + } + if r.htmlEscape!=nil { + withUrlQueryParam(requestURL, "htmlEscape", *r.htmlEscape) + } + if r.includeHeadingId!=nil { + withUrlQueryParam(requestURL, "includeHeadingId", *r.includeHeadingId) + } + if r.hardwrap!=nil { + withUrlQueryParam(requestURL, "hardwrap", *r.hardwrap) + } + return a.makeStreamRawCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) StreamRaw(ctx context.Context, path string, projectKey string, repositorySlug string, at string, markup string, htmlEscape string, includeHeadingId string, hardwrap string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/raw/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "at", at) + withUrlQueryParam(requestURL, "markup", markup) + withUrlQueryParam(requestURL, "htmlEscape", htmlEscape) + withUrlQueryParam(requestURL, "includeHeadingId", includeHeadingId) + withUrlQueryParam(requestURL, "hardwrap", hardwrap) + return a.makeStreamRawCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeStreamRawCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIStreamRawDiffRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + contextLines *string + srcPath *string + until *string + whitespace *string + since *string +} + + // The number of context lines to include around added/removed lines in the diff +func (r *RepositoryAPIStreamRawDiffRequest) ContextLines(contextLines string) *RepositoryAPIStreamRawDiffRequest { + r.contextLines = &contextLines + return r +} + + // The source path for the file, if it was copied, moved or renamed +func (r *RepositoryAPIStreamRawDiffRequest) SrcPath(srcPath string) *RepositoryAPIStreamRawDiffRequest { + r.srcPath = &srcPath + return r +} + + // The target revision to diff to (required) +func (r *RepositoryAPIStreamRawDiffRequest) Until(until string) *RepositoryAPIStreamRawDiffRequest { + r.until = &until + return r +} + + // Optional whitespace flag which can be set to <code>ignore-all</code> +func (r *RepositoryAPIStreamRawDiffRequest) Whitespace(whitespace string) *RepositoryAPIStreamRawDiffRequest { + r.whitespace = &whitespace + return r +} + + // The base revision to diff from. If omitted the parent revision of the until revision is used +func (r *RepositoryAPIStreamRawDiffRequest) Since(since string) *RepositoryAPIStreamRawDiffRequest { + r.since = &since + return r +} + +func (r *RepositoryAPIStreamRawDiffRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamRawDiffExecute(r) +} + +func (a *RepositoryAPIRepository) StreamRawDiffRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIStreamRawDiffRequest { + return RepositoryAPIStreamRawDiffRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) StreamRawDiffExecute(r *RepositoryAPIStreamRawDiffRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/diff" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.contextLines!=nil { + withUrlQueryParam(requestURL, "contextLines", *r.contextLines) + } + if r.srcPath!=nil { + withUrlQueryParam(requestURL, "srcPath", *r.srcPath) + } + if r.until!=nil { + withUrlQueryParam(requestURL, "until", *r.until) + } + if r.whitespace!=nil { + withUrlQueryParam(requestURL, "whitespace", *r.whitespace) + } + if r.since!=nil { + withUrlQueryParam(requestURL, "since", *r.since) + } + return a.makeStreamRawDiffCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) StreamRawDiff(ctx context.Context, projectKey string, repositorySlug string, contextLines string, srcPath string, until string, whitespace string, since string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/diff" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "contextLines", contextLines) + withUrlQueryParam(requestURL, "srcPath", srcPath) + withUrlQueryParam(requestURL, "until", until) + withUrlQueryParam(requestURL, "whitespace", whitespace) + withUrlQueryParam(requestURL, "since", since) + return a.makeStreamRawDiffCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeStreamRawDiffCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIStreamRawDiff1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + path string + projectKey string + repositorySlug string + contextLines *string + srcPath *string + until *string + whitespace *string + since *string +} + + // The number of context lines to include around added/removed lines in the diff +func (r *RepositoryAPIStreamRawDiff1Request) ContextLines(contextLines string) *RepositoryAPIStreamRawDiff1Request { + r.contextLines = &contextLines + return r +} + + // The source path for the file, if it was copied, moved or renamed +func (r *RepositoryAPIStreamRawDiff1Request) SrcPath(srcPath string) *RepositoryAPIStreamRawDiff1Request { + r.srcPath = &srcPath + return r +} + + // The target revision to diff to (required) +func (r *RepositoryAPIStreamRawDiff1Request) Until(until string) *RepositoryAPIStreamRawDiff1Request { + r.until = &until + return r +} + + // Optional whitespace flag which can be set to <code>ignore-all</code> +func (r *RepositoryAPIStreamRawDiff1Request) Whitespace(whitespace string) *RepositoryAPIStreamRawDiff1Request { + r.whitespace = &whitespace + return r +} + + // The base revision to diff from. If omitted the parent revision of the until revision is used +func (r *RepositoryAPIStreamRawDiff1Request) Since(since string) *RepositoryAPIStreamRawDiff1Request { + r.since = &since + return r +} + +func (r *RepositoryAPIStreamRawDiff1Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.StreamRawDiff1Execute(r) +} + +func (a *RepositoryAPIRepository) StreamRawDiff1Request(ctx context.Context, path string, projectKey string, repositorySlug string) RepositoryAPIStreamRawDiff1Request { + return RepositoryAPIStreamRawDiff1Request{ + ApiService: a, + ctx: ctx, + path: path, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) StreamRawDiff1Execute(r *RepositoryAPIStreamRawDiff1Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/diff/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(r.path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.contextLines!=nil { + withUrlQueryParam(requestURL, "contextLines", *r.contextLines) + } + if r.srcPath!=nil { + withUrlQueryParam(requestURL, "srcPath", *r.srcPath) + } + if r.until!=nil { + withUrlQueryParam(requestURL, "until", *r.until) + } + if r.whitespace!=nil { + withUrlQueryParam(requestURL, "whitespace", *r.whitespace) + } + if r.since!=nil { + withUrlQueryParam(requestURL, "since", *r.since) + } + return a.makeStreamRawDiff1Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) StreamRawDiff1(ctx context.Context, path string, projectKey string, repositorySlug string, contextLines string, srcPath string, until string, whitespace string, since string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/diff/{path}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{path}", urlUtil.PathEscape(path)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "contextLines", contextLines) + withUrlQueryParam(requestURL, "srcPath", srcPath) + withUrlQueryParam(requestURL, "until", until) + withUrlQueryParam(requestURL, "whitespace", whitespace) + withUrlQueryParam(requestURL, "since", since) + return a.makeStreamRawDiff1Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeStreamRawDiff1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPISynchronizeRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restRefSyncRequest *RestRefSyncRequest +} + +func (r *RepositoryAPISynchronizeRequest) RestRefSyncRequest(restRefSyncRequest RestRefSyncRequest) *RepositoryAPISynchronizeRequest { + r.restRefSyncRequest = &restRefSyncRequest + return r +} + +func (r *RepositoryAPISynchronizeRequest) Execute() (RestRejectedRef, aurestclientapi.ParsedResponse, error) { + return r.ApiService.SynchronizeExecute(r) +} + +func (a *RepositoryAPIRepository) SynchronizeRequest(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPISynchronizeRequest { + return RepositoryAPISynchronizeRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) SynchronizeExecute(r *RepositoryAPISynchronizeRequest) (RestRejectedRef, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/sync/latest/projects/{projectKey}/repos/{repositorySlug}/synchronize" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSynchronizeCall(r.ctx, requestURL, r.restRefSyncRequest) +} + +func (a *RepositoryAPIRepository) Synchronize(ctx context.Context, projectKey string, repositorySlug string, restRefSyncRequest RestRefSyncRequest) (RestRejectedRef, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/sync/latest/projects/{projectKey}/repos/{repositorySlug}/synchronize" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeSynchronizeCall(ctx, requestURL, restRefSyncRequest) +} + +func (a *RepositoryAPIRepository) makeSynchronizeCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestRejectedRef, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestRejectedRef + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 501 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestRejectedRef](&response) + if err == nil { + result = response.Body.(RestRejectedRef) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPITestWebhook1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + webhookId *int32 + sslVerificationRequired *string + url *string + restWebhookCredentials *RestWebhookCredentials +} + +func (r *RepositoryAPITestWebhook1Request) WebhookId(webhookId int32) *RepositoryAPITestWebhook1Request { + r.webhookId = &webhookId + return r +} + + // Whether SSL verification is required for the specified webhook URL. Default value is <code>true</code>. +func (r *RepositoryAPITestWebhook1Request) SslVerificationRequired(sslVerificationRequired string) *RepositoryAPITestWebhook1Request { + r.sslVerificationRequired = &sslVerificationRequired + return r +} + + // The url in which to connect to +func (r *RepositoryAPITestWebhook1Request) Url(url string) *RepositoryAPITestWebhook1Request { + r.url = &url + return r +} + + // Basic authentication credentials, if required. +func (r *RepositoryAPITestWebhook1Request) RestWebhookCredentials(restWebhookCredentials RestWebhookCredentials) *RepositoryAPITestWebhook1Request { + r.restWebhookCredentials = &restWebhookCredentials + return r +} + +func (r *RepositoryAPITestWebhook1Request) Execute() (interface{}, aurestclientapi.ParsedResponse, error) { + return r.ApiService.TestWebhook1Execute(r) +} + +func (a *RepositoryAPIRepository) TestWebhook1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPITestWebhook1Request { + return RepositoryAPITestWebhook1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) TestWebhook1Execute(r *RepositoryAPITestWebhook1Request) (interface{}, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/test" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + if r.webhookId!=nil { + withUrlQueryParam(requestURL, "webhookId", parameterValueToString(*r.webhookId)) + } + if r.sslVerificationRequired!=nil { + withUrlQueryParam(requestURL, "sslVerificationRequired", *r.sslVerificationRequired) + } + if r.url!=nil { + withUrlQueryParam(requestURL, "url", *r.url) + } + return a.makeTestWebhook1Call(r.ctx, requestURL, r.restWebhookCredentials) +} + +func (a *RepositoryAPIRepository) TestWebhook1(ctx context.Context, projectKey string, repositorySlug string, restWebhookCredentials RestWebhookCredentials, webhookId int32, sslVerificationRequired string, url string) (interface{}, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/test" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + withUrlQueryParam(requestURL, "webhookId", parameterValueToString(webhookId)) + withUrlQueryParam(requestURL, "sslVerificationRequired", sslVerificationRequired) + withUrlQueryParam(requestURL, "url", url) + return a.makeTestWebhook1Call(ctx, requestURL, restWebhookCredentials) +} + +func (a *RepositoryAPIRepository) makeTestWebhook1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (interface{}, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result interface{} + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[interface{}](&response) + if err == nil { + result = response.Body.(interface{}) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIUnReactRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commentId string + commitId string + emoticon string + repositorySlug string +} + +func (r *RepositoryAPIUnReactRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.UnReactExecute(r) +} + +func (a *RepositoryAPIRepository) UnReactRequest(ctx context.Context, projectKey string, commentId string, commitId string, emoticon string, repositorySlug string) RepositoryAPIUnReactRequest { + return RepositoryAPIUnReactRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + commitId: commitId, + emoticon: emoticon, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) UnReactExecute(r *RepositoryAPIUnReactRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/comment-likes/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}/reactions/{emoticon}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{emoticon}", urlUtil.PathEscape(r.emoticon)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUnReactCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) UnReact(ctx context.Context, projectKey string, commentId string, commitId string, emoticon string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/comment-likes/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}/reactions/{emoticon}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{emoticon}", urlUtil.PathEscape(emoticon)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUnReactCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeUnReactCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIUnwatchRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commitId string + repositorySlug string +} + +func (r *RepositoryAPIUnwatchRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.UnwatchExecute(r) +} + +func (a *RepositoryAPIRepository) UnwatchRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIUnwatchRequest { + return RepositoryAPIUnwatchRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) UnwatchExecute(r *RepositoryAPIUnwatchRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/watch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUnwatchCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) Unwatch(ctx context.Context, projectKey string, commitId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/watch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUnwatchCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeUnwatchCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIUnwatch2Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string +} + +func (r *RepositoryAPIUnwatch2Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.Unwatch2Execute(r) +} + +func (a *RepositoryAPIRepository) Unwatch2Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIUnwatch2Request { + return RepositoryAPIUnwatch2Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) Unwatch2Execute(r *RepositoryAPIUnwatch2Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/watch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUnwatch2Call(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) Unwatch2(ctx context.Context, projectKey string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/watch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUnwatch2Call(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeUnwatch2Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodDelete + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIUpdateCommentRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commentId string + commitId string + repositorySlug string + restComment *RestComment +} + + // The comment to update +func (r *RepositoryAPIUpdateCommentRequest) RestComment(restComment RestComment) *RepositoryAPIUpdateCommentRequest { + r.restComment = &restComment + return r +} + +func (r *RepositoryAPIUpdateCommentRequest) Execute() (RestComment, aurestclientapi.ParsedResponse, error) { + return r.ApiService.UpdateCommentExecute(r) +} + +func (a *RepositoryAPIRepository) UpdateCommentRequest(ctx context.Context, projectKey string, commentId string, commitId string, repositorySlug string) RepositoryAPIUpdateCommentRequest { + return RepositoryAPIUpdateCommentRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commentId: commentId, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) UpdateCommentExecute(r *RepositoryAPIUpdateCommentRequest) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(r.commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdateCommentCall(r.ctx, requestURL, r.restComment) +} + +func (a *RepositoryAPIRepository) UpdateComment(ctx context.Context, projectKey string, commentId string, commitId string, repositorySlug string, restComment RestComment) (RestComment, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/comments/{commentId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commentId}", urlUtil.PathEscape(commentId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdateCommentCall(ctx, requestURL, restComment) +} + +func (a *RepositoryAPIRepository) makeUpdateCommentCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestComment, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestComment + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 409 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestComment](&response) + if err == nil { + result = response.Body.(RestComment) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIUpdatePullRequestSettings1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restRepositoryPullRequestSettings *RestRepositoryPullRequestSettings +} + + // The updated settings. +func (r *RepositoryAPIUpdatePullRequestSettings1Request) RestRepositoryPullRequestSettings(restRepositoryPullRequestSettings RestRepositoryPullRequestSettings) *RepositoryAPIUpdatePullRequestSettings1Request { + r.restRepositoryPullRequestSettings = &restRepositoryPullRequestSettings + return r +} + +func (r *RepositoryAPIUpdatePullRequestSettings1Request) Execute() (RestRepositoryPullRequestSettings, aurestclientapi.ParsedResponse, error) { + return r.ApiService.UpdatePullRequestSettings1Execute(r) +} + +func (a *RepositoryAPIRepository) UpdatePullRequestSettings1Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIUpdatePullRequestSettings1Request { + return RepositoryAPIUpdatePullRequestSettings1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) UpdatePullRequestSettings1Execute(r *RepositoryAPIUpdatePullRequestSettings1Request) (RestRepositoryPullRequestSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/pull-requests" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdatePullRequestSettings1Call(r.ctx, requestURL, r.restRepositoryPullRequestSettings) +} + +func (a *RepositoryAPIRepository) UpdatePullRequestSettings1(ctx context.Context, projectKey string, repositorySlug string, restRepositoryPullRequestSettings RestRepositoryPullRequestSettings) (RestRepositoryPullRequestSettings, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/settings/pull-requests" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdatePullRequestSettings1Call(ctx, requestURL, restRepositoryPullRequestSettings) +} + +func (a *RepositoryAPIRepository) makeUpdatePullRequestSettings1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestRepositoryPullRequestSettings, aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + var result RestRepositoryPullRequestSettings + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 400 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestRepositoryPullRequestSettings](&response) + if err == nil { + result = response.Body.(RestRepositoryPullRequestSettings) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIUpdateWebhook1Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + webhookId string + repositorySlug string + restWebhook *RestWebhook +} + + // The representation of the updated values for the webhook +func (r *RepositoryAPIUpdateWebhook1Request) RestWebhook(restWebhook RestWebhook) *RepositoryAPIUpdateWebhook1Request { + r.restWebhook = &restWebhook + return r +} + +func (r *RepositoryAPIUpdateWebhook1Request) Execute() (RestWebhook, aurestclientapi.ParsedResponse, error) { + return r.ApiService.UpdateWebhook1Execute(r) +} + +func (a *RepositoryAPIRepository) UpdateWebhook1Request(ctx context.Context, projectKey string, webhookId string, repositorySlug string) RepositoryAPIUpdateWebhook1Request { + return RepositoryAPIUpdateWebhook1Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + webhookId: webhookId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) UpdateWebhook1Execute(r *RepositoryAPIUpdateWebhook1Request) (RestWebhook, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{webhookId}", urlUtil.PathEscape(r.webhookId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdateWebhook1Call(r.ctx, requestURL, r.restWebhook) +} + +func (a *RepositoryAPIRepository) UpdateWebhook1(ctx context.Context, projectKey string, webhookId string, repositorySlug string, restWebhook RestWebhook) (RestWebhook, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/webhooks/{webhookId}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{webhookId}", urlUtil.PathEscape(webhookId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeUpdateWebhook1Call(ctx, requestURL, restWebhook) +} + +func (a *RepositoryAPIRepository) makeUpdateWebhook1Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestWebhook, aurestclientapi.ParsedResponse, error) { + method := http.MethodPut + requestUrl := requestURL.String() + + var result RestWebhook + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestWebhook](&response) + if err == nil { + result = response.Body.(RestWebhook) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + type RepositoryAPIWatchRequest struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + commitId string + repositorySlug string +} + +func (r *RepositoryAPIWatchRequest) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.WatchExecute(r) +} + +func (a *RepositoryAPIRepository) WatchRequest(ctx context.Context, projectKey string, commitId string, repositorySlug string) RepositoryAPIWatchRequest { + return RepositoryAPIWatchRequest{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + commitId: commitId, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) WatchExecute(r *RepositoryAPIWatchRequest) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/watch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(r.commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeWatchCall(r.ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) Watch(ctx context.Context, projectKey string, commitId string, repositorySlug string) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/commits/{commitId}/watch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{commitId}", urlUtil.PathEscape(commitId)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeWatchCall(ctx, requestURL, nil) +} + +func (a *RepositoryAPIRepository) makeWatchCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + type RepositoryAPIWatch2Request struct { + ctx context.Context + ApiService *RepositoryAPIRepository + projectKey string + repositorySlug string + restRepository *RestRepository +} + + // The repository to watch. +func (r *RepositoryAPIWatch2Request) RestRepository(restRepository RestRepository) *RepositoryAPIWatch2Request { + r.restRepository = &restRepository + return r +} + +func (r *RepositoryAPIWatch2Request) Execute() (aurestclientapi.ParsedResponse, error) { + return r.ApiService.Watch2Execute(r) +} + +func (a *RepositoryAPIRepository) Watch2Request(ctx context.Context, projectKey string, repositorySlug string) RepositoryAPIWatch2Request { + return RepositoryAPIWatch2Request{ + ApiService: a, + ctx: ctx, + projectKey: projectKey, + repositorySlug: repositorySlug, + } +} + +func (a *RepositoryAPIRepository) Watch2Execute(r *RepositoryAPIWatch2Request) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/watch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(r.projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(r.repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeWatch2Call(r.ctx, requestURL, r.restRepository) +} + +func (a *RepositoryAPIRepository) Watch2(ctx context.Context, projectKey string, repositorySlug string, restRepository RestRepository) (aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/projects/{projectKey}/repos/{repositorySlug}/watch" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{projectKey}", urlUtil.PathEscape(projectKey)) + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{repositorySlug}", urlUtil.PathEscape(repositorySlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeWatch2Call(ctx, requestURL, restRepository) +} + +func (a *RepositoryAPIRepository) makeWatch2Call(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (aurestclientapi.ParsedResponse, error) { + method := http.MethodPost + requestUrl := requestURL.String() + + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return response, err + } + + if response.Status < 400 { + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return response, err +} + +type RepositoryAPIRepository struct { + ApiClient *ApiClient +} + +func (c *RepositoryAPIRepository) baseUrl() string { + return c.ApiClient.BaseUrl +} + +func (c *RepositoryAPIRepository) httpClient() aurestclientapi.Client { + return c.ApiClient.Client +} + +func NewRepositoryAPI(client *ApiClient) RepositoryAPI { + return &RepositoryAPIRepository{ApiClient: client} +} diff --git a/internal/client/bitbucket/generated_api_user.go b/internal/client/bitbucket/generated_api_user.go new file mode 100644 index 0000000..7cd73d2 --- /dev/null +++ b/internal/client/bitbucket/generated_api_user.go @@ -0,0 +1,120 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + +import ( + "context" + "fmt" + aurestclientapi "github.com/StephanHCB/go-autumn-restclient/api" + "net/http" + urlUtil "net/url" + "strings" +) + +type UserAPI interface { + + /* + GetUser Get user + */ + GetUser(ctx context.Context, userSlug string) (RestApplicationUser, aurestclientapi.ParsedResponse, error) + + // GetUserExecutes the request + // @return RestApplicationUser + GetUserRequest(ctx context.Context, userSlug string) UserAPIGetUserRequest +} + + type UserAPIGetUserRequest struct { + ctx context.Context + ApiService *UserAPIRepository + userSlug string +} + +func (r *UserAPIGetUserRequest) Execute() (RestApplicationUser, aurestclientapi.ParsedResponse, error) { + return r.ApiService.GetUserExecute(r) +} + +func (a *UserAPIRepository) GetUserRequest(ctx context.Context, userSlug string) UserAPIGetUserRequest { + return UserAPIGetUserRequest{ + ApiService: a, + ctx: ctx, + userSlug: userSlug, + } +} + +func (a *UserAPIRepository) GetUserExecute(r *UserAPIGetUserRequest) (RestApplicationUser, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/users/{userSlug}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{userSlug}", urlUtil.PathEscape(r.userSlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetUserCall(r.ctx, requestURL, nil) +} + +func (a *UserAPIRepository) GetUser(ctx context.Context, userSlug string) (RestApplicationUser, aurestclientapi.ParsedResponse, error) { + fullUrlValue := a.baseUrl() + "/api/latest/users/{userSlug}" + fullUrlValue = strings.ReplaceAll(fullUrlValue, "{userSlug}", urlUtil.PathEscape(userSlug)) + requestURL, _ := urlUtil.Parse(fullUrlValue) + return a.makeGetUserCall(ctx, requestURL, nil) +} + +func (a *UserAPIRepository) makeGetUserCall(ctx context.Context, requestURL *urlUtil.URL, requestBody any) (RestApplicationUser, aurestclientapi.ParsedResponse, error) { + method := http.MethodGet + requestUrl := requestURL.String() + + var result RestApplicationUser + emptyResponse := make([]byte, 0) + responseBodyPointer := &emptyResponse + response := aurestclientapi.ParsedResponse{ + Body: &responseBodyPointer, + } + err := a.httpClient().Perform(ctx, method, requestUrl, requestBody, &response) + if err != nil { + return result,response, err + } + if response.Status == 401 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + if response.Status == 404 { + err = safeUnmarshal[DismissRetentionConfigReviewNotification401Response](&response) + if err == nil { + err = NewError(fmt.Sprintf("Got status %d", response.Status), response.Status) + } + return result, response, err + } + + if response.Status < 400 { + err = safeUnmarshal[RestApplicationUser](&response) + if err == nil { + result = response.Body.(RestApplicationUser) + } + } else { + err = NewError(fmt.Sprintf("Got unknown status %d", response.Status), response.Status) + } + return result, response, err +} + +type UserAPIRepository struct { + ApiClient *ApiClient +} + +func (c *UserAPIRepository) baseUrl() string { + return c.ApiClient.BaseUrl +} + +func (c *UserAPIRepository) httpClient() aurestclientapi.Client { + return c.ApiClient.Client +} + +func NewUserAPI(client *ApiClient) UserAPI { + return &UserAPIRepository{ApiClient: client} +} diff --git a/internal/client/bitbucket/generated_base_client.go b/internal/client/bitbucket/generated_base_client.go new file mode 100644 index 0000000..1079ddc --- /dev/null +++ b/internal/client/bitbucket/generated_base_client.go @@ -0,0 +1,342 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + +import ( + "bytes" + "context" + "encoding/json" + "fmt" + "io" + "mime/multipart" + "net/http" + urlUtil "net/url" + "strings" + "time" + + aulogging "github.com/StephanHCB/go-autumn-logging" + auloggingapi "github.com/StephanHCB/go-autumn-logging/api" + auapmclient "github.com/StephanHCB/go-autumn-restclient-apm/implementation/client" + aurestbreakerprometheus "github.com/StephanHCB/go-autumn-restclient-circuitbreaker-prometheus" + aurestbreaker "github.com/StephanHCB/go-autumn-restclient-circuitbreaker/implementation/breaker" + aurestclientprometheus "github.com/StephanHCB/go-autumn-restclient-prometheus" + aurestclientapi "github.com/StephanHCB/go-autumn-restclient/api" + aurestcaching "github.com/StephanHCB/go-autumn-restclient/implementation/caching" + auresthttpclient "github.com/StephanHCB/go-autumn-restclient/implementation/httpclient" + aurestrecorder "github.com/StephanHCB/go-autumn-restclient/implementation/recorder" + aurestlogging "github.com/StephanHCB/go-autumn-restclient/implementation/requestlogging" + aurestretry "github.com/StephanHCB/go-autumn-restclient/implementation/retry" + "github.com/go-http-utils/headers" +) + +const Authorization_ctx_value = "authorization" + +type ApiClient struct { + BaseUrl string + Client aurestclientapi.Client +} + +func NewApiClient() (*ApiClient) { + return &ApiClient{} +} + +func NewApiClientConfigured(cfg *ClientConfig) (*ApiClient, error) { + apiClient := NewApiClient() + err := apiClient.SetupApiClient(cfg) + return apiClient, err +} + +// --- setup --- +func (c *ApiClient) SetupApiClient(cfg *ClientConfig) error { + c.BaseUrl = cfg.BaseUrl + + //allow tests to pre-populate + if c.Client != nil { + return nil + } + + client, err := setupHttpClient(cfg.RequestManipulator) + if err != nil { + return err + } + + if cfg.LoggingConfigurer != nil { + client = cfg.LoggingConfigurer(client) + } + + if cfg.CircuitBreakerConfigurer != nil { + client = cfg.CircuitBreakerConfigurer(client) + } + + if cfg.ApmConfigurer != nil { + client = cfg.ApmConfigurer(client) + } + + if cfg.RetryConfigurer != nil { + client = cfg.RetryConfigurer(client) + } + if cfg.RecorderConfigurer != nil { + client = cfg.RecorderConfigurer(client) + } + if cfg.CachingConfigurer != nil { + client = cfg.CachingConfigurer(client, cfg.CacheRetention, cfg.CacheSize) + } + + c.Client = client + + return nil +} + +type RequestManipulatorFunc func(ctx context.Context, r *http.Request) + +func BasicAuthRequestManipulator(username string, password string) RequestManipulatorFunc { + return func(ctx context.Context, r *http.Request) { + r.SetBasicAuth(username, password) + } +} + +type ClientConfig struct { + BaseUrl string + + CacheRetention time.Duration + CacheSize int + + RequestManipulator RequestManipulatorFunc + AuthorizationRequestManipulator RequestManipulatorFunc + TracingRequestManipulator RequestManipulatorFunc + LoggingConfigurer func(client aurestclientapi.Client) aurestclientapi.Client + CircuitBreakerConfigurer func(client aurestclientapi.Client) aurestclientapi.Client + ApmConfigurer func(client aurestclientapi.Client) aurestclientapi.Client + RetryConfigurer func(client aurestclientapi.Client) aurestclientapi.Client + RecorderConfigurer func(client aurestclientapi.Client) aurestclientapi.Client + CachingConfigurer func(client aurestclientapi.Client, cacheRetentionSeconds time.Duration, cacheSize int) aurestclientapi.Client +} + +func DefaultApiClientConfig(baseUrl string) *ClientConfig { + config := &ClientConfig{ + BaseUrl: baseUrl, + RequestManipulator: nil, + AuthorizationRequestManipulator: authorizationHeaderSetter, + TracingRequestManipulator: nil, + LoggingConfigurer: setupLogging, + CircuitBreakerConfigurer: setupCircuitBreakerClient, + ApmConfigurer: setupApm, + RetryConfigurer: setupRetryClient, + RecorderConfigurer: setupRecorder, + CachingConfigurer: setupCachingClient, + CacheRetention: 60 * time.Second, + CacheSize: 1000, + } + config.RequestManipulator = requestHeaderManipulator(config) + return config +} + +func DefaultApiClientConfigNewWithOptions(baseUrl string) *ClientConfig { + config := DefaultApiClientConfig(baseUrl) + + config.LoggingConfigurer = CreateSetupLoggingNewWithOptions(aurestlogging.Debug, aurestlogging.Info, aurestlogging.Info) + config.RetryConfigurer = CreateRetryClientNewWithOptions(retryCondition(), betweenFailureAndRetry(), true) + + return config +} + +func setupHttpClient(configuredHeaderManipulator func(ctx context.Context, r *http.Request)) (aurestclientapi.Client, error) { + client, err := auresthttpclient.New(0, nil, configuredHeaderManipulator) + if err != nil { + return nil, err + } + aurestclientprometheus.InstrumentHttpClient(client) + + return client, nil +} + +func requestHeaderManipulator(config *ClientConfig) func(ctx context.Context, r *http.Request) { + return func(ctx context.Context, r *http.Request) { + r.Header.Set(headers.Accept, aurestclientapi.ContentTypeApplicationJson) + + if config != nil && config.AuthorizationRequestManipulator != nil { + config.AuthorizationRequestManipulator(ctx, r) + } + + if config != nil && config.TracingRequestManipulator != nil { + config.TracingRequestManipulator(ctx, r) + } + } +} + +func authorizationHeaderSetter(ctx context.Context, r *http.Request) { + ctxAuthorizationValue := ctx.Value(Authorization_ctx_value) + if ctxAuthorizationValue != nil { + ctxAuthrizationValueStr, ok := ctxAuthorizationValue.(string) + if ok && ctxAuthrizationValueStr != "" { + r.Header.Set(headers.Authorization, ctxAuthrizationValueStr) + } + } +} + +func setupCircuitBreakerClient(client aurestclientapi.Client) aurestclientapi.Client { + circuitBreakerWrapper := aurestbreaker.New( + client, + "Metadata", + 100, + 5*time.Minute, + 60*time.Second, + // includes possible retries, once the context is cancelled further requests will fail directly + 15*time.Second, + ) + aurestbreakerprometheus.InstrumentCircuitBreakerClient(circuitBreakerWrapper) + return circuitBreakerWrapper +} + +func CreateRetryClientNewWithOptions(retryConditionCallback aurestclientapi.RetryConditionCallback, + beforeRetryCallback aurestclientapi.BeforeRetryCallback, + silenceGivingUp bool) func(client aurestclientapi.Client) aurestclientapi.Client { + return func(client aurestclientapi.Client) aurestclientapi.Client { + retryWrapper := aurestretry.NewWithOptions( + client, + retryConditionCallback, + aurestretry.RetryOptions{ + RepeatCount: 3, + BeforeRetryOrNil: beforeRetryCallback, + SilenceGivingUp: silenceGivingUp, + }, + ) + aurestclientprometheus.InstrumentRetryClient(retryWrapper) + return retryWrapper + } +} + +func CreateSetupLoggingNewWithOptions(beforeRequestLogger func(ctx context.Context) auloggingapi.LeveledLoggingImplementation, + successLogger func(ctx context.Context) auloggingapi.LeveledLoggingImplementation, + failureLogger func(ctx context.Context) auloggingapi.LeveledLoggingImplementation) func(client aurestclientapi.Client) aurestclientapi.Client { + + return func(client aurestclientapi.Client) aurestclientapi.Client { + return aurestlogging.NewWithOptions(client, aurestlogging.RequestLoggingOptions{ + BeforeRequest: beforeRequestLogger, + Success: successLogger, + Failure: failureLogger, + }) + } +} + +func setupRetryClient(client aurestclientapi.Client) aurestclientapi.Client { + retryWrapper := aurestretry.New( + client, + 3, + retryCondition(), + betweenFailureAndRetry(), + ) + aurestclientprometheus.InstrumentRetryClient(retryWrapper) + return retryWrapper +} + +func retryCondition() aurestclientapi.RetryConditionCallback { + return func(_ context.Context, response *aurestclientapi.ParsedResponse, err error) bool { + return response.Status == http.StatusServiceUnavailable + } +} + +func betweenFailureAndRetry() aurestclientapi.BeforeRetryCallback { + return func(ctx context.Context, originalResponse *aurestclientapi.ParsedResponse, originalError error) error { + aulogging.Logger.Ctx(ctx).Warn().Print("got 503 from Metadata-endpoint - retrying request") + return nil + } +} + +func setupCachingClient(client aurestclientapi.Client, cacheRetentionSeconds time.Duration, cacheSize int) aurestclientapi.Client { + cacheWrapper := aurestcaching.New( + client, + func(ctx context.Context, method string, url string, requestBody interface{}) bool { + return method == http.MethodGet + }, + func(ctx context.Context, method string, url string, requestBody interface{}, response *aurestclientapi.ParsedResponse) bool { + return response != nil && response.Status == http.StatusOK + }, + nil, + cacheRetentionSeconds, + cacheSize, + ) + aurestclientprometheus.InstrumentCacheClient(cacheWrapper) + return cacheWrapper +} + +func setupLogging(client aurestclientapi.Client) aurestclientapi.Client { + return aurestlogging.New(client) +} + +func setupApm(client aurestclientapi.Client) aurestclientapi.Client { + return auapmclient.New(client) +} + +func setupRecorder(client aurestclientapi.Client) aurestclientapi.Client { + return aurestrecorder.New(client) +} + +// --- request implementations --- + +func safeUnmarshal[T any](response *aurestclientapi.ParsedResponse) error { + var result T + responseData, ok := response.Body.(**[]byte) + if ok { + if len(**responseData) > 0 { + err := json.Unmarshal(**responseData, &result) + if err != nil { + return NewErrorWrap(err, response.Status) + } + } + response.Body = result + } else { + return NewError(fmt.Sprintf("Something wrong"), response.Status) + } + return nil +} + +func createMultipartRequestForFile(ctx context.Context, fileName string, fileContent string) (aurestclientapi.CustomRequestBody, error) { + bufferBytes := &bytes.Buffer{} + + writer := multipart.NewWriter(bufferBytes) + defer func(writer *multipart.Writer) { + _ = writer.Close() + }(writer) + + part, _ := writer.CreateFormFile("files", fmt.Sprintf("%s.txt", fileName)) + _, err := io.Copy(part, strings.NewReader(fileContent)) + if err != nil { + return aurestclientapi.CustomRequestBody{}, err + } + + return aurestclientapi.CustomRequestBody{ + BodyReader: bufferBytes, + BodyLength: len(fileContent), + ContentType: writer.FormDataContentType(), + }, nil +} + +// ---- helper methods + +func withUrlQueryParam(requestUrl *urlUtil.URL, valueName string, value string) { + if value != "" { + queryParams := requestUrl.Query() + queryParams.Add(valueName, value) + requestUrl.RawQuery = queryParams.Encode() + } +} + +func parameterValueToString(obj interface{}) string { + return fmt.Sprint(obj) +} + +// A wrapper for strict JSON decoding +func newStrictDecoder(data []byte) *json.Decoder { + dec := json.NewDecoder(bytes.NewBuffer(data)) + dec.DisallowUnknownFields() + return dec +} \ No newline at end of file diff --git a/internal/client/bitbucket/generated_client_error.go b/internal/client/bitbucket/generated_client_error.go new file mode 100644 index 0000000..e77d0a1 --- /dev/null +++ b/internal/client/bitbucket/generated_client_error.go @@ -0,0 +1,53 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + +import "fmt" + +type IError interface { + IsHttpError() bool +} + +type HttpError struct { + err error + status int +} + +func NewErrorWrap(err error, status int) error { + return &HttpError{ + err: err, + status: status, + } +} + +func NewError(message string, status int) error { + return &HttpError{ + err: fmt.Errorf(message), + status: status, + } +} + +func (e *HttpError) Error() string { + return e.err.Error() +} + +func (e *HttpError) Status() int { + return e.status +} + +func (e *HttpError) IsHttpError() bool { + return true +} + +func IsHttpError(err error) bool { + _, ok := err.(IError) + return ok +} diff --git a/internal/client/bitbucket/generated_model_application_user.go b/internal/client/bitbucket/generated_model_application_user.go new file mode 100644 index 0000000..ffcaf0b --- /dev/null +++ b/internal/client/bitbucket/generated_model_application_user.go @@ -0,0 +1,23 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// ApplicationUser struct for ApplicationUser +type ApplicationUser struct { + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + Active *bool `yaml:"active,omitempty" json:"active,omitempty"` + DisplayName *string `yaml:"displayName,omitempty" json:"displayName,omitempty"` + Slug *string `yaml:"slug,omitempty" json:"slug,omitempty"` + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + EmailAddress *string `yaml:"emailAddress,omitempty" json:"emailAddress,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_context.go b/internal/client/bitbucket/generated_model_context.go new file mode 100644 index 0000000..292c742 --- /dev/null +++ b/internal/client/bitbucket/generated_model_context.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// Context struct for Context +type Context struct { + CommitMessage *string `yaml:"commitMessage,omitempty" json:"commitMessage,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_dismiss_retention_config_review_notification_401_response.go b/internal/client/bitbucket/generated_model_dismiss_retention_config_review_notification_401_response.go new file mode 100644 index 0000000..ecc8315 --- /dev/null +++ b/internal/client/bitbucket/generated_model_dismiss_retention_config_review_notification_401_response.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// DismissRetentionConfigReviewNotification401Response struct for DismissRetentionConfigReviewNotification401Response +type DismissRetentionConfigReviewNotification401Response struct { + Errors []RestErrorMessage `yaml:"errors,omitempty" json:"errors,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_example_files.go b/internal/client/bitbucket/generated_model_example_files.go new file mode 100644 index 0000000..61b96f0 --- /dev/null +++ b/internal/client/bitbucket/generated_model_example_files.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// ExampleFiles struct for ExampleFiles +type ExampleFiles struct { + Files *ExampleJsonLastModifiedCallback `yaml:"files,omitempty" json:"files,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_example_json_last_modified_callback.go b/internal/client/bitbucket/generated_model_example_json_last_modified_callback.go new file mode 100644 index 0000000..a02c5ef --- /dev/null +++ b/internal/client/bitbucket/generated_model_example_json_last_modified_callback.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// ExampleJsonLastModifiedCallback struct for ExampleJsonLastModifiedCallback +type ExampleJsonLastModifiedCallback struct { + LatestCommit *RestChangesetToCommit `yaml:"latestCommit,omitempty" json:"latestCommit,omitempty"` + ReadmeMd *RestChangesetToCommit `yaml:"readmeMd,omitempty" json:"readmeMd,omitempty"` + PomXml *RestChangesetToCommit `yaml:"pomXml,omitempty" json:"pomXml,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_example_multipart_form_data.go b/internal/client/bitbucket/generated_model_example_multipart_form_data.go new file mode 100644 index 0000000..e9fa3d5 --- /dev/null +++ b/internal/client/bitbucket/generated_model_example_multipart_form_data.go @@ -0,0 +1,26 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// ExampleMultipartFormData struct for ExampleMultipartFormData +type ExampleMultipartFormData struct { + // The branch on which the path should be modified or created. + Branch *string `yaml:"branch,omitempty" json:"branch,omitempty"` + // The full content of the file at path. + Content *string `yaml:"content,omitempty" json:"content,omitempty"` + // The message associated with this change, to be used as the commit message. Or null if the default message should be used. + Message *string `yaml:"message,omitempty" json:"message,omitempty"` + // The starting point for branch. If provided and different from branch, branch will be created as a new branch, branching off from sourceBranch. + SourceBranch *string `yaml:"sourceBranch,omitempty" json:"sourceBranch,omitempty"` + // The commit ID of the file before it was edited, used to identify if content has changed. Or null if this is a new file + SourceCommitId *string `yaml:"sourceCommitId,omitempty" json:"sourceCommitId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_example_settings.go b/internal/client/bitbucket/generated_model_example_settings.go new file mode 100644 index 0000000..731d152 --- /dev/null +++ b/internal/client/bitbucket/generated_model_example_settings.go @@ -0,0 +1,21 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// ExampleSettings struct for ExampleSettings +type ExampleSettings struct { + StringValue *string `yaml:"stringValue,omitempty" json:"stringValue,omitempty"` + BooleanValue *bool `yaml:"booleanValue,omitempty" json:"booleanValue,omitempty"` + DoubleValue *float64 `yaml:"doubleValue,omitempty" json:"doubleValue,omitempty"` + IntegerValue *int32 `yaml:"integerValue,omitempty" json:"integerValue,omitempty"` + LongValue *int64 `yaml:"longValue,omitempty" json:"longValue,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_find_by_commit_200_response.go b/internal/client/bitbucket/generated_model_find_by_commit_200_response.go new file mode 100644 index 0000000..456766c --- /dev/null +++ b/internal/client/bitbucket/generated_model_find_by_commit_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// FindByCommit200Response struct for FindByCommit200Response +type FindByCommit200Response struct { + Values []RestMinimalRef `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_activities_200_response.go b/internal/client/bitbucket/generated_model_get_activities_200_response.go new file mode 100644 index 0000000..1d37ac1 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_activities_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetActivities200Response struct for GetActivities200Response +type GetActivities200Response struct { + Values []RestPullRequestActivity `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_branches_200_response.go b/internal/client/bitbucket/generated_model_get_branches_200_response.go new file mode 100644 index 0000000..239e56b --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_branches_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetBranches200Response struct for GetBranches200Response +type GetBranches200Response struct { + Values []RestBranch `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_changes_1_200_response.go b/internal/client/bitbucket/generated_model_get_changes_1_200_response.go new file mode 100644 index 0000000..ca0eca2 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_changes_1_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetChanges1200Response struct for GetChanges1200Response +type GetChanges1200Response struct { + Values []RestChange `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_comments_200_response.go b/internal/client/bitbucket/generated_model_get_comments_200_response.go new file mode 100644 index 0000000..b497875 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_comments_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetComments200Response struct for GetComments200Response +type GetComments200Response struct { + Values []RestComment `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_commits_200_response.go b/internal/client/bitbucket/generated_model_get_commits_200_response.go new file mode 100644 index 0000000..b672160 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_commits_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetCommits200Response struct for GetCommits200Response +type GetCommits200Response struct { + Values []RestCommit `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_configurations_200_response.go b/internal/client/bitbucket/generated_model_get_configurations_200_response.go new file mode 100644 index 0000000..b1db149 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_configurations_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetConfigurations200Response struct for GetConfigurations200Response +type GetConfigurations200Response struct { + Values []RestHookScriptConfig `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_content_1_200_response.go b/internal/client/bitbucket/generated_model_get_content_1_200_response.go new file mode 100644 index 0000000..6012272 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_content_1_200_response.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetContent1200Response struct for GetContent1200Response +type GetContent1200Response struct { + Lines []GetContent1200ResponseLinesInner `yaml:"lines,omitempty" json:"lines,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + NextPageStart *float32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_content_1_200_response_lines_inner.go b/internal/client/bitbucket/generated_model_get_content_1_200_response_lines_inner.go new file mode 100644 index 0000000..b5c1ccf --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_content_1_200_response_lines_inner.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetContent1200ResponseLinesInner struct for GetContent1200ResponseLinesInner +type GetContent1200ResponseLinesInner struct { + Text *string `yaml:"text,omitempty" json:"text,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_likers_200_response.go b/internal/client/bitbucket/generated_model_get_likers_200_response.go new file mode 100644 index 0000000..01c5a8e --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_likers_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetLikers200Response struct for GetLikers200Response +type GetLikers200Response struct { + Values []RestApplicationUser `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_page_of_required_builds_merge_checks_200_response.go b/internal/client/bitbucket/generated_model_get_page_of_required_builds_merge_checks_200_response.go new file mode 100644 index 0000000..2dfecd0 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_page_of_required_builds_merge_checks_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetPageOfRequiredBuildsMergeChecks200Response struct for GetPageOfRequiredBuildsMergeChecks200Response +type GetPageOfRequiredBuildsMergeChecks200Response struct { + Values []RestRequiredBuildCondition `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_pull_requests_1_200_response.go b/internal/client/bitbucket/generated_model_get_pull_requests_1_200_response.go new file mode 100644 index 0000000..c308636 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_pull_requests_1_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetPullRequests1200Response struct for GetPullRequests1200Response +type GetPullRequests1200Response struct { + Values []RestPullRequest `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_ref_change_activity_200_response.go b/internal/client/bitbucket/generated_model_get_ref_change_activity_200_response.go new file mode 100644 index 0000000..a0b1533 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_ref_change_activity_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetRefChangeActivity200Response struct for GetRefChangeActivity200Response +type GetRefChangeActivity200Response struct { + Values []RestRepositoryRefChangeActivity `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_reports_200_response.go b/internal/client/bitbucket/generated_model_get_reports_200_response.go new file mode 100644 index 0000000..6366466 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_reports_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetReports200Response struct for GetReports200Response +type GetReports200Response struct { + Values []RestInsightReport `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_repositories_recently_accessed_200_response.go b/internal/client/bitbucket/generated_model_get_repositories_recently_accessed_200_response.go new file mode 100644 index 0000000..3b66ba7 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_repositories_recently_accessed_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetRepositoriesRecentlyAccessed200Response struct for GetRepositoriesRecentlyAccessed200Response +type GetRepositoriesRecentlyAccessed200Response struct { + Values []RestRepository `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_repository_hooks_1_200_response.go b/internal/client/bitbucket/generated_model_get_repository_hooks_1_200_response.go new file mode 100644 index 0000000..fccab31 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_repository_hooks_1_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetRepositoryHooks1200Response struct for GetRepositoryHooks1200Response +type GetRepositoryHooks1200Response struct { + Values []RestRepositoryHook `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_restrictions_1_200_response.go b/internal/client/bitbucket/generated_model_get_restrictions_1_200_response.go new file mode 100644 index 0000000..5849b2e --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_restrictions_1_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetRestrictions1200Response struct for GetRestrictions1200Response +type GetRestrictions1200Response struct { + Values []RestRefRestriction `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_reviewer_groups_1_200_response.go b/internal/client/bitbucket/generated_model_get_reviewer_groups_1_200_response.go new file mode 100644 index 0000000..2898dd4 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_reviewer_groups_1_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetReviewerGroups1200Response struct for GetReviewerGroups1200Response +type GetReviewerGroups1200Response struct { + Values []RestReviewerGroup `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_get_tags_200_response.go b/internal/client/bitbucket/generated_model_get_tags_200_response.go new file mode 100644 index 0000000..19b64e8 --- /dev/null +++ b/internal/client/bitbucket/generated_model_get_tags_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// GetTags200Response struct for GetTags200Response +type GetTags200Response struct { + Values []RestTag `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_list_participants_200_response.go b/internal/client/bitbucket/generated_model_list_participants_200_response.go new file mode 100644 index 0000000..e2dda96 --- /dev/null +++ b/internal/client/bitbucket/generated_model_list_participants_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// ListParticipants200Response struct for ListParticipants200Response +type ListParticipants200Response struct { + Values []RestPullRequestParticipant `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_repository_hook_details.go b/internal/client/bitbucket/generated_model_repository_hook_details.go new file mode 100644 index 0000000..fa2ca3d --- /dev/null +++ b/internal/client/bitbucket/generated_model_repository_hook_details.go @@ -0,0 +1,23 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RepositoryHookDetails struct for RepositoryHookDetails +type RepositoryHookDetails struct { + Version *string `yaml:"version,omitempty" json:"version,omitempty"` + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Key *string `yaml:"key,omitempty" json:"key,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + ConfigFormKey *string `yaml:"configFormKey,omitempty" json:"configFormKey,omitempty"` + SupportedScopes []string `yaml:"supportedScopes,omitempty" json:"supportedScopes,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_application_user.go b/internal/client/bitbucket/generated_model_rest_application_user.go new file mode 100644 index 0000000..d81334c --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_application_user.go @@ -0,0 +1,25 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestApplicationUser struct for RestApplicationUser +type RestApplicationUser struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + Active *bool `yaml:"active,omitempty" json:"active,omitempty"` + DisplayName *string `yaml:"displayName,omitempty" json:"displayName,omitempty"` + EmailAddress *string `yaml:"emailAddress,omitempty" json:"emailAddress,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` + Slug *string `yaml:"slug,omitempty" json:"slug,omitempty"` + AvatarUrl *string `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_apply_suggestion_request.go b/internal/client/bitbucket/generated_model_rest_apply_suggestion_request.go new file mode 100644 index 0000000..29d8328 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_apply_suggestion_request.go @@ -0,0 +1,20 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestApplySuggestionRequest struct for RestApplySuggestionRequest +type RestApplySuggestionRequest struct { + CommentVersion *RestApplySuggestionRequestCommentVersion `yaml:"commentVersion,omitempty" json:"commentVersion,omitempty"` + CommitMessage *string `yaml:"commitMessage,omitempty" json:"commitMessage,omitempty"` + PullRequestVersion *RestApplySuggestionRequestPullRequestVersion `yaml:"pullRequestVersion,omitempty" json:"pullRequestVersion,omitempty"` + SuggestionIndex *RestApplySuggestionRequestSuggestionIndex `yaml:"suggestionIndex,omitempty" json:"suggestionIndex,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_apply_suggestion_request_comment_version.go b/internal/client/bitbucket/generated_model_rest_apply_suggestion_request_comment_version.go new file mode 100644 index 0000000..53d9c92 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_apply_suggestion_request_comment_version.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestApplySuggestionRequestCommentVersion struct for RestApplySuggestionRequestCommentVersion +type RestApplySuggestionRequestCommentVersion struct { + AsInt *int32 `yaml:"asInt,omitempty" json:"asInt,omitempty"` + Present *bool `yaml:"present,omitempty" json:"present,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_apply_suggestion_request_pull_request_version.go b/internal/client/bitbucket/generated_model_rest_apply_suggestion_request_pull_request_version.go new file mode 100644 index 0000000..a96a881 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_apply_suggestion_request_pull_request_version.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestApplySuggestionRequestPullRequestVersion struct for RestApplySuggestionRequestPullRequestVersion +type RestApplySuggestionRequestPullRequestVersion struct { + AsInt *int32 `yaml:"asInt,omitempty" json:"asInt,omitempty"` + Present *bool `yaml:"present,omitempty" json:"present,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_apply_suggestion_request_suggestion_index.go b/internal/client/bitbucket/generated_model_rest_apply_suggestion_request_suggestion_index.go new file mode 100644 index 0000000..4b3747b --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_apply_suggestion_request_suggestion_index.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestApplySuggestionRequestSuggestionIndex struct for RestApplySuggestionRequestSuggestionIndex +type RestApplySuggestionRequestSuggestionIndex struct { + AsInt *int32 `yaml:"asInt,omitempty" json:"asInt,omitempty"` + Present *bool `yaml:"present,omitempty" json:"present,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_attachment_metadata.go b/internal/client/bitbucket/generated_model_rest_attachment_metadata.go new file mode 100644 index 0000000..928fa61 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_attachment_metadata.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestAttachmentMetadata struct for RestAttachmentMetadata +type RestAttachmentMetadata struct { + Id *int64 `yaml:"id,omitempty" json:"id,omitempty"` + Metadata *string `yaml:"metadata,omitempty" json:"metadata,omitempty"` + Url *string `yaml:"url,omitempty" json:"url,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_auto_decline_settings.go b/internal/client/bitbucket/generated_model_rest_auto_decline_settings.go new file mode 100644 index 0000000..dbfdaac --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_auto_decline_settings.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestAutoDeclineSettings struct for RestAutoDeclineSettings +type RestAutoDeclineSettings struct { + InactivityWeeks *int32 `yaml:"inactivityWeeks,omitempty" json:"inactivityWeeks,omitempty"` + Scope *RestAutoDeclineSettingsScope `yaml:"scope,omitempty" json:"scope,omitempty"` + Enabled *bool `yaml:"enabled,omitempty" json:"enabled,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_auto_decline_settings_request.go b/internal/client/bitbucket/generated_model_rest_auto_decline_settings_request.go new file mode 100644 index 0000000..6d6fb59 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_auto_decline_settings_request.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestAutoDeclineSettingsRequest struct for RestAutoDeclineSettingsRequest +type RestAutoDeclineSettingsRequest struct { + Enabled *bool `yaml:"enabled,omitempty" json:"enabled,omitempty"` + InactivityWeeks *int32 `yaml:"inactivityWeeks,omitempty" json:"inactivityWeeks,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_auto_decline_settings_scope.go b/internal/client/bitbucket/generated_model_rest_auto_decline_settings_scope.go new file mode 100644 index 0000000..8840dc0 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_auto_decline_settings_scope.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestAutoDeclineSettingsScope struct for RestAutoDeclineSettingsScope +type RestAutoDeclineSettingsScope struct { + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + ResourceId *int32 `yaml:"resourceId,omitempty" json:"resourceId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_auto_merge_processing_result.go b/internal/client/bitbucket/generated_model_rest_auto_merge_processing_result.go new file mode 100644 index 0000000..7faca98 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_auto_merge_processing_result.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestAutoMergeProcessingResult struct for RestAutoMergeProcessingResult +type RestAutoMergeProcessingResult struct { + PullRequest *RestAutoMergeProcessingResultPullRequest `yaml:"pullRequest,omitempty" json:"pullRequest,omitempty"` + AutoMergeProcessingStatus *string `yaml:"autoMergeProcessingStatus,omitempty" json:"autoMergeProcessingStatus,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_auto_merge_processing_result_pull_request.go b/internal/client/bitbucket/generated_model_rest_auto_merge_processing_result_pull_request.go new file mode 100644 index 0000000..1381446 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_auto_merge_processing_result_pull_request.go @@ -0,0 +1,34 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestAutoMergeProcessingResultPullRequest struct for RestAutoMergeProcessingResultPullRequest +type RestAutoMergeProcessingResultPullRequest struct { + Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` + Open *bool `yaml:"open,omitempty" json:"open,omitempty"` + Id *int64 `yaml:"id,omitempty" json:"id,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + Locked *bool `yaml:"locked,omitempty" json:"locked,omitempty"` + Closed *bool `yaml:"closed,omitempty" json:"closed,omitempty"` + CreatedDate *int64 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + UpdatedDate *int64 `yaml:"updatedDate,omitempty" json:"updatedDate,omitempty"` + HtmlDescription *string `yaml:"-" json:"-"` + ClosedDate *int64 `yaml:"closedDate,omitempty" json:"closedDate,omitempty"` + Participants []RestPullRequestParticipant `yaml:"participants,omitempty" json:"participants,omitempty"` + Reviewers []RestPullRequestParticipant `yaml:"reviewers,omitempty" json:"reviewers,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + Title *string `yaml:"title,omitempty" json:"title,omitempty"` + FromRef *RestPullRequestFromRef `yaml:"fromRef,omitempty" json:"fromRef,omitempty"` + ToRef *RestPullRequestFromRef `yaml:"toRef,omitempty" json:"toRef,omitempty"` + Draft *bool `yaml:"draft,omitempty" json:"draft,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_auto_merge_request.go b/internal/client/bitbucket/generated_model_rest_auto_merge_request.go new file mode 100644 index 0000000..361c9de --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_auto_merge_request.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestAutoMergeRequest struct for RestAutoMergeRequest +type RestAutoMergeRequest struct { + Message *string `yaml:"message,omitempty" json:"message,omitempty"` + AutoSubject *bool `yaml:"autoSubject,omitempty" json:"autoSubject,omitempty"` + StrategyId *string `yaml:"strategyId,omitempty" json:"strategyId,omitempty"` + CreatedDate *int64 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + FromHash *string `yaml:"fromHash,omitempty" json:"fromHash,omitempty"` + ToRefId *string `yaml:"toRefId,omitempty" json:"toRefId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_auto_merge_restricted_settings.go b/internal/client/bitbucket/generated_model_rest_auto_merge_restricted_settings.go new file mode 100644 index 0000000..56a9fd8 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_auto_merge_restricted_settings.go @@ -0,0 +1,20 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestAutoMergeRestrictedSettings struct for RestAutoMergeRestrictedSettings +type RestAutoMergeRestrictedSettings struct { + // The restriction state of this scope's project. + RestrictionState *string `yaml:"restrictionState,omitempty" json:"restrictionState,omitempty"` + Scope *RestAutoMergeRestrictedSettingsScope `yaml:"scope,omitempty" json:"scope,omitempty"` + Enabled *bool `yaml:"enabled,omitempty" json:"enabled,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_auto_merge_restricted_settings_scope.go b/internal/client/bitbucket/generated_model_rest_auto_merge_restricted_settings_scope.go new file mode 100644 index 0000000..1a1c68e --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_auto_merge_restricted_settings_scope.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestAutoMergeRestrictedSettingsScope The scope that these settings apply to. +type RestAutoMergeRestrictedSettingsScope struct { + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + ResourceId *int32 `yaml:"resourceId,omitempty" json:"resourceId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_auto_merge_settings_request.go b/internal/client/bitbucket/generated_model_rest_auto_merge_settings_request.go new file mode 100644 index 0000000..0be83c8 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_auto_merge_settings_request.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestAutoMergeSettingsRequest struct for RestAutoMergeSettingsRequest +type RestAutoMergeSettingsRequest struct { + Enabled *bool `yaml:"enabled,omitempty" json:"enabled,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_branch.go b/internal/client/bitbucket/generated_model_rest_branch.go new file mode 100644 index 0000000..1e443b9 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_branch.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestBranch struct for RestBranch +type RestBranch struct { + Type *interface{} `yaml:"type" json:"type"` + Default *bool `yaml:"default,omitempty" json:"default,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` + LatestCommit *string `yaml:"latestCommit,omitempty" json:"latestCommit,omitempty"` + LatestChangeset *string `yaml:"latestChangeset,omitempty" json:"latestChangeset,omitempty"` + Id *string `yaml:"id,omitempty" json:"id,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_branch_create_request.go b/internal/client/bitbucket/generated_model_rest_branch_create_request.go new file mode 100644 index 0000000..2b62803 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_branch_create_request.go @@ -0,0 +1,20 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestBranchCreateRequest struct for RestBranchCreateRequest +type RestBranchCreateRequest struct { + // Name of the branch to be created + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + // Commit ID from which the branch is created + StartPoint *string `yaml:"startPoint,omitempty" json:"startPoint,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_branch_delete_request.go b/internal/client/bitbucket/generated_model_rest_branch_delete_request.go new file mode 100644 index 0000000..92320fa --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_branch_delete_request.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestBranchDeleteRequest struct for RestBranchDeleteRequest +type RestBranchDeleteRequest struct { + // Don't actually delete the ref name, just do a dry run + DryRun *bool `yaml:"dryRun,omitempty" json:"dryRun,omitempty"` + // Commit ID that the provided ref name is expected to point to + EndPoint *string `yaml:"endPoint,omitempty" json:"endPoint,omitempty"` + // Name of the ref to be deleted + Name *string `yaml:"name,omitempty" json:"name,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_build_stats.go b/internal/client/bitbucket/generated_model_rest_build_stats.go new file mode 100644 index 0000000..8d43f87 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_build_stats.go @@ -0,0 +1,21 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestBuildStats struct for RestBuildStats +type RestBuildStats struct { + Successful *int32 `yaml:"successful,omitempty" json:"successful,omitempty"` + Cancelled *int32 `yaml:"cancelled,omitempty" json:"cancelled,omitempty"` + InProgress *int32 `yaml:"inProgress,omitempty" json:"inProgress,omitempty"` + Failed *int32 `yaml:"failed,omitempty" json:"failed,omitempty"` + Unknown *int32 `yaml:"unknown,omitempty" json:"unknown,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_build_status.go b/internal/client/bitbucket/generated_model_rest_build_status.go new file mode 100644 index 0000000..c98740b --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_build_status.go @@ -0,0 +1,28 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestBuildStatus struct for RestBuildStatus +type RestBuildStatus struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Key *string `yaml:"key,omitempty" json:"key,omitempty"` + Parent *string `yaml:"parent,omitempty" json:"parent,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + Ref *string `yaml:"ref,omitempty" json:"ref,omitempty"` + Duration *int64 `yaml:"duration,omitempty" json:"duration,omitempty"` + TestResults *RestBuildStatusTestResults `yaml:"testResults,omitempty" json:"testResults,omitempty"` + CreatedDate *int64 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + UpdatedDate *int64 `yaml:"updatedDate,omitempty" json:"updatedDate,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + BuildNumber *string `yaml:"buildNumber,omitempty" json:"buildNumber,omitempty"` + Url *string `yaml:"url,omitempty" json:"url,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_build_status_set_request.go b/internal/client/bitbucket/generated_model_rest_build_status_set_request.go new file mode 100644 index 0000000..4ce9138 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_build_status_set_request.go @@ -0,0 +1,27 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestBuildStatusSetRequest struct for RestBuildStatusSetRequest +type RestBuildStatusSetRequest struct { + BuildNumber *string `yaml:"buildNumber,omitempty" json:"buildNumber,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + Duration *int64 `yaml:"duration,omitempty" json:"duration,omitempty"` + Key string `yaml:"key" json:"key"` + LastUpdated *int64 `yaml:"lastUpdated,omitempty" json:"lastUpdated,omitempty"` + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Parent *string `yaml:"parent,omitempty" json:"parent,omitempty"` + Ref *string `yaml:"ref,omitempty" json:"ref,omitempty" validate:"regexp=^refs\\/.*"` + State string `yaml:"state" json:"state"` + TestResults *RestBuildStatusSetRequestTestResults `yaml:"testResults,omitempty" json:"testResults,omitempty"` + Url string `yaml:"url" json:"url"` +} diff --git a/internal/client/bitbucket/generated_model_rest_build_status_set_request_test_results.go b/internal/client/bitbucket/generated_model_rest_build_status_set_request_test_results.go new file mode 100644 index 0000000..4c1cf4b --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_build_status_set_request_test_results.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestBuildStatusSetRequestTestResults struct for RestBuildStatusSetRequestTestResults +type RestBuildStatusSetRequestTestResults struct { + Failed *int32 `yaml:"failed,omitempty" json:"failed,omitempty"` + Skipped *int32 `yaml:"skipped,omitempty" json:"skipped,omitempty"` + Successful *int32 `yaml:"successful,omitempty" json:"successful,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_build_status_test_results.go b/internal/client/bitbucket/generated_model_rest_build_status_test_results.go new file mode 100644 index 0000000..c1ce933 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_build_status_test_results.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestBuildStatusTestResults struct for RestBuildStatusTestResults +type RestBuildStatusTestResults struct { + Successful *int32 `yaml:"successful,omitempty" json:"successful,omitempty"` + Skipped *int32 `yaml:"skipped,omitempty" json:"skipped,omitempty"` + Failed *int32 `yaml:"failed,omitempty" json:"failed,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_bulk_add_insight_annotation_request.go b/internal/client/bitbucket/generated_model_rest_bulk_add_insight_annotation_request.go new file mode 100644 index 0000000..05cc7b5 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_bulk_add_insight_annotation_request.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestBulkAddInsightAnnotationRequest struct for RestBulkAddInsightAnnotationRequest +type RestBulkAddInsightAnnotationRequest struct { + Annotations []RestSingleAddInsightAnnotationRequest `yaml:"annotations,omitempty" json:"annotations,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_change.go b/internal/client/bitbucket/generated_model_rest_change.go new file mode 100644 index 0000000..ead8963 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_change.go @@ -0,0 +1,27 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestChange struct for RestChange +type RestChange struct { + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + Path *RestCommentThreadDiffAnchorPath `yaml:"path,omitempty" json:"path,omitempty"` + SrcExecutable *bool `yaml:"srcExecutable,omitempty" json:"srcExecutable,omitempty"` + PercentUnchanged *int32 `yaml:"percentUnchanged,omitempty" json:"percentUnchanged,omitempty"` + Conflict *RestChangeConflict `yaml:"conflict,omitempty" json:"conflict,omitempty"` + ContentId *string `yaml:"contentId,omitempty" json:"contentId,omitempty"` + FromContentId *string `yaml:"fromContentId,omitempty" json:"fromContentId,omitempty"` + NodeType *string `yaml:"nodeType,omitempty" json:"nodeType,omitempty"` + Executable *bool `yaml:"executable,omitempty" json:"executable,omitempty"` + SrcPath *RestCommentThreadDiffAnchorPath `yaml:"srcPath,omitempty" json:"srcPath,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_change_conflict.go b/internal/client/bitbucket/generated_model_rest_change_conflict.go new file mode 100644 index 0000000..727f624 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_change_conflict.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestChangeConflict struct for RestChangeConflict +type RestChangeConflict struct { + OurChange *RestChangeConflictOurChange `yaml:"ourChange,omitempty" json:"ourChange,omitempty"` + TheirChange *RestChangeConflictOurChange `yaml:"theirChange,omitempty" json:"theirChange,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_change_conflict_our_change.go b/internal/client/bitbucket/generated_model_rest_change_conflict_our_change.go new file mode 100644 index 0000000..ffeaad4 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_change_conflict_our_change.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestChangeConflictOurChange struct for RestChangeConflictOurChange +type RestChangeConflictOurChange struct { + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + Path *RestCommentThreadDiffAnchorPath `yaml:"path,omitempty" json:"path,omitempty"` + SrcPath *RestCommentThreadDiffAnchorPath `yaml:"srcPath,omitempty" json:"srcPath,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_changeset_from_commit.go b/internal/client/bitbucket/generated_model_rest_changeset_from_commit.go new file mode 100644 index 0000000..a82ab44 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_changeset_from_commit.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestChangesetFromCommit struct for RestChangesetFromCommit +type RestChangesetFromCommit struct { + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_changeset_to_commit.go b/internal/client/bitbucket/generated_model_rest_changeset_to_commit.go new file mode 100644 index 0000000..d11f31f --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_changeset_to_commit.go @@ -0,0 +1,24 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestChangesetToCommit struct for RestChangesetToCommit +type RestChangesetToCommit struct { + Message *string `yaml:"message,omitempty" json:"message,omitempty"` + CommitterTimestamp *int64 `yaml:"committerTimestamp,omitempty" json:"committerTimestamp,omitempty"` + Committer *RestChangesetToCommitCommitter `yaml:"committer,omitempty" json:"committer,omitempty"` + AuthorTimestamp *int64 `yaml:"authorTimestamp,omitempty" json:"authorTimestamp,omitempty"` + Parents []RestMinimalCommit `yaml:"parents,omitempty" json:"parents,omitempty"` + Author *RestChangesetToCommitCommitter `yaml:"author,omitempty" json:"author,omitempty"` + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_changeset_to_commit_committer.go b/internal/client/bitbucket/generated_model_rest_changeset_to_commit_committer.go new file mode 100644 index 0000000..a888e0f --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_changeset_to_commit_committer.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestChangesetToCommitCommitter struct for RestChangesetToCommitCommitter +type RestChangesetToCommitCommitter struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + EmailAddress *string `yaml:"emailAddress,omitempty" json:"emailAddress,omitempty"` + AvatarUrl *string `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_comment.go b/internal/client/bitbucket/generated_model_rest_comment.go new file mode 100644 index 0000000..3f057dd --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_comment.go @@ -0,0 +1,38 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestComment struct for RestComment +type RestComment struct { + Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` + Parent *RestUserReactionCommentParent `yaml:"parent,omitempty" json:"parent,omitempty"` + Id *int64 `yaml:"id,omitempty" json:"id,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + Severity *string `yaml:"severity,omitempty" json:"severity,omitempty"` + ThreadResolvedDate *int64 `yaml:"threadResolvedDate,omitempty" json:"threadResolvedDate,omitempty"` + ThreadResolver *RestUserReactionCommentParentThreadResolver `yaml:"threadResolver,omitempty" json:"threadResolver,omitempty"` + // Indicates if this comment thread has been marked as resolved or not + ThreadResolved *bool `yaml:"threadResolved,omitempty" json:"threadResolved,omitempty"` + CreatedDate *int64 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + ResolvedDate *int64 `yaml:"resolvedDate,omitempty" json:"resolvedDate,omitempty"` + Resolver *RestUserReactionCommentParentThreadResolver `yaml:"resolver,omitempty" json:"resolver,omitempty"` + UpdatedDate *int64 `yaml:"updatedDate,omitempty" json:"updatedDate,omitempty"` + Comments []RestComment `yaml:"comments,omitempty" json:"comments,omitempty"` + Text *string `yaml:"text,omitempty" json:"text,omitempty"` + Anchor *RestUserReactionCommentParentAnchor `yaml:"anchor,omitempty" json:"anchor,omitempty"` + Author *RestUserReactionCommentParentThreadResolver `yaml:"author,omitempty" json:"author,omitempty"` + Html *string `yaml:"html,omitempty" json:"html,omitempty"` + Anchored *bool `yaml:"anchored,omitempty" json:"anchored,omitempty"` + Pending *bool `yaml:"pending,omitempty" json:"pending,omitempty"` + Reply *bool `yaml:"reply,omitempty" json:"reply,omitempty"` + Properties map[string]interface{} `yaml:"properties,omitempty" json:"properties,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_comment_thread_diff_anchor_path.go b/internal/client/bitbucket/generated_model_rest_comment_thread_diff_anchor_path.go new file mode 100644 index 0000000..bd3eb78 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_comment_thread_diff_anchor_path.go @@ -0,0 +1,20 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestCommentThreadDiffAnchorPath struct for RestCommentThreadDiffAnchorPath +type RestCommentThreadDiffAnchorPath struct { + Extension *string `yaml:"extension,omitempty" json:"extension,omitempty"` + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Parent *string `yaml:"parent,omitempty" json:"parent,omitempty"` + Components []string `yaml:"components,omitempty" json:"components,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_comment_thread_diff_anchor_pull_request.go b/internal/client/bitbucket/generated_model_rest_comment_thread_diff_anchor_pull_request.go new file mode 100644 index 0000000..5ac1d7b --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_comment_thread_diff_anchor_pull_request.go @@ -0,0 +1,34 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestCommentThreadDiffAnchorPullRequest struct for RestCommentThreadDiffAnchorPullRequest +type RestCommentThreadDiffAnchorPullRequest struct { + Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` + Open *bool `yaml:"open,omitempty" json:"open,omitempty"` + Id *int64 `yaml:"id,omitempty" json:"id,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + Locked *bool `yaml:"locked,omitempty" json:"locked,omitempty"` + Closed *bool `yaml:"closed,omitempty" json:"closed,omitempty"` + CreatedDate *int64 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + UpdatedDate *int64 `yaml:"updatedDate,omitempty" json:"updatedDate,omitempty"` + HtmlDescription *string `yaml:"-" json:"-"` + ClosedDate *int64 `yaml:"closedDate,omitempty" json:"closedDate,omitempty"` + Participants []RestPullRequestParticipant `yaml:"participants,omitempty" json:"participants,omitempty"` + Reviewers []RestPullRequestParticipant `yaml:"reviewers,omitempty" json:"reviewers,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + Title *string `yaml:"title,omitempty" json:"title,omitempty"` + FromRef *RestPullRequestFromRef `yaml:"fromRef,omitempty" json:"fromRef,omitempty"` + ToRef *RestPullRequestFromRef `yaml:"toRef,omitempty" json:"toRef,omitempty"` + Draft *bool `yaml:"draft,omitempty" json:"draft,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_commit.go b/internal/client/bitbucket/generated_model_rest_commit.go new file mode 100644 index 0000000..5c36473 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_commit.go @@ -0,0 +1,24 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestCommit struct for RestCommit +type RestCommit struct { + Message *string `yaml:"message,omitempty" json:"message,omitempty"` + CommitterTimestamp *int64 `yaml:"committerTimestamp,omitempty" json:"committerTimestamp,omitempty"` + Committer *RestChangesetToCommitCommitter `yaml:"committer,omitempty" json:"committer,omitempty"` + AuthorTimestamp *int64 `yaml:"authorTimestamp,omitempty" json:"authorTimestamp,omitempty"` + Parents []RestMinimalCommit `yaml:"parents,omitempty" json:"parents,omitempty"` + Author *RestChangesetToCommitCommitter `yaml:"author,omitempty" json:"author,omitempty"` + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_commit_message_suggestion.go b/internal/client/bitbucket/generated_model_rest_commit_message_suggestion.go new file mode 100644 index 0000000..85b0d48 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_commit_message_suggestion.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestCommitMessageSuggestion struct for RestCommitMessageSuggestion +type RestCommitMessageSuggestion struct { + Title *string `yaml:"title,omitempty" json:"title,omitempty"` + Body *string `yaml:"body,omitempty" json:"body,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_create_branch_request.go b/internal/client/bitbucket/generated_model_rest_create_branch_request.go new file mode 100644 index 0000000..56fcab1 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_create_branch_request.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestCreateBranchRequest struct for RestCreateBranchRequest +type RestCreateBranchRequest struct { + Message *string `yaml:"message,omitempty" json:"message,omitempty"` + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + StartPoint *string `yaml:"startPoint,omitempty" json:"startPoint,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_create_tag_request.go b/internal/client/bitbucket/generated_model_rest_create_tag_request.go new file mode 100644 index 0000000..1c6d100 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_create_tag_request.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestCreateTagRequest struct for RestCreateTagRequest +type RestCreateTagRequest struct { + Message *string `yaml:"message,omitempty" json:"message,omitempty"` + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + StartPoint *string `yaml:"startPoint,omitempty" json:"startPoint,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_default_reviewers_request.go b/internal/client/bitbucket/generated_model_rest_default_reviewers_request.go new file mode 100644 index 0000000..b951ec3 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_default_reviewers_request.go @@ -0,0 +1,20 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestDefaultReviewersRequest struct for RestDefaultReviewersRequest +type RestDefaultReviewersRequest struct { + RequiredApprovals *int32 `yaml:"requiredApprovals,omitempty" json:"requiredApprovals,omitempty"` + Reviewers []RestApplicationUser `yaml:"reviewers,omitempty" json:"reviewers,omitempty"` + SourceMatcher *UpdatePullRequestCondition1RequestSourceMatcher `yaml:"sourceMatcher,omitempty" json:"sourceMatcher,omitempty"` + TargetMatcher *UpdatePullRequestCondition1RequestSourceMatcher `yaml:"targetMatcher,omitempty" json:"targetMatcher,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_deployment.go b/internal/client/bitbucket/generated_model_rest_deployment.go new file mode 100644 index 0000000..e365c8f --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_deployment.go @@ -0,0 +1,27 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestDeployment struct for RestDeployment +type RestDeployment struct { + Key *string `yaml:"key,omitempty" json:"key,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + DisplayName *string `yaml:"displayName,omitempty" json:"displayName,omitempty"` + Environment *RestDeploymentEnvironment `yaml:"environment,omitempty" json:"environment,omitempty"` + FromCommit *RestChangesetFromCommit `yaml:"fromCommit,omitempty" json:"fromCommit,omitempty"` + ToCommit *RestChangesetFromCommit `yaml:"toCommit,omitempty" json:"toCommit,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + Repository *RestPullRequestFromRefRepository `yaml:"repository,omitempty" json:"repository,omitempty"` + LastUpdated *int64 `yaml:"lastUpdated,omitempty" json:"lastUpdated,omitempty"` + Url *string `yaml:"url,omitempty" json:"url,omitempty"` + DeploymentSequenceNumber *int64 `yaml:"deploymentSequenceNumber,omitempty" json:"deploymentSequenceNumber,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_deployment_environment.go b/internal/client/bitbucket/generated_model_rest_deployment_environment.go new file mode 100644 index 0000000..6312b0c --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_deployment_environment.go @@ -0,0 +1,20 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestDeploymentEnvironment struct for RestDeploymentEnvironment +type RestDeploymentEnvironment struct { + Key string `yaml:"key" json:"key"` + Type *string `yaml:"type,omitempty" json:"type,omitempty" validate:"regexp=DEVELOPMENT|TESTING|STAGING|PRODUCTION"` + DisplayName string `yaml:"displayName" json:"displayName"` + Url *string `yaml:"url,omitempty" json:"url,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_deployment_set_request.go b/internal/client/bitbucket/generated_model_rest_deployment_set_request.go new file mode 100644 index 0000000..45bcdf1 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_deployment_set_request.go @@ -0,0 +1,24 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestDeploymentSetRequest struct for RestDeploymentSetRequest +type RestDeploymentSetRequest struct { + DeploymentSequenceNumber int64 `yaml:"deploymentSequenceNumber" json:"deploymentSequenceNumber"` + Description string `yaml:"description" json:"description"` + DisplayName string `yaml:"displayName" json:"displayName"` + Environment RestDeploymentEnvironment `yaml:"environment" json:"environment"` + Key string `yaml:"key" json:"key"` + LastUpdated *int64 `yaml:"lastUpdated,omitempty" json:"lastUpdated,omitempty"` + State string `yaml:"state" json:"state"` + Url string `yaml:"url" json:"url"` +} diff --git a/internal/client/bitbucket/generated_model_rest_detailed_invocation.go b/internal/client/bitbucket/generated_model_rest_detailed_invocation.go new file mode 100644 index 0000000..17f2ede --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_detailed_invocation.go @@ -0,0 +1,24 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestDetailedInvocation struct for RestDetailedInvocation +type RestDetailedInvocation struct { + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` + Result map[string]interface{} `yaml:"result,omitempty" json:"result,omitempty"` + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + Duration *int32 `yaml:"duration,omitempty" json:"duration,omitempty"` + EventScope *RestDetailedInvocationEventScope `yaml:"eventScope,omitempty" json:"eventScope,omitempty"` + Request map[string]interface{} `yaml:"request,omitempty" json:"request,omitempty"` + Event *string `yaml:"event,omitempty" json:"event,omitempty"` + Finish *int32 `yaml:"finish,omitempty" json:"finish,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_detailed_invocation_event_scope.go b/internal/client/bitbucket/generated_model_rest_detailed_invocation_event_scope.go new file mode 100644 index 0000000..b157bee --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_detailed_invocation_event_scope.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestDetailedInvocationEventScope struct for RestDetailedInvocationEventScope +type RestDetailedInvocationEventScope struct { + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_diff.go b/internal/client/bitbucket/generated_model_rest_diff.go new file mode 100644 index 0000000..07688cb --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_diff.go @@ -0,0 +1,23 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestDiff struct for RestDiff +type RestDiff struct { + Truncated *bool `yaml:"truncated,omitempty" json:"truncated,omitempty"` + LineComments []RestComment `yaml:"lineComments,omitempty" json:"lineComments,omitempty"` + Destination *RestCommentThreadDiffAnchorPath `yaml:"destination,omitempty" json:"destination,omitempty"` + Source *RestCommentThreadDiffAnchorPath `yaml:"source,omitempty" json:"source,omitempty"` + Binary *bool `yaml:"binary,omitempty" json:"binary,omitempty"` + Hunks []RestDiffHunk `yaml:"hunks,omitempty" json:"hunks,omitempty"` + Properties map[string]interface{} `yaml:"properties,omitempty" json:"properties,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_diff_hunk.go b/internal/client/bitbucket/generated_model_rest_diff_hunk.go new file mode 100644 index 0000000..514cba2 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_diff_hunk.go @@ -0,0 +1,23 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestDiffHunk struct for RestDiffHunk +type RestDiffHunk struct { + Context *string `yaml:"context,omitempty" json:"context,omitempty"` + SourceLine *int32 `yaml:"sourceLine,omitempty" json:"sourceLine,omitempty"` + Segments []RestDiffSegment `yaml:"segments,omitempty" json:"segments,omitempty"` + SourceSpan *int32 `yaml:"sourceSpan,omitempty" json:"sourceSpan,omitempty"` + DestinationSpan *int32 `yaml:"destinationSpan,omitempty" json:"destinationSpan,omitempty"` + DestinationLine *int32 `yaml:"destinationLine,omitempty" json:"destinationLine,omitempty"` + Truncated *bool `yaml:"truncated,omitempty" json:"truncated,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_diff_line.go b/internal/client/bitbucket/generated_model_rest_diff_line.go new file mode 100644 index 0000000..1e9f8e1 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_diff_line.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestDiffLine struct for RestDiffLine +type RestDiffLine struct { + Truncated *bool `yaml:"truncated,omitempty" json:"truncated,omitempty"` + ConflictMarker *string `yaml:"conflictMarker,omitempty" json:"conflictMarker,omitempty"` + CommentIds []int64 `yaml:"commentIds,omitempty" json:"commentIds,omitempty"` + Destination *int32 `yaml:"destination,omitempty" json:"destination,omitempty"` + Source *int32 `yaml:"source,omitempty" json:"source,omitempty"` + Line *string `yaml:"line,omitempty" json:"line,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_diff_segment.go b/internal/client/bitbucket/generated_model_rest_diff_segment.go new file mode 100644 index 0000000..44bed40 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_diff_segment.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestDiffSegment struct for RestDiffSegment +type RestDiffSegment struct { + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + Truncated *bool `yaml:"truncated,omitempty" json:"truncated,omitempty"` + Lines []RestDiffLine `yaml:"lines,omitempty" json:"lines,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_error_message.go b/internal/client/bitbucket/generated_model_rest_error_message.go new file mode 100644 index 0000000..db9d3b4 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_error_message.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestErrorMessage struct for RestErrorMessage +type RestErrorMessage struct { + Message *string `yaml:"message,omitempty" json:"message,omitempty"` + Context *string `yaml:"context,omitempty" json:"context,omitempty"` + ExceptionName *string `yaml:"exceptionName,omitempty" json:"exceptionName,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_errors.go b/internal/client/bitbucket/generated_model_rest_errors.go new file mode 100644 index 0000000..94dcd96 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_errors.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestErrors struct for RestErrors +type RestErrors struct { + Errors []RestErrorMessage `yaml:"errors,omitempty" json:"errors,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_git_tag_create_request.go b/internal/client/bitbucket/generated_model_rest_git_tag_create_request.go new file mode 100644 index 0000000..4c93b87 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_git_tag_create_request.go @@ -0,0 +1,21 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestGitTagCreateRequest struct for RestGitTagCreateRequest +type RestGitTagCreateRequest struct { + Force *bool `yaml:"force,omitempty" json:"force,omitempty"` + Message *string `yaml:"message,omitempty" json:"message,omitempty"` + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + StartPoint *string `yaml:"startPoint,omitempty" json:"startPoint,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_hook_script_config.go b/internal/client/bitbucket/generated_model_rest_hook_script_config.go new file mode 100644 index 0000000..2a6fcce --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_hook_script_config.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestHookScriptConfig struct for RestHookScriptConfig +type RestHookScriptConfig struct { + Script *RestHookScriptConfigScript `yaml:"script,omitempty" json:"script,omitempty"` + Scope *RestAutoDeclineSettingsScope `yaml:"scope,omitempty" json:"scope,omitempty"` + TriggerIds []string `yaml:"triggerIds,omitempty" json:"triggerIds,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_hook_script_config_script.go b/internal/client/bitbucket/generated_model_rest_hook_script_config_script.go new file mode 100644 index 0000000..e97ee60 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_hook_script_config_script.go @@ -0,0 +1,27 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + +import ( + "time" +) + +// RestHookScriptConfigScript struct for RestHookScriptConfigScript +type RestHookScriptConfigScript struct { + Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Id *int64 `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + CreatedDate *time.Time `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + UpdatedDate *time.Time `yaml:"updatedDate,omitempty" json:"updatedDate,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + PluginKey *string `yaml:"pluginKey,omitempty" json:"pluginKey,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_hook_script_triggers.go b/internal/client/bitbucket/generated_model_rest_hook_script_triggers.go new file mode 100644 index 0000000..e7a8c07 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_hook_script_triggers.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestHookScriptTriggers struct for RestHookScriptTriggers +type RestHookScriptTriggers struct { + TriggerIds []string `yaml:"triggerIds,omitempty" json:"triggerIds,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_insight_annotation.go b/internal/client/bitbucket/generated_model_rest_insight_annotation.go new file mode 100644 index 0000000..bd60fa5 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_insight_annotation.go @@ -0,0 +1,24 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestInsightAnnotation struct for RestInsightAnnotation +type RestInsightAnnotation struct { + Message *string `yaml:"message,omitempty" json:"message,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + Path *string `yaml:"path,omitempty" json:"path,omitempty"` + Severity *string `yaml:"severity,omitempty" json:"severity,omitempty"` + ExternalId *string `yaml:"externalId,omitempty" json:"externalId,omitempty"` + ReportKey *string `yaml:"reportKey,omitempty" json:"reportKey,omitempty"` + Line *int32 `yaml:"line,omitempty" json:"line,omitempty"` + Link *string `yaml:"link,omitempty" json:"link,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_insight_annotations_response.go b/internal/client/bitbucket/generated_model_rest_insight_annotations_response.go new file mode 100644 index 0000000..201f84b --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_insight_annotations_response.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestInsightAnnotationsResponse struct for RestInsightAnnotationsResponse +type RestInsightAnnotationsResponse struct { + Annotations []RestInsightAnnotation `yaml:"annotations,omitempty" json:"annotations,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_insight_report.go b/internal/client/bitbucket/generated_model_rest_insight_report.go new file mode 100644 index 0000000..17d5b14 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_insight_report.go @@ -0,0 +1,25 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestInsightReport struct for RestInsightReport +type RestInsightReport struct { + Result *string `yaml:"result,omitempty" json:"result,omitempty"` + Key *string `yaml:"key,omitempty" json:"key,omitempty"` + CreatedDate *float32 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + Reporter *string `yaml:"reporter,omitempty" json:"reporter,omitempty"` + Data []RestInsightReportData `yaml:"data,omitempty" json:"data,omitempty"` + Title *string `yaml:"title,omitempty" json:"title,omitempty"` + Details *string `yaml:"details,omitempty" json:"details,omitempty"` + Link *string `yaml:"link,omitempty" json:"link,omitempty"` + LogoUrl *string `yaml:"logoUrl,omitempty" json:"logoUrl,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_insight_report_data.go b/internal/client/bitbucket/generated_model_rest_insight_report_data.go new file mode 100644 index 0000000..88411c6 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_insight_report_data.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestInsightReportData struct for RestInsightReportData +type RestInsightReportData struct { + Value map[string]interface{} `yaml:"value,omitempty" json:"value,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty" validate:"regexp=BOOLEAN|DATE|DURATION|LINK|NUMBER|PERCENTAGE|TEXT"` + Title *string `yaml:"title,omitempty" json:"title,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_label.go b/internal/client/bitbucket/generated_model_rest_label.go new file mode 100644 index 0000000..bfb595a --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_label.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestLabel struct for RestLabel +type RestLabel struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_minimal_commit.go b/internal/client/bitbucket/generated_model_rest_minimal_commit.go new file mode 100644 index 0000000..d5dbfba --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_minimal_commit.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestMinimalCommit struct for RestMinimalCommit +type RestMinimalCommit struct { + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_minimal_ref.go b/internal/client/bitbucket/generated_model_rest_minimal_ref.go new file mode 100644 index 0000000..0cdbedf --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_minimal_ref.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestMinimalRef struct for RestMinimalRef +type RestMinimalRef struct { + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request.go b/internal/client/bitbucket/generated_model_rest_pull_request.go new file mode 100644 index 0000000..5d993fd --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request.go @@ -0,0 +1,34 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequest struct for RestPullRequest +type RestPullRequest struct { + Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` + Open *bool `yaml:"open,omitempty" json:"open,omitempty"` + Id *int64 `yaml:"id,omitempty" json:"id,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + Locked *bool `yaml:"locked,omitempty" json:"locked,omitempty"` + Closed *bool `yaml:"closed,omitempty" json:"closed,omitempty"` + CreatedDate *int64 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + UpdatedDate *int64 `yaml:"updatedDate,omitempty" json:"updatedDate,omitempty"` + HtmlDescription *string `yaml:"-" json:"-"` + ClosedDate *int64 `yaml:"closedDate,omitempty" json:"closedDate,omitempty"` + Participants []RestPullRequestParticipant `yaml:"participants,omitempty" json:"participants,omitempty"` + Reviewers []RestPullRequestParticipant `yaml:"reviewers,omitempty" json:"reviewers,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + Title *string `yaml:"title,omitempty" json:"title,omitempty"` + FromRef *RestPullRequestFromRef `yaml:"fromRef,omitempty" json:"fromRef,omitempty"` + ToRef *RestPullRequestFromRef `yaml:"toRef,omitempty" json:"toRef,omitempty"` + Draft *bool `yaml:"draft,omitempty" json:"draft,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_activity.go b/internal/client/bitbucket/generated_model_rest_pull_request_activity.go new file mode 100644 index 0000000..87a377c --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_activity.go @@ -0,0 +1,20 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestActivity struct for RestPullRequestActivity +type RestPullRequestActivity struct { + Action *string `yaml:"action,omitempty" json:"action,omitempty"` + Id *int64 `yaml:"id,omitempty" json:"id,omitempty"` + CreatedDate *int64 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + User *RestPullRequestParticipantUser `yaml:"user,omitempty" json:"user,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_assign_participant_role_request.go b/internal/client/bitbucket/generated_model_rest_pull_request_assign_participant_role_request.go new file mode 100644 index 0000000..eac5cd5 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_assign_participant_role_request.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestAssignParticipantRoleRequest struct for RestPullRequestAssignParticipantRoleRequest +type RestPullRequestAssignParticipantRoleRequest struct { + Role *string `yaml:"role,omitempty" json:"role,omitempty"` + User *RestPullRequestAssignParticipantRoleRequestUser `yaml:"user,omitempty" json:"user,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_assign_participant_role_request_user.go b/internal/client/bitbucket/generated_model_rest_pull_request_assign_participant_role_request_user.go new file mode 100644 index 0000000..6809662 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_assign_participant_role_request_user.go @@ -0,0 +1,25 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestAssignParticipantRoleRequestUser struct for RestPullRequestAssignParticipantRoleRequestUser +type RestPullRequestAssignParticipantRoleRequestUser struct { + Active *bool `yaml:"active,omitempty" json:"active,omitempty"` + AvatarUrl *string `yaml:"-" json:"-"` + DisplayName *string `yaml:"displayName,omitempty" json:"displayName,omitempty"` + EmailAddress *string `yaml:"emailAddress,omitempty" json:"emailAddress,omitempty"` + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Slug *string `yaml:"slug,omitempty" json:"slug,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_assign_status_request.go b/internal/client/bitbucket/generated_model_rest_pull_request_assign_status_request.go new file mode 100644 index 0000000..94ff541 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_assign_status_request.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestAssignStatusRequest struct for RestPullRequestAssignStatusRequest +type RestPullRequestAssignStatusRequest struct { + Status *string `yaml:"status,omitempty" json:"status,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_condition.go b/internal/client/bitbucket/generated_model_rest_pull_request_condition.go new file mode 100644 index 0000000..9f54c83 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_condition.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestCondition struct for RestPullRequestCondition +type RestPullRequestCondition struct { + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + SourceRefMatcher *RestRequiredBuildConditionRefMatcher `yaml:"sourceRefMatcher,omitempty" json:"sourceRefMatcher,omitempty"` + TargetRefMatcher *RestRequiredBuildConditionRefMatcher `yaml:"targetRefMatcher,omitempty" json:"targetRefMatcher,omitempty"` + Reviewers []RestApplicationUser `yaml:"reviewers,omitempty" json:"reviewers,omitempty"` + RequiredApprovals *int32 `yaml:"requiredApprovals,omitempty" json:"requiredApprovals,omitempty"` + Scope *RestPullRequestConditionScope `yaml:"scope,omitempty" json:"scope,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_condition_scope.go b/internal/client/bitbucket/generated_model_rest_pull_request_condition_scope.go new file mode 100644 index 0000000..6bcac6c --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_condition_scope.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestConditionScope struct for RestPullRequestConditionScope +type RestPullRequestConditionScope struct { + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + ResourceId *int32 `yaml:"resourceId,omitempty" json:"resourceId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_decline_request.go b/internal/client/bitbucket/generated_model_rest_pull_request_decline_request.go new file mode 100644 index 0000000..0b56744 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_decline_request.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestDeclineRequest struct for RestPullRequestDeclineRequest +type RestPullRequestDeclineRequest struct { + Comment *string `yaml:"comment,omitempty" json:"comment,omitempty"` + Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_delete_request.go b/internal/client/bitbucket/generated_model_rest_pull_request_delete_request.go new file mode 100644 index 0000000..29b0d57 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_delete_request.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestDeleteRequest struct for RestPullRequestDeleteRequest +type RestPullRequestDeleteRequest struct { + Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_finish_review_request.go b/internal/client/bitbucket/generated_model_rest_pull_request_finish_review_request.go new file mode 100644 index 0000000..8d2bf0c --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_finish_review_request.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestFinishReviewRequest struct for RestPullRequestFinishReviewRequest +type RestPullRequestFinishReviewRequest struct { + CommentText *string `yaml:"commentText,omitempty" json:"commentText,omitempty"` + ParticipantStatus *string `yaml:"participantStatus,omitempty" json:"participantStatus,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_from_ref.go b/internal/client/bitbucket/generated_model_rest_pull_request_from_ref.go new file mode 100644 index 0000000..452c27b --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_from_ref.go @@ -0,0 +1,21 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestFromRef struct for RestPullRequestFromRef +type RestPullRequestFromRef struct { + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` + LatestCommit *string `yaml:"latestCommit,omitempty" json:"latestCommit,omitempty"` + Repository *RestPullRequestFromRefRepository `yaml:"repository,omitempty" json:"repository,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_from_ref_repository.go b/internal/client/bitbucket/generated_model_rest_pull_request_from_ref_repository.go new file mode 100644 index 0000000..9469d49 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_from_ref_repository.go @@ -0,0 +1,34 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestFromRefRepository struct for RestPullRequestFromRefRepository +type RestPullRequestFromRefRepository struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Public *bool `yaml:"public,omitempty" json:"public,omitempty"` + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + StatusMessage *string `yaml:"statusMessage,omitempty" json:"statusMessage,omitempty"` + DefaultBranch *string `yaml:"defaultBranch,omitempty" json:"defaultBranch,omitempty"` + RelatedLinks map[string]interface{} `yaml:"relatedLinks,omitempty" json:"relatedLinks,omitempty"` + Partition *int32 `yaml:"partition,omitempty" json:"partition,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + HierarchyId *string `yaml:"hierarchyId,omitempty" json:"hierarchyId,omitempty"` + Project *RestPullRequestFromRefRepositoryProject `yaml:"project,omitempty" json:"project,omitempty"` + Scope *string `yaml:"scope,omitempty" json:"scope,omitempty"` + Origin *RestPullRequestFromRefRepositoryOrigin `yaml:"origin,omitempty" json:"origin,omitempty"` + Slug *string `yaml:"slug,omitempty" json:"slug,omitempty"` + Forkable *bool `yaml:"forkable,omitempty" json:"forkable,omitempty"` + Archived *bool `yaml:"archived,omitempty" json:"archived,omitempty"` + ScmId *string `yaml:"scmId,omitempty" json:"scmId,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_from_ref_repository_origin.go b/internal/client/bitbucket/generated_model_rest_pull_request_from_ref_repository_origin.go new file mode 100644 index 0000000..5c18ecd --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_from_ref_repository_origin.go @@ -0,0 +1,33 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestFromRefRepositoryOrigin struct for RestPullRequestFromRefRepositoryOrigin +type RestPullRequestFromRefRepositoryOrigin struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Public *bool `yaml:"public,omitempty" json:"public,omitempty"` + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + StatusMessage *string `yaml:"statusMessage,omitempty" json:"statusMessage,omitempty"` + DefaultBranch *string `yaml:"defaultBranch,omitempty" json:"defaultBranch,omitempty"` + RelatedLinks map[string]interface{} `yaml:"relatedLinks,omitempty" json:"relatedLinks,omitempty"` + Partition *int32 `yaml:"partition,omitempty" json:"partition,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + HierarchyId *string `yaml:"hierarchyId,omitempty" json:"hierarchyId,omitempty"` + Project *RestPullRequestFromRefRepositoryProject `yaml:"project,omitempty" json:"project,omitempty"` + Scope *string `yaml:"scope,omitempty" json:"scope,omitempty"` + Slug *string `yaml:"slug,omitempty" json:"slug,omitempty"` + Forkable *bool `yaml:"forkable,omitempty" json:"forkable,omitempty"` + Archived *bool `yaml:"archived,omitempty" json:"archived,omitempty"` + ScmId *string `yaml:"scmId,omitempty" json:"scmId,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_from_ref_repository_project.go b/internal/client/bitbucket/generated_model_rest_pull_request_from_ref_repository_project.go new file mode 100644 index 0000000..4de4fce --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_from_ref_repository_project.go @@ -0,0 +1,28 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestFromRefRepositoryProject struct for RestPullRequestFromRefRepositoryProject +type RestPullRequestFromRefRepositoryProject struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty" validate:"regexp=^[^~].*"` + Key string `yaml:"key" json:"key"` + Public *bool `yaml:"public,omitempty" json:"public,omitempty"` + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + AvatarUrl *string `yaml:"-" json:"-"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + // Deprecated + Namespace *string `yaml:"namespace,omitempty" json:"namespace,omitempty"` + Scope *string `yaml:"scope,omitempty" json:"scope,omitempty"` + Avatar *string `yaml:"avatar,omitempty" json:"avatar,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_merge_config.go b/internal/client/bitbucket/generated_model_rest_pull_request_merge_config.go new file mode 100644 index 0000000..056b1d6 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_merge_config.go @@ -0,0 +1,21 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestMergeConfig struct for RestPullRequestMergeConfig +type RestPullRequestMergeConfig struct { + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + CommitMessageTemplate *RestPullRequestMergeConfigCommitMessageTemplate `yaml:"commitMessageTemplate,omitempty" json:"commitMessageTemplate,omitempty"` + CommitSummaries *int32 `yaml:"commitSummaries,omitempty" json:"commitSummaries,omitempty"` + DefaultStrategy *RestPullRequestMergeConfigDefaultStrategy `yaml:"defaultStrategy,omitempty" json:"defaultStrategy,omitempty"` + Strategies []RestPullRequestMergeStrategy `yaml:"strategies,omitempty" json:"strategies,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_merge_config_commit_message_template.go b/internal/client/bitbucket/generated_model_rest_pull_request_merge_config_commit_message_template.go new file mode 100644 index 0000000..f473ec4 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_merge_config_commit_message_template.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestMergeConfigCommitMessageTemplate struct for RestPullRequestMergeConfigCommitMessageTemplate +type RestPullRequestMergeConfigCommitMessageTemplate struct { + Title *string `yaml:"title,omitempty" json:"title,omitempty"` + Body *string `yaml:"body,omitempty" json:"body,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_merge_config_default_strategy.go b/internal/client/bitbucket/generated_model_rest_pull_request_merge_config_default_strategy.go new file mode 100644 index 0000000..b43335f --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_merge_config_default_strategy.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestMergeConfigDefaultStrategy struct for RestPullRequestMergeConfigDefaultStrategy +type RestPullRequestMergeConfigDefaultStrategy struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + Enabled *bool `yaml:"enabled,omitempty" json:"enabled,omitempty"` + Flag *string `yaml:"flag,omitempty" json:"flag,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_merge_request.go b/internal/client/bitbucket/generated_model_rest_pull_request_merge_request.go new file mode 100644 index 0000000..2995cfc --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_merge_request.go @@ -0,0 +1,21 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestMergeRequest struct for RestPullRequestMergeRequest +type RestPullRequestMergeRequest struct { + AutoMerge *bool `yaml:"autoMerge,omitempty" json:"autoMerge,omitempty"` + AutoSubject *string `yaml:"autoSubject,omitempty" json:"autoSubject,omitempty"` + Message *string `yaml:"message,omitempty" json:"message,omitempty"` + StrategyId *string `yaml:"strategyId,omitempty" json:"strategyId,omitempty"` + Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_merge_strategy.go b/internal/client/bitbucket/generated_model_rest_pull_request_merge_strategy.go new file mode 100644 index 0000000..fa1620f --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_merge_strategy.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestMergeStrategy struct for RestPullRequestMergeStrategy +type RestPullRequestMergeStrategy struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + Enabled *bool `yaml:"enabled,omitempty" json:"enabled,omitempty"` + Flag *string `yaml:"flag,omitempty" json:"flag,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_mergeability.go b/internal/client/bitbucket/generated_model_rest_pull_request_mergeability.go new file mode 100644 index 0000000..cc2b08f --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_mergeability.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestMergeability struct for RestPullRequestMergeability +type RestPullRequestMergeability struct { + Conflicted *bool `yaml:"conflicted,omitempty" json:"conflicted,omitempty"` + Outcome *string `yaml:"outcome,omitempty" json:"outcome,omitempty"` + Vetoes []RestRepositoryHookVeto `yaml:"vetoes,omitempty" json:"vetoes,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_participant.go b/internal/client/bitbucket/generated_model_rest_pull_request_participant.go new file mode 100644 index 0000000..1f9e659 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_participant.go @@ -0,0 +1,21 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestParticipant struct for RestPullRequestParticipant +type RestPullRequestParticipant struct { + LastReviewedCommit *string `yaml:"lastReviewedCommit,omitempty" json:"lastReviewedCommit,omitempty"` + Status *string `yaml:"status,omitempty" json:"status,omitempty"` + Role *string `yaml:"role,omitempty" json:"role,omitempty"` + User *RestPullRequestParticipantUser `yaml:"user,omitempty" json:"user,omitempty"` + Approved *bool `yaml:"approved,omitempty" json:"approved,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_participant_user.go b/internal/client/bitbucket/generated_model_rest_pull_request_participant_user.go new file mode 100644 index 0000000..4268ca7 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_participant_user.go @@ -0,0 +1,25 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestParticipantUser struct for RestPullRequestParticipantUser +type RestPullRequestParticipantUser struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + Active *bool `yaml:"active,omitempty" json:"active,omitempty"` + DisplayName *string `yaml:"displayName,omitempty" json:"displayName,omitempty"` + EmailAddress *string `yaml:"emailAddress,omitempty" json:"emailAddress,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` + Slug *string `yaml:"slug,omitempty" json:"slug,omitempty"` + AvatarUrl *string `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_rebase_request.go b/internal/client/bitbucket/generated_model_rest_pull_request_rebase_request.go new file mode 100644 index 0000000..ad73bf5 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_rebase_request.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestRebaseRequest struct for RestPullRequestRebaseRequest +type RestPullRequestRebaseRequest struct { + Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_rebase_result.go b/internal/client/bitbucket/generated_model_rest_pull_request_rebase_result.go new file mode 100644 index 0000000..d17138d --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_rebase_result.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestRebaseResult struct for RestPullRequestRebaseResult +type RestPullRequestRebaseResult struct { + RefChange *RestPullRequestRebaseResultRefChange `yaml:"refChange,omitempty" json:"refChange,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_rebase_result_ref_change.go b/internal/client/bitbucket/generated_model_rest_pull_request_rebase_result_ref_change.go new file mode 100644 index 0000000..7ede0bd --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_rebase_result_ref_change.go @@ -0,0 +1,21 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestRebaseResultRefChange struct for RestPullRequestRebaseResultRefChange +type RestPullRequestRebaseResultRefChange struct { + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + Ref *RestPullRequestRebaseResultRefChangeRef `yaml:"ref,omitempty" json:"ref,omitempty"` + FromHash *string `yaml:"fromHash,omitempty" json:"fromHash,omitempty"` + RefId *string `yaml:"refId,omitempty" json:"refId,omitempty"` + ToHash *string `yaml:"toHash,omitempty" json:"toHash,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_rebase_result_ref_change_ref.go b/internal/client/bitbucket/generated_model_rest_pull_request_rebase_result_ref_change_ref.go new file mode 100644 index 0000000..e01c735 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_rebase_result_ref_change_ref.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestRebaseResultRefChangeRef struct for RestPullRequestRebaseResultRefChangeRef +type RestPullRequestRebaseResultRefChangeRef struct { + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_rebaseability.go b/internal/client/bitbucket/generated_model_rest_pull_request_rebaseability.go new file mode 100644 index 0000000..143f979 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_rebaseability.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestRebaseability struct for RestPullRequestRebaseability +type RestPullRequestRebaseability struct { + Vetoes []RestRepositoryHookVeto `yaml:"vetoes,omitempty" json:"vetoes,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_reopen_request.go b/internal/client/bitbucket/generated_model_rest_pull_request_reopen_request.go new file mode 100644 index 0000000..922b79f --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_reopen_request.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestReopenRequest struct for RestPullRequestReopenRequest +type RestPullRequestReopenRequest struct { + Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_settings.go b/internal/client/bitbucket/generated_model_rest_pull_request_settings.go new file mode 100644 index 0000000..6fc6db1 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_settings.go @@ -0,0 +1,17 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestSettings struct for RestPullRequestSettings +type RestPullRequestSettings struct { + MergeConfig *RestPullRequestSettingsMergeConfig `yaml:"mergeConfig,omitempty" json:"mergeConfig,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_pull_request_settings_merge_config.go b/internal/client/bitbucket/generated_model_rest_pull_request_settings_merge_config.go new file mode 100644 index 0000000..5a2007f --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_pull_request_settings_merge_config.go @@ -0,0 +1,21 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestPullRequestSettingsMergeConfig struct for RestPullRequestSettingsMergeConfig +type RestPullRequestSettingsMergeConfig struct { + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + CommitMessageTemplate *RestPullRequestMergeConfigCommitMessageTemplate `yaml:"commitMessageTemplate,omitempty" json:"commitMessageTemplate,omitempty"` + CommitSummaries *int32 `yaml:"commitSummaries,omitempty" json:"commitSummaries,omitempty"` + DefaultStrategy *RestPullRequestMergeConfigDefaultStrategy `yaml:"defaultStrategy,omitempty" json:"defaultStrategy,omitempty"` + Strategies []RestPullRequestMergeStrategy `yaml:"strategies,omitempty" json:"strategies,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_ref_matcher.go b/internal/client/bitbucket/generated_model_rest_ref_matcher.go new file mode 100644 index 0000000..d8b0bd4 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_ref_matcher.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRefMatcher struct for RestRefMatcher +type RestRefMatcher struct { + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Type *RestRefMatcherType `yaml:"type,omitempty" json:"type,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_ref_matcher_type.go b/internal/client/bitbucket/generated_model_rest_ref_matcher_type.go new file mode 100644 index 0000000..f408074 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_ref_matcher_type.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRefMatcherType struct for RestRefMatcherType +type RestRefMatcherType struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Id *string `yaml:"id,omitempty" json:"id,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_ref_restriction.go b/internal/client/bitbucket/generated_model_rest_ref_restriction.go new file mode 100644 index 0000000..f00b6eb --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_ref_restriction.go @@ -0,0 +1,23 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRefRestriction struct for RestRefRestriction +type RestRefRestriction struct { + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + AccessKeys []RestSshAccessKey `yaml:"accessKeys,omitempty" json:"accessKeys,omitempty"` + Scope *RestPullRequestConditionScope `yaml:"scope,omitempty" json:"scope,omitempty"` + Groups []string `yaml:"groups,omitempty" json:"groups,omitempty"` + Matcher *RestRequiredBuildConditionRefMatcher `yaml:"matcher,omitempty" json:"matcher,omitempty"` + Users []RestApplicationUser `yaml:"users,omitempty" json:"users,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_ref_sync_request.go b/internal/client/bitbucket/generated_model_rest_ref_sync_request.go new file mode 100644 index 0000000..f66acd1 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_ref_sync_request.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRefSyncRequest struct for RestRefSyncRequest +type RestRefSyncRequest struct { + Action *string `yaml:"action,omitempty" json:"action,omitempty"` + Context *Context `yaml:"context,omitempty" json:"context,omitempty"` + RefId *string `yaml:"refId,omitempty" json:"refId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_ref_sync_status.go b/internal/client/bitbucket/generated_model_rest_ref_sync_status.go new file mode 100644 index 0000000..cb2189c --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_ref_sync_status.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRefSyncStatus struct for RestRefSyncStatus +type RestRefSyncStatus struct { + Available *bool `yaml:"available,omitempty" json:"available,omitempty"` + AheadRefs *RestRefSyncStatusAheadRefs `yaml:"aheadRefs,omitempty" json:"aheadRefs,omitempty"` + OrphanedRefs *RestRefSyncStatusAheadRefs `yaml:"orphanedRefs,omitempty" json:"orphanedRefs,omitempty"` + LastSync *float32 `yaml:"lastSync,omitempty" json:"lastSync,omitempty"` + DivergedRefs *RestRefSyncStatusAheadRefs `yaml:"divergedRefs,omitempty" json:"divergedRefs,omitempty"` + Enabled *bool `yaml:"enabled,omitempty" json:"enabled,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_ref_sync_status_ahead_refs.go b/internal/client/bitbucket/generated_model_rest_ref_sync_status_ahead_refs.go new file mode 100644 index 0000000..0eb4e19 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_ref_sync_status_ahead_refs.go @@ -0,0 +1,21 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRefSyncStatusAheadRefs struct for RestRefSyncStatusAheadRefs +type RestRefSyncStatusAheadRefs struct { + Tag *bool `yaml:"tag,omitempty" json:"tag,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_rejected_ref.go b/internal/client/bitbucket/generated_model_rest_rejected_ref.go new file mode 100644 index 0000000..2c44acd --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_rejected_ref.go @@ -0,0 +1,21 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRejectedRef struct for RestRejectedRef +type RestRejectedRef struct { + Tag *bool `yaml:"tag,omitempty" json:"tag,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_repository.go b/internal/client/bitbucket/generated_model_rest_repository.go new file mode 100644 index 0000000..660cb00 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_repository.go @@ -0,0 +1,33 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRepository struct for RestRepository +type RestRepository struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Public *bool `yaml:"public,omitempty" json:"public,omitempty"` + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + StatusMessage *string `yaml:"statusMessage,omitempty" json:"statusMessage,omitempty"` + DefaultBranch *string `yaml:"defaultBranch,omitempty" json:"defaultBranch,omitempty"` + RelatedLinks map[string]interface{} `yaml:"relatedLinks,omitempty" json:"relatedLinks,omitempty"` + Partition *int32 `yaml:"partition,omitempty" json:"partition,omitempty"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + HierarchyId *string `yaml:"hierarchyId,omitempty" json:"hierarchyId,omitempty"` + Project *RestPullRequestFromRefRepositoryProject `yaml:"project,omitempty" json:"project,omitempty"` + Scope *string `yaml:"scope,omitempty" json:"scope,omitempty"` + Slug *string `yaml:"slug,omitempty" json:"slug,omitempty"` + Forkable *bool `yaml:"forkable,omitempty" json:"forkable,omitempty"` + Archived *bool `yaml:"archived,omitempty" json:"archived,omitempty"` + ScmId *string `yaml:"scmId,omitempty" json:"scmId,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_repository_hook.go b/internal/client/bitbucket/generated_model_rest_repository_hook.go new file mode 100644 index 0000000..df297d0 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_repository_hook.go @@ -0,0 +1,20 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRepositoryHook struct for RestRepositoryHook +type RestRepositoryHook struct { + Configured *bool `yaml:"configured,omitempty" json:"configured,omitempty"` + Enabled *bool `yaml:"enabled,omitempty" json:"enabled,omitempty"` + Scope *RestAutoDeclineSettingsScope `yaml:"scope,omitempty" json:"scope,omitempty"` + Details *RepositoryHookDetails `yaml:"details,omitempty" json:"details,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_repository_hook_veto.go b/internal/client/bitbucket/generated_model_rest_repository_hook_veto.go new file mode 100644 index 0000000..028c52c --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_repository_hook_veto.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRepositoryHookVeto struct for RestRepositoryHookVeto +type RestRepositoryHookVeto struct { + SummaryMessage *string `yaml:"summaryMessage,omitempty" json:"summaryMessage,omitempty"` + DetailedMessage *string `yaml:"detailedMessage,omitempty" json:"detailedMessage,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_repository_pull_request_settings.go b/internal/client/bitbucket/generated_model_rest_repository_pull_request_settings.go new file mode 100644 index 0000000..a30b843 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_repository_pull_request_settings.go @@ -0,0 +1,23 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRepositoryPullRequestSettings struct for RestRepositoryPullRequestSettings +type RestRepositoryPullRequestSettings struct { + MergeConfig *RestPullRequestSettingsMergeConfig `yaml:"mergeConfig,omitempty" json:"mergeConfig,omitempty"` + RequiredApprovers *RestRepositoryPullRequestSettingsRequiredApprovers `yaml:"requiredApprovers,omitempty" json:"requiredApprovers,omitempty"` + RequiredAllApprovers *bool `yaml:"requiredAllApprovers,omitempty" json:"requiredAllApprovers,omitempty"` + RequiredApproversDeprecated *int32 `yaml:"requiredApproversDeprecated,omitempty" json:"requiredApproversDeprecated,omitempty"` + RequiredSuccessfulBuildsDeprecated *int32 `yaml:"requiredSuccessfulBuildsDeprecated,omitempty" json:"requiredSuccessfulBuildsDeprecated,omitempty"` + RequiredAllTasksComplete *bool `yaml:"requiredAllTasksComplete,omitempty" json:"requiredAllTasksComplete,omitempty"` + RequiredSuccessfulBuilds *RestRepositoryPullRequestSettingsRequiredApprovers `yaml:"requiredSuccessfulBuilds,omitempty" json:"requiredSuccessfulBuilds,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_repository_pull_request_settings_required_approvers.go b/internal/client/bitbucket/generated_model_rest_repository_pull_request_settings_required_approvers.go new file mode 100644 index 0000000..35fe75b --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_repository_pull_request_settings_required_approvers.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRepositoryPullRequestSettingsRequiredApprovers struct for RestRepositoryPullRequestSettingsRequiredApprovers +type RestRepositoryPullRequestSettingsRequiredApprovers struct { + Count *string `yaml:"count,omitempty" json:"count,omitempty"` + Enabled *bool `yaml:"enabled,omitempty" json:"enabled,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_repository_ref_change_activity.go b/internal/client/bitbucket/generated_model_rest_repository_ref_change_activity.go new file mode 100644 index 0000000..469d51e --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_repository_ref_change_activity.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRepositoryRefChangeActivity struct for RestRepositoryRefChangeActivity +type RestRepositoryRefChangeActivity struct { + RefChange *RestRepositoryRefChangeActivityRefChange `yaml:"refChange,omitempty" json:"refChange,omitempty"` + Repository *RestPullRequestFromRefRepository `yaml:"repository,omitempty" json:"repository,omitempty"` + Trigger *string `yaml:"trigger,omitempty" json:"trigger,omitempty"` + Id *int64 `yaml:"id,omitempty" json:"id,omitempty"` + CreatedDate *int64 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + User *RestPullRequestParticipantUser `yaml:"user,omitempty" json:"user,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_repository_ref_change_activity_ref_change.go b/internal/client/bitbucket/generated_model_rest_repository_ref_change_activity_ref_change.go new file mode 100644 index 0000000..b6271c4 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_repository_ref_change_activity_ref_change.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRepositoryRefChangeActivityRefChange struct for RestRepositoryRefChangeActivityRefChange +type RestRepositoryRefChangeActivityRefChange struct { + UpdatedType *string `yaml:"updatedType,omitempty" json:"updatedType,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + Ref *RestPullRequestRebaseResultRefChangeRef `yaml:"ref,omitempty" json:"ref,omitempty"` + FromHash *string `yaml:"fromHash,omitempty" json:"fromHash,omitempty"` + RefId *string `yaml:"refId,omitempty" json:"refId,omitempty"` + ToHash *string `yaml:"toHash,omitempty" json:"toHash,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_required_build_condition.go b/internal/client/bitbucket/generated_model_rest_required_build_condition.go new file mode 100644 index 0000000..0e4af82 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_required_build_condition.go @@ -0,0 +1,21 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRequiredBuildCondition struct for RestRequiredBuildCondition +type RestRequiredBuildCondition struct { + Id *int64 `yaml:"id,omitempty" json:"id,omitempty"` + // A non-empty list of build parent keys that require green builds for this merge check to pass + BuildParentKeys []string `yaml:"buildParentKeys,omitempty" json:"buildParentKeys,omitempty"` + RefMatcher *RestRequiredBuildConditionRefMatcher `yaml:"refMatcher,omitempty" json:"refMatcher,omitempty"` + ExemptRefMatcher *RestRequiredBuildConditionRefMatcher `yaml:"exemptRefMatcher,omitempty" json:"exemptRefMatcher,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_required_build_condition_ref_matcher.go b/internal/client/bitbucket/generated_model_rest_required_build_condition_ref_matcher.go new file mode 100644 index 0000000..bbe5a02 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_required_build_condition_ref_matcher.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRequiredBuildConditionRefMatcher struct for RestRequiredBuildConditionRefMatcher +type RestRequiredBuildConditionRefMatcher struct { + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Type *RestRefMatcherType `yaml:"type,omitempty" json:"type,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_required_build_condition_set_request.go b/internal/client/bitbucket/generated_model_rest_required_build_condition_set_request.go new file mode 100644 index 0000000..2a8cad3 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_required_build_condition_set_request.go @@ -0,0 +1,20 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRequiredBuildConditionSetRequest struct for RestRequiredBuildConditionSetRequest +type RestRequiredBuildConditionSetRequest struct { + // A non-empty list of build parent keys that require green builds for this merge check to pass + BuildParentKeys []string `yaml:"buildParentKeys" json:"buildParentKeys"` + ExemptRefMatcher *RestRefMatcher `yaml:"exemptRefMatcher,omitempty" json:"exemptRefMatcher,omitempty"` + RefMatcher UpdatePullRequestCondition1RequestSourceMatcher `yaml:"refMatcher" json:"refMatcher"` +} diff --git a/internal/client/bitbucket/generated_model_rest_restriction_request.go b/internal/client/bitbucket/generated_model_rest_restriction_request.go new file mode 100644 index 0000000..a97690f --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_restriction_request.go @@ -0,0 +1,26 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRestrictionRequest struct for RestRestrictionRequest +type RestRestrictionRequest struct { + AccessKeyIds []int32 `yaml:"accessKeyIds,omitempty" json:"accessKeyIds,omitempty"` + AccessKeys []RestSshAccessKey `yaml:"accessKeys,omitempty" json:"accessKeys,omitempty"` + GroupNames []string `yaml:"groupNames,omitempty" json:"groupNames,omitempty"` + Groups []string `yaml:"groups,omitempty" json:"groups,omitempty"` + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + Matcher *UpdatePullRequestCondition1RequestSourceMatcher `yaml:"matcher,omitempty" json:"matcher,omitempty"` + Scope *RestRestrictionRequestScope `yaml:"scope,omitempty" json:"scope,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + UserSlugs []string `yaml:"userSlugs,omitempty" json:"userSlugs,omitempty"` + Users []RestApplicationUser `yaml:"users,omitempty" json:"users,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_restriction_request_scope.go b/internal/client/bitbucket/generated_model_rest_restriction_request_scope.go new file mode 100644 index 0000000..1db826d --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_restriction_request_scope.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestRestrictionRequestScope struct for RestRestrictionRequestScope +type RestRestrictionRequestScope struct { + ResourceId *int32 `yaml:"resourceId,omitempty" json:"resourceId,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_reviewer_group.go b/internal/client/bitbucket/generated_model_rest_reviewer_group.go new file mode 100644 index 0000000..30a8eea --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_reviewer_group.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestReviewerGroup struct for RestReviewerGroup +type RestReviewerGroup struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Id *int64 `yaml:"id,omitempty" json:"id,omitempty"` + AvatarUrl *string `yaml:"-" json:"-"` + Description *string `yaml:"description,omitempty" json:"description,omitempty"` + Scope *RestAutoDeclineSettingsScope `yaml:"scope,omitempty" json:"scope,omitempty"` + Users []ApplicationUser `yaml:"users,omitempty" json:"users,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_set_insight_report_request.go b/internal/client/bitbucket/generated_model_rest_set_insight_report_request.go new file mode 100644 index 0000000..fa99367 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_set_insight_report_request.go @@ -0,0 +1,25 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestSetInsightReportRequest struct for RestSetInsightReportRequest +type RestSetInsightReportRequest struct { + CoverageProviderKey *string `yaml:"coverageProviderKey,omitempty" json:"coverageProviderKey,omitempty"` + CreatedDate *int64 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + Data []RestInsightReportData `yaml:"data" json:"data"` + Details *string `yaml:"details,omitempty" json:"details,omitempty"` + Link *string `yaml:"link,omitempty" json:"link,omitempty"` + LogoUrl *string `yaml:"logoUrl,omitempty" json:"logoUrl,omitempty"` + Reporter *string `yaml:"reporter,omitempty" json:"reporter,omitempty"` + Result *string `yaml:"result,omitempty" json:"result,omitempty" validate:"regexp=FAIL|PASS"` + Title string `yaml:"title" json:"title"` +} diff --git a/internal/client/bitbucket/generated_model_rest_single_add_insight_annotation_request.go b/internal/client/bitbucket/generated_model_rest_single_add_insight_annotation_request.go new file mode 100644 index 0000000..d90139d --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_single_add_insight_annotation_request.go @@ -0,0 +1,23 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestSingleAddInsightAnnotationRequest struct for RestSingleAddInsightAnnotationRequest +type RestSingleAddInsightAnnotationRequest struct { + ExternalId *string `yaml:"externalId,omitempty" json:"externalId,omitempty"` + Line *int32 `yaml:"line,omitempty" json:"line,omitempty"` + Link *string `yaml:"link,omitempty" json:"link,omitempty"` + Message string `yaml:"message" json:"message"` + Path *string `yaml:"path,omitempty" json:"path,omitempty"` + Severity string `yaml:"severity" json:"severity" validate:"regexp=LOW|MEDIUM|HIGH"` + Type *string `yaml:"type,omitempty" json:"type,omitempty" validate:"regexp=VULNERABILITY|CODE_SMELL|BUG"` +} diff --git a/internal/client/bitbucket/generated_model_rest_ssh_access_key.go b/internal/client/bitbucket/generated_model_rest_ssh_access_key.go new file mode 100644 index 0000000..ff65cc4 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_ssh_access_key.go @@ -0,0 +1,20 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestSshAccessKey struct for RestSshAccessKey +type RestSshAccessKey struct { + Permission *string `yaml:"permission,omitempty" json:"permission,omitempty"` + Key *RestSshAccessKeyKey `yaml:"key,omitempty" json:"key,omitempty"` + Repository *RestPullRequestFromRefRepository `yaml:"repository,omitempty" json:"repository,omitempty"` + Project *RestPullRequestFromRefRepositoryProject `yaml:"project,omitempty" json:"project,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_ssh_access_key_key.go b/internal/client/bitbucket/generated_model_rest_ssh_access_key_key.go new file mode 100644 index 0000000..788816d --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_ssh_access_key_key.go @@ -0,0 +1,28 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + +import ( + "time" +) + +// RestSshAccessKeyKey struct for RestSshAccessKeyKey +type RestSshAccessKeyKey struct { + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + CreatedDate *time.Time `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + ExpiryDays *int32 `yaml:"expiryDays,omitempty" json:"expiryDays,omitempty"` + LastAuthenticated *string `yaml:"lastAuthenticated,omitempty" json:"lastAuthenticated,omitempty"` + Fingerprint *string `yaml:"fingerprint,omitempty" json:"fingerprint,omitempty"` + BitLength *int32 `yaml:"bitLength,omitempty" json:"bitLength,omitempty"` + AlgorithmType *string `yaml:"algorithmType,omitempty" json:"algorithmType,omitempty"` + Text *string `yaml:"text,omitempty" json:"text,omitempty"` + Label *string `yaml:"label,omitempty" json:"label,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_tag.go b/internal/client/bitbucket/generated_model_rest_tag.go new file mode 100644 index 0000000..f22d38c --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_tag.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestTag struct for RestTag +type RestTag struct { + Hash *string `yaml:"hash,omitempty" json:"hash,omitempty"` + LatestCommit *string `yaml:"latestCommit,omitempty" json:"latestCommit,omitempty"` + LatestChangeset *string `yaml:"latestChangeset,omitempty" json:"latestChangeset,omitempty"` + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_user_reaction.go b/internal/client/bitbucket/generated_model_rest_user_reaction.go new file mode 100644 index 0000000..89f2648 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_user_reaction.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestUserReaction struct for RestUserReaction +type RestUserReaction struct { + Comment *RestUserReactionComment `yaml:"comment,omitempty" json:"comment,omitempty"` + Emoticon *RestUserReactionEmoticon `yaml:"emoticon,omitempty" json:"emoticon,omitempty"` + User *RestPullRequestParticipantUser `yaml:"user,omitempty" json:"user,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_user_reaction_comment.go b/internal/client/bitbucket/generated_model_rest_user_reaction_comment.go new file mode 100644 index 0000000..6de1391 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_user_reaction_comment.go @@ -0,0 +1,38 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestUserReactionComment struct for RestUserReactionComment +type RestUserReactionComment struct { + Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` + Parent *RestUserReactionCommentParent `yaml:"parent,omitempty" json:"parent,omitempty"` + Id *int64 `yaml:"id,omitempty" json:"id,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + Severity *string `yaml:"severity,omitempty" json:"severity,omitempty"` + ThreadResolvedDate *int64 `yaml:"threadResolvedDate,omitempty" json:"threadResolvedDate,omitempty"` + ThreadResolver *RestUserReactionCommentParentThreadResolver `yaml:"threadResolver,omitempty" json:"threadResolver,omitempty"` + // Indicates if this comment thread has been marked as resolved or not + ThreadResolved *bool `yaml:"threadResolved,omitempty" json:"threadResolved,omitempty"` + CreatedDate *int64 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + ResolvedDate *int64 `yaml:"resolvedDate,omitempty" json:"resolvedDate,omitempty"` + Resolver *RestUserReactionCommentParentThreadResolver `yaml:"resolver,omitempty" json:"resolver,omitempty"` + UpdatedDate *int64 `yaml:"updatedDate,omitempty" json:"updatedDate,omitempty"` + Comments []RestComment `yaml:"comments,omitempty" json:"comments,omitempty"` + Text *string `yaml:"text,omitempty" json:"text,omitempty"` + Anchor *RestUserReactionCommentParentAnchor `yaml:"anchor,omitempty" json:"anchor,omitempty"` + Author *RestUserReactionCommentParentThreadResolver `yaml:"author,omitempty" json:"author,omitempty"` + Html *string `yaml:"html,omitempty" json:"html,omitempty"` + Anchored *bool `yaml:"anchored,omitempty" json:"anchored,omitempty"` + Pending *bool `yaml:"pending,omitempty" json:"pending,omitempty"` + Reply *bool `yaml:"reply,omitempty" json:"reply,omitempty"` + Properties map[string]interface{} `yaml:"properties,omitempty" json:"properties,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_user_reaction_comment_parent.go b/internal/client/bitbucket/generated_model_rest_user_reaction_comment_parent.go new file mode 100644 index 0000000..fbec5e1 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_user_reaction_comment_parent.go @@ -0,0 +1,37 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestUserReactionCommentParent struct for RestUserReactionCommentParent +type RestUserReactionCommentParent struct { + Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` + Id *int64 `yaml:"id,omitempty" json:"id,omitempty"` + State *string `yaml:"state,omitempty" json:"state,omitempty"` + Severity *string `yaml:"severity,omitempty" json:"severity,omitempty"` + ThreadResolvedDate *int64 `yaml:"threadResolvedDate,omitempty" json:"threadResolvedDate,omitempty"` + ThreadResolver *RestUserReactionCommentParentThreadResolver `yaml:"threadResolver,omitempty" json:"threadResolver,omitempty"` + // Indicates if this comment thread has been marked as resolved or not + ThreadResolved *bool `yaml:"threadResolved,omitempty" json:"threadResolved,omitempty"` + CreatedDate *int64 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` + ResolvedDate *int64 `yaml:"resolvedDate,omitempty" json:"resolvedDate,omitempty"` + Resolver *RestUserReactionCommentParentThreadResolver `yaml:"resolver,omitempty" json:"resolver,omitempty"` + UpdatedDate *int64 `yaml:"updatedDate,omitempty" json:"updatedDate,omitempty"` + Comments []RestComment `yaml:"comments,omitempty" json:"comments,omitempty"` + Text *string `yaml:"text,omitempty" json:"text,omitempty"` + Anchor *RestUserReactionCommentParentAnchor `yaml:"anchor,omitempty" json:"anchor,omitempty"` + Author *RestUserReactionCommentParentThreadResolver `yaml:"author,omitempty" json:"author,omitempty"` + Html *string `yaml:"html,omitempty" json:"html,omitempty"` + Anchored *bool `yaml:"anchored,omitempty" json:"anchored,omitempty"` + Pending *bool `yaml:"pending,omitempty" json:"pending,omitempty"` + Reply *bool `yaml:"reply,omitempty" json:"reply,omitempty"` + Properties map[string]interface{} `yaml:"properties,omitempty" json:"properties,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_user_reaction_comment_parent_anchor.go b/internal/client/bitbucket/generated_model_rest_user_reaction_comment_parent_anchor.go new file mode 100644 index 0000000..57c3d54 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_user_reaction_comment_parent_anchor.go @@ -0,0 +1,26 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestUserReactionCommentParentAnchor struct for RestUserReactionCommentParentAnchor +type RestUserReactionCommentParentAnchor struct { + Path *RestCommentThreadDiffAnchorPath `yaml:"path,omitempty" json:"path,omitempty"` + DiffType *string `yaml:"diffType,omitempty" json:"diffType,omitempty"` + FileType *string `yaml:"fileType,omitempty" json:"fileType,omitempty"` + FromHash *string `yaml:"fromHash,omitempty" json:"fromHash,omitempty"` + LineType *string `yaml:"lineType,omitempty" json:"lineType,omitempty"` + PullRequest *RestCommentThreadDiffAnchorPullRequest `yaml:"pullRequest,omitempty" json:"pullRequest,omitempty"` + LineComment *bool `yaml:"lineComment,omitempty" json:"lineComment,omitempty"` + Line *int32 `yaml:"line,omitempty" json:"line,omitempty"` + SrcPath *RestCommentThreadDiffAnchorPath `yaml:"srcPath,omitempty" json:"srcPath,omitempty"` + ToHash *string `yaml:"toHash,omitempty" json:"toHash,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_user_reaction_comment_parent_thread_resolver.go b/internal/client/bitbucket/generated_model_rest_user_reaction_comment_parent_thread_resolver.go new file mode 100644 index 0000000..e7843a8 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_user_reaction_comment_parent_thread_resolver.go @@ -0,0 +1,25 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestUserReactionCommentParentThreadResolver struct for RestUserReactionCommentParentThreadResolver +type RestUserReactionCommentParentThreadResolver struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` + Type *string `yaml:"type,omitempty" json:"type,omitempty"` + Active *bool `yaml:"active,omitempty" json:"active,omitempty"` + DisplayName *string `yaml:"displayName,omitempty" json:"displayName,omitempty"` + EmailAddress *string `yaml:"emailAddress,omitempty" json:"emailAddress,omitempty"` + Links map[string]interface{} `yaml:"-" json:"-"` + Slug *string `yaml:"slug,omitempty" json:"slug,omitempty"` + AvatarUrl *string `yaml:"-" json:"-"` +} diff --git a/internal/client/bitbucket/generated_model_rest_user_reaction_emoticon.go b/internal/client/bitbucket/generated_model_rest_user_reaction_emoticon.go new file mode 100644 index 0000000..cf684cf --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_user_reaction_emoticon.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestUserReactionEmoticon struct for RestUserReactionEmoticon +type RestUserReactionEmoticon struct { + Value *string `yaml:"value,omitempty" json:"value,omitempty"` + Shortcut *string `yaml:"shortcut,omitempty" json:"shortcut,omitempty"` + Url *string `yaml:"url,omitempty" json:"url,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_webhook.go b/internal/client/bitbucket/generated_model_rest_webhook.go new file mode 100644 index 0000000..2a5b54c --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_webhook.go @@ -0,0 +1,25 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestWebhook struct for RestWebhook +type RestWebhook struct { + Name *string `yaml:"name,omitempty" json:"name,omitempty"` + SslVerificationRequired *bool `yaml:"sslVerificationRequired,omitempty" json:"sslVerificationRequired,omitempty"` + Statistics map[string]interface{} `yaml:"-" json:"-"` + ScopeType *string `yaml:"scopeType,omitempty" json:"scopeType,omitempty"` + Configuration map[string]interface{} `yaml:"configuration,omitempty" json:"configuration,omitempty"` + Credentials *RestWebhookCredentials `yaml:"credentials,omitempty" json:"credentials,omitempty"` + Url *string `yaml:"url,omitempty" json:"url,omitempty"` + Events []string `yaml:"events,omitempty" json:"events,omitempty"` + Active *bool `yaml:"active,omitempty" json:"active,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_rest_webhook_credentials.go b/internal/client/bitbucket/generated_model_rest_webhook_credentials.go new file mode 100644 index 0000000..e22a006 --- /dev/null +++ b/internal/client/bitbucket/generated_model_rest_webhook_credentials.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// RestWebhookCredentials struct for RestWebhookCredentials +type RestWebhookCredentials struct { + Password *string `yaml:"password,omitempty" json:"password,omitempty"` + Username *string `yaml:"username,omitempty" json:"username,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_stream_diff_1_200_response.go b/internal/client/bitbucket/generated_model_stream_diff_1_200_response.go new file mode 100644 index 0000000..1ffbd1d --- /dev/null +++ b/internal/client/bitbucket/generated_model_stream_diff_1_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// StreamDiff1200Response struct for StreamDiff1200Response +type StreamDiff1200Response struct { + Values []RestDiff `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_stream_files_200_response.go b/internal/client/bitbucket/generated_model_stream_files_200_response.go new file mode 100644 index 0000000..1db6125 --- /dev/null +++ b/internal/client/bitbucket/generated_model_stream_files_200_response.go @@ -0,0 +1,22 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// StreamFiles200Response struct for StreamFiles200Response +type StreamFiles200Response struct { + Values []interface{} `yaml:"values,omitempty" json:"values,omitempty"` + Size *float32 `yaml:"size,omitempty" json:"size,omitempty"` + Limit *float32 `yaml:"limit,omitempty" json:"limit,omitempty"` + NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` + IsLastPage *bool `yaml:"isLastPage,omitempty" json:"isLastPage,omitempty"` + Start *int32 `yaml:"start,omitempty" json:"start,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_update_pull_request_condition_1_request.go b/internal/client/bitbucket/generated_model_update_pull_request_condition_1_request.go new file mode 100644 index 0000000..8412cf7 --- /dev/null +++ b/internal/client/bitbucket/generated_model_update_pull_request_condition_1_request.go @@ -0,0 +1,20 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// UpdatePullRequestCondition1Request struct for UpdatePullRequestCondition1Request +type UpdatePullRequestCondition1Request struct { + RequiredApprovals *int32 `yaml:"requiredApprovals,omitempty" json:"requiredApprovals,omitempty"` + Reviewers []RestApplicationUser `yaml:"reviewers,omitempty" json:"reviewers,omitempty"` + SourceMatcher *UpdatePullRequestCondition1RequestSourceMatcher `yaml:"sourceMatcher,omitempty" json:"sourceMatcher,omitempty"` + TargetMatcher *UpdatePullRequestCondition1RequestSourceMatcher `yaml:"targetMatcher,omitempty" json:"targetMatcher,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_update_pull_request_condition_1_request_source_matcher.go b/internal/client/bitbucket/generated_model_update_pull_request_condition_1_request_source_matcher.go new file mode 100644 index 0000000..af25518 --- /dev/null +++ b/internal/client/bitbucket/generated_model_update_pull_request_condition_1_request_source_matcher.go @@ -0,0 +1,19 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// UpdatePullRequestCondition1RequestSourceMatcher struct for UpdatePullRequestCondition1RequestSourceMatcher +type UpdatePullRequestCondition1RequestSourceMatcher struct { + DisplayId *string `yaml:"displayId,omitempty" json:"displayId,omitempty"` + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Type *UpdatePullRequestCondition1RequestSourceMatcherType `yaml:"type,omitempty" json:"type,omitempty"` +} diff --git a/internal/client/bitbucket/generated_model_update_pull_request_condition_1_request_source_matcher_type.go b/internal/client/bitbucket/generated_model_update_pull_request_condition_1_request_source_matcher_type.go new file mode 100644 index 0000000..eb01403 --- /dev/null +++ b/internal/client/bitbucket/generated_model_update_pull_request_condition_1_request_source_matcher_type.go @@ -0,0 +1,18 @@ +/* +Bitbucket Data Center + +This is the reference document for the Atlassian Bitbucket REST API. The REST API is for developers who want to: - integrate Bitbucket with other applications; - create scripts that interact with Bitbucket; or - develop plugins that enhance the Bitbucket UI, using REST to interact with the backend. You can read more about developing Bitbucket plugins in the [Bitbucket Developer Documentation](https://developer.atlassian.com/bitbucket/server/docs/latest/). + +API version: 8.19 +*/ + +// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT. + +package bitbucketclient + + +// UpdatePullRequestCondition1RequestSourceMatcherType struct for UpdatePullRequestCondition1RequestSourceMatcherType +type UpdatePullRequestCondition1RequestSourceMatcherType struct { + Id *string `yaml:"id,omitempty" json:"id,omitempty"` + Name *string `yaml:"name,omitempty" json:"name,omitempty"` +} diff --git a/internal/client/github/client.go b/internal/client/github/client.go new file mode 100644 index 0000000..a754a1b --- /dev/null +++ b/internal/client/github/client.go @@ -0,0 +1,10 @@ +package githubclient + +import ( + "github.com/google/go-github/v66/github" + "net/http" +) + +func NewClient(client *http.Client, accessToken string) (*github.Client, error) { + return github.NewClient(client).WithAuthToken(accessToken), nil +} diff --git a/internal/client/github/github.go b/internal/client/github/github.go new file mode 100644 index 0000000..4d81158 --- /dev/null +++ b/internal/client/github/github.go @@ -0,0 +1,103 @@ +package githubclient + +import ( + "context" + "fmt" + "github.com/Interhyp/metadata-service/internal/acorn/config" + "github.com/Interhyp/metadata-service/internal/acorn/repository" + "github.com/Interhyp/metadata-service/internal/util" + "github.com/google/go-github/v66/github" + "strconv" + "strings" +) + +type Impl struct { + CustomConfig config.CustomConfiguration + client *github.Client +} + +func New(client *github.Client, customConfig config.CustomConfiguration) *Impl { + return &Impl{ + CustomConfig: customConfig, + client: client, + } +} + +func (r *Impl) SetCommitStatusInProgress(ctx context.Context, owner, repoName, commitID, url string, statusKey string) error { + _, _, err := r.client.Repositories.CreateStatus(ctx, owner, repoName, commitID, &github.RepoStatus{ + State: util.Ptr("pending"), + Context: &statusKey, + URL: &url, + }) + return err +} + +func (r *Impl) SetCommitStatusSucceeded(ctx context.Context, owner, repoName, commitID, url string, statusKey string) error { + _, _, err := r.client.Repositories.CreateStatus(ctx, owner, repoName, commitID, &github.RepoStatus{ + State: util.Ptr("success"), + Context: &statusKey, + URL: &url, + }) + return err +} + +func (r *Impl) SetCommitStatusFailed(ctx context.Context, owner, repoName, commitID, url string, statusKey string) error { + _, _, err := r.client.Repositories.CreateStatus(ctx, owner, repoName, commitID, &github.RepoStatus{ + State: util.Ptr("failure"), + Context: &statusKey, + URL: &url, + }) + return err +} + +func (r *Impl) CreatePullRequestComment(ctx context.Context, owner, repoName, pullRequestID, text string) error { + id, err := strconv.Atoi(pullRequestID) + if err != nil { + return err + } + _, _, err = r.client.Issues.CreateComment(ctx, owner, repoName, id, &github.IssueComment{ + Body: &text, + }) + return err +} + +func (r *Impl) GetChangedFilesOnPullRequest(ctx context.Context, repoPath, repoName, pullRequestID, toRef string) ([]repository.File, string, error) { + prId, _ := strconv.Atoi(pullRequestID) + changes, _, err := r.client.PullRequests.ListFiles(ctx, repoPath, repoName, prId, &github.ListOptions{}) + if err != nil { + return nil, "", err + } + + result := make([]repository.File, 0) + for _, change := range changes { + contents, _, _, err := r.client.Repositories.GetContents(ctx, repoPath, repoName, change.GetFilename(), &github.RepositoryContentGetOptions{ + Ref: toRef, + }) + if err != nil { + // ignore go to next changed file + continue + } + content, _ := contents.GetContent() + if err != nil || content == "" { + // ignore go to next changed file + continue + } + result = append(result, repository.File{ + Path: change.GetFilename(), + Contents: content, + }) + } + return result, toRef, nil +} + +func (r *Impl) GetUser(ctx context.Context, username string) (string, error) { + prefix := r.CustomConfig.UserPrefix() + user, _, err := r.client.Users.Get(ctx, fmt.Sprintf("%s%s", username, prefix)) + if err != nil { + return "", err + } + if prefix != "" { + return strings.Split(*user.Login, prefix)[0], nil + } + return *user.Login, nil +} diff --git a/internal/repository/bitbucket/bbclient/bbclient.go b/internal/repository/bitbucket/bbclient/bbclient.go deleted file mode 100644 index 6bb50f9..0000000 --- a/internal/repository/bitbucket/bbclient/bbclient.go +++ /dev/null @@ -1,258 +0,0 @@ -package bbclient - -import ( - "context" - "fmt" - librepo "github.com/Interhyp/go-backend-service-common/acorns/repository" - "github.com/Interhyp/metadata-service/internal/acorn/config" - "github.com/Interhyp/metadata-service/internal/acorn/errors/httperror" - "github.com/Interhyp/metadata-service/internal/acorn/repository" - "github.com/Interhyp/metadata-service/internal/repository/bitbucket/bbclientint" - auapmclient "github.com/StephanHCB/go-autumn-restclient-apm/implementation/client" - aurestbreakerprometheus "github.com/StephanHCB/go-autumn-restclient-circuitbreaker-prometheus" - aurestbreaker "github.com/StephanHCB/go-autumn-restclient-circuitbreaker/implementation/breaker" - aurestclientprometheus "github.com/StephanHCB/go-autumn-restclient-prometheus" - aurestclientapi "github.com/StephanHCB/go-autumn-restclient/api" - aurestcaching "github.com/StephanHCB/go-autumn-restclient/implementation/caching" - auresthttpclient "github.com/StephanHCB/go-autumn-restclient/implementation/httpclient" - aurestrecorder "github.com/StephanHCB/go-autumn-restclient/implementation/recorder" - aurestlogging "github.com/StephanHCB/go-autumn-restclient/implementation/requestlogging" - aurestretry "github.com/StephanHCB/go-autumn-restclient/implementation/retry" - "github.com/go-http-utils/headers" - "net/http" - "net/url" - "strings" - "time" -) - -type Impl struct { - Configuration librepo.Configuration - CustomConfiguration config.CustomConfiguration - Logging librepo.Logging - Vault librepo.Vault - - apiBaseUrl string - - Client aurestclientapi.Client - NoRetryClient aurestclientapi.Client -} - -func New(configuration librepo.Configuration, logging librepo.Logging, vault librepo.Vault) bbclientint.BitbucketClient { - return &Impl{ - Configuration: configuration, - CustomConfiguration: config.Custom(configuration), - Logging: logging, - Vault: vault, - } -} - -// --- setup --- - -func (c *Impl) Setup() error { - c.apiBaseUrl = c.CustomConfiguration.BitbucketServer() + "/bitbucket" - - client, err := auresthttpclient.New(0, nil, c.requestHeaderManipulator()) - if err != nil { - return err - } - aurestclientprometheus.InstrumentHttpClient(client) - - logWrapper := aurestlogging.New(client) - - circuitBreakerWrapper := aurestbreaker.New( - logWrapper, - "bitbucket", - 100, - 5*time.Minute, - 60*time.Second, - // includes possible retries, once the context is cancelled further requests will fail directly - 15*time.Second, - ) - aurestbreakerprometheus.InstrumentCircuitBreakerClient(circuitBreakerWrapper) - - // allow tests to pre-populate - if c.NoRetryClient == nil { - c.NoRetryClient = circuitBreakerWrapper - } - - apmClientWrapper := auapmclient.New(circuitBreakerWrapper) - - retryWrapper := aurestretry.New( - apmClientWrapper, - 3, - c.retryCondition(), - c.betweenFailureAndRetry(), - ) - aurestclientprometheus.InstrumentRetryClient(retryWrapper) - - recordingWrapper := aurestrecorder.New(retryWrapper) - - cacheWrapper := aurestcaching.New( - recordingWrapper, - func(ctx context.Context, method string, url string, requestBody interface{}) bool { - return method == http.MethodGet && strings.Contains(url, fmt.Sprintf("%s/users", bbclientint.CoreApi)) - }, - func(ctx context.Context, method string, url string, requestBody interface{}, response *aurestclientapi.ParsedResponse) bool { - return response != nil && response.Status == http.StatusOK && strings.Contains(url, fmt.Sprintf("%s/users", bbclientint.CoreApi)) - }, - nil, - time.Duration(c.CustomConfiguration.BitbucketCacheRetentionSeconds())*time.Second, - c.CustomConfiguration.BitbucketCacheSize(), - ) - aurestclientprometheus.InstrumentCacheClient(cacheWrapper) - - //allow tests to pre-populate - if c.Client == nil { - c.Client = cacheWrapper - } - - return nil -} - -func (c *Impl) requestHeaderManipulator() func(ctx context.Context, r *http.Request) { - return func(ctx context.Context, r *http.Request) { - if r.Method != http.MethodPost { - r.Header.Set(headers.Accept, aurestclientapi.ContentTypeApplicationJson) - } - if ctx.Value("authorization") != nil && ctx.Value("authorization") != "" && r.Method == http.MethodPost { - r.Header.Set("Authorization", ctx.Value("authorization").(string)) - } else { - r.SetBasicAuth(c.CustomConfiguration.BitbucketUsername(), c.CustomConfiguration.BitbucketPassword()) - } - } -} - -func (c *Impl) retryCondition() aurestclientapi.RetryConditionCallback { - return func(_ context.Context, response *aurestclientapi.ParsedResponse, err error) bool { - // bitbucket sometimes does this rather randomly, we just retry up to 3 times - return response.Status == http.StatusServiceUnavailable - } -} - -func (c *Impl) betweenFailureAndRetry() aurestclientapi.BeforeRetryCallback { - return func(ctx context.Context, originalResponse *aurestclientapi.ParsedResponse, originalError error) error { - c.Logging.Logger().Ctx(ctx).Warn().Print("got 503 from bitbucket - retrying request") - return nil - } -} - -// --- request implementations --- - -func (c *Impl) call(ctx context.Context, method string, requestUrlExtension string, requestBody interface{}, responseBodyPointer interface{}) error { - remoteUrl := fmt.Sprintf("%s/%s", c.apiBaseUrl, requestUrlExtension) - response := aurestclientapi.ParsedResponse{ - Body: responseBodyPointer, - } - err := c.Client.Perform(ctx, method, remoteUrl, requestBody, &response) - if err != nil { - return err - } - - switch response.Status { - case - http.StatusOK, - http.StatusCreated, - http.StatusNoContent: - return nil - } - - return httperror.New(ctx, fmt.Sprintf("received unexpected status %d from bitbucket %s %s", response.Status, method, requestUrlExtension), response.Status) -} - -func (c *Impl) GetBitbucketUser(ctx context.Context, username string) (repository.BitbucketUser, error) { - urlExt := fmt.Sprintf("%s/users/%s", - bbclientint.CoreApi, - url.PathEscape(username)) - response := repository.BitbucketUser{} - err := c.call(ctx, http.MethodGet, urlExt, nil, &response) - return response, err -} - -func (c *Impl) GetPullRequest(ctx context.Context, projectKey string, repositorySlug string, pullRequestId int32) (bbclientint.PullRequest, error) { - urlExt := fmt.Sprintf("%s/projects/%s/repos/%s/pull-requests/%d", - bbclientint.CoreApi, - url.PathEscape(projectKey), - url.PathEscape(repositorySlug), - pullRequestId) - response := bbclientint.PullRequest{} - err := c.call(ctx, http.MethodGet, urlExt, nil, &response) - return response, err -} - -func (c *Impl) GetChanges(ctx context.Context, projectKey string, repositorySlug string, sinceHash string, untilHash string) (bbclientint.Changes, error) { - // since : main - // until : pr head - urlExt := fmt.Sprintf("%s/projects/%s/repos/%s/changes?since=%s&until=%s&limit=%d", - bbclientint.CoreApi, - url.PathEscape(projectKey), - url.PathEscape(repositorySlug), - url.QueryEscape(sinceHash), - url.QueryEscape(untilHash), - 1000) // TODO pagination? - response := bbclientint.Changes{} - err := c.call(ctx, http.MethodGet, urlExt, nil, &response) - return response, err -} - -func (c *Impl) getFileContentsPage(ctx context.Context, projectKey string, repositorySlug string, atHash string, path string, start int, limit int) (bbclientint.PaginatedLines, error) { - escapedPath := "" - for _, pathComponent := range strings.Split(path, "/") { - escapedPath += "/" + url.PathEscape(pathComponent) - } - urlExt := fmt.Sprintf("%s/projects/%s/repos/%s/browse/%s?at=%s&start=%d&limit=%d", - bbclientint.CoreApi, - url.PathEscape(projectKey), - url.PathEscape(repositorySlug), - escapedPath, - url.QueryEscape(atHash), - start, - limit) - response := bbclientint.PaginatedLines{} - err := c.call(ctx, http.MethodGet, urlExt, nil, &response) - return response, err -} - -func (c *Impl) GetFileContentsAt(ctx context.Context, projectKey string, repositorySlug string, atHash string, path string) (string, error) { - var contents strings.Builder - var err error - start := 0 - - page := bbclientint.PaginatedLines{ - IsLastPage: false, - NextPageStart: &start, - } - - for !page.IsLastPage && page.NextPageStart != nil { - page, err = c.getFileContentsPage(ctx, projectKey, repositorySlug, atHash, path, *page.NextPageStart, 1000) - if err != nil { - return contents.String(), err - } - for _, line := range page.Lines { - contents.WriteString(line.Text + "\n") - } - } - - return contents.String(), nil -} - -func (c *Impl) AddProjectRepositoryCommitBuildStatus(ctx context.Context, projectKey string, repositorySlug string, commitId string, commitBuildStatusRequest bbclientint.CommitBuildStatusRequest) error { - urlExt := fmt.Sprintf("%s/projects/%s/repos/%s/commits/%s/builds", - bbclientint.CoreApi, - url.PathEscape(projectKey), - url.PathEscape(repositorySlug), - url.PathEscape(commitId)) - - return c.call(ctx, http.MethodPost, urlExt, commitBuildStatusRequest, nil) -} - -func (c *Impl) CreatePullRequestComment(ctx context.Context, projectKey string, repositorySlug string, pullRequestId int64, pullRequestCommentRequest bbclientint.PullRequestCommentRequest) (bbclientint.PullRequestComment, error) { - urlExt := fmt.Sprintf("%s/projects/%s/repos/%s/pull-requests/%d/comments", - bbclientint.CoreApi, - url.PathEscape(projectKey), - url.PathEscape(repositorySlug), - pullRequestId) - - response := bbclientint.PullRequestComment{} - err := c.call(ctx, http.MethodPost, urlExt, pullRequestCommentRequest, &response) - return response, err -} diff --git a/internal/repository/bitbucket/bbclientint/bbclientint.go b/internal/repository/bitbucket/bbclientint/bbclientint.go deleted file mode 100644 index 4619f23..0000000 --- a/internal/repository/bitbucket/bbclientint/bbclientint.go +++ /dev/null @@ -1,24 +0,0 @@ -package bbclientint - -import ( - "context" - "github.com/Interhyp/metadata-service/internal/acorn/repository" -) - -type BitbucketClient interface { - Setup() error - - GetBitbucketUser(ctx context.Context, username string) (repository.BitbucketUser, error) - - GetPullRequest(ctx context.Context, projectKey string, repositorySlug string, pullRequestId int32) (PullRequest, error) - GetChanges(ctx context.Context, projectKey string, repositorySlug string, sinceHash string, untilHash string) (Changes, error) - GetFileContentsAt(ctx context.Context, projectKey string, repositorySlug string, atHash string, path string) (string, error) - - AddProjectRepositoryCommitBuildStatus(ctx context.Context, projectKey string, repositorySlug string, commitId string, commitBuildStatusRequest CommitBuildStatusRequest) error - - CreatePullRequestComment(ctx context.Context, projectKey string, repositorySlug string, pullRequestId int64, pullRequestCommentRequest PullRequestCommentRequest) (PullRequestComment, error) -} - -const ( - CoreApi = "rest/api/latest" -) diff --git a/internal/repository/bitbucket/bbclientint/bbmodels.go b/internal/repository/bitbucket/bbclientint/bbmodels.go deleted file mode 100644 index bbef3b0..0000000 --- a/internal/repository/bitbucket/bbclientint/bbmodels.go +++ /dev/null @@ -1,214 +0,0 @@ -package bbclientint - -// not part of spec - FileOrDirectory is missing useful fields - -type PaginatedLines struct { - Lines []struct { - Text string `json:"text"` - } `json:"lines"` - Start int `json:"start"` - Size int `json:"size"` - IsLastPage bool `json:"isLastPage"` - Limit int `json:"limit"` - NextPageStart *int `json:"nextPageStart"` -} - -// part of spec, sorted alphabetically - -type Changes struct { - FromHash string `json:"fromHash"` - ToHash string `json:"toHash"` - Values []Change `json:"values,omitempty"` - Size int `json:"size"` - IsLastPage bool `json:"isLastPage"` - Start int `json:"start"` - Limit int `json:"limit"` - NextPageStart *int `json:"nextPageStart"` -} - -type Change struct { - ContentId string `json:"contentId"` - FromContentId string `json:"fromContentId"` - Path struct { - Components []string `json:"components"` - Parent string `json:"parent"` - Name string `json:"name"` - Extension string `json:"extension"` - ToString string `json:"toString"` - } `json:"path"` - Executable bool `json:"executable"` - PercentUnchanged int `json:"percentUnchanged"` - Type string `json:"type"` - NodeType string `json:"nodeType"` - SrcExecutable bool `json:"srcExecutable"` - Links struct { - Self []struct { - Href string `json:"href"` - } `json:"self"` - } `json:"links"` - Properties struct { - GitChangeType string `json:"gitChangeType"` - } `json:"properties"` -} - -type CommitBuildStatusRequest struct { - Key string `yaml:"key" json:"key"` - State string `yaml:"state" json:"state"` - Url string `yaml:"url" json:"url"` - BuildNumber *int32 `yaml:"buildNumber,omitempty" json:"buildNumber,omitempty"` - Description *string `yaml:"description,omitempty" json:"description,omitempty"` - Duration *int32 `yaml:"duration,omitempty" json:"duration,omitempty"` - LastUpdated *int32 `yaml:"lastUpdated,omitempty" json:"lastUpdated,omitempty"` - Name *string `yaml:"name,omitempty" json:"name,omitempty"` - Parent *string `yaml:"parent,omitempty" json:"parent,omitempty"` - Ref *string `yaml:"ref,omitempty" json:"ref,omitempty"` - TestResults *TestResults `yaml:"testResults,omitempty" json:"testResults,omitempty"` -} - -type Link struct { - Href string `yaml:"href" json:"href"` - Name *string `yaml:"name,omitempty" json:"name,omitempty"` -} - -type ProjectLinks struct { - Self []Link `yaml:"self,omitempty" json:"self,omitempty"` -} - -type PullRequest struct { - Id int64 `yaml:"id" json:"id"` - Version *int32 `yaml:"version,omitempty" json:"version,omitempty"` - Title string `yaml:"title" json:"title"` - Description string `yaml:"description" json:"description"` - State PullRequestState `yaml:"state" json:"state"` - Open bool `yaml:"open" json:"open"` - Closed bool `yaml:"closed" json:"closed"` - CreatedDate *int64 `yaml:"createdDate,omitempty" json:"createdDate,omitempty"` - UpdatedDate *int64 `yaml:"updatedDate,omitempty" json:"updatedDate,omitempty"` - FromRef RepositoryRef `yaml:"fromRef" json:"fromRef"` - ToRef RepositoryRef `yaml:"toRef" json:"toRef"` - Locked bool `yaml:"locked" json:"locked"` - Author *UserRole `yaml:"author,omitempty" json:"author,omitempty"` - Reviewers []UserRole `yaml:"reviewers,omitempty" json:"reviewers,omitempty"` - Participants []UserRole `yaml:"participants,omitempty" json:"participants,omitempty"` - Links *ProjectLinks `yaml:"links,omitempty" json:"links,omitempty"` -} - -type PullRequestComment struct { - Properties PullRequestCommentProperties `yaml:"properties" json:"properties"` - Id int32 `yaml:"id" json:"id"` - Version int32 `yaml:"version" json:"version"` - Text string `yaml:"text" json:"text"` - Author PullRequestCommentAuthor `yaml:"author" json:"author"` - CreatedDate int64 `yaml:"createdDate" json:"createdDate"` - UpdatedDate int64 `yaml:"updatedDate" json:"updatedDate"` - Comments []PullRequestComment `yaml:"comments" json:"comments"` - Tasks []interface{} `yaml:"tasks" json:"tasks"` - Severity string `yaml:"severity" json:"severity"` - State string `yaml:"state" json:"state"` - PermittedOperations PullRequestCommentPermittedOperations `yaml:"permittedOperations" json:"permittedOperations"` -} - -type PullRequestCommentAuthor struct { - Name string `yaml:"name" json:"name"` - EmailAddress string `yaml:"emailAddress" json:"emailAddress"` - Id int32 `yaml:"id" json:"id"` - DisplayName string `yaml:"displayName" json:"displayName"` - Active bool `yaml:"active" json:"active"` - Slug string `yaml:"slug" json:"slug"` - Type string `yaml:"type" json:"type"` -} - -type PullRequestCommentPage struct { - Size int32 `yaml:"size" json:"size"` - Limit int32 `yaml:"limit" json:"limit"` - Start int32 `yaml:"start" json:"start"` - IsLastPage bool `yaml:"isLastPage" json:"isLastPage"` - NextPageStart *int32 `yaml:"nextPageStart,omitempty" json:"nextPageStart,omitempty"` - Values []PullRequestComment `yaml:"values" json:"values"` -} - -type PullRequestCommentPermittedOperations struct { - Editable bool `yaml:"editable" json:"editable"` - Deletable bool `yaml:"deletable" json:"deletable"` -} - -type PullRequestCommentProperties struct { - Key string `yaml:"key" json:"key"` -} - -type PullRequestCommentRequest struct { - Text string `yaml:"text" json:"text"` - Parent *PullRequestCommentRequestParent `yaml:"parent,omitempty" json:"parent,omitempty"` - Anchor *PullRequestCommentRequestAnchor `yaml:"anchor,omitempty" json:"anchor,omitempty"` - Severity *string `yaml:"severity,omitempty" json:"severity,omitempty"` - State *string `yaml:"state,omitempty" json:"state,omitempty"` -} - -type PullRequestCommentRequestAnchor struct { - Line *int32 `yaml:"line,omitempty" json:"line,omitempty"` - LineType *string `yaml:"lineType,omitempty" json:"lineType,omitempty"` - FileType *string `yaml:"fileType,omitempty" json:"fileType,omitempty"` - Path *string `yaml:"path,omitempty" json:"path,omitempty"` - SrcPath *string `yaml:"srcPath,omitempty" json:"srcPath,omitempty"` -} - -type PullRequestCommentRequestParent struct { - Id int32 `yaml:"id" json:"id"` - Severity *string `yaml:"severity,omitempty" json:"severity,omitempty"` - State *string `yaml:"state,omitempty" json:"state,omitempty"` -} - -type PullRequestState string - -// List of pullRequestState -const ( - OPEN PullRequestState = "OPEN" - MERGED PullRequestState = "MERGED" - DECLINED PullRequestState = "DECLINED" -) - -// All allowed values of PullRequestState enum -var AllowedPullRequestStateEnumValues = []PullRequestState{ - "OPEN", - "MERGED", - "DECLINED", -} - -type RepositoryRef struct { - Id string `yaml:"id" json:"id"` - LatestCommit string `yaml:"latestCommit" json:"latestCommit"` - Repository RepositoryRefRepository `yaml:"repository" json:"repository"` -} - -type RepositoryRefRepository struct { - Slug string `yaml:"slug" json:"slug"` - Name *string `yaml:"name,omitempty" json:"name,omitempty"` - Project RepositoryRefRepositoryProject `yaml:"project" json:"project"` -} - -type RepositoryRefRepositoryProject struct { - Key string `yaml:"key" json:"key"` -} - -type TestResults struct { - Failed int32 `yaml:"failed" json:"failed"` - Skipped int32 `yaml:"skipped" json:"skipped"` - Successful int32 `yaml:"successful" json:"successful"` -} - -type User struct { - Id *int32 `yaml:"id,omitempty" json:"id,omitempty"` - Name string `yaml:"name" json:"name"` - EmailAddress *string `yaml:"emailAddress,omitempty" json:"emailAddress,omitempty"` - DisplayName *string `yaml:"displayName,omitempty" json:"displayName,omitempty"` - Active bool `yaml:"active" json:"active"` - Slug string `yaml:"slug" json:"slug"` - Type *string `yaml:"type,omitempty" json:"type,omitempty"` -} - -type UserRole struct { - User User `yaml:"user" json:"user"` - Role *string `yaml:"role,omitempty" json:"role,omitempty"` - Approved *bool `yaml:"approved,omitempty" json:"approved,omitempty"` - Status *string `yaml:"status,omitempty" json:"status,omitempty"` -} diff --git a/internal/repository/bitbucket/repository.go b/internal/repository/bitbucket/repository.go deleted file mode 100644 index 4fb1975..0000000 --- a/internal/repository/bitbucket/repository.go +++ /dev/null @@ -1,187 +0,0 @@ -package bitbucket - -import ( - "context" - "fmt" - librepo "github.com/Interhyp/go-backend-service-common/acorns/repository" - "github.com/Interhyp/metadata-service/internal/acorn/config" - "github.com/Interhyp/metadata-service/internal/acorn/errors/httperror" - "github.com/Interhyp/metadata-service/internal/acorn/repository" - "github.com/Interhyp/metadata-service/internal/repository/bitbucket/bbclient" - "github.com/Interhyp/metadata-service/internal/repository/bitbucket/bbclientint" - aulogging "github.com/StephanHCB/go-autumn-logging" - auzerolog "github.com/StephanHCB/go-autumn-logging-zerolog" - "net/http" - "sort" -) - -type Impl struct { - Configuration librepo.Configuration - CustomConfiguration config.CustomConfiguration - Logging librepo.Logging - Vault librepo.Vault - - LowLevel bbclientint.BitbucketClient -} - -func New( - configuration librepo.Configuration, - customConfiguration config.CustomConfiguration, - logging librepo.Logging, - vault librepo.Vault, -) repository.Bitbucket { - return &Impl{ - Configuration: configuration, - CustomConfiguration: customConfiguration, - Logging: logging, - Vault: vault, - LowLevel: bbclient.New(configuration, logging, vault), - } -} - -func (r *Impl) IsBitbucket() bool { - return true -} - -func (r *Impl) Setup() error { - ctx := auzerolog.AddLoggerToCtx(context.Background()) - - if err := r.SetupClient(ctx); err != nil { - r.Logging.Logger().Ctx(ctx).Error().WithErr(err).Print("failed to set up bitbucket client. BAILING OUT") - return err - } - - r.Logging.Logger().Ctx(ctx).Info().Print("successfully set up bitbucket") - return nil -} - -func (r *Impl) SetupClient(ctx context.Context) error { - r.Logging.Logger().Ctx(ctx).Info().Print("setting up bitbucket client") - return r.LowLevel.Setup() -} - -func (r *Impl) GetBitbucketUser(ctx context.Context, username string) (repository.BitbucketUser, error) { - response, err := r.LowLevel.GetBitbucketUser(ctx, username) - if err != nil { - return repository.BitbucketUser{}, err - } - return response, nil -} - -func (r *Impl) GetBitbucketUsers(ctx context.Context, usernames []string) ([]repository.BitbucketUser, error) { - users := make([]repository.BitbucketUser, 0) - for _, username := range usernames { - bbUser, err := r.GetBitbucketUser(ctx, username) - if err != nil { - if httperror.Is(err) && err.(*httperror.Impl).Status() == http.StatusNotFound { - r.Logging.Logger().Ctx(ctx).Warn().Printf("bitbucket user %s does not exist", username) - continue - } - r.Logging.Logger().Ctx(ctx).Error().WithErr(err).Print(fmt.Sprintf("failed to read bitbucket user %s", username)) - return make([]repository.BitbucketUser, 0), err - } - users = append(users, bbUser) - } - return users, nil -} - -func (r *Impl) FilterExistingUsernames(ctx context.Context, usernames []string) ([]string, error) { - existingUsernames := make([]string, 0) - - dedupUsers := Unique(usernames) - existingUsers, err := r.GetBitbucketUsers(ctx, dedupUsers) - if err != nil { - return existingUsernames, err - } - - for _, user := range existingUsers { - existingUsernames = append(existingUsernames, user.Name) - } - sort.Strings(existingUsernames) - - return existingUsernames, nil -} - -func Unique[T comparable](sliceList []T) []T { - allKeys := make(map[T]bool) - list := make([]T, 0) - for _, item := range sliceList { - if _, value := allKeys[item]; !value { - allKeys[item] = true - list = append(list, item) - } - } - return list -} - -func (r *Impl) GetChangedFilesOnPullRequest(ctx context.Context, pullRequestId int) ([]repository.File, string, error) { - aulogging.Logger.Ctx(ctx).Info().Printf("obtaining changes for pull request %d", pullRequestId) - - project := r.CustomConfiguration.MetadataRepoProject() - slug := r.CustomConfiguration.MetadataRepoName() - pullRequest, err := r.LowLevel.GetPullRequest(ctx, project, slug, int32(pullRequestId)) - if err != nil { - return nil, "", err - } - - prSourceHead := pullRequest.FromRef.LatestCommit - changes, err := r.LowLevel.GetChanges(ctx, project, slug, pullRequest.ToRef.LatestCommit, prSourceHead) - if err != nil { - return nil, prSourceHead, err - } - - aulogging.Logger.Ctx(ctx).Info().Printf("pull request had %d changed files", len(changes.Values)) - - result := make([]repository.File, 0) - for _, change := range changes.Values { - contents, err := r.LowLevel.GetFileContentsAt(ctx, project, slug, prSourceHead, change.Path.ToString) - if err != nil { - asHttpError, ok := err.(httperror.Error) - if ok && asHttpError.Status() == http.StatusNotFound { - aulogging.Logger.Ctx(ctx).Debug().Printf("path %s not present on PR head - skipping and continuing", change.Path.ToString) - continue // expected situation - happens for deleted files, or for files added on mainline after fork (which show up in changes) - } else { - aulogging.Logger.Ctx(ctx).Info().Printf("failed to retrieve change for %s: %s", change.Path.ToString, err.Error()) - return nil, prSourceHead, err - } - } - - result = append(result, repository.File{ - Path: change.Path.ToString, - Contents: contents, - }) - } - - aulogging.Logger.Ctx(ctx).Info().Printf("successfully obtained %d changes for pull request %d", len(result), pullRequestId) - return result, prSourceHead, nil -} - -func (r *Impl) AddCommitBuildStatus(ctx context.Context, commitHash string, url string, key string, success bool) error { - project := r.CustomConfiguration.MetadataRepoProject() - slug := r.CustomConfiguration.MetadataRepoName() - - state := "FAILED" - if success { - state = "SUCCESSFUL" - } - - request := bbclientint.CommitBuildStatusRequest{ - Key: key, - State: state, - Url: url, - } - - return r.LowLevel.AddProjectRepositoryCommitBuildStatus(ctx, project, slug, commitHash, request) -} - -func (r *Impl) CreatePullRequestComment(ctx context.Context, pullRequestId int, comment string) error { - project := r.CustomConfiguration.MetadataRepoProject() - slug := r.CustomConfiguration.MetadataRepoName() - - request := bbclientint.PullRequestCommentRequest{ - Text: comment, - } - - _, err := r.LowLevel.CreatePullRequestComment(ctx, project, slug, int64(pullRequestId), request) - return err -} diff --git a/internal/repository/bitbucket/repository_test.go b/internal/repository/bitbucket/repository_test.go deleted file mode 100644 index 108bea3..0000000 --- a/internal/repository/bitbucket/repository_test.go +++ /dev/null @@ -1,136 +0,0 @@ -package bitbucket - -import ( - "context" - libconfig "github.com/Interhyp/go-backend-service-common/repository/config" - "github.com/Interhyp/go-backend-service-common/repository/logging" - configint "github.com/Interhyp/metadata-service/internal/acorn/config" - "github.com/Interhyp/metadata-service/internal/acorn/errors/httperror" - "github.com/Interhyp/metadata-service/internal/acorn/repository" - "github.com/Interhyp/metadata-service/internal/repository/config" - "github.com/Interhyp/metadata-service/test/mock/bbclientmock" - "github.com/Interhyp/metadata-service/test/mock/vaultmock" - auconfigenv "github.com/StephanHCB/go-autumn-config-env" - "github.com/stretchr/testify/require" - "testing" -) - -func tstSetup() Impl { - lowLevel := bbclientmock.BitbucketClientMock{} - vault := vaultmock.VaultImpl{} - logger := logging.LoggingImpl{} - return Impl{ - Vault: &vault, - LowLevel: &lowLevel, - Logging: &logger, - } -} - -func TestNewAndSetup(t *testing.T) { - vault := &vaultmock.VaultImpl{} - logger := &logging.LoggingImpl{} - conf := tstConfig(t) - customConf := configint.Custom(conf) - cut := New(conf, customConf, logger, vault) - - lowLevel := &bbclientmock.BitbucketClientMock{} - cut.(*Impl).LowLevel = lowLevel - - require.True(t, cut.IsBitbucket()) - - err := cut.Setup() - require.Nil(t, err) -} - -const validConfigurationPath = "../resources/valid-config.yaml" - -func tstConfig(t *testing.T) *libconfig.ConfigImpl { - impl, _ := config.New() - configImpl := impl.(*libconfig.ConfigImpl) - auconfigenv.LocalConfigFileName = validConfigurationPath - err := configImpl.Read() - require.Nil(t, err) - return configImpl -} - -func TestGetBitbucketUser_Success(t *testing.T) { - cut := tstSetup() - - result, err := cut.GetBitbucketUser(context.Background(), "some-user") - - require.NotNil(t, result) - require.Nil(t, err) - require.Equal(t, bbclientmock.MockBitbucketUser(), result) -} - -func TestGetBitbucketUser_Error(t *testing.T) { - cut := tstSetup() - - result, err := cut.GetBitbucketUser(context.Background(), bbclientmock.NOT_EXISITNG_USER) - - require.NotNil(t, result) - require.NotNil(t, err) - require.Equal(t, repository.BitbucketUser{}, result) -} - -func TestGetBitbucketUsers_Success(t *testing.T) { - cut := tstSetup() - - result, err := cut.GetBitbucketUsers(context.Background(), []string{"some-user", "other-user"}) - - require.NotNil(t, result) - require.Nil(t, err) - require.Equal(t, []repository.BitbucketUser{bbclientmock.MockBitbucketUser(), bbclientmock.MockBitbucketUser()}, result) -} - -func TestGetBitbucketUsers_UserNotFound(t *testing.T) { - cut := tstSetup() - - result, err := cut.GetBitbucketUsers(context.Background(), []string{bbclientmock.NOT_EXISITNG_USER}) - - require.NotNil(t, result) - require.Nil(t, err) - require.Equal(t, []repository.BitbucketUser{}, result) -} - -func TestGetBitbucketUsers_OtherHttpError(t *testing.T) { - cut := tstSetup() - - result, err := cut.GetBitbucketUsers(context.Background(), []string{bbclientmock.HTTP_ERROR_USER}) - - require.NotNil(t, result) - require.NotNil(t, err) - require.True(t, httperror.Is(err)) - require.Equal(t, []repository.BitbucketUser{}, result) -} - -func TestGetBitbucketUsers_Error(t *testing.T) { - cut := tstSetup() - - result, err := cut.GetBitbucketUsers(context.Background(), []string{bbclientmock.OTHER_ERROR_USER}) - - require.NotNil(t, result) - require.NotNil(t, err) - require.False(t, httperror.Is(err)) - require.Equal(t, []repository.BitbucketUser{}, result) -} - -func TestFilterExistingUsernames_Success(t *testing.T) { - cut := tstSetup() - - result, err := cut.FilterExistingUsernames(context.Background(), []string{"some-user", "other-user", bbclientmock.NOT_EXISITNG_USER}) - - require.NotNil(t, result) - require.Nil(t, err) - require.Equal(t, []string{"mock-user", "mock-user"}, result) -} - -func TestFilterExistingUsernames_Error(t *testing.T) { - cut := tstSetup() - - result, err := cut.FilterExistingUsernames(context.Background(), []string{"some-user", "other-user", bbclientmock.OTHER_ERROR_USER}) - - require.NotNil(t, result) - require.NotNil(t, err) - require.Equal(t, []string{}, result) -} diff --git a/internal/repository/config/accessors.go b/internal/repository/config/accessors.go index 8ecd556..3d9de4e 100644 --- a/internal/repository/config/accessors.go +++ b/internal/repository/config/accessors.go @@ -179,10 +179,18 @@ func (c *CustomConfigImpl) MetadataRepoProject() string { if len(match) == 3 { return match[1] } + match = c.GitHubGitUrlMatcher.FindStringSubmatch(sshUrl) + if len(match) == 4 { + return match[2] + } } httpUrl := c.MetadataRepoUrl() if httpUrl != "" { - match := c.BitbucketGitUrlMatcher.FindStringSubmatch(sshUrl) + match := c.BitbucketGitUrlMatcher.FindStringSubmatch(httpUrl) + if len(match) == 3 { + return match[1] + } + match = c.GitHubGitUrlMatcher.FindStringSubmatch(httpUrl) if len(match) == 3 { return match[1] } @@ -197,10 +205,18 @@ func (c *CustomConfigImpl) MetadataRepoName() string { if len(match) == 3 { return match[2] } + match = c.GitHubGitUrlMatcher.FindStringSubmatch(sshUrl) + if len(match) == 4 { + return match[3] + } } httpUrl := c.MetadataRepoUrl() if httpUrl != "" { - match := c.BitbucketGitUrlMatcher.FindStringSubmatch(sshUrl) + match := c.BitbucketGitUrlMatcher.FindStringSubmatch(httpUrl) + if len(match) == 3 { + return match[2] + } + match = c.GitHubGitUrlMatcher.FindStringSubmatch(httpUrl) if len(match) == 3 { return match[2] } @@ -215,3 +231,15 @@ func (c *CustomConfigImpl) PullRequestBuildUrl() string { func (c *CustomConfigImpl) PullRequestBuildKey() string { return c.VPullRequestBuildKey } + +func (c *CustomConfigImpl) VCSConfigs() map[string]config.VCSConfig { + return c.VVCSConfig +} + +func (c *CustomConfigImpl) WebhooksProcessAsync() bool { + return c.VWebhooksProcessAsync +} + +func (c *CustomConfigImpl) UserPrefix() string { + return c.VUserPrefix +} diff --git a/internal/repository/config/config.go b/internal/repository/config/config.go index 2b0a589..eb249ee 100644 --- a/internal/repository/config/config.go +++ b/internal/repository/config/config.go @@ -303,4 +303,25 @@ var CustomConfigItems = []auconfigapi.ConfigItem{ Description: "Key to use for pull request builds.", Validate: auconfigapi.ConfigNeedsNoValidation, }, + { + Key: config.KeyVCSConfigs, + EnvName: config.KeyVCSConfigs, + Description: "Version control system configuration settings", + Default: "{}", + Validate: auconfigenv.ObtainNotEmptyValidator(), + }, + { + Key: config.KeyWebhooksProcessAsync, + EnvName: config.KeyWebhooksProcessAsync, + Description: "Webhooks handling async", + Default: "true", + Validate: auconfigapi.ConfigNeedsNoValidation, + }, + { + Key: config.KeyUserPrefix, + EnvName: config.KeyUserPrefix, + Description: "User prefix", + Default: "", + Validate: auconfigapi.ConfigNeedsNoValidation, + }, } diff --git a/internal/repository/config/plumbing.go b/internal/repository/config/plumbing.go index cb816f0..1f1667a 100644 --- a/internal/repository/config/plumbing.go +++ b/internal/repository/config/plumbing.go @@ -59,15 +59,20 @@ type CustomConfigImpl struct { VRedisPassword string VPullRequestBuildUrl string VPullRequestBuildKey string + VVCSConfig map[string]config.VCSConfig + VWebhooksProcessAsync bool + VUserPrefix string VKafkaConfig *kafka.Config BitbucketGitUrlMatcher *regexp.Regexp + GitHubGitUrlMatcher *regexp.Regexp } func New() (librepo.Configuration, config.CustomConfiguration) { instance := &CustomConfigImpl{ VKafkaConfig: kafka.NewConfig(), BitbucketGitUrlMatcher: regexp.MustCompile(`/([^/]+)/([^/]+).git$`), + GitHubGitUrlMatcher: regexp.MustCompile(`(/|:)([^/]+)/([^/]+).git$`), } configItems := make([]auconfigapi.ConfigItem, 0) configItems = append(configItems, CustomConfigItems...) @@ -122,6 +127,9 @@ func (c *CustomConfigImpl) Obtain(getter func(key string) string) { c.VRedisPassword = getter(config.KeyRedisPassword) c.VPullRequestBuildUrl = getter(config.KeyPullRequestBuildUrl) c.VPullRequestBuildKey = getter(config.KeyPullRequestBuildKey) + c.VVCSConfig, _ = parseVCSConfigs(getter(config.KeyVCSConfigs), getter) + c.VWebhooksProcessAsync, _ = toBoolean(getter(config.KeyWebhooksProcessAsync)) + c.VUserPrefix = getter(config.KeyUserPrefix) c.VKafkaConfig.Obtain(getter) } @@ -143,6 +151,14 @@ func toUint32(s string) uint32 { return uint32(val) } +func toBoolean(value string) (bool, error) { + boolValue, err := strconv.ParseBool(value) + if err != nil { + return false, fmt.Errorf("value %s is not a valid boolean", value) + } + return boolValue, nil +} + func parseNotificationConsumerConfigs(rawJson string) (map[string]config.NotificationConsumerConfig, error) { result := make(map[string]config.NotificationConsumerConfig) if rawJson == "" { @@ -230,3 +246,56 @@ func parseAllowedFileCategories(rawJson string) ([]string, error) { return result, nil } + +type rawVCSConfig struct { + Platform string `json:"platform"` + APIBaseURL string `json:"apiBaseURL"` + AccessToken *string `json:"accessToken,omitempty"` + AccessTokenEnvVar *string `json:"accessTokenEnvVar,omitempty"` +} + +func parseVCSConfigs(jsonString string, getter func(string) string) (map[string]config.VCSConfig, error) { + var vcsConfigsRaw map[string]rawVCSConfig + if err := json.Unmarshal([]byte(jsonString), &vcsConfigsRaw); err != nil { + return nil, err + } + + vcsConfigs := make(map[string]config.VCSConfig, 0) + for key, raw := range vcsConfigsRaw { + var accessToken string + // We do not support accessing vcs without access token + if raw.AccessTokenEnvVar != nil { + accessToken = getter(*raw.AccessTokenEnvVar) + if accessToken == "" { + return nil, fmt.Errorf("vcs %s: access-token variable %s is empty", key, *raw.AccessTokenEnvVar) + } + } else if raw.AccessToken != nil && *raw.AccessToken != "" { + accessToken = *raw.AccessToken + } else { + return nil, fmt.Errorf("vcs %s: neither access-token environment variable or access-token value is set", key) + } + + platform, err := parseVCSPlatform(raw.Platform) + if err != nil { + return nil, fmt.Errorf("vcs %s: %s", key, err.Error()) + } + + vcsConfigs[key] = config.VCSConfig{ + Platform: platform, + APIBaseURL: raw.APIBaseURL, + AccessToken: accessToken, + } + } + return vcsConfigs, nil +} + +func parseVCSPlatform(value string) (config.VCSPlatform, error) { + switch value { + case "BITBUCKET_DATACENTER": + return config.VCSPlatformBitbucketDatacenter, nil + case "GITHUB": + return config.VCSPlatformGitHub, nil + default: + return config.VCSPlatformUnknown, fmt.Errorf("invalid vcs platform: '%s'", value) + } +} diff --git a/internal/repository/metadata/metadata.go b/internal/repository/metadata/metadata.go index 2f73c7b..f250112 100644 --- a/internal/repository/metadata/metadata.go +++ b/internal/repository/metadata/metadata.go @@ -97,7 +97,7 @@ func (r *Impl) Teardown() { const insecureSkipTLS = false -var UseHTTP = true +var UseHTTP = false func (r *Impl) pathsTouchedInCommit(ctx context.Context, commit *object.Commit) ([]string, error) { result := make([]string, 0) diff --git a/internal/service/mapper/mapper.go b/internal/service/mapper/mapper.go index 7c6ce49..e72b4cf 100644 --- a/internal/service/mapper/mapper.go +++ b/internal/service/mapper/mapper.go @@ -6,6 +6,7 @@ import ( "github.com/Interhyp/metadata-service/internal/acorn/config" "github.com/Interhyp/metadata-service/internal/acorn/repository" "github.com/Interhyp/metadata-service/internal/acorn/service" + "github.com/Interhyp/metadata-service/internal/service/vcswebhookshandler" auzerolog "github.com/StephanHCB/go-autumn-logging-zerolog" "strings" "sync" @@ -16,7 +17,7 @@ type Impl struct { CustomConfiguration config.CustomConfiguration Logging librepo.Logging Metadata repository.Metadata - Bitbucket repository.Bitbucket + VcsPlatforms map[string]vcswebhookshandler.VCSPlatform Timestamp librepo.Timestamp muOwnerCaches sync.Mutex @@ -30,15 +31,14 @@ func New( logging librepo.Logging, timestamp librepo.Timestamp, metadata repository.Metadata, - bitbucket repository.Bitbucket, -) service.Mapper { + vcsPlatforms map[string]vcswebhookshandler.VCSPlatform) service.Mapper { return &Impl{ Configuration: configuration, CustomConfiguration: customConfig, Logging: logging, Timestamp: timestamp, Metadata: metadata, - Bitbucket: bitbucket, + VcsPlatforms: vcsPlatforms, } } diff --git a/internal/service/mapper/owner.go b/internal/service/mapper/owner.go index b068a93..185b1a3 100644 --- a/internal/service/mapper/owner.go +++ b/internal/service/mapper/owner.go @@ -2,8 +2,13 @@ package mapper import ( "context" + "fmt" "github.com/Interhyp/metadata-service/api" + "github.com/Interhyp/metadata-service/internal/acorn/errors/httperror" + "github.com/Interhyp/metadata-service/internal/acorn/repository" + "net/http" "sort" + "strings" "github.com/Interhyp/metadata-service/internal/service/util" ) @@ -51,15 +56,15 @@ func (s *Impl) processGroupMap(ctx context.Context, groupsMap map[string][]strin for groupName, groupMembers := range groupsMap { users, groups := util.SplitUsersAndGroups(groupMembers) if len(users) > 0 { - filteredExistingUsers, err2 := s.Bitbucket.FilterExistingUsernames(ctx, users) - if err2 == nil { + filteredExistingUsers, err := s.filterExistingUsernames(ctx, users) + if err == nil { userDifference := util.Difference(users, filteredExistingUsers) if len(userDifference) > 0 { s.Logging.Logger().Ctx(ctx).Warn().Printf("Found unknown users in configuration: %v", userDifference) } groupsMap[groupName] = append(filteredExistingUsers, groups...) } else { - s.Logging.Logger().Ctx(ctx).Error().Printf("Error checking existing bitbucket users: %s", err2.Error()) + s.Logging.Logger().Ctx(ctx).Error().Printf("Error checking existing bitbucket users: %s", err.Error()) } if len(groupsMap[groupName]) <= 0 && len(users) > 0 { @@ -117,3 +122,74 @@ func (s *Impl) IsOwnerEmpty(_ context.Context, ownerAlias string) bool { return true } + +func (s *Impl) filterExistingUsernames(ctx context.Context, usernames []string) ([]string, error) { + existingUsernames := make([]string, 0) + + dedupUsers := Unique(usernames) + existingUsers, err := s.getExisingUsers(ctx, dedupUsers) + if err != nil { + return existingUsernames, err + } + + for _, user := range existingUsers { + existingUsernames = append(existingUsernames, user) + } + sort.Strings(existingUsernames) + + return existingUsernames, nil +} + +func Unique[T comparable](sliceList []T) []T { + allKeys := make(map[T]bool) + list := make([]T, 0) + for _, item := range sliceList { + if _, value := allKeys[item]; !value { + allKeys[item] = true + list = append(list, item) + } + } + return list +} + +func (s *Impl) getExisingUsers(ctx context.Context, usernames []string) ([]string, error) { + users := make([]string, 0) + vcs, err := getMatchingVCS(s) + if err != nil { + return []string{}, err + } + + for _, username := range usernames { + bbUser, err := vcs.GetUser(ctx, username) + if err != nil { + if httperror.Is(err) && err.(*httperror.Impl).Status() == http.StatusNotFound { + s.Logging.Logger().Ctx(ctx).Warn().Printf("bitbucket user %s does not exist", username) + continue + } + s.Logging.Logger().Ctx(ctx).Error().WithErr(err).Print(fmt.Sprintf("failed to read bitbucket user %s", username)) + return []string{}, err + } + users = append(users, bbUser) + } + return users, nil +} + +func getMatchingVCS(s *Impl) (repository.VcsPlugin, error) { + vcs := new(repository.VcsPlugin) + if strings.Contains(s.CustomConfiguration.MetadataRepoUrl(), "github.com") { + platform, ok := s.VcsPlatforms["github"] + if !ok { + return nil, fmt.Errorf("github vcs not configured") + } + vcs = &platform.VCS + } else if strings.Contains(s.CustomConfiguration.MetadataRepoUrl(), "bitbucket") { + platform, ok := s.VcsPlatforms["bitbucket"] + if !ok { + return nil, fmt.Errorf("bitbucket vcs not configured") + } + vcs = &platform.VCS + } else { + return nil, fmt.Errorf("unknown vcs for repository url %s", s.CustomConfiguration.MetadataRepoUrl()) + } + return *vcs, nil +} diff --git a/internal/service/mapper/repository.go b/internal/service/mapper/repository.go index de55b4b..a548d57 100644 --- a/internal/service/mapper/repository.go +++ b/internal/service/mapper/repository.go @@ -86,7 +86,7 @@ func (s *Impl) GetRepository(ctx context.Context, repoKey string) (openapi.Repos for approversGroupName, approversGroup := range approversGroupsMap { users, groups := util.SplitUsersAndGroups(approversGroup) if len(users) > 0 { - filteredExistingUsers, err2 := s.Bitbucket.FilterExistingUsernames(ctx, users) + filteredExistingUsers, err2 := s.filterExistingUsernames(ctx, users) if err2 == nil { userDifference := util.Difference(users, filteredExistingUsers) if len(userDifference) > 0 { diff --git a/internal/service/prvalidator/prvalidator.go b/internal/service/prvalidator/prvalidator.go deleted file mode 100644 index 22c5d79..0000000 --- a/internal/service/prvalidator/prvalidator.go +++ /dev/null @@ -1,103 +0,0 @@ -package prvalidator - -import ( - "context" - "fmt" - librepo "github.com/Interhyp/go-backend-service-common/acorns/repository" - openapi "github.com/Interhyp/metadata-service/api" - "github.com/Interhyp/metadata-service/internal/acorn/config" - "github.com/Interhyp/metadata-service/internal/acorn/repository" - "github.com/Interhyp/metadata-service/internal/acorn/service" - aulogging "github.com/StephanHCB/go-autumn-logging" - "gopkg.in/yaml.v3" - "strings" -) - -type Impl struct { - Configuration librepo.Configuration - CustomConfiguration config.CustomConfiguration - Logging librepo.Logging - Timestamp librepo.Timestamp - BitBucket repository.Bitbucket -} - -func New( - configuration librepo.Configuration, - customConfig config.CustomConfiguration, - logging librepo.Logging, - timestamp librepo.Timestamp, - bitbucket repository.Bitbucket, -) service.PRValidator { - return &Impl{ - Configuration: configuration, - CustomConfiguration: customConfig, - Logging: logging, - Timestamp: timestamp, - BitBucket: bitbucket, - } -} - -func (s *Impl) IsPRValidator() bool { - return true -} - -func (s *Impl) ValidatePullRequest(ctx context.Context, id uint64, toRef string, fromRef string) error { - fileInfos, prHead, err := s.BitBucket.GetChangedFilesOnPullRequest(ctx, int(id)) - if err != nil { - return fmt.Errorf("error getting changed files on pull request: %v", err) - } - - var errorMessages []string - for _, fileInfo := range fileInfos { - err := s.validateYamlFile(ctx, fileInfo.Path, fileInfo.Contents) - if err != nil { - errorMessages = append(errorMessages, err.Error()) - } - } - - buildUrl := s.CustomConfiguration.PullRequestBuildUrl() - buildKey := s.CustomConfiguration.PullRequestBuildKey() - message := "all changed files are valid\n" - if len(errorMessages) > 0 { - message = "# yaml validation failure\n\nThere were validation errors in changed files. Please fix yaml syntax and/or remove unknown fields:\n\n" + - strings.Join(errorMessages, "\n\n") + "\n" - } - err = s.BitBucket.CreatePullRequestComment(ctx, int(id), message) - if err != nil { - return fmt.Errorf("error creating pull request comment: %v", err) - } - err = s.BitBucket.AddCommitBuildStatus(ctx, prHead, buildUrl, buildKey, len(errorMessages) == 0) - if err != nil { - return fmt.Errorf("error adding commit build status: %v", err) - } - - return nil -} - -func (s *Impl) validateYamlFile(ctx context.Context, path string, contents string) error { - if strings.HasPrefix(path, "owners/") && strings.HasSuffix(path, ".yaml") { - if strings.Contains(path, "owner.info.yaml") { - return parseStrict(ctx, path, contents, &openapi.OwnerDto{}) - } else if strings.Contains(path, "/services/") { - return parseStrict(ctx, path, contents, &openapi.ServiceDto{}) - } else if strings.Contains(path, "/repositories/") { - return parseStrict(ctx, path, contents, &openapi.RepositoryDto{}) - } else { - aulogging.Logger.Ctx(ctx).Info().Printf("ignoring changed file %s in pull request (neither owner info, nor service nor repository)", path) - return nil - } - } else { - aulogging.Logger.Ctx(ctx).Info().Printf("ignoring changed file %s in pull request (not in owners/ or not .yaml)", path) - return nil - } -} - -func parseStrict[T openapi.OwnerDto | openapi.ServiceDto | openapi.RepositoryDto](_ context.Context, path string, contents string, resultPtr *T) error { - decoder := yaml.NewDecoder(strings.NewReader(contents)) - decoder.KnownFields(true) - err := decoder.Decode(resultPtr) - if err != nil { - return fmt.Errorf(" - failed to parse `%s`:\n %s", path, strings.ReplaceAll(err.Error(), "\n", "\n ")) - } - return nil -} diff --git a/internal/service/vcswebhookshandler/errors.go b/internal/service/vcswebhookshandler/errors.go new file mode 100644 index 0000000..a6ff4a2 --- /dev/null +++ b/internal/service/vcswebhookshandler/errors.go @@ -0,0 +1,17 @@ +package vcswebhookshandler + +import "fmt" + +type ErrVCSConfigurationNotFound struct { + key string +} + +func NewErrVCSConfigurationNotFound(key string) error { + return ErrVCSConfigurationNotFound{ + key: key, + } +} + +func (e ErrVCSConfigurationNotFound) Error() string { + return fmt.Sprintf("failed to find vcs configuration for key '%s'", e.key) +} diff --git a/internal/service/vcswebhookshandler/vcswebhookshandler.go b/internal/service/vcswebhookshandler/vcswebhookshandler.go new file mode 100644 index 0000000..1f9d519 --- /dev/null +++ b/internal/service/vcswebhookshandler/vcswebhookshandler.go @@ -0,0 +1,234 @@ +package vcswebhookshandler + +import ( + "context" + "fmt" + librepo "github.com/Interhyp/go-backend-service-common/acorns/repository" + "github.com/Interhyp/go-backend-service-common/web/util/contexthelper" + openapi "github.com/Interhyp/metadata-service/api" + "github.com/Interhyp/metadata-service/internal/acorn/config" + "github.com/Interhyp/metadata-service/internal/acorn/repository" + "github.com/Interhyp/metadata-service/internal/acorn/service" + aulogging "github.com/StephanHCB/go-autumn-logging" + bitbucketserver "github.com/go-playground/webhooks/v6/bitbucket-server" + githubhook "github.com/go-playground/webhooks/v6/github" + "github.com/google/uuid" + "gopkg.in/yaml.v3" + "net/http" + "strconv" + "strings" + "time" +) + +const ( + webhookContextTimeout = 10 * time.Minute +) + +type VCSPlatform struct { + Platform config.VCSPlatform + VCS repository.VcsPlugin +} + +type Impl struct { + CustomConfiguration config.CustomConfiguration + Logging librepo.Logging + Timestamp librepo.Timestamp + + Updater service.Updater + + //Provider service.DeploymentRepositoryProvider + //ManifestProcessor service.ImageExtractor + + vcsPlatforms map[string]VCSPlatform +} + +func New( + configuration librepo.Configuration, + logging librepo.Logging, + timestamp librepo.Timestamp, + updater service.Updater, + vcsPlatforms map[string]VCSPlatform, +) service.VCSWebhooksHandler { + return &Impl{ + CustomConfiguration: config.Custom(configuration), + Logging: logging, + Timestamp: timestamp, + Updater: updater, + vcsPlatforms: vcsPlatforms, + } +} + +func (h *Impl) HandleEvent( + ctx context.Context, + vcsKey string, + r *http.Request, +) error { + aulogging.Logger.Ctx(ctx).Info().Printf("received webhook from VCS") + + vcsPlatform, ok := h.vcsPlatforms[vcsKey] + if !ok { + return NewErrVCSConfigurationNotFound(vcsKey) + } + + payload, err := h.parsePayload(ctx, r, vcsPlatform.Platform) + if err != nil { + return err + } + + if h.CustomConfiguration.WebhooksProcessAsync() { + transactionName := fmt.Sprintf("vcs-webhook-%s", uuid.NewString()) + asyncCtx, asyncCtxCancel := contexthelper.AsyncCopyRequestContext(ctx, transactionName, "backgroundJob") + asyncCtx, asyncTimeoutCtxCancel := context.WithTimeout(asyncCtx, webhookContextTimeout) + go func() { + defer func() { + asyncCtxCancel() + asyncTimeoutCtxCancel() + }() + + if innerErr := h.processPayload(asyncCtx, vcsPlatform.VCS, payload); err != nil { + aulogging.Logger.Ctx(ctx).Warn().WithErr(innerErr).Print("failed to asynchronously process vcs webhook") + } + }() + } else { + timeoutCtx, timeoutCtxCancel := context.WithTimeout(ctx, webhookContextTimeout) + defer timeoutCtxCancel() + + return h.processPayload(timeoutCtx, vcsPlatform.VCS, payload) + } + + return nil +} + +func (h *Impl) parsePayload(ctx context.Context, r *http.Request, platform config.VCSPlatform) (any, error) { + switch platform { + case config.VCSPlatformBitbucketDatacenter: + return h.parseBitbucketPayload(ctx, r) + case config.VCSPlatformGitHub: + return h.parseGitHubPayload(r) + default: + return nil, fmt.Errorf("failed to parse payload: unsupported or unknown vcs platform") + } +} + +func (h *Impl) processPayload( + ctx context.Context, + vcs repository.VcsPlugin, + payload any, +) error { + switch payload.(type) { + case bitbucketserver.PullRequestOpenedPayload: + return h.processBitbucketRepositoryPullRequestEvent(ctx, vcs, payload) + case bitbucketserver.RepositoryReferenceChangedPayload: + return h.processBitbucketRepositoryPullRequestEvent(ctx, vcs, payload) + case bitbucketserver.PullRequestModifiedPayload: + return h.processBitbucketRepositoryPullRequestEvent(ctx, vcs, payload) + case bitbucketserver.PullRequestFromReferenceUpdatedPayload: + return h.processBitbucketRepositoryPullRequestEvent(ctx, vcs, payload) + case githubhook.PullRequestPayload: + return h.processGitHubPullRequestEvent(ctx, vcs, payload.(githubhook.PullRequestPayload)) + case githubhook.PushPayload: + return h.processGitHubPushEvent(ctx, payload.(githubhook.PushPayload)) + default: + return nil + } +} + +func (h *Impl) setCommitStatusSafely( + ctx context.Context, + vcs repository.VcsPlugin, + commitID string, + status repository.CommitBuildStatus, +) { + switch status { + case repository.CommitBuildStatusInProgress: + if err := vcs.SetCommitStatusInProgress(ctx, h.CustomConfiguration.MetadataRepoProject(), h.CustomConfiguration.MetadataRepoName(), commitID, h.CustomConfiguration.PullRequestBuildUrl(), h.CustomConfiguration.PullRequestBuildKey()); err != nil { + aulogging.Logger.Ctx(ctx).Warn().WithErr(err).Printf("failed to create 'in-progress' commit status for commit %s in workload repository", commitID) + } + case repository.CommitBuildStatusSuccess: + if err := vcs.SetCommitStatusSucceeded(ctx, h.CustomConfiguration.MetadataRepoProject(), h.CustomConfiguration.MetadataRepoName(), commitID, h.CustomConfiguration.PullRequestBuildUrl(), h.CustomConfiguration.PullRequestBuildKey()); err != nil { + aulogging.Logger.Ctx(ctx).Warn().WithErr(err).Printf("failed to create 'succeeded' commit status for commit %s in workload repository", commitID) + } + case repository.CommitBuildStatusFailed: + if err := vcs.SetCommitStatusFailed(ctx, h.CustomConfiguration.MetadataRepoProject(), h.CustomConfiguration.MetadataRepoName(), commitID, h.CustomConfiguration.PullRequestBuildUrl(), h.CustomConfiguration.PullRequestBuildKey()); err != nil { + aulogging.Logger.Ctx(ctx).Warn().WithErr(err).Printf("failed to create 'failed' commit status for commit %s in workload repository", commitID) + } + } +} + +func (h *Impl) createPullRequestCommentSafely( + ctx context.Context, + vcs repository.VcsPlugin, + pullRequestID string, + text string, +) { + err := vcs.CreatePullRequestComment(ctx, h.CustomConfiguration.MetadataRepoProject(), h.CustomConfiguration.MetadataRepoName(), pullRequestID, text) + if err != nil { + aulogging.Logger.Ctx(ctx).Warn().WithErr(err).Printf("failed to create pull-request comment for pull-request %s in workload repository", pullRequestID) + } +} + +func (h *Impl) validate(ctx context.Context, vcs repository.VcsPlugin, id uint64, toRef string, fromRef string) error { + fileInfos, prHead, err := h.getChangedFilesOnPullRequest(ctx, vcs, strconv.FormatUint(id, 10), toRef) + if err != nil { + return fmt.Errorf("error getting changed files on pull request: %v", err) + } + + var errorMessages []string + for _, fileInfo := range fileInfos { + err = h.validateYamlFile(ctx, fileInfo.Path, fileInfo.Contents) + if err != nil { + errorMessages = append(errorMessages, err.Error()) + } + } + + message := "all changed files are valid\n" + if len(errorMessages) > 0 { + message = "# yaml validation failure\n\nThere were validation errors in changed files. Please fix yaml syntax and/or remove unknown fields:\n\n" + + strings.Join(errorMessages, "\n\n") + "\n" + } + h.createPullRequestCommentSafely(ctx, vcs, strconv.FormatUint(id, 10), message) + status := repository.CommitBuildStatusFailed + if len(errorMessages) == 0 { + status = repository.CommitBuildStatusSuccess + } + h.setCommitStatusSafely(ctx, vcs, prHead, status) + + return nil +} + +func (h *Impl) getChangedFilesOnPullRequest( + ctx context.Context, + vcs repository.VcsPlugin, + pullRequestID string, + toRef string, +) ([]repository.File, string, error) { + return vcs.GetChangedFilesOnPullRequest(ctx, h.CustomConfiguration.MetadataRepoProject(), h.CustomConfiguration.MetadataRepoName(), pullRequestID, toRef) +} + +func (h *Impl) validateYamlFile(ctx context.Context, path string, contents string) error { + if strings.HasPrefix(path, "owners/") && strings.HasSuffix(path, ".yaml") { + if strings.Contains(path, "owner.info.yaml") { + return parseStrict(ctx, path, contents, &openapi.OwnerDto{}) + } else if strings.Contains(path, "/services/") { + return parseStrict(ctx, path, contents, &openapi.ServiceDto{}) + } else if strings.Contains(path, "/repositories/") { + return parseStrict(ctx, path, contents, &openapi.RepositoryDto{}) + } else { + aulogging.Logger.Ctx(ctx).Info().Printf("ignoring changed file %s in pull request (neither owner info, nor service nor repository)", path) + return nil + } + } else { + aulogging.Logger.Ctx(ctx).Info().Printf("ignoring changed file %s in pull request (not in owners/ or not .yaml)", path) + return nil + } +} + +func parseStrict[T openapi.OwnerDto | openapi.ServiceDto | openapi.RepositoryDto](_ context.Context, path string, contents string, resultPtr *T) error { + decoder := yaml.NewDecoder(strings.NewReader(contents)) + decoder.KnownFields(true) + err := decoder.Decode(resultPtr) + if err != nil { + return fmt.Errorf(" - failed to parse `%s`:\n %s", path, strings.ReplaceAll(err.Error(), "\n", "\n ")) + } + return nil +} diff --git a/internal/service/vcswebhookshandler/vcswebhookshandler_bitbucket.go b/internal/service/vcswebhookshandler/vcswebhookshandler_bitbucket.go new file mode 100644 index 0000000..c874e18 --- /dev/null +++ b/internal/service/vcswebhookshandler/vcswebhookshandler_bitbucket.go @@ -0,0 +1,73 @@ +package vcswebhookshandler + +import ( + "context" + "fmt" + "github.com/Interhyp/go-backend-service-common/api/apierrors" + "github.com/Interhyp/metadata-service/internal/acorn/repository" + aulogging "github.com/StephanHCB/go-autumn-logging" + bitbucketserver "github.com/go-playground/webhooks/v6/bitbucket-server" + "net/http" +) + +func (h *Impl) parseBitbucketPayload(ctx context.Context, r *http.Request) (any, error) { + webhook, err := bitbucketserver.New() // we don't need signature checking here + if err != nil { + aulogging.Logger.Ctx(ctx).Info().WithErr(err).Printf("unexpected error while instantiating bitbucket webhook parser - ignoring webhook") + return nil, apierrors.NewInternalServerError(err.Error(), "", err, h.Timestamp.Now()) + } + + eventPayload, err := webhook.Parse(r, bitbucketserver.DiagnosticsPingEvent, bitbucketserver.PullRequestOpenedEvent, + bitbucketserver.RepositoryReferenceChangedEvent, bitbucketserver.PullRequestModifiedEvent, bitbucketserver.PullRequestFromReferenceUpdatedEvent) + if err != nil { + aulogging.Logger.Ctx(ctx).Info().WithErr(err).Printf("bad request error while parsing bitbucket webhook payload - ignoring webhook") + return nil, apierrors.NewBadRequestError("webhook.payload.invalid", "parse payload error", err, h.Timestamp.Now()) + } + return eventPayload, nil +} + +func (h *Impl) processBitbucketRepositoryPullRequestEvent(ctx context.Context, vcs repository.VcsPlugin, eventPayload any) error { + switch eventPayload.(type) { + case bitbucketserver.PullRequestOpenedPayload: + payload, ok := eventPayload.(bitbucketserver.PullRequestOpenedPayload) + h.validatePullRequest(ctx, "opened", ok, vcs, payload.PullRequest) + case bitbucketserver.PullRequestModifiedPayload: + payload, ok := eventPayload.(bitbucketserver.PullRequestModifiedPayload) + h.validatePullRequest(ctx, "modified", ok, vcs, payload.PullRequest) + case bitbucketserver.PullRequestFromReferenceUpdatedPayload: + payload, ok := eventPayload.(bitbucketserver.PullRequestFromReferenceUpdatedPayload) + h.validatePullRequest(ctx, "from_reference", ok, vcs, payload.PullRequest) + case bitbucketserver.RepositoryReferenceChangedPayload: + payload, ok := eventPayload.(bitbucketserver.RepositoryReferenceChangedPayload) + if !ok || len(payload.Changes) < 1 || payload.Changes[0].ReferenceID == "" { + aulogging.Logger.Ctx(ctx).Error().Printf("bad request while processing bitbucket webhook - got reference changed with invalid info - ignoring webhook") + return nil // error here + } + aulogging.Logger.Ctx(ctx).Info().Printf("got repository reference changed, refreshing caches") + + err := h.Updater.PerformFullUpdateWithNotifications(ctx) + if err != nil { + aulogging.Logger.Ctx(ctx).Error().WithErr(err).Printf("webhook error") + } + default: + // ignore unknown events + } + return nil +} + +func (h *Impl) validatePullRequest(ctx context.Context, operation string, parsedOk bool, vcs repository.VcsPlugin, pullRequestPayload bitbucketserver.PullRequest) { + description := fmt.Sprintf("id: %d, toRef: %s, fromRef: %s", pullRequestPayload.ID, pullRequestPayload.ToRef.ID, pullRequestPayload.FromRef.ID) + if !parsedOk || pullRequestPayload.ID == 0 || pullRequestPayload.ToRef.ID == "" || pullRequestPayload.FromRef.ID == "" { + aulogging.Logger.Ctx(ctx).Error().Printf("bad request while processing bitbucket webhook - got pull request %s with invalid info (%s) - ignoring webhook", operation, description) + return + } + aulogging.Logger.Ctx(ctx).Info().Printf("got pull request %s (%s)", operation, description) + + err := h.validate(ctx, vcs, pullRequestPayload.ID, pullRequestPayload.ToRef.ID, pullRequestPayload.FromRef.ID) + if err != nil { + aulogging.Logger.Ctx(ctx).Error().WithErr(err).Printf("error while processing bitbucket webhook: pull request %s (%s): %s", operation, description, err.Error()) + return + } + + aulogging.Logger.Ctx(ctx).Info().Printf("successfully processed pull request %s (%s) event", operation, description) +} diff --git a/internal/service/vcswebhookshandler/vcswebhookshandler_github.go b/internal/service/vcswebhookshandler/vcswebhookshandler_github.go new file mode 100644 index 0000000..caeb628 --- /dev/null +++ b/internal/service/vcswebhookshandler/vcswebhookshandler_github.go @@ -0,0 +1,79 @@ +package vcswebhookshandler + +import ( + "context" + "fmt" + "github.com/Interhyp/go-backend-service-common/api/apierrors" + "github.com/Interhyp/metadata-service/internal/acorn/repository" + aulogging "github.com/StephanHCB/go-autumn-logging" + githubhook "github.com/go-playground/webhooks/v6/github" + "net/http" +) + +func (h *Impl) parseGitHubPayload(r *http.Request) (any, error) { + hook, _ := githubhook.New() + + body, err := hook.Parse(r, githubhook.PushEvent, githubhook.PullRequestEvent) + if err != nil { + return nil, apierrors.NewBadRequestError("webhook.payload.invalid", "parse payload error", err, h.Timestamp.Now()) + } + return body, nil +} + +func (h *Impl) processGitHubPushEvent( + ctx context.Context, + payload githubhook.PushPayload, +) error { + if len(payload.Commits) < 1 || payload.Commits[0].ID == "" { + aulogging.Logger.Ctx(ctx).Error().Printf("bad request while processing bitbucket webhook - got reference changed with invalid info - ignoring webhook") + return nil // error here + } + aulogging.Logger.Ctx(ctx).Info().Printf("got repository reference changed, refreshing caches") + + err := h.Updater.PerformFullUpdateWithNotifications(ctx) + if err != nil { + aulogging.Logger.Ctx(ctx).Error().WithErr(err).Printf("webhook error") + } + return nil +} + +func (h *Impl) processGitHubPullRequestEvent( + ctx context.Context, + vcs repository.VcsPlugin, + payload githubhook.PullRequestPayload, +) error { + switch payload.Action { + case "opened": + fallthrough + case "reopened": + fallthrough + case "synchronize": + fallthrough + case "edited": + return h.validateWorkloadPullRequest(ctx, vcs, payload) + } + return nil +} + +func (h *Impl) validateWorkloadPullRequest(ctx context.Context, vcs repository.VcsPlugin, payload githubhook.PullRequestPayload) error { + operation := payload.Action + description := fmt.Sprintf("id: %d, toRef: %s, fromRef: %s", payload.PullRequest.Number, payload.PullRequest.Base.Sha, payload.PullRequest.Head.Sha) + if payload.PullRequest.Number == 0 || payload.PullRequest.Head.Sha == "" || payload.PullRequest.Base.Sha == "" { + errorMsg := fmt.Sprintf("bad request while processing bitbucket webhook - got pull request %s with invalid info (%s) - ignoring webhook", operation, description) + aulogging.Logger.Ctx(ctx).Error().Printf(errorMsg) + return fmt.Errorf(errorMsg) + } + aulogging.Logger.Ctx(ctx).Info().Printf("got pull request %s (%s)", operation, description) + + sourceCommitID := payload.PullRequest.Head.Sha + h.setCommitStatusSafely(ctx, vcs, sourceCommitID, repository.CommitBuildStatusInProgress) + err := h.validate(ctx, vcs, uint64(payload.PullRequest.Number), payload.PullRequest.Head.Sha, payload.PullRequest.Base.Sha) + if err != nil { + errorMsg := fmt.Sprintf("error while processing bitbucket webhook: pull request %s (%s): %s", operation, description, err.Error()) + aulogging.Logger.Ctx(ctx).Error().WithErr(err).Printf(errorMsg) + return fmt.Errorf(errorMsg) + } + + aulogging.Logger.Ctx(ctx).Info().Printf("successfully processed pull request %s (%s) event", operation, description) + return nil +} diff --git a/internal/util/util.go b/internal/util/util.go new file mode 100644 index 0000000..03e1e90 --- /dev/null +++ b/internal/util/util.go @@ -0,0 +1,5 @@ +package util + +func Ptr[T any](input T) *T { + return &input +} diff --git a/internal/web/app/app.go b/internal/web/app/app.go index af44813..e085838 100644 --- a/internal/web/app/app.go +++ b/internal/web/app/app.go @@ -1,6 +1,7 @@ package app import ( + "fmt" libcontroller "github.com/Interhyp/go-backend-service-common/acorns/controller" librepo "github.com/Interhyp/go-backend-service-common/acorns/repository" "github.com/Interhyp/go-backend-service-common/repository/logging" @@ -13,7 +14,8 @@ import ( "github.com/Interhyp/metadata-service/internal/acorn/controller" "github.com/Interhyp/metadata-service/internal/acorn/repository" "github.com/Interhyp/metadata-service/internal/acorn/service" - "github.com/Interhyp/metadata-service/internal/repository/bitbucket" + bitbucketclient "github.com/Interhyp/metadata-service/internal/client/bitbucket" + githubclient "github.com/Interhyp/metadata-service/internal/client/github" "github.com/Interhyp/metadata-service/internal/repository/cache" "github.com/Interhyp/metadata-service/internal/repository/config" "github.com/Interhyp/metadata-service/internal/repository/hostip" @@ -24,11 +26,11 @@ import ( "github.com/Interhyp/metadata-service/internal/repository/sshAuthProvider" "github.com/Interhyp/metadata-service/internal/service/mapper" "github.com/Interhyp/metadata-service/internal/service/owners" - "github.com/Interhyp/metadata-service/internal/service/prvalidator" "github.com/Interhyp/metadata-service/internal/service/repositories" "github.com/Interhyp/metadata-service/internal/service/services" "github.com/Interhyp/metadata-service/internal/service/trigger" "github.com/Interhyp/metadata-service/internal/service/updater" + "github.com/Interhyp/metadata-service/internal/service/vcswebhookshandler" "github.com/Interhyp/metadata-service/internal/web/controller/ownerctl" "github.com/Interhyp/metadata-service/internal/web/controller/repositoryctl" "github.com/Interhyp/metadata-service/internal/web/controller/servicectl" @@ -47,20 +49,20 @@ type ApplicationImpl struct { Kafka repository.Kafka IdentityProvider repository.IdentityProvider HostIP repository.HostIP - Bitbucket repository.Bitbucket Timestamp librepo.Timestamp SshAuthProvider repository.SshAuthProvider Notifier repository.Notifier Cache repository.Cache // services (business logic) - Mapper service.Mapper - Trigger service.Trigger - Updater service.Updater - Owners service.Owners - Services service.Services - Repositories service.Repositories - PRValidator service.PRValidator + Mapper service.Mapper + Trigger service.Trigger + Updater service.Updater + Owners service.Owners + Services service.Services + Repositories service.Repositories + VCSPlatforms *map[string]vcswebhookshandler.VCSPlatform + VCSWebhooksHandler service.VCSWebhooksHandler // controllers (incoming connectors) HealthCtl libcontroller.HealthController @@ -177,13 +179,6 @@ func (a *ApplicationImpl) ConstructRepositories() error { return err } - if a.Bitbucket == nil { - a.Bitbucket = bitbucket.New(a.Config, a.CustomConfig, a.Logging, a.Vault) - } - if err := a.Bitbucket.Setup(); err != nil { - return err - } - a.Notifier = notifier.New(a.Config, a.CustomConfig, a.Logging) if err := a.Notifier.Setup(); err != nil { return err @@ -194,13 +189,17 @@ func (a *ApplicationImpl) ConstructRepositories() error { return err } + if err := a.createVCSPlatforms(); err != nil { + return err + } + return nil } func (a *ApplicationImpl) ConstructServices() error { // construct the business logic components(must ensure correct order yourself) - a.Mapper = mapper.New(a.Config, a.CustomConfig, a.Logging, a.Timestamp, a.Metadata, a.Bitbucket) + a.Mapper = mapper.New(a.Config, a.CustomConfig, a.Logging, a.Timestamp, a.Metadata, *a.VCSPlatforms) if err := a.Mapper.Setup(); err != nil { return err } @@ -230,8 +229,9 @@ func (a *ApplicationImpl) ConstructServices() error { return err } - a.PRValidator = prvalidator.New(a.Config, a.CustomConfig, a.Logging, a.Timestamp, a.Bitbucket) - // no setup required + if a.VCSWebhooksHandler == nil { + a.VCSWebhooksHandler = vcswebhookshandler.New(a.Config, a.Logging, a.Timestamp, a.Updater, *a.VCSPlatforms) + } return nil } @@ -244,7 +244,7 @@ func (a *ApplicationImpl) ConstructControllers() error { a.OwnerCtl = ownerctl.New(a.Config, a.CustomConfig, a.Logging, a.Timestamp, a.Owners) a.ServiceCtl = servicectl.New(a.Config, a.CustomConfig, a.Logging, a.Timestamp, a.Services) a.RepositoryCtl = repositoryctl.New(a.Config, a.CustomConfig, a.Logging, a.Timestamp, a.Repositories) - a.WebhookCtl = webhookctl.New(a.Logging, a.Timestamp, a.Updater, a.PRValidator) + a.WebhookCtl = webhookctl.New(a.Logging, a.Timestamp, a.VCSWebhooksHandler) a.Server = server.New(a.Config, a.CustomConfig, a.Logging, a.IdentityProvider, a.HealthCtl, a.SwaggerCtl, a.OwnerCtl, a.ServiceCtl, a.RepositoryCtl, a.WebhookCtl) @@ -254,3 +254,35 @@ func (a *ApplicationImpl) ConstructControllers() error { return nil } + +func (a *ApplicationImpl) createVCSPlatforms() error { + if a.VCSPlatforms == nil { + vcsPlatforms := make(map[string]vcswebhookshandler.VCSPlatform) + for key, vcsConfig := range a.CustomConfig.VCSConfigs() { + switch vcsConfig.Platform { + case configrepo.VCSPlatformBitbucketDatacenter: + client, err := bitbucketclient.NewClient(vcsConfig.APIBaseURL, vcsConfig.AccessToken) + if err != nil { + return err + } + vcsPlatforms[key] = vcswebhookshandler.VCSPlatform{ + Platform: vcsConfig.Platform, + VCS: bitbucketclient.New(client, a.Logging), + } + case configrepo.VCSPlatformGitHub: + client, err := githubclient.NewClient(nil, vcsConfig.AccessToken) + if err != nil { + return err + } + vcsPlatforms[key] = vcswebhookshandler.VCSPlatform{ + Platform: vcsConfig.Platform, + VCS: githubclient.New(client, a.CustomConfig), + } + default: + return fmt.Errorf("vcs config '%s' contains an unsupported vcs platform", key) + } + } + a.VCSPlatforms = &vcsPlatforms + } + return nil +} diff --git a/internal/web/controller/webhookctl/webhookctl.go b/internal/web/controller/webhookctl/webhookctl.go index 5bc68d1..4af77c6 100644 --- a/internal/web/controller/webhookctl/webhookctl.go +++ b/internal/web/controller/webhookctl/webhookctl.go @@ -3,39 +3,35 @@ package webhookctl import ( "context" "fmt" - "github.com/Interhyp/go-backend-service-common/web/util/contexthelper" + "github.com/Interhyp/go-backend-service-common/api/apierrors" "github.com/Interhyp/metadata-service/internal/acorn/controller" "github.com/Interhyp/metadata-service/internal/acorn/service" - bitbucketserver "github.com/go-playground/webhooks/v6/bitbucket-server" "net/http" librepo "github.com/Interhyp/go-backend-service-common/acorns/repository" "github.com/Interhyp/metadata-service/internal/web/util" - aulogging "github.com/StephanHCB/go-autumn-logging" "github.com/go-chi/chi/v5" ) -type Impl struct { - Logging librepo.Logging - Timestamp librepo.Timestamp - Updater service.Updater - PRValidator service.PRValidator +const ( + vcsKeyParam = "vcsKey" +) - EnableAsync bool +type Impl struct { + Logging librepo.Logging + Timestamp librepo.Timestamp + VCSWebhooksHandler service.VCSWebhooksHandler } func New( logging librepo.Logging, timestamp librepo.Timestamp, - updater service.Updater, - prValidator service.PRValidator, + vcswebhookshandler service.VCSWebhooksHandler, ) controller.WebhookController { return &Impl{ - Logging: logging, - Timestamp: timestamp, - Updater: updater, - PRValidator: prValidator, - EnableAsync: true, + Logging: logging, + Timestamp: timestamp, + VCSWebhooksHandler: vcswebhookshandler, } } @@ -44,102 +40,28 @@ func (c *Impl) IsWebhookController() bool { } func (c *Impl) WireUp(_ context.Context, router chi.Router) { - router.Post("/webhook", c.Webhook) - router.Post("/webhook/bitbucket", c.WebhookBitBucket) + router.Post(fmt.Sprintf("/webhooks/vcs/{%s}", vcsKeyParam), c.PostVCSWebhook) } // --- handlers --- -// Webhook is deprecated and will be removed after the switch -func (c *Impl) Webhook(w http.ResponseWriter, r *http.Request) { - ctx := r.Context() - - routineCtx, routineCtxCancel := contexthelper.AsyncCopyRequestContext(ctx, "webhookExternalRepoChange", "backgroundJob") - go func() { - defer routineCtxCancel() - err := c.Updater.PerformFullUpdateWithNotifications(routineCtx) - if err != nil { - aulogging.Logger.Ctx(routineCtx).Error().WithErr(err).Printf("webhook error") - } - }() - - util.SuccessNoBody(ctx, w, r, http.StatusNoContent) -} - -func (c *Impl) WebhookBitBucket(w http.ResponseWriter, r *http.Request) { +func (c *Impl) PostVCSWebhook(w http.ResponseWriter, r *http.Request) { ctx := r.Context() - aulogging.Logger.Ctx(ctx).Info().Printf("received webhook from BitBucket") - webhook, err := bitbucketserver.New() // we don't need signature checking here + vcsKey, err := util.NonEmptyStringPathParam(ctx, r, vcsKeyParam, c.Timestamp) if err != nil { - aulogging.Logger.Ctx(ctx).Info().WithErr(err).Printf("unexpected error while instantiating bitbucket webhook parser - ignoring webhook") - util.UnexpectedErrorHandler(ctx, w, r, err, c.Timestamp.Now()) + apierrors.HandleError(ctx, w, r, err, + apierrors.IsBadRequestError, + ) return } - eventPayload, err := webhook.Parse(r, bitbucketserver.DiagnosticsPingEvent, bitbucketserver.PullRequestOpenedEvent, - bitbucketserver.RepositoryReferenceChangedEvent, bitbucketserver.PullRequestModifiedEvent, bitbucketserver.PullRequestFromReferenceUpdatedEvent) - if err != nil { - aulogging.Logger.Ctx(ctx).Info().WithErr(err).Printf("bad request error while parsing bitbucket webhook payload - ignoring webhook") - util.ErrorHandler(ctx, w, r, "webhook.payload.invalid", http.StatusBadRequest, "parse payload error", c.Timestamp.Now()) + if err := c.VCSWebhooksHandler.HandleEvent(ctx, vcsKey, r); err != nil { + apierrors.HandleError(ctx, w, r, err, + apierrors.IsBadRequestError, + apierrors.IsBadGatewayError, + apierrors.IsInternalServerError) return } - - if c.EnableAsync { - routineCtx, routineCtxCancel := contexthelper.AsyncCopyRequestContext(ctx, "webhookBitbucket", "backgroundJob") - go func() { - defer routineCtxCancel() - - c.WebhookBitBucketProcessSync(routineCtx, eventPayload) - }() - } else { - c.WebhookBitBucketProcessSync(ctx, eventPayload) - } - util.SuccessNoBody(ctx, w, r, http.StatusNoContent) } - -func (c *Impl) WebhookBitBucketProcessSync(ctx context.Context, eventPayload any) { - switch eventPayload.(type) { - case bitbucketserver.PullRequestOpenedPayload: - payload, ok := eventPayload.(bitbucketserver.PullRequestOpenedPayload) - c.validatePullRequest(ctx, "opened", ok, payload.PullRequest) - case bitbucketserver.PullRequestModifiedPayload: - payload, ok := eventPayload.(bitbucketserver.PullRequestModifiedPayload) - c.validatePullRequest(ctx, "modified", ok, payload.PullRequest) - case bitbucketserver.PullRequestFromReferenceUpdatedPayload: - payload, ok := eventPayload.(bitbucketserver.PullRequestFromReferenceUpdatedPayload) - c.validatePullRequest(ctx, "from_reference", ok, payload.PullRequest) - case bitbucketserver.RepositoryReferenceChangedPayload: - payload, ok := eventPayload.(bitbucketserver.RepositoryReferenceChangedPayload) - if !ok || len(payload.Changes) < 1 || payload.Changes[0].ReferenceID == "" { - aulogging.Logger.Ctx(ctx).Error().Printf("bad request while processing bitbucket webhook - got reference changed with invalid info - ignoring webhook") - return - } - aulogging.Logger.Ctx(ctx).Info().Printf("got repository reference changed, refreshing caches") - - err := c.Updater.PerformFullUpdateWithNotifications(ctx) - if err != nil { - aulogging.Logger.Ctx(ctx).Error().WithErr(err).Printf("webhook error") - } - default: - // ignore unknown events - } -} - -func (c *Impl) validatePullRequest(ctx context.Context, operation string, parsedOk bool, pullRequestPayload bitbucketserver.PullRequest) { - description := fmt.Sprintf("id: %d, toRef: %s, fromRef: %s", pullRequestPayload.ID, pullRequestPayload.ToRef.ID, pullRequestPayload.FromRef.ID) - if !parsedOk || pullRequestPayload.ID == 0 || pullRequestPayload.ToRef.ID == "" || pullRequestPayload.FromRef.ID == "" { - aulogging.Logger.Ctx(ctx).Error().Printf("bad request while processing bitbucket webhook - got pull request %s with invalid info (%s) - ignoring webhook", operation, description) - return - } - aulogging.Logger.Ctx(ctx).Info().Printf("got pull request %s (%s)", operation, description) - - err := c.PRValidator.ValidatePullRequest(ctx, pullRequestPayload.ID, pullRequestPayload.ToRef.ID, pullRequestPayload.FromRef.ID) - if err != nil { - aulogging.Logger.Ctx(ctx).Error().WithErr(err).Printf("error while processing bitbucket webhook: pull request %s (%s): %s", operation, description, err.Error()) - return - } - - aulogging.Logger.Ctx(ctx).Info().Printf("successfully processed pull request %s (%s) event", operation, description) -} diff --git a/internal/web/server/server.go b/internal/web/server/server.go index d67d883..44a94d2 100644 --- a/internal/web/server/server.go +++ b/internal/web/server/server.go @@ -116,7 +116,7 @@ func (s *Impl) WireUp(ctx context.Context) { "GET /rest/api/v1/owners.*", "GET /rest/api/v1/services.*", "GET /rest/api/v1/repositories.*", - "POST /webhook", + "POST /webhooks/.*", "POST /webhook/bitbucket", // health (provides just up) "GET /", diff --git a/internal/web/util/paramhelper.go b/internal/web/util/paramhelper.go index 6bb1624..f8c29a0 100644 --- a/internal/web/util/paramhelper.go +++ b/internal/web/util/paramhelper.go @@ -3,11 +3,15 @@ package util import ( "context" "encoding/json" + "fmt" + "github.com/Interhyp/go-backend-service-common/acorns/repository" "github.com/Interhyp/go-backend-service-common/api/apierrors" "github.com/Interhyp/metadata-service/api" aulogging "github.com/StephanHCB/go-autumn-logging" "github.com/go-chi/chi/v5" "net/http" + "net/url" + "strings" "time" ) @@ -20,6 +24,14 @@ func StringQueryParam(r *http.Request, key string) string { return query.Get(key) } +func NonEmptyStringPathParam(_ context.Context, r *http.Request, key string, timestamp repository.Timestamp) (string, error) { + param, _ := url.QueryUnescape(chi.URLParam(r, key)) + if strings.TrimSpace(param) == "" { + return "", apierrors.NewBadRequestError("invalid.path.param", fmt.Sprintf("path param %s must be non empty", key), nil, timestamp.Now()) + } + return param, nil +} + func ParseBodyToDeletionDto(ctx context.Context, r *http.Request, timestamp time.Time) (openapi.DeletionDto, error) { decoder := json.NewDecoder(r.Body) dto := openapi.DeletionDto{} diff --git a/local-config.template.yaml b/local-config.template.yaml index 0692c28..8686730 100644 --- a/local-config.template.yaml +++ b/local-config.template.yaml @@ -32,10 +32,28 @@ VAULT_SECRETS_CONFIG: >- {"vaultKey": "KAFKA_PASSWORD"}, {"vaultKey": "METADATA_CHANGE_EVENTS_CONNECTION_STRING"}, {"vaultKey": "SSH_PRIVATE_KEY"}, - {"vaultKey": "SSH_PRIVATE_KEY_PASSWORD"} + {"vaultKey": "SSH_PRIVATE_KEY_PASSWORD"}, + {"vaultKey": "BITBUCKET_ACCESS_TOKEN"}, + {"vaultKey": "GITHUB_ACCESS_TOKEN"} ] } +VCS_CONFIGS: | + { + "bitbucket": { + "platform": "BITBUCKET_DATACENTER", + "apiBaseURL": , + "accessTokenEnvVar": "BITBUCKET_ACCESS_TOKEN" + }, + "github": { + "platform": "GITHUB", + "apiBaseURL": "https://api.github.com", + "accessTokenEnvVar": "GITHUB_ACCESS_TOKEN" + } + } + +WEBHOOKS_PROCESS_ASYNC: false + AUTH_OIDC_KEY_SET_URL: https://login.microsoftonline.com//discovery/v2.0/keys AUTH_OIDC_TOKEN_AUDIENCE: diff --git a/pkg/recorder/recorder.go b/pkg/recorder/recorder.go new file mode 100644 index 0000000..c8dd717 --- /dev/null +++ b/pkg/recorder/recorder.go @@ -0,0 +1,28 @@ +package recorder + +import ( + "crypto/md5" + "encoding/hex" + "fmt" + "net/url" + "strings" +) + +func ConstructFilenameV4(method string, requestUrl string, _ interface{}) (string, error) { + parsedUrl, err := url.Parse(requestUrl) + if err != nil { + return "", err + } + + m := strings.ToLower(method) + md5sumOverPath := md5.Sum([]byte(parsedUrl.EscapedPath())) + p := hex.EncodeToString(md5sumOverPath[:]) + p = p[:8] + // we have to ensure the filenames don't get too long. git for windows only supports 260 character paths + md5sumOverQuery := md5.Sum([]byte(parsedUrl.Query().Encode())) + q := hex.EncodeToString(md5sumOverQuery[:]) + q = q[:8] + + filename := fmt.Sprintf("request_%s_%s_%s.json", m, p, q) + return filename, nil +} diff --git a/test/acceptance/util_setup_test.go b/test/acceptance/util_setup_test.go index 0b38e06..83081db 100644 --- a/test/acceptance/util_setup_test.go +++ b/test/acceptance/util_setup_test.go @@ -2,25 +2,35 @@ package acceptance import ( "context" + "crypto/md5" + "encoding/hex" + "fmt" libconfig "github.com/Interhyp/go-backend-service-common/repository/config" "github.com/Interhyp/go-backend-service-common/repository/logging" "github.com/Interhyp/go-backend-service-common/repository/timestamp" "github.com/Interhyp/go-backend-service-common/web/middleware/security" + bitbucketclient "github.com/Interhyp/metadata-service/internal/client/bitbucket" + githubclient "github.com/Interhyp/metadata-service/internal/client/github" "github.com/Interhyp/metadata-service/internal/repository/config" "github.com/Interhyp/metadata-service/internal/repository/notifier" "github.com/Interhyp/metadata-service/internal/service/trigger" + "github.com/Interhyp/metadata-service/internal/service/vcswebhookshandler" "github.com/Interhyp/metadata-service/internal/web/app" - "github.com/Interhyp/metadata-service/internal/web/controller/webhookctl" "github.com/Interhyp/metadata-service/internal/web/server" - "github.com/Interhyp/metadata-service/test/mock/bitbucketmock" "github.com/Interhyp/metadata-service/test/mock/idpmock" "github.com/Interhyp/metadata-service/test/mock/kafkamock" "github.com/Interhyp/metadata-service/test/mock/metadatamock" "github.com/Interhyp/metadata-service/test/mock/notifiermock" "github.com/Interhyp/metadata-service/test/mock/vaultmock" auconfigenv "github.com/StephanHCB/go-autumn-config-env" + aurestcapture "github.com/StephanHCB/go-autumn-restclient/implementation/capture" + aurestplayback "github.com/StephanHCB/go-autumn-restclient/implementation/playback" + aurestrecorder "github.com/StephanHCB/go-autumn-restclient/implementation/recorder" "github.com/rs/zerolog/log" + "net/http" "net/http/httptest" + "net/url" + "strings" "time" ) @@ -40,7 +50,6 @@ var ( metadataImpl *metadatamock.Impl kafkaImpl *kafkamock.Impl idpImpl *idpmock.Impl - bbImpl *bitbucketmock.BitbucketMock notifierImpl *notifier.Impl application *ApplicationWithMocksImpl @@ -53,6 +62,36 @@ func fakeNow() time.Time { return time.Date(2022, 11, 6, 18, 14, 10, 0, time.UTC) } +func ConstructFilenameV4WithBody(method string, requestUrl string, body interface{}) (string, error) { + parsedUrl, err := url.Parse(requestUrl) + if err != nil { + return "", err + } + + m := strings.ToLower(method) + p := url.QueryEscape(parsedUrl.EscapedPath()) + if len(p) > 120 { + p = string([]byte(p)[:120]) + } + p = strings.ReplaceAll(p, "%2F", "-") + p = strings.TrimLeft(p, "-") + p = strings.TrimRight(p, "-") + + if body != nil { + parsedUrl.RawQuery = fmt.Sprintf("%v", body) + } else if parsedUrl.RawQuery != "" { + parsedUrl.RawQuery = fmt.Sprintf("%v", parsedUrl.Query()) + } + + // we have to ensure the filenames don't get too long. git for windows only supports 260 character paths + md5sumOverQuery := md5.Sum([]byte(parsedUrl.Query().Encode())) + q := hex.EncodeToString(md5sumOverQuery[:]) + q = q[:8] + + filename := fmt.Sprintf("request_%s_%s_%s.json", m, p, q) + return filename, nil +} + func (a *ApplicationWithMocksImpl) Create() error { a.ConstructConfigLoggingVaultTimestamp_ForTesting() @@ -60,12 +99,36 @@ func (a *ApplicationWithMocksImpl) Create() error { a.Metadata = metadataImpl a.Kafka = kafkaImpl a.IdentityProvider = idpImpl - a.Bitbucket = bbImpl // now can use normal construct functions, they respect the prefilled mocks if err := a.ConstructRepositories(); err != nil { return err } + + opts := aurestplayback.PlaybackOptions{ + ConstructFilenameCandidates: []aurestrecorder.ConstructFilenameFunction{ConstructFilenameV4WithBody}, + } + bitbucketPlayback := aurestplayback.New("../resources/recordings/bitbucket", opts) + bitbucketCapture := aurestcapture.New(bitbucketPlayback) + bitbucketClient, _ := bitbucketclient.NewClient("localhost", "access-token") + bitbucketClient.Client = bitbucketCapture + + githubPlayback := aurestplayback.New("../resources/recordings/github", opts) + githubCapture := aurestcapture.NewRoundTripper(githubPlayback) + client := http.Client{Transport: githubCapture} + githubClient, _ := githubclient.NewClient(&client, "access-token") + + vcsPlatforms := make(map[string]vcswebhookshandler.VCSPlatform) + vcsPlatforms["bitbucket_datacenter"] = vcswebhookshandler.VCSPlatform{ + Platform: 0, + VCS: bitbucketclient.New(bitbucketClient, nil), + } + vcsPlatforms["github"] = vcswebhookshandler.VCSPlatform{ + Platform: 1, + VCS: githubclient.New(githubClient, nil), + } + a.VCSPlatforms = &vcsPlatforms + if err := a.ConstructServices(); err != nil { return err } @@ -73,8 +136,6 @@ func (a *ApplicationWithMocksImpl) Create() error { return err } - a.WebhookCtl.(*webhookctl.Impl).EnableAsync = false - return nil } @@ -107,7 +168,6 @@ func tstSetup(configPath string) error { metadataImpl = metadatamock.New().(*metadatamock.Impl) kafkaImpl = kafkamock.New().(*kafkamock.Impl) idpImpl = idpmock.New().(*idpmock.Impl) - bbImpl = bitbucketmock.New().(*bitbucketmock.BitbucketMock) metadataImpl.Now = fakeNow @@ -173,7 +233,4 @@ func tstReset() { for _, client := range notifierImpl.Clients { client.(*notifiermock.NotifierClientMock).Reset() } - bbImpl.Recording = nil - bbImpl.PRHead = "" - bbImpl.ChangedFilesResponse = nil } diff --git a/test/acceptance/webhook_acc_test.go b/test/acceptance/webhook_bitbucket_acc_test.go similarity index 58% rename from test/acceptance/webhook_acc_test.go rename to test/acceptance/webhook_bitbucket_acc_test.go index 51d0743..d7370f0 100644 --- a/test/acceptance/webhook_acc_test.go +++ b/test/acceptance/webhook_bitbucket_acc_test.go @@ -4,7 +4,6 @@ import ( "bytes" "encoding/json" "github.com/Interhyp/go-backend-service-common/docs" - "github.com/Interhyp/metadata-service/internal/acorn/repository" bitbucketserver "github.com/go-playground/webhooks/v6/bitbucket-server" "github.com/stretchr/testify/require" "net/http" @@ -15,27 +14,6 @@ import ( func TestPOSTWebhookBitbucket_Success(t *testing.T) { tstReset() - docs.Given("Given a pull request in BitBucket with valid file edits") - bbImpl.PRHead = "e2d2000000000000000000000000000000000000" - bbImpl.ChangedFilesResponse = []repository.File{ - { - Path: "owners/fun-owner/owner.info.yaml", - Contents: `contact: someone@example.com -productOwner: someone -displayName: Test Owner`, - }, - { - Path: "owners/fun-owner/services/golang-forever.yaml", - Contents: `description: golang is the best -repositories: - - golang-forever/implementation -alertTarget: someone@example.com -developmentOnly: false -operationType: WORKLOAD -lifecycle: experimental`, - }, - } - docs.When("When BitBucket sends a webhook with valid payload") body := bitbucketserver.PullRequestOpenedPayload{ Date: bitbucketserver.Date(time.Now()), @@ -59,7 +37,7 @@ lifecycle: experimental`, } bodyBytes, err := json.Marshal(&body) require.Nil(t, err) - request, err := http.NewRequest(http.MethodPost, ts.URL+"/webhook/bitbucket", bytes.NewReader(bodyBytes)) + request, err := http.NewRequest(http.MethodPost, ts.URL+"/webhooks/vcs/bitbucket_datacenter", bytes.NewReader(bodyBytes)) require.Nil(t, err) request.Header.Set("X-Event-Key", string(bitbucketserver.PullRequestOpenedEvent)) rawResponse, err := http.DefaultClient.Do(request) @@ -69,27 +47,11 @@ lifecycle: experimental`, docs.Then("Then the request is successful") tstAssertNoBody(t, response, err, http.StatusNoContent) - - docs.Then("And the expected interactions with the BitBucket API have occurred") - require.EqualValues(t, []string{ - "GetChangedFilesOnPullRequest(42)", - "CreatePullRequestComment(42, all changed files are valid|)", - "AddCommitBuildStatus(e2d2000000000000000000000000000000000000, metadata-service, true)", - }, bbImpl.Recording) } func TestPOSTWebhookBitbucket_InvalidPR(t *testing.T) { tstReset() - docs.Given("Given a pull request in BitBucket with invalid file edits") - bbImpl.PRHead = "e2d2000000000000000000000000000000000000" - bbImpl.ChangedFilesResponse = []repository.File{ - { - Path: "owners/fun-owner/repositories/golang-forever.implementation.yaml", - Contents: `unknown: field`, - }, - } - docs.When("When BitBucket sends a webhook with valid payload") body := bitbucketserver.PullRequestOpenedPayload{ Date: bitbucketserver.Date(time.Now()), @@ -98,14 +60,14 @@ func TestPOSTWebhookBitbucket_InvalidPR(t *testing.T) { // don't care }, PullRequest: bitbucketserver.PullRequest{ - ID: 42, + ID: 43, Title: "some pr title", Description: "some pr description", FromRef: bitbucketserver.RepositoryReference{ - ID: "e2d2000000000000000000000000000000000000", // pr head + ID: "e2d3000000000000000000000000000000000000", // pr head }, ToRef: bitbucketserver.RepositoryReference{ - ID: "e100000000000000000000000000000000000000", // mainline + ID: "e200000000000000000000000000000000000000", // mainline }, Locked: false, Author: bitbucketserver.PullRequestParticipant{}, @@ -113,7 +75,7 @@ func TestPOSTWebhookBitbucket_InvalidPR(t *testing.T) { } bodyBytes, err := json.Marshal(&body) require.Nil(t, err) - request, err := http.NewRequest(http.MethodPost, ts.URL+"/webhook/bitbucket", bytes.NewReader(bodyBytes)) + request, err := http.NewRequest(http.MethodPost, ts.URL+"/webhooks/vcs/bitbucket_datacenter", bytes.NewReader(bodyBytes)) require.Nil(t, err) request.Header.Set("X-Event-Key", string(bitbucketserver.PullRequestOpenedEvent)) rawResponse, err := http.DefaultClient.Do(request) @@ -123,13 +85,6 @@ func TestPOSTWebhookBitbucket_InvalidPR(t *testing.T) { docs.Then("Then the request is successful") tstAssertNoBody(t, response, err, http.StatusNoContent) - - docs.Then("And the expected interactions with the BitBucket API have occurred") - require.EqualValues(t, []string{ - "GetChangedFilesOnPullRequest(42)", - "CreatePullRequestComment(42, # yaml validation failure||There were validation errors in changed files. Please fix yaml syntax and/or remove unknown fields:|| - failed to parse `owners/fun-owner/repositories/golang-forever.implementation.yaml`:| yaml: unmarshal errors:| line 1: field unknown not found in type openapi.RepositoryDto|)", - "AddCommitBuildStatus(e2d2000000000000000000000000000000000000, metadata-service, false)", - }, bbImpl.Recording) } func TestPOSTWebhookBitbucket_InvalidPayload(t *testing.T) { @@ -140,7 +95,7 @@ func TestPOSTWebhookBitbucket_InvalidPayload(t *testing.T) { docs.When("When they send a webhook with invalid payload") body := bitbucketserver.PullRequestOpenedPayload{} // hopefully invalid - response, err := tstPerformPost("/webhook/bitbucket", token, &body) + response, err := tstPerformPost("/webhooks/vcs/bitbucket_datacenter", token, &body) docs.Then("Then the request fails and the error response is as expected") tstAssert(t, response, err, http.StatusBadRequest, "webhook-invalid.json") diff --git a/test/acceptance/webhook_github_acc_test.go b/test/acceptance/webhook_github_acc_test.go new file mode 100644 index 0000000..f94f7c6 --- /dev/null +++ b/test/acceptance/webhook_github_acc_test.go @@ -0,0 +1,76 @@ +package acceptance + +import ( + "bytes" + "encoding/json" + "fmt" + "github.com/Interhyp/go-backend-service-common/docs" + "github.com/go-playground/webhooks/v6/github" + "github.com/stretchr/testify/require" + "net/http" + "testing" +) + +func TestPOSTWebhookGitHub_Success(t *testing.T) { + tstReset() + + docs.When("When GitHub sends a webhook with valid payload") + body := createGithubPullRequestPayload("refs/heads/test-test", "refs/heads/main") + + bodyBytes, err := json.Marshal(&body) + require.Nil(t, err) + request, err := http.NewRequest(http.MethodPost, ts.URL+"/webhooks/vcs/github", bytes.NewReader(bodyBytes)) + require.Nil(t, err) + request.Header.Set("X-GitHub-Event", string(github.PullRequestEvent)) + rawResponse, err := http.DefaultClient.Do(request) + require.Nil(t, err) + response, err := tstWebResponseFromResponse(rawResponse) + require.Nil(t, err) + + docs.Then("Then the request is successful") + tstAssertNoBody(t, response, err, http.StatusNoContent) +} + +func TestPOSTWebhookGitHub_InvalidPR(t *testing.T) { + tstReset() + + docs.When("When GitHub sends a webhook with valid payload") + body := createGithubPullRequestPayload("refs/heads/invalid-test", "refs/heads/main") + body.PullRequest.Number = 2222 + + bodyBytes, err := json.Marshal(&body) + require.Nil(t, err) + request, err := http.NewRequest(http.MethodPost, ts.URL+"/webhooks/vcs/github", bytes.NewReader(bodyBytes)) + require.Nil(t, err) + request.Header.Set("X-GitHub-Event", string(github.PullRequestEvent)) + rawResponse, err := http.DefaultClient.Do(request) + require.Nil(t, err) + response, err := tstWebResponseFromResponse(rawResponse) + require.Nil(t, err) + + docs.Then("Then the request is successful") + tstAssertNoBody(t, response, err, http.StatusNoContent) +} + +func TestPOSTWebhookGitHub_InvalidPayload(t *testing.T) { + tstReset() + + docs.When("When they send a webhook with invalid payload") + request, err := http.NewRequest(http.MethodPost, ts.URL+"/webhooks/vcs/github", bytes.NewReader([]byte(""))) + require.Nil(t, err) + request.Header.Set("X-GitHub-Event", string(github.PullRequestEvent)) + rawResponse, err := http.DefaultClient.Do(request) + require.Nil(t, err) + response, err := tstWebResponseFromResponse(rawResponse) + require.Nil(t, err) + + docs.Then("Then the request fails and the error response is as expected") + tstAssert(t, response, err, http.StatusBadRequest, "webhook-invalid.json") +} + +func createGithubPullRequestPayload(fromRef string, toRef string) github.PullRequestPayload { + s := fmt.Sprintf(`{"action": "opened", "pull_request": {"number": 4711, "head": {"sha": "%s"}, "base": {"sha": "%s"}}, "repository": {"name": "some-repo", "ssh_url": "ssh://git@github.com:Someorg/some-service-deployment.git", "owner": {"login": "some-org"}}}`, fromRef, toRef) + data := github.PullRequestPayload{} + _ = json.Unmarshal([]byte(s), &data) + return data +} diff --git a/test/mock/bbclientmock/bbclientmock.go b/test/mock/bbclientmock/bbclientmock.go deleted file mode 100644 index 381db61..0000000 --- a/test/mock/bbclientmock/bbclientmock.go +++ /dev/null @@ -1,64 +0,0 @@ -package bbclientmock - -import ( - "context" - "errors" - "github.com/Interhyp/metadata-service/internal/acorn/errors/httperror" - "github.com/Interhyp/metadata-service/internal/acorn/repository" - "github.com/Interhyp/metadata-service/internal/repository/bitbucket/bbclientint" - "strings" -) - -const NOT_EXISITNG_USER = "notexistinguser" -const HTTP_ERROR_USER = "httperroruser" -const OTHER_ERROR_USER = "othererroruser" - -func MockBitbucketUser() repository.BitbucketUser { - return repository.BitbucketUser{ - Id: 1234, - Name: "mock-user", - } -} - -type BitbucketClientMock struct { -} - -func (m *BitbucketClientMock) GetBitbucketUser(ctx context.Context, username string) (repository.BitbucketUser, error) { - if strings.EqualFold(username, NOT_EXISITNG_USER) { - return repository.BitbucketUser{}, httperror.New(context.Background(), "not-found", 404) - } - if strings.EqualFold(username, HTTP_ERROR_USER) { - return repository.BitbucketUser{}, httperror.New(context.Background(), "http-error", 502) - } - if strings.EqualFold(username, OTHER_ERROR_USER) { - return repository.BitbucketUser{}, errors.New("some-error") - } - return MockBitbucketUser(), nil -} - -func (m *BitbucketClientMock) Setup() error { - return nil -} - -func (c *BitbucketClientMock) GetPullRequest(ctx context.Context, projectKey string, repositorySlug string, pullRequestId int32) (bbclientint.PullRequest, error) { - response := bbclientint.PullRequest{} - return response, nil -} - -func (c *BitbucketClientMock) GetChanges(ctx context.Context, projectKey string, repositorySlug string, sinceHash string, untilHash string) (bbclientint.Changes, error) { - response := bbclientint.Changes{} - return response, nil -} - -func (c *BitbucketClientMock) GetFileContentsAt(ctx context.Context, projectKey string, repositorySlug string, atHash string, path string) (string, error) { - return "", nil -} - -func (c *BitbucketClientMock) AddProjectRepositoryCommitBuildStatus(ctx context.Context, projectKey string, repositorySlug string, commitId string, commitBuildStatusRequest bbclientint.CommitBuildStatusRequest) error { - return nil -} - -func (c *BitbucketClientMock) CreatePullRequestComment(ctx context.Context, projectKey string, repositorySlug string, pullRequestId int64, pullRequestCommentRequest bbclientint.PullRequestCommentRequest) (bbclientint.PullRequestComment, error) { - response := bbclientint.PullRequestComment{} - return response, nil -} diff --git a/test/mock/bitbucketmock/bitbucketmock.go b/test/mock/bitbucketmock/bitbucketmock.go deleted file mode 100644 index db5d722..0000000 --- a/test/mock/bitbucketmock/bitbucketmock.go +++ /dev/null @@ -1,71 +0,0 @@ -package bitbucketmock - -import ( - "context" - "fmt" - "github.com/Interhyp/metadata-service/internal/acorn/repository" - "github.com/pkg/errors" - "strings" -) - -const FILTER_FAILED_USERNAME = "filterfailedusername" - -type BitbucketMock struct { - ChangedFilesResponse []repository.File - PRHead string - Recording []string -} - -func New() repository.Bitbucket { - return &BitbucketMock{} -} - -func (b *BitbucketMock) IsBitbucket() bool { - return true -} - -func (b *BitbucketMock) Setup() error { - return nil -} - -func (b *BitbucketMock) SetupClient(ctx context.Context) error { - return nil -} - -func (b *BitbucketMock) GetBitbucketUser(ctx context.Context, username string) (repository.BitbucketUser, error) { - return repository.BitbucketUser{ - Name: username, - }, nil -} - -func (b *BitbucketMock) GetBitbucketUsers(ctx context.Context, usernames []string) ([]repository.BitbucketUser, error) { - result := []repository.BitbucketUser{} - for _, username := range usernames { - result = append(result, repository.BitbucketUser{ - Name: username, - }) - } - return result, nil -} - -func (b *BitbucketMock) FilterExistingUsernames(ctx context.Context, usernames []string) ([]string, error) { - if usernames[0] == FILTER_FAILED_USERNAME { - return []string{}, errors.New("error") - } - return usernames, nil -} - -func (b *BitbucketMock) GetChangedFilesOnPullRequest(ctx context.Context, pullRequestId int) ([]repository.File, string, error) { - b.Recording = append(b.Recording, fmt.Sprintf("GetChangedFilesOnPullRequest(%d)", pullRequestId)) - return b.ChangedFilesResponse, b.PRHead, nil -} - -func (b *BitbucketMock) AddCommitBuildStatus(ctx context.Context, commitHash string, url string, key string, success bool) error { - b.Recording = append(b.Recording, fmt.Sprintf("AddCommitBuildStatus(%s, %s, %t)", commitHash, key, success)) - return nil -} - -func (b *BitbucketMock) CreatePullRequestComment(ctx context.Context, pullRequestId int, comment string) error { - b.Recording = append(b.Recording, fmt.Sprintf("CreatePullRequestComment(%d, %s)", pullRequestId, strings.ReplaceAll(comment, "\n", "|"))) - return nil -} diff --git a/test/mock/configmock/configmock.go b/test/mock/configmock/configmock.go index b47829b..9eb8688 100644 --- a/test/mock/configmock/configmock.go +++ b/test/mock/configmock/configmock.go @@ -10,6 +10,20 @@ import ( type MockConfig struct { } +func (c *MockConfig) UserPrefix() string { + return "" +} + +func (c *MockConfig) VCSConfigs() map[string]config.VCSConfig { + //TODO implement me + panic("implement me") +} + +func (c *MockConfig) WebhooksProcessAsync() bool { + //TODO implement me + panic("implement me") +} + func (c *MockConfig) BasicAuthUsername() string { //TODO implement me panic("implement me") diff --git a/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-browse-owners-invalid-test-owner-dev-owner.in_f3eebb5a.json b/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-browse-owners-invalid-test-owner-dev-owner.in_f3eebb5a.json new file mode 100644 index 0000000..2741a55 --- /dev/null +++ b/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-browse-owners-invalid-test-owner-dev-owner.in_f3eebb5a.json @@ -0,0 +1,32 @@ +{ + "method": "GET", + "requestUrl": "localhost/rest/api/latest/projects/er/repos/metadata/browse/owners/test-owner-dev/owner.info.yaml?at=0221b127f58baf5304d98b1fa7a2535f8db68583", + "requestBody": "", + "parsedResponse": { + "Body": { + "lines": [ + { + "text": "contact: email@localhost.com" + }, + { + "text": "productOwner: po-user" + }, + { + "text": "invalid:" + }, + { + "text": " yaml:" + } + ], + "start": 0, + "size": 16, + "isLastPage": true, + "limit": 500, + "nextPageStart": null + }, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-browse-owners-test-owner-dev-owner.info.yaml_af2c6e55.json b/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-browse-owners-test-owner-dev-owner.info.yaml_af2c6e55.json new file mode 100644 index 0000000..7f91a21 --- /dev/null +++ b/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-browse-owners-test-owner-dev-owner.info.yaml_af2c6e55.json @@ -0,0 +1,56 @@ +{ + "method": "GET", + "requestUrl": "localhost/rest/api/latest/projects/er/repos/metadata/browse/owners/test-owner-dev/owner.info.yaml?at=0221b127f58baf5304d98b1fa7a2535f8db68583", + "requestBody": "", + "parsedResponse": { + "Body": { + "lines": [ + { + "text": "contact: email@localhost.com" + }, + { + "text": "productOwner: po-user" + }, + { + "text": "groups:" + }, + { + "text": " users:" + }, + { + "text": " - user-one" + }, + { + "text": " - user-two" + }, + { + "text": " - user-three" + }, + { + "text": "defaultJiraProject: some-project" + }, + { + "text": "displayName: some owner" + }, + { + "text": "links:" + }, + { + "text": " - url: www.google.com" + }, + { + "text": " title: \"Google\"" + } + ], + "start": 0, + "size": 16, + "isLastPage": true, + "limit": 500, + "nextPageStart": null + }, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-changes_2f22d5d3.json b/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-changes_2f22d5d3.json new file mode 100644 index 0000000..9369fe8 --- /dev/null +++ b/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-changes_2f22d5d3.json @@ -0,0 +1,53 @@ +{ + "method": "GET", + "requestUrl": "localhost/rest/api/latest/projects/er/repos/metadata/changes?limit=1000&since=85dcfccd2b20b6766c497f51bd860d7509b68f99&start=0&until=0221b127f58baf5304d98b1fa7a2535f8db68599", + "requestBody": "", + "parsedResponse": { + "Body": { + "fromHash": "85dcfccd2b20b6766c497f51bd860d7509b68f10", + "toHash": "0221b127f58baf5304d98b1fa7a2535f8db68583", + "properties": {}, + "values": [ + { + "contentId": "87fd90378563c17945e02f5fa3793e3b888614ed", + "fromContentId": "1528215b49816a19356b86bfdb6e22aaf9b821c7", + "path": { + "components": [ + "owners", + "invalid-test-owner-dev", + "owner.info.yaml" + ], + "parent": "owners/invalid-test-owner-dev", + "name": "owner.info.yaml", + "extension": "yaml", + "toString": "owners/invalid-test-owner-dev/owner.info.yaml" + }, + "executable": false, + "percentUnchanged": -1, + "type": "MODIFY", + "nodeType": "FILE", + "srcExecutable": false, + "links": { + "self": [ + { + "href": "https://localhost.com/bitbucket/projects/ER/repos/metadata/commits/0221b127f58baf5304d98b1fa7a2535f8db68583#owners/test-owner-dev/owner.info.yaml" + } + ] + }, + "properties": { + "gitChangeType": "MODIFY" + } + } + ], + "size": 1, + "isLastPage": true, + "start": 0, + "limit": 1000, + "nextPageStart": null + }, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-changes_af2c6e55.json b/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-changes_af2c6e55.json new file mode 100644 index 0000000..38c1550 --- /dev/null +++ b/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-changes_af2c6e55.json @@ -0,0 +1,53 @@ +{ + "method": "GET", + "requestUrl": "localhost/rest/api/latest/projects/er/repos/metadata/changes?limit=1000&since=85dcfccd2b20b6766c497f51bd860d7509b68f10&start=0&until=0221b127f58baf5304d98b1fa7a2535f8db68583", + "requestBody": "", + "parsedResponse": { + "Body": { + "fromHash": "85dcfccd2b20b6766c497f51bd860d7509b68f10", + "toHash": "0221b127f58baf5304d98b1fa7a2535f8db68583", + "properties": {}, + "values": [ + { + "contentId": "87fd90378563c17945e02f5fa3793e3b888614ed", + "fromContentId": "1528215b49816a19356b86bfdb6e22aaf9b821c7", + "path": { + "components": [ + "owners", + "test-owner-dev", + "owner.info.yaml" + ], + "parent": "owners/test-owner-dev", + "name": "owner.info.yaml", + "extension": "yaml", + "toString": "owners/test-owner-dev/owner.info.yaml" + }, + "executable": false, + "percentUnchanged": -1, + "type": "MODIFY", + "nodeType": "FILE", + "srcExecutable": false, + "links": { + "self": [ + { + "href": "https://localhost.com/bitbucket/projects/ER/repos/metadata/commits/0221b127f58baf5304d98b1fa7a2535f8db68583#owners/test-owner-dev/owner.info.yaml" + } + ] + }, + "properties": { + "gitChangeType": "MODIFY" + } + } + ], + "size": 1, + "isLastPage": true, + "start": 0, + "limit": 1000, + "nextPageStart": null + }, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-pull-requests-42_af2c6e55.json b/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-pull-requests-42_af2c6e55.json new file mode 100644 index 0000000..5ba5b7d --- /dev/null +++ b/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-pull-requests-42_af2c6e55.json @@ -0,0 +1,153 @@ +{ + "method": "GET", + "requestUrl": "localhost/rest/api/latest/projects/er/repos/metadata/pull-requests/42", + "requestBody": "", + "parsedResponse": { + "Body": { + "id": 64, + "version": 0, + "title": "test", + "state": "OPEN", + "open": true, + "closed": false, + "draft": false, + "createdDate": 1729835672873, + "updatedDate": 1729835672873, + "fromRef": { + "id": "refs/heads/feature-branch", + "displayId": "feature-branch", + "latestCommit": "0221b127f58baf5304d98b1fa7a2535f8db68583", + "type": "BRANCH", + "repository": { + "slug": "metadata", + "id": 3882, + "name": "metadata", + "hierarchyId": "467081fc5f57deed19c4", + "scmId": "git", + "state": "AVAILABLE", + "statusMessage": "Available", + "forkable": true, + "project": { + "key": "ER", + "id": 125, + "name": "er", + "description": "ER", + "public": false, + "type": "NORMAL", + "links": { + "self": [ + { + "href": "localhost/bitbucket/projects/ER" + } + ] + } + }, + "public": false, + "archived": false, + "links": { + "clone": [ + { + "href": "ssh://git@localhost.com:7999/er/metadata.git", + "name": "ssh" + }, + { + "href": "https://localhost.com/bitbucket/scm/er/metadata.git", + "name": "http" + } + ], + "self": [ + { + "href": "https://localhost.com/bitbucket/projects/ER/repos/metadata/browse" + } + ] + } + } + }, + "toRef": { + "id": "refs/heads/main", + "displayId": "main", + "latestCommit": "85dcfccd2b20b6766c497f51bd860d7509b68f10", + "type": "BRANCH", + "repository": { + "slug": "metadata", + "id": 3882, + "name": "metadata", + "hierarchyId": "467081fc5f57deed19c4", + "scmId": "git", + "state": "AVAILABLE", + "statusMessage": "Available", + "forkable": true, + "project": { + "key": "ER", + "id": 125, + "name": "Projekt: Entwicklungs-und Releasetechnologie", + "description": "Repositories im Bereich ER", + "public": false, + "type": "NORMAL", + "links": { + "self": [ + { + "href": "https://localhost.com/bitbucket/projects/ER" + } + ] + } + }, + "public": false, + "archived": false, + "links": { + "clone": [ + { + "href": "ssh://git@localhost.com:7999/er/metadata.git", + "name": "ssh" + }, + { + "href": "https://localhost.com/bitbucket/scm/er/metadata.git", + "name": "http" + } + ], + "self": [ + { + "href": "https://localhost.com/bitbucket/projects/ER/repos/metadata/browse" + } + ] + } + } + }, + "locked": false, + "author": { + "user": { + "name": "some-user", + "emailAddress": "some-user@localhost.com", + "active": true, + "displayName": "User, Some", + "id": 305, + "slug": "some-user", + "type": "NORMAL", + "links": { + "self": [ + { + "href": "https://localhost.com/bitbucket/users/some-user" + } + ] + } + }, + "role": "AUTHOR", + "approved": false, + "status": "UNAPPROVED" + }, + "reviewers": [], + "participants": [], + "links": { + "self": [ + { + "href": "https://localhost.com/bitbucket/projects/ER/repos/metadata/pull-requests/64" + } + ] + } + }, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-pull-requests-43_d41d8cd9.json b/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-pull-requests-43_d41d8cd9.json new file mode 100644 index 0000000..518acad --- /dev/null +++ b/test/resources/recordings/bitbucket/request_get_localhost-rest-api-latest-projects-er-repos-metadata-pull-requests-43_d41d8cd9.json @@ -0,0 +1,153 @@ +{ + "method": "GET", + "requestUrl": "localhost/rest/api/latest/projects/er/repos/metadata/pull-requests/43", + "requestBody": "", + "parsedResponse": { + "Body": { + "id": 64, + "version": 0, + "title": "test", + "state": "OPEN", + "open": true, + "closed": false, + "draft": false, + "createdDate": 1729835672873, + "updatedDate": 1729835672873, + "fromRef": { + "id": "refs/heads/feature-branch", + "displayId": "feature-branch", + "latestCommit": "0221b127f58baf5304d98b1fa7a2535f8db68599", + "type": "BRANCH", + "repository": { + "slug": "metadata", + "id": 3882, + "name": "metadata", + "hierarchyId": "467081fc5f57deed19c4", + "scmId": "git", + "state": "AVAILABLE", + "statusMessage": "Available", + "forkable": true, + "project": { + "key": "ER", + "id": 125, + "name": "er", + "description": "ER", + "public": false, + "type": "NORMAL", + "links": { + "self": [ + { + "href": "localhost/bitbucket/projects/ER" + } + ] + } + }, + "public": false, + "archived": false, + "links": { + "clone": [ + { + "href": "ssh://git@localhost.com:7999/er/metadata.git", + "name": "ssh" + }, + { + "href": "https://localhost.com/bitbucket/scm/er/metadata.git", + "name": "http" + } + ], + "self": [ + { + "href": "https://localhost.com/bitbucket/projects/ER/repos/metadata/browse" + } + ] + } + } + }, + "toRef": { + "id": "refs/heads/main", + "displayId": "main", + "latestCommit": "85dcfccd2b20b6766c497f51bd860d7509b68f99", + "type": "BRANCH", + "repository": { + "slug": "metadata", + "id": 3882, + "name": "metadata", + "hierarchyId": "467081fc5f57deed19c4", + "scmId": "git", + "state": "AVAILABLE", + "statusMessage": "Available", + "forkable": true, + "project": { + "key": "ER", + "id": 125, + "name": "Projekt: Entwicklungs-und Releasetechnologie", + "description": "Repositories im Bereich ER", + "public": false, + "type": "NORMAL", + "links": { + "self": [ + { + "href": "https://localhost.com/bitbucket/projects/ER" + } + ] + } + }, + "public": false, + "archived": false, + "links": { + "clone": [ + { + "href": "ssh://git@localhost.com:7999/er/metadata.git", + "name": "ssh" + }, + { + "href": "https://localhost.com/bitbucket/scm/er/metadata.git", + "name": "http" + } + ], + "self": [ + { + "href": "https://localhost.com/bitbucket/projects/ER/repos/metadata/browse" + } + ] + } + } + }, + "locked": false, + "author": { + "user": { + "name": "some-user", + "emailAddress": "some-user@localhost.com", + "active": true, + "displayName": "User, Some", + "id": 305, + "slug": "some-user", + "type": "NORMAL", + "links": { + "self": [ + { + "href": "https://localhost.com/bitbucket/users/some-user" + } + ] + } + }, + "role": "AUTHOR", + "approved": false, + "status": "UNAPPROVED" + }, + "reviewers": [], + "participants": [], + "links": { + "self": [ + { + "href": "https://localhost.com/bitbucket/projects/ER/repos/metadata/pull-requests/64" + } + ] + } + }, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/bitbucket/request_post_localhost-rest-api-latest-projects-er-repos-metadata-commits-0221b127f58baf5304d98b1fa7a2535f8db68583%_80a97784.json b/test/resources/recordings/bitbucket/request_post_localhost-rest-api-latest-projects-er-repos-metadata-commits-0221b127f58baf5304d98b1fa7a2535f8db68583%_80a97784.json new file mode 100644 index 0000000..6e0a34b --- /dev/null +++ b/test/resources/recordings/bitbucket/request_post_localhost-rest-api-latest-projects-er-repos-metadata-commits-0221b127f58baf5304d98b1fa7a2535f8db68583%_80a97784.json @@ -0,0 +1,12 @@ +{ + "method": "POST", + "requestUrl": "localhost/rest/api/latest/projects/er/repos/metadata/commits/0221b127f58baf5304d98b1fa7a2535f8db68583/builds", + "requestBody": "BUILD STATUS SUCCESS", + "parsedResponse": { + "Body": {}, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/bitbucket/request_post_localhost-rest-api-latest-projects-er-repos-metadata-commits-0221b127f58baf5304d98b1fa7a2535f8db68599%_d8910681.json b/test/resources/recordings/bitbucket/request_post_localhost-rest-api-latest-projects-er-repos-metadata-commits-0221b127f58baf5304d98b1fa7a2535f8db68599%_d8910681.json new file mode 100644 index 0000000..75aaa8d --- /dev/null +++ b/test/resources/recordings/bitbucket/request_post_localhost-rest-api-latest-projects-er-repos-metadata-commits-0221b127f58baf5304d98b1fa7a2535f8db68599%_d8910681.json @@ -0,0 +1,12 @@ +{ + "method": "POST", + "requestUrl": "localhost/rest/api/latest/projects/er/repos/metadata/commits/0221b127f58baf5304d98b1fa7a2535f8db68599/builds", + "requestBody": "BUILD STATUS FAILED", + "parsedResponse": { + "Body": {}, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/bitbucket/request_post_localhost-rest-api-latest-projects-er-repos-metadata-pull-requests-43-comments_79cafa3f.json b/test/resources/recordings/bitbucket/request_post_localhost-rest-api-latest-projects-er-repos-metadata-pull-requests-43-comments_79cafa3f.json new file mode 100644 index 0000000..050377c --- /dev/null +++ b/test/resources/recordings/bitbucket/request_post_localhost-rest-api-latest-projects-er-repos-metadata-pull-requests-43-comments_79cafa3f.json @@ -0,0 +1,9 @@ +{ + "method": "GET", + "requestUrl": "localhost/rest/api/latest/projects/er/repos/metadata/pull-requests/43/comments", + "requestBody": "COMMENT yaml parse error", + "parsedResponse": {}, + "Status": 200, + "Header": {}, + "Time": "2024-10-22T11:29:55.5326883+02:00" +} \ No newline at end of file diff --git a/test/resources/recordings/github/request_get_repos-er-metadata-contents-owners-invalid-owner-dev-owner.info.yaml_72764a5f.json b/test/resources/recordings/github/request_get_repos-er-metadata-contents-owners-invalid-owner-dev-owner.info.yaml_72764a5f.json new file mode 100644 index 0000000..3c303f3 --- /dev/null +++ b/test/resources/recordings/github/request_get_repos-er-metadata-contents-owners-invalid-owner-dev-owner.info.yaml_72764a5f.json @@ -0,0 +1,29 @@ +{ + "method": "GET", + "requestUrl": "https://api.github.com/repos/er/metadata/contents/owners/invalid-owner-dev/owner.info.yaml?ref=refs%2Fheads%2Finvalid-test", + "requestBody": "{}", + "parsedResponse": { + "Body": { + "name": "owner.info.yaml", + "path": "owners/invalid-owner-dev/owner.info.yaml", + "sha": "1528215b49816a19356b86bfdb6e22aaf9b821c7", + "size": 332, + "url": "https://api.github.com/repos/interhyp-intern-test/service-metadata-test/contents/owners/invalid-owner-dev/owner.info.yaml?ref=e0d0a175f0a00cdc650be862b21563212ac28a85", + "html_url": "https://github.com/interhyp-intern-test/service-metadata-test/blob/e0d0a175f0a00cdc650be862b21563212ac28a85/owners/test-owner-dev/owner.info.yaml", + "git_url": "https://api.github.com/repos/interhyp-intern-test/service-metadata-test/git/blobs/1528215b49816a19356b86bfdb6e22aaf9b821c7", + "download_url": "https://raw.githubusercontent.com/interhyp-intern-test/service-metadata-test/e0d0a175f0a00cdc650be862b21563212ac28a85/owners/test-owner-dev/owner.info.yaml?token=BL6UMW7QPSOKPXX5UCAWRS3HD5FE2", + "type": "file", + "content": "Y29udGFjdDogZW1haWxAZG9tYWluLmNvbQpwcm9kdWN0T3duZXI6IHNvbWUtcHJvZHVjdC1vd25lcgppbnZhbGlkOgogICAgeApkaXNwbGF5TmFtZTogVGVzdCBPd25lciBEZXYK", + "encoding": "base64", + "_links": { + "self": "https://api.github.com/repos/interhyp-intern-test/service-metadata-test/contents/owners/invalid-owner-dev/owner.info.yaml?ref=e0d0a175f0a00cdc650be862b21563212ac28a85", + "git": "https://api.github.com/repos/interhyp-intern-test/service-metadata-test/git/blobs/1528215b49816a19356b86bfdb6e22aaf9b821c7", + "html": "https://github.com/interhyp-intern-test/service-metadata-test/blob/e0d0a175f0a00cdc650be862b21563212ac28a85/owners/test-owner-dev/owner.info.yaml" + } + }, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/github/request_get_repos-er-metadata-contents-owners-test-owner-dev-owner.info.yaml_5ca2d2ab.json b/test/resources/recordings/github/request_get_repos-er-metadata-contents-owners-test-owner-dev-owner.info.yaml_5ca2d2ab.json new file mode 100644 index 0000000..fbaab3f --- /dev/null +++ b/test/resources/recordings/github/request_get_repos-er-metadata-contents-owners-test-owner-dev-owner.info.yaml_5ca2d2ab.json @@ -0,0 +1,29 @@ +{ + "method": "GET", + "requestUrl": "https://api.github.com/repos/er/metadata/contents/owners/test-owner-dev/owner.info.yaml?ref=refs%2Fheads%2Ftest-test", + "requestBody": "{}", + "parsedResponse": { + "Body": { + "name": "owner.info.yaml", + "path": "owners/test-owner-dev/owner.info.yaml", + "sha": "1528215b49816a19356b86bfdb6e22aaf9b821c7", + "size": 332, + "url": "https://api.github.com/repos/interhyp-intern-test/service-metadata-test/contents/owners/test-owner-dev/owner.info.yaml?ref=e0d0a175f0a00cdc650be862b21563212ac28a85", + "html_url": "https://github.com/interhyp-intern-test/service-metadata-test/blob/e0d0a175f0a00cdc650be862b21563212ac28a85/owners/test-owner-dev/owner.info.yaml", + "git_url": "https://api.github.com/repos/interhyp-intern-test/service-metadata-test/git/blobs/1528215b49816a19356b86bfdb6e22aaf9b821c7", + "download_url": "https://raw.githubusercontent.com/interhyp-intern-test/service-metadata-test/e0d0a175f0a00cdc650be862b21563212ac28a85/owners/test-owner-dev/owner.info.yaml?token=BL6UMW7QPSOKPXX5UCAWRS3HD5FE2", + "type": "file", + "content": "Y29udGFjdDogZW1haWxAZG9tYWluLmNvbQpwcm9kdWN0T3duZXI6IHNvbWUtcHJvZHVjdC1vd25lcgpncm91cHM6CiAgICB1c2VyczoKICAgICAgICAtIHNvbWUtdXNlci0yCiAgICAgICAgLSBzb21lLXVzZXItMQpkaXNwbGF5TmFtZTogVGVzdCBPd25lciBEZXYK", + "encoding": "base64", + "_links": { + "self": "https://api.github.com/repos/interhyp-intern-test/service-metadata-test/contents/owners/test-owner-dev/owner.info.yaml?ref=e0d0a175f0a00cdc650be862b21563212ac28a85", + "git": "https://api.github.com/repos/interhyp-intern-test/service-metadata-test/git/blobs/1528215b49816a19356b86bfdb6e22aaf9b821c7", + "html": "https://github.com/interhyp-intern-test/service-metadata-test/blob/e0d0a175f0a00cdc650be862b21563212ac28a85/owners/test-owner-dev/owner.info.yaml" + } + }, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/github/request_get_repos-er-metadata-pulls-2222-files_d41d8cd9.json b/test/resources/recordings/github/request_get_repos-er-metadata-pulls-2222-files_d41d8cd9.json new file mode 100644 index 0000000..0885931 --- /dev/null +++ b/test/resources/recordings/github/request_get_repos-er-metadata-pulls-2222-files_d41d8cd9.json @@ -0,0 +1,25 @@ +{ + "method": "GET", + "requestUrl": "https://api.github.com/repos/er/metadata/pulls/2222/files", + "requestBody": "{}", + "parsedResponse": { + "Body": [ + { + "sha": "b74b0f278e8a8c0c8ae4265cc48c48e8a5b2df42", + "filename": "owners/invalid-owner-dev/owner.info.yaml", + "status": "modified", + "additions": 2, + "deletions": 0, + "changes": 2, + "blob_url": "https://github.com/org/service-metadata-test/blob/48f93f1a77fbe613e5333ae24485ad0e7467f20f/owners%2Ftest-owner-dev%2Fowner.info.yaml", + "raw_url": "https://github.com/org/service-metadata-test/raw/48f93f1a77fbe613e5333ae24485ad0e7467f20f/owners%2Ftest-owner-dev%2Fowner.info.yaml", + "contents_url": "https://api.github.com/repos/org/service-metadata-test/contents/invalid%2Ftest-owner-dev%2Fowner.info.yaml?ref=48f93f1a77fbe613e5333ae24485ad0e7467f20f", + "patch": "@@ -12,3 +12,5 @@ displayName: Test Owner Dev\n links:\n - invalid: tps://domain.com/bitbucket/dashboard\n title: \"BitBucket\"\n+ - url: asdf\n+ title: asdfasdf" + } + ], + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/github/request_get_repos-er-metadata-pulls-4711-files_d41d8cd9.json b/test/resources/recordings/github/request_get_repos-er-metadata-pulls-4711-files_d41d8cd9.json new file mode 100644 index 0000000..7f91320 --- /dev/null +++ b/test/resources/recordings/github/request_get_repos-er-metadata-pulls-4711-files_d41d8cd9.json @@ -0,0 +1,25 @@ +{ + "method": "GET", + "requestUrl": "https://api.github.com/repos/er/metadata/pulls/4711/files", + "requestBody": "{}", + "parsedResponse": { + "Body": [ + { + "sha": "b74b0f278e8a8c0c8ae4265cc48c48e8a5b2df42", + "filename": "owners/test-owner-dev/owner.info.yaml", + "status": "modified", + "additions": 2, + "deletions": 0, + "changes": 2, + "blob_url": "https://github.com/org/service-metadata-test/blob/48f93f1a77fbe613e5333ae24485ad0e7467f20f/owners%2Ftest-owner-dev%2Fowner.info.yaml", + "raw_url": "https://github.com/org/service-metadata-test/raw/48f93f1a77fbe613e5333ae24485ad0e7467f20f/owners%2Ftest-owner-dev%2Fowner.info.yaml", + "contents_url": "https://api.github.com/repos/org/service-metadata-test/contents/owners%2Ftest-owner-dev%2Fowner.info.yaml?ref=48f93f1a77fbe613e5333ae24485ad0e7467f20f", + "patch": "@@ -12,3 +12,5 @@ displayName: Test Owner Dev\n links:\n - url: tps://domain.com/bitbucket/dashboard\n title: \"BitBucket\"\n+ - url: asdf\n+ title: asdfasdf" + } + ], + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/github/request_post_repos-er-metadata-issues-2222-comments_eaea79c9.json b/test/resources/recordings/github/request_post_repos-er-metadata-issues-2222-comments_eaea79c9.json new file mode 100644 index 0000000..4ed9836 --- /dev/null +++ b/test/resources/recordings/github/request_post_repos-er-metadata-issues-2222-comments_eaea79c9.json @@ -0,0 +1,12 @@ +{ + "method": "POST", + "requestUrl": "https://api.github.com/repos/er/metadata/issues/2222/comments", + "requestBody": "COMMENT FAILURE", + "parsedResponse": { + "Body": {}, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/github/request_post_repos-er-metadata-issues-4711-comments_8e21cef7.json b/test/resources/recordings/github/request_post_repos-er-metadata-issues-4711-comments_8e21cef7.json new file mode 100644 index 0000000..aa68c20 --- /dev/null +++ b/test/resources/recordings/github/request_post_repos-er-metadata-issues-4711-comments_8e21cef7.json @@ -0,0 +1,12 @@ +{ + "method": "POST", + "requestUrl": "https://api.github.com/repos/er/metadata/issues/4711/comments", + "requestBody": "COMMENT SUCCESS", + "parsedResponse": { + "Body": {}, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/github/request_post_repos-er-metadata-statuses-refs-heads-invalid-test_83d7174b.json b/test/resources/recordings/github/request_post_repos-er-metadata-statuses-refs-heads-invalid-test_83d7174b.json new file mode 100644 index 0000000..a18ccf6 --- /dev/null +++ b/test/resources/recordings/github/request_post_repos-er-metadata-statuses-refs-heads-invalid-test_83d7174b.json @@ -0,0 +1,12 @@ +{ + "method": "POST", + "requestUrl": "https://api.github.com/repos/er/metadata/statuses/refs/heads/invalid-test", + "requestBody": "BUILD STATUS SUCCESS", + "parsedResponse": { + "Body": {}, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/github/request_post_repos-er-metadata-statuses-refs-heads-invalid-test_f0014e19.json b/test/resources/recordings/github/request_post_repos-er-metadata-statuses-refs-heads-invalid-test_f0014e19.json new file mode 100644 index 0000000..b23f3f5 --- /dev/null +++ b/test/resources/recordings/github/request_post_repos-er-metadata-statuses-refs-heads-invalid-test_f0014e19.json @@ -0,0 +1,12 @@ +{ + "method": "POST", + "requestUrl": "https://api.github.com/repos/er/metadata/statuses/refs/heads/invalid-test", + "requestBody": "BUILD STATUS FAILED", + "parsedResponse": { + "Body": {}, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/github/request_post_repos-er-metadata-statuses-refs-heads-test-test_4ace4d3f.json b/test/resources/recordings/github/request_post_repos-er-metadata-statuses-refs-heads-test-test_4ace4d3f.json new file mode 100644 index 0000000..48bddf9 --- /dev/null +++ b/test/resources/recordings/github/request_post_repos-er-metadata-statuses-refs-heads-test-test_4ace4d3f.json @@ -0,0 +1,12 @@ +{ + "method": "POST", + "requestUrl": "https://api.github.com/repos/er/metadata/statuses/refs/heads/test-test", + "requestBody": "BUILD STATUS SUCCESS", + "parsedResponse": { + "Body": {}, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file diff --git a/test/resources/recordings/github/request_post_repos-er-metadata-statuses-refs-heads-test-test_83d7174b.json b/test/resources/recordings/github/request_post_repos-er-metadata-statuses-refs-heads-test-test_83d7174b.json new file mode 100644 index 0000000..bbe74c5 --- /dev/null +++ b/test/resources/recordings/github/request_post_repos-er-metadata-statuses-refs-heads-test-test_83d7174b.json @@ -0,0 +1,12 @@ +{ + "method": "POST", + "requestUrl": "https://api.github.com/repos/er/metadata/statuses/refs/heads/test-test", + "requestBody": "BUILD STATUS IN-PROGRESS", + "parsedResponse": { + "Body": {}, + "Status": 200, + "Header": { + }, + "Time": "2024-10-22T11:29:55.5326883+02:00" + } +} \ No newline at end of file