diff --git a/.copywrite.hcl b/.copywrite.hcl
new file mode 100644
index 00000000..b26d46f2
--- /dev/null
+++ b/.copywrite.hcl
@@ -0,0 +1,24 @@
+# NOTE: This file is for HashiCorp specific licensing automation and can be deleted after creating a new repo with this template.
+schema_version = 1
+
+project {
+ license = "Apache-2.0"
+ copyright_year = 2025
+
+ header_ignore = [
+ # internal catalog metadata (prose)
+ "META.d/**/*.yaml",
+
+ # examples used within documentation (prose)
+ "examples/**",
+
+ # GitHub issue template configuration
+ ".github/ISSUE_TEMPLATE/*.yml",
+
+ # golangci-lint tooling configuration
+ ".golangci.yml",
+
+ # GoReleaser tooling configuration
+ ".goreleaser.yml",
+ ]
+}
diff --git a/.github/actions/build/action.yaml b/.github/actions/build/action.yaml
index 3601b23f..c5e5becd 100644
--- a/.github/actions/build/action.yaml
+++ b/.github/actions/build/action.yaml
@@ -1,3 +1,5 @@
+# Copyright (c) STACKIT
+
name: Build
description: "Build pipeline"
inputs:
diff --git a/.github/docs/contribution-guide/resource.go b/.github/docs/contribution-guide/resource.go
index 3d604d11..7dedfa12 100644
--- a/.github/docs/contribution-guide/resource.go
+++ b/.github/docs/contribution-guide/resource.go
@@ -1,3 +1,5 @@
+// Copyright (c) STACKIT
+
package foo
import (
diff --git a/.github/docs/contribution-guide/utils/util.go b/.github/docs/contribution-guide/utils/util.go
index bc58a48d..61ee7257 100644
--- a/.github/docs/contribution-guide/utils/util.go
+++ b/.github/docs/contribution-guide/utils/util.go
@@ -1,3 +1,5 @@
+// Copyright (c) STACKIT
+
package utils
import (
diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci.yaml
index ae3117ea..bbd69400 100644
--- a/.github/workflows/ci.yaml
+++ b/.github/workflows/ci.yaml
@@ -8,7 +8,7 @@ on:
- main
env:
- GO_VERSION: "1.24"
+ GO_VERSION: "1.25"
CODE_COVERAGE_FILE_NAME: "coverage.out" # must be the same as in Makefile
CODE_COVERAGE_ARTIFACT_NAME: "code-coverage"
@@ -33,6 +33,17 @@ jobs:
- name: "Ensure docs are up-to-date"
if: ${{ github.event_name == 'pull_request' }}
run: ./scripts/check-docs.sh
+ continue-on-error: true
+
+ - name: "Run go mod tidy"
+ if: ${{ github.event_name == 'pull_request' }}
+ run: go mod tidy
+
+ - name: golangci-lint
+ uses: golangci/golangci-lint-action@v9
+ with:
+ version: v2.7
+ args: --config=golang-ci.yaml --allow-parallel-runners --timeout=5m
- name: Lint
run: make lint
@@ -40,7 +51,6 @@ jobs:
- name: Test
run: make test
-
- name: Archive code coverage results
uses: actions/upload-artifact@v4
with:
diff --git a/.github/workflows/publish.yaml b/.github/workflows/publish.yaml
new file mode 100644
index 00000000..53ab6dff
--- /dev/null
+++ b/.github/workflows/publish.yaml
@@ -0,0 +1,124 @@
+name: Publish
+
+on:
+ workflow_dispatch:
+ push:
+ tags:
+ - 'v0.*'
+
+env:
+ GO_VERSION: "1.25"
+ CODE_COVERAGE_FILE_NAME: "coverage.out" # must be the same as in Makefile
+ CODE_COVERAGE_ARTIFACT_NAME: "code-coverage"
+
+jobs:
+ config:
+ name: Check GoReleaser config
+ if: github.event_name == 'workflow_dispatch' || (github.event_name == 'push' && contains(github.ref, 'refs/tags/'))
+ runs-on: ubuntu-latest
+ steps:
+ - name: Checkout
+ uses: actions/checkout@v6
+
+ - name: Check GoReleaser
+ uses: goreleaser/goreleaser-action@v6
+ with:
+ args: check
+
+ publish:
+ name: "Publish provider"
+ if: github.event_name == 'workflow_dispatch' || (github.event_name == 'push' && contains(github.ref, 'refs/tags/'))
+ needs: config
+ runs-on: ubuntu-latest
+ permissions:
+ actions: read # Required to identify workflow run.
+ checks: write # Required to add status summary.
+ contents: read # Required to checkout repository.
+ pull-requests: write # Required to add PR comment.
+ steps:
+ - name: Install needed tools
+ run: |
+ apt-get -y -qq update
+ apt-get -y -qq install jq python3 python3-pip python-is-python3 s3cmd git make wget
+
+ - name: Checkout
+ uses: actions/checkout@v6
+
+ - name: Install Go ${{ env.GO_VERSION }}
+ uses: actions/setup-go@v6
+ with:
+ go-version: ${{ env.GO_VERSION }}
+
+ - name: Install go tools
+ run: |
+ go install golang.org/x/tools/cmd/goimports@latest
+ go install github.com/hashicorp/terraform-plugin-codegen-framework/cmd/tfplugingen-framework@latest
+ go install github.com/hashicorp/terraform-plugin-codegen-openapi/cmd/tfplugingen-openapi@latest
+
+ - uses: actions/setup-java@v5
+ with:
+ distribution: 'temurin' # See 'Supported distributions' for available options
+ java-version: '21'
+
+ - name: Run build pkg directory
+ run: |
+ go run cmd/main.go build
+
+ - name: Set up s3cfg
+ run: |
+ cat <<'EOF' >> ~/.s3cfg
+ [default]
+ host_base = https://object.storage.eu01.onstackit.cloud
+ host_bucket = https://%(bucket).object.storage.eu01.onstackit.cloud
+ check_ssl_certificate = False
+ access_key = ${{ secrets.S3_ACCESS_KEY }}
+ secret_key = ${{ secrets.S3_SECRET_KEY }}
+ EOF
+
+ - name: Import GPG key
+ run: |
+ gpg --import private.key
+
+ - name: Run GoReleaser
+ if: github.event_name == 'workflow_dispatch'
+ id: goreleaser
+ env:
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
+ GPG_FINGERPRINT: ${{ secrets.GPG_FINGERPRINT }}
+ uses: goreleaser/goreleaser-action@v6
+ with:
+ args: release --skip publish --clean --snapshot
+
+ - name: Run GoReleaser
+ if: github.event_name != 'workflow_dispatch'
+ id: goreleaser
+ env:
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
+ GPG_FINGERPRINT: ${{ secrets.GPG_FINGERPRINT }}
+ uses: goreleaser/goreleaser-action@v6
+ with:
+ args: release --skip publish --clean
+
+ - name: Prepare key file
+ run: |
+ echo $(echo ${{ secrets.KEY_FILE_B64 }} | base64 -d) >public_key.pem
+
+ - name: Prepare provider directory structure
+ run: |
+ VERSION=$(jq -r .version < dist/metadata.json)
+ go run cmd/main.go \
+ publish \
+ --namespace=mhenselin \
+ --providerName=stackitprivatepreview \
+ --repoName=terraform-provider-stackitprivatepreview \
+ --domain=tfregistry.sysops.stackit.rocks \
+ --gpgFingerprint=${{ secrets.GPG_FINGERPRINT }} \
+ --gpgPubKeyFile=public_key.pem \
+ --version=${VERSION}
+
+ - name: Publish provider to S3
+ run: |
+ set -e
+ cd release/
+ s3cmd put --recursive v1 s3://terraform-provider-privatepreview/
+ s3cmd put --recursive .well-known s3://terraform-provider-privatepreview/
diff --git a/.goreleaser.yaml b/.goreleaser.yaml
index 6483bfb0..55baab60 100644
--- a/.goreleaser.yaml
+++ b/.goreleaser.yaml
@@ -1,4 +1,4 @@
-# Copyright (c) HashiCorp, Inc.
+# Copyright (c) STACKIT
# SPDX-License-Identifier: MPL-2.0
# Visit https://goreleaser.com for documentation on how to customize this
diff --git a/Makefile b/Makefile
index 38b7abfd..cdcc36b2 100644
--- a/Makefile
+++ b/Makefile
@@ -25,7 +25,7 @@ generate-docs:
@$(SCRIPTS_BASE)/tfplugindocs.sh
build:
- @go build -o bin/terraform-provider-stackit
+ @go build -o bin/terraform-provider-stackitalpha
fmt:
@gofmt -s -w .
diff --git a/docs/data-sources/sqlserverflexalpha_user.md b/docs/data-sources/sqlserverflexalpha_user.md
new file mode 100644
index 00000000..5e646af1
--- /dev/null
+++ b/docs/data-sources/sqlserverflexalpha_user.md
@@ -0,0 +1,46 @@
+---
+# generated by https://github.com/hashicorp/terraform-plugin-docs
+page_title: "stackitprivatepreview_sqlserverflexalpha_user Data Source - stackitprivatepreview"
+subcategory: ""
+description: |-
+ SQLServer Flex user data source schema. Must have a region specified in the provider configuration.
+---
+
+# stackitprivatepreview_sqlserverflexalpha_user (Data Source)
+
+SQLServer Flex user data source schema. Must have a `region` specified in the provider configuration.
+
+## Example Usage
+
+```terraform
+# Copyright (c) STACKIT
+
+data "stackitprivatepreview_sqlserverflexalpha_user" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ instance_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ user_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+}
+```
+
+
+## Schema
+
+### Required
+
+- `instance_id` (String) ID of the SQLServer Flex instance.
+- `project_id` (String) STACKIT project ID to which the instance is associated.
+- `user_id` (Number) User ID.
+
+### Optional
+
+- `region` (String) The resource region. If not defined, the provider region is used.
+
+### Read-Only
+
+- `default_database` (String)
+- `host` (String)
+- `id` (String) Terraform's internal data source. ID. It is structured as "`project_id`,`region`,`instance_id`,`user_id`".
+- `port` (Number)
+- `roles` (Set of String) Database access levels for the user.
+- `status` (String)
+- `username` (String) Username of the SQLServer Flex instance.
diff --git a/docs/index.md b/docs/index.md
new file mode 100644
index 00000000..10a64dc1
--- /dev/null
+++ b/docs/index.md
@@ -0,0 +1,86 @@
+---
+# generated by https://github.com/hashicorp/terraform-plugin-docs
+page_title: "stackitprivatepreview Provider"
+description: |-
+
+---
+
+# stackitprivatepreview Provider
+
+
+
+## Example Usage
+
+```terraform
+# Copyright (c) STACKIT
+
+provider "stackitprivatepreview" {
+ default_region = "eu01"
+}
+
+# Authentication
+
+# Token flow (scheduled for deprecation and will be removed on December 17, 2025)
+provider "stackitprivatepreview" {
+ default_region = "eu01"
+ service_account_token = var.service_account_token
+}
+
+# Key flow
+provider "stackitprivatepreview" {
+ default_region = "eu01"
+ service_account_key = var.service_account_key
+ private_key = var.private_key
+}
+
+# Key flow (using path)
+provider "stackitprivatepreview" {
+ default_region = "eu01"
+ service_account_key_path = var.service_account_key_path
+ private_key_path = var.private_key_path
+}
+```
+
+
+## Schema
+
+### Optional
+
+- `authorization_custom_endpoint` (String) Custom endpoint for the Membership service
+- `cdn_custom_endpoint` (String) Custom endpoint for the CDN service
+- `credentials_path` (String) Path of JSON from where the credentials are read. Takes precedence over the env var `STACKIT_CREDENTIALS_PATH`. Default value is `~/.stackit/credentials.json`.
+- `default_region` (String) Region will be used as the default location for regional services. Not all services require a region, some are global
+- `dns_custom_endpoint` (String) Custom endpoint for the DNS service
+- `enable_beta_resources` (Boolean) Enable beta resources. Default is false.
+- `experiments` (List of String) Enables experiments. These are unstable features without official support. More information can be found in the README. Available Experiments: iam, routing-tables, network
+- `git_custom_endpoint` (String) Custom endpoint for the Git service
+- `iaas_custom_endpoint` (String) Custom endpoint for the IaaS service
+- `kms_custom_endpoint` (String) Custom endpoint for the KMS service
+- `loadbalancer_custom_endpoint` (String) Custom endpoint for the Load Balancer service
+- `logme_custom_endpoint` (String) Custom endpoint for the LogMe service
+- `mariadb_custom_endpoint` (String) Custom endpoint for the MariaDB service
+- `modelserving_custom_endpoint` (String) Custom endpoint for the AI Model Serving service
+- `mongodbflex_custom_endpoint` (String) Custom endpoint for the MongoDB Flex service
+- `objectstorage_custom_endpoint` (String) Custom endpoint for the Object Storage service
+- `observability_custom_endpoint` (String) Custom endpoint for the Observability service
+- `opensearch_custom_endpoint` (String) Custom endpoint for the OpenSearch service
+- `postgresflex_custom_endpoint` (String) Custom endpoint for the PostgresFlex service
+- `private_key` (String) Private RSA key used for authentication, relevant for the key flow. It takes precedence over the private key that is included in the service account key.
+- `private_key_path` (String) Path for the private RSA key used for authentication, relevant for the key flow. It takes precedence over the private key that is included in the service account key.
+- `rabbitmq_custom_endpoint` (String) Custom endpoint for the RabbitMQ service
+- `redis_custom_endpoint` (String) Custom endpoint for the Redis service
+- `region` (String, Deprecated) Region will be used as the default location for regional services. Not all services require a region, some are global
+- `resourcemanager_custom_endpoint` (String) Custom endpoint for the Resource Manager service
+- `scf_custom_endpoint` (String) Custom endpoint for the Cloud Foundry (SCF) service
+- `secretsmanager_custom_endpoint` (String) Custom endpoint for the Secrets Manager service
+- `server_backup_custom_endpoint` (String) Custom endpoint for the Server Backup service
+- `server_update_custom_endpoint` (String) Custom endpoint for the Server Update service
+- `service_account_custom_endpoint` (String) Custom endpoint for the Service Account service
+- `service_account_email` (String, Deprecated) Service account email. It can also be set using the environment variable STACKIT_SERVICE_ACCOUNT_EMAIL. It is required if you want to use the resource manager project resource.
+- `service_account_key` (String) Service account key used for authentication. If set, the key flow will be used to authenticate all operations.
+- `service_account_key_path` (String) Path for the service account key used for authentication. If set, the key flow will be used to authenticate all operations.
+- `service_account_token` (String, Deprecated) Token used for authentication. If set, the token flow will be used to authenticate all operations.
+- `service_enablement_custom_endpoint` (String) Custom endpoint for the Service Enablement API
+- `ske_custom_endpoint` (String) Custom endpoint for the Kubernetes Engine (SKE) service
+- `sqlserverflex_custom_endpoint` (String) Custom endpoint for the SQL Server Flex service
+- `token_custom_endpoint` (String) Custom endpoint for the token API, which is used to request access tokens when using the key flow
diff --git a/docs/resources/postgresflexalpha_instance.md b/docs/resources/postgresflexalpha_instance.md
new file mode 100644
index 00000000..64878367
--- /dev/null
+++ b/docs/resources/postgresflexalpha_instance.md
@@ -0,0 +1,106 @@
+---
+# generated by https://github.com/hashicorp/terraform-plugin-docs
+page_title: "stackitprivatepreview_postgresflexalpha_instance Resource - stackitprivatepreview"
+subcategory: ""
+description: |-
+ Postgres Flex instance resource schema. Must have a region specified in the provider configuration.
+---
+
+# stackitprivatepreview_postgresflexalpha_instance (Resource)
+
+Postgres Flex instance resource schema. Must have a `region` specified in the provider configuration.
+
+## Example Usage
+
+```terraform
+# Copyright (c) STACKIT
+
+resource "stackitprivatepreview_postgresflexalpha_instance" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ name = "example-instance"
+ acl = ["XXX.XXX.XXX.X/XX", "XX.XXX.XX.X/XX"]
+ backup_schedule = "00 00 * * *"
+ flavor = {
+ cpu = 2
+ ram = 4
+ }
+ replicas = 3
+ storage = {
+ class = "class"
+ size = 5
+ }
+ version = 14
+}
+
+# Only use the import statement, if you want to import an existing postgresflex instance
+import {
+ to = stackitprivatepreview_postgresflexalpha_instance.import-example
+ id = "${var.project_id},${var.region},${var.postgres_instance_id}"
+}
+```
+
+
+## Schema
+
+### Required
+
+- `acl` (List of String) The Access Control List (ACL) for the PostgresFlex instance.
+- `backup_schedule` (String)
+- `encryption` (Attributes) The encryption block. (see [below for nested schema](#nestedatt--encryption))
+- `flavor` (Attributes) (see [below for nested schema](#nestedatt--flavor))
+- `name` (String) Instance name.
+- `network` (Attributes) (see [below for nested schema](#nestedatt--network))
+- `project_id` (String) STACKIT project ID to which the instance is associated.
+- `replicas` (Number)
+- `storage` (Attributes) (see [below for nested schema](#nestedatt--storage))
+- `version` (String)
+
+### Optional
+
+- `region` (String) The resource region. If not defined, the provider region is used.
+
+### Read-Only
+
+- `id` (String) Terraform's internal resource ID. It is structured as "`project_id`,`region`,`instance_id`".
+- `instance_id` (String) ID of the PostgresFlex instance.
+
+
+### Nested Schema for `encryption`
+
+Required:
+
+- `key_id` (String) Key ID of the encryption key.
+- `key_ring_id` (String)
+- `key_version` (String)
+- `service_account` (String)
+
+
+
+### Nested Schema for `flavor`
+
+Required:
+
+- `cpu` (Number)
+- `ram` (Number)
+
+Read-Only:
+
+- `description` (String)
+- `id` (String)
+
+
+
+### Nested Schema for `network`
+
+Required:
+
+- `access_scope` (String)
+
+
+
+### Nested Schema for `storage`
+
+Required:
+
+- `class` (String)
+- `size` (Number)
diff --git a/docs/resources/sqlserverflexalpha_user.md b/docs/resources/sqlserverflexalpha_user.md
new file mode 100644
index 00000000..1554ad07
--- /dev/null
+++ b/docs/resources/sqlserverflexalpha_user.md
@@ -0,0 +1,54 @@
+---
+# generated by https://github.com/hashicorp/terraform-plugin-docs
+page_title: "stackitprivatepreview_sqlserverflexalpha_user Resource - stackitprivatepreview"
+subcategory: ""
+description: |-
+ SQLServer Flex user resource schema. Must have a region specified in the provider configuration.
+---
+
+# stackitprivatepreview_sqlserverflexalpha_user (Resource)
+
+SQLServer Flex user resource schema. Must have a `region` specified in the provider configuration.
+
+## Example Usage
+
+```terraform
+# Copyright (c) STACKIT
+
+resource "stackitprivatepreview_sqlserverflexalpha_user" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ instance_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ username = "username"
+ roles = ["role"]
+}
+
+# Only use the import statement, if you want to import an existing sqlserverflex user
+import {
+ to = stackitprivatepreview_sqlserverflexalpha_user.import-example
+ id = "${var.project_id},${var.region},${var.sql_instance_id},${var.sql_user_id}"
+}
+```
+
+
+## Schema
+
+### Required
+
+- `instance_id` (String) ID of the SQLServer Flex instance.
+- `project_id` (String) STACKIT project ID to which the instance is associated.
+- `roles` (Set of String) Database access levels for the user. The values for the default roles are: `##STACKIT_DatabaseManager##`, `##STACKIT_LoginManager##`, `##STACKIT_ProcessManager##`, `##STACKIT_ServerManager##`, `##STACKIT_SQLAgentManager##`, `##STACKIT_SQLAgentUser##`
+- `username` (String) Username of the SQLServer Flex instance.
+
+### Optional
+
+- `region` (String)
+
+### Read-Only
+
+- `default_database` (String)
+- `host` (String)
+- `id` (String) Terraform's internal resource ID. It is structured as "`project_id`,`region`,`instance_id`,`user_id`".
+- `password` (String, Sensitive) Password of the user account.
+- `port` (Number)
+- `status` (String)
+- `user_id` (String) User ID.
diff --git a/examples/data-sources/stackitprivatepreview_postgresflexalpha_database/data-source.tf b/examples/data-sources/stackitprivatepreview_postgresflexalpha_database/data-source.tf
new file mode 100644
index 00000000..81f069ff
--- /dev/null
+++ b/examples/data-sources/stackitprivatepreview_postgresflexalpha_database/data-source.tf
@@ -0,0 +1,7 @@
+# Copyright (c) STACKIT
+
+data "stackitprivatepreview_postgresflexalpha_database" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ instance_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ database_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+}
diff --git a/examples/data-sources/stackitprivatepreview_postgresflexalpha_instance/data-source.tf b/examples/data-sources/stackitprivatepreview_postgresflexalpha_instance/data-source.tf
new file mode 100644
index 00000000..6485022a
--- /dev/null
+++ b/examples/data-sources/stackitprivatepreview_postgresflexalpha_instance/data-source.tf
@@ -0,0 +1,6 @@
+# Copyright (c) STACKIT
+
+data "stackitprivatepreview_postgresflexalpha_instance" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ instance_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+}
diff --git a/examples/data-sources/stackitprivatepreview_postgresflexalpha_user/data-source.tf b/examples/data-sources/stackitprivatepreview_postgresflexalpha_user/data-source.tf
new file mode 100644
index 00000000..eed426b2
--- /dev/null
+++ b/examples/data-sources/stackitprivatepreview_postgresflexalpha_user/data-source.tf
@@ -0,0 +1,7 @@
+# Copyright (c) STACKIT
+
+data "stackitprivatepreview_postgresflexalpha_user" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ instance_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ user_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+}
diff --git a/examples/data-sources/stackitprivatepreview_sqlserverflexalpha_instance/data-source.tf b/examples/data-sources/stackitprivatepreview_sqlserverflexalpha_instance/data-source.tf
new file mode 100644
index 00000000..75779eac
--- /dev/null
+++ b/examples/data-sources/stackitprivatepreview_sqlserverflexalpha_instance/data-source.tf
@@ -0,0 +1,6 @@
+# Copyright (c) STACKIT
+
+data "stackitprivatepreview_sqlserverflexalpha_instance" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ instance_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+}
diff --git a/examples/data-sources/stackitprivatepreview_sqlserverflexalpha_user/data-source.tf b/examples/data-sources/stackitprivatepreview_sqlserverflexalpha_user/data-source.tf
new file mode 100644
index 00000000..8ba5af78
--- /dev/null
+++ b/examples/data-sources/stackitprivatepreview_sqlserverflexalpha_user/data-source.tf
@@ -0,0 +1,7 @@
+# Copyright (c) STACKIT
+
+data "stackitprivatepreview_sqlserverflexalpha_user" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ instance_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ user_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+}
diff --git a/examples/provider/provider.tf b/examples/provider/provider.tf
new file mode 100644
index 00000000..85a2a39b
--- /dev/null
+++ b/examples/provider/provider.tf
@@ -0,0 +1,28 @@
+# Copyright (c) STACKIT
+
+provider "stackitprivatepreview" {
+ default_region = "eu01"
+}
+
+# Authentication
+
+# Token flow (scheduled for deprecation and will be removed on December 17, 2025)
+provider "stackitprivatepreview" {
+ default_region = "eu01"
+ service_account_token = var.service_account_token
+}
+
+# Key flow
+provider "stackitprivatepreview" {
+ default_region = "eu01"
+ service_account_key = var.service_account_key
+ private_key = var.private_key
+}
+
+# Key flow (using path)
+provider "stackitprivatepreview" {
+ default_region = "eu01"
+ service_account_key_path = var.service_account_key_path
+ private_key_path = var.private_key_path
+}
+
diff --git a/examples/resources/stackitprivatepreview_postgresflexalpha_database/resource.tf b/examples/resources/stackitprivatepreview_postgresflexalpha_database/resource.tf
new file mode 100644
index 00000000..4dac8bfe
--- /dev/null
+++ b/examples/resources/stackitprivatepreview_postgresflexalpha_database/resource.tf
@@ -0,0 +1,14 @@
+# Copyright (c) STACKIT
+
+resource "stackitprivatepreview_postgresflexalpha_database" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ instance_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ name = "mydb"
+ owner = "myusername"
+}
+
+# Only use the import statement, if you want to import an existing postgresflex database
+import {
+ to = stackitprivatepreview_postgresflexalpha_database.import-example
+ id = "${var.project_id},${var.region},${var.postgres_instance_id},${var.postgres_database_id}"
+}
\ No newline at end of file
diff --git a/examples/resources/stackitprivatepreview_postgresflexalpha_instance/resource.tf b/examples/resources/stackitprivatepreview_postgresflexalpha_instance/resource.tf
new file mode 100644
index 00000000..e65f8073
--- /dev/null
+++ b/examples/resources/stackitprivatepreview_postgresflexalpha_instance/resource.tf
@@ -0,0 +1,24 @@
+# Copyright (c) STACKIT
+
+resource "stackitprivatepreview_postgresflexalpha_instance" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ name = "example-instance"
+ acl = ["XXX.XXX.XXX.X/XX", "XX.XXX.XX.X/XX"]
+ backup_schedule = "00 00 * * *"
+ flavor = {
+ cpu = 2
+ ram = 4
+ }
+ replicas = 3
+ storage = {
+ class = "class"
+ size = 5
+ }
+ version = 14
+}
+
+# Only use the import statement, if you want to import an existing postgresflex instance
+import {
+ to = stackitprivatepreview_postgresflexalpha_instance.import-example
+ id = "${var.project_id},${var.region},${var.postgres_instance_id}"
+}
\ No newline at end of file
diff --git a/examples/resources/stackitprivatepreview_postgresflexalpha_user/resource.tf b/examples/resources/stackitprivatepreview_postgresflexalpha_user/resource.tf
new file mode 100644
index 00000000..5ab8c922
--- /dev/null
+++ b/examples/resources/stackitprivatepreview_postgresflexalpha_user/resource.tf
@@ -0,0 +1,14 @@
+# Copyright (c) STACKIT
+
+resource "stackitprivatepreview_postgresflexalpha_user" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ instance_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ username = "username"
+ roles = ["role"]
+}
+
+# Only use the import statement, if you want to import an existing postgresflex user
+import {
+ to = stackitprivatepreview_postgresflexalpha_user.import-example
+ id = "${var.project_id},${var.region},${var.postgres_instance_id},${var.user_id}"
+}
\ No newline at end of file
diff --git a/examples/resources/stackitprivatepreview_sqlserverflexalpha_instance/resource.tf b/examples/resources/stackitprivatepreview_sqlserverflexalpha_instance/resource.tf
new file mode 100644
index 00000000..059948d0
--- /dev/null
+++ b/examples/resources/stackitprivatepreview_sqlserverflexalpha_instance/resource.tf
@@ -0,0 +1,23 @@
+# Copyright (c) STACKIT
+
+resource "stackitprivatepreview_sqlserverflexalpha_instance" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ name = "example-instance"
+ acl = ["XXX.XXX.XXX.X/XX", "XX.XXX.XX.X/XX"]
+ backup_schedule = "00 00 * * *"
+ flavor = {
+ cpu = 4
+ ram = 16
+ }
+ storage = {
+ class = "class"
+ size = 5
+ }
+ version = 2022
+}
+
+# Only use the import statement, if you want to import an existing sqlserverflex instance
+import {
+ to = stackitprivatepreview_sqlserverflexalpha_instance.import-example
+ id = "${var.project_id},${var.region},${var.sql_instance_id}"
+}
diff --git a/examples/resources/stackitprivatepreview_sqlserverflexalpha_user/resource.tf b/examples/resources/stackitprivatepreview_sqlserverflexalpha_user/resource.tf
new file mode 100644
index 00000000..b328576c
--- /dev/null
+++ b/examples/resources/stackitprivatepreview_sqlserverflexalpha_user/resource.tf
@@ -0,0 +1,14 @@
+# Copyright (c) STACKIT
+
+resource "stackitprivatepreview_sqlserverflexalpha_user" "example" {
+ project_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ instance_id = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
+ username = "username"
+ roles = ["role"]
+}
+
+# Only use the import statement, if you want to import an existing sqlserverflex user
+import {
+ to = stackitprivatepreview_sqlserverflexalpha_user.import-example
+ id = "${var.project_id},${var.region},${var.sql_instance_id},${var.sql_user_id}"
+}
\ No newline at end of file
diff --git a/go.mod b/go.mod
new file mode 100644
index 00000000..d3409ce0
--- /dev/null
+++ b/go.mod
@@ -0,0 +1,156 @@
+module github.com/stackitcloud/terraform-provider-stackit
+
+go 1.24.0
+
+require (
+ github.com/google/go-cmp v0.7.0
+ github.com/google/uuid v1.6.0
+ github.com/gorilla/mux v1.8.1
+ github.com/hashicorp/terraform-plugin-framework v1.17.0
+ github.com/hashicorp/terraform-plugin-framework-validators v0.19.0
+ github.com/hashicorp/terraform-plugin-go v0.29.0
+ github.com/hashicorp/terraform-plugin-log v0.10.0
+ github.com/hashicorp/terraform-plugin-testing v1.14.0
+ github.com/stackitcloud/stackit-sdk-go/core v0.20.1
+ github.com/stackitcloud/stackit-sdk-go/services/cdn v1.6.0
+ github.com/stackitcloud/stackit-sdk-go/services/dns v0.17.1
+ github.com/stackitcloud/stackit-sdk-go/services/git v0.8.0
+ github.com/stackitcloud/stackit-sdk-go/services/iaas v1.3.0
+ github.com/stackitcloud/stackit-sdk-go/services/iaasalpha v0.1.21-alpha
+ github.com/stackitcloud/stackit-sdk-go/services/kms v1.0.0
+ github.com/stackitcloud/stackit-sdk-go/services/loadbalancer v1.6.0
+ github.com/stackitcloud/stackit-sdk-go/services/logme v0.25.1
+ github.com/stackitcloud/stackit-sdk-go/services/mariadb v0.25.1
+ github.com/stackitcloud/stackit-sdk-go/services/modelserving v0.6.0
+ github.com/stackitcloud/stackit-sdk-go/services/mongodbflex v1.5.2
+ github.com/stackitcloud/stackit-sdk-go/services/objectstorage v1.4.0
+ github.com/stackitcloud/stackit-sdk-go/services/observability v0.15.0
+ github.com/stackitcloud/stackit-sdk-go/services/opensearch v0.24.1
+ github.com/stackitcloud/stackit-sdk-go/services/postgresflex v1.2.1
+ github.com/stackitcloud/stackit-sdk-go/services/rabbitmq v0.25.1
+ github.com/stackitcloud/stackit-sdk-go/services/redis v0.25.1
+ github.com/stackitcloud/stackit-sdk-go/services/resourcemanager v0.18.2
+ github.com/stackitcloud/stackit-sdk-go/services/scf v0.2.1
+ github.com/stackitcloud/stackit-sdk-go/services/secretsmanager v0.13.1
+ github.com/stackitcloud/stackit-sdk-go/services/serverbackup v1.3.2
+ github.com/stackitcloud/stackit-sdk-go/services/serverupdate v1.2.1
+ github.com/stackitcloud/stackit-sdk-go/services/serviceaccount v0.11.1
+ github.com/stackitcloud/stackit-sdk-go/services/serviceenablement v1.2.2
+ github.com/stackitcloud/stackit-sdk-go/services/ske v1.4.0
+ github.com/stackitcloud/stackit-sdk-go/services/sqlserverflex v1.3.3
+ github.com/teambition/rrule-go v1.8.2
+ golang.org/x/mod v0.31.0
+)
+
+require (
+ github.com/AlecAivazis/survey/v2 v2.3.7 // indirect
+ github.com/BurntSushi/toml v1.2.1 // indirect
+ github.com/Kunde21/markdownfmt/v3 v3.1.0 // indirect
+ github.com/Masterminds/goutils v1.1.1 // indirect
+ github.com/Masterminds/semver/v3 v3.2.0 // indirect
+ github.com/Masterminds/sprig/v3 v3.2.3 // indirect
+ github.com/armon/go-radix v1.0.0 // indirect
+ github.com/asaskevich/govalidator v0.0.0-20200907205600-7a23bdc65eef // indirect
+ github.com/bgentry/speakeasy v0.1.0 // indirect
+ github.com/bmatcuk/doublestar/v4 v4.9.1 // indirect
+ github.com/bradleyfalzon/ghinstallation/v2 v2.5.0 // indirect
+ github.com/cli/go-gh/v2 v2.11.2 // indirect
+ github.com/cli/safeexec v1.0.0 // indirect
+ github.com/fsnotify/fsnotify v1.5.4 // indirect
+ github.com/go-openapi/errors v0.20.2 // indirect
+ github.com/go-openapi/strfmt v0.21.3 // indirect
+ github.com/golang-jwt/jwt/v4 v4.5.1 // indirect
+ github.com/google/go-github/v45 v45.2.0 // indirect
+ github.com/google/go-github/v53 v53.0.0 // indirect
+ github.com/google/go-querystring v1.1.0 // indirect
+ github.com/hashicorp/cli v1.1.7 // indirect
+ github.com/hashicorp/copywrite v0.22.0 // indirect
+ github.com/hashicorp/go-retryablehttp v0.7.7 // indirect
+ github.com/hashicorp/hcl v1.0.0 // indirect
+ github.com/hashicorp/terraform-plugin-docs v0.24.0 // indirect
+ github.com/huandu/xstrings v1.3.3 // indirect
+ github.com/imdario/mergo v0.3.15 // indirect
+ github.com/inconshreveable/mousetrap v1.0.1 // indirect
+ github.com/jedib0t/go-pretty v4.3.0+incompatible // indirect
+ github.com/jedib0t/go-pretty/v6 v6.4.6 // indirect
+ github.com/joho/godotenv v1.3.0 // indirect
+ github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51 // indirect
+ github.com/knadh/koanf v1.5.0 // indirect
+ github.com/kr/text v0.2.0 // indirect
+ github.com/mattn/go-runewidth v0.0.15 // indirect
+ github.com/mergestat/timediff v0.0.3 // indirect
+ github.com/mgutz/ansi v0.0.0-20200706080929-d51e80ef957d // indirect
+ github.com/mitchellh/go-homedir v1.1.0 // indirect
+ github.com/oklog/ulid v1.3.1 // indirect
+ github.com/posener/complete v1.2.3 // indirect
+ github.com/rivo/uniseg v0.4.7 // indirect
+ github.com/samber/lo v1.37.0 // indirect
+ github.com/shopspring/decimal v1.3.1 // indirect
+ github.com/spf13/cast v1.5.0 // indirect
+ github.com/spf13/cobra v1.6.1 // indirect
+ github.com/spf13/pflag v1.0.5 // indirect
+ github.com/thanhpk/randstr v1.0.4 // indirect
+ github.com/yuin/goldmark v1.7.7 // indirect
+ github.com/yuin/goldmark-meta v1.1.0 // indirect
+ go.abhg.dev/goldmark/frontmatter v0.2.0 // indirect
+ go.mongodb.org/mongo-driver v1.10.0 // indirect
+ golang.org/x/exp v0.0.0-20230626212559-97b1e661b5df // indirect
+ golang.org/x/oauth2 v0.30.0 // indirect
+ golang.org/x/telemetry v0.0.0-20251203150158-8fff8a5912fc // indirect
+ golang.org/x/term v0.38.0 // indirect
+ gopkg.in/yaml.v2 v2.4.0 // indirect
+ gopkg.in/yaml.v3 v3.0.1 // indirect
+)
+
+require (
+ github.com/ProtonMail/go-crypto v1.1.6 // indirect
+ github.com/agext/levenshtein v1.2.2 // indirect
+ github.com/apparentlymart/go-textseg/v15 v15.0.0 // indirect
+ github.com/cloudflare/circl v1.6.1 // indirect
+ github.com/fatih/color v1.18.0 // indirect
+ github.com/golang-jwt/jwt/v5 v5.3.0 // indirect
+ github.com/golang/protobuf v1.5.4 // indirect
+ github.com/hashicorp/errwrap v1.1.0 // indirect
+ github.com/hashicorp/go-checkpoint v0.5.0 // indirect
+ github.com/hashicorp/go-cleanhttp v0.5.2 // indirect
+ github.com/hashicorp/go-cty v1.5.0 // indirect
+ github.com/hashicorp/go-hclog v1.6.3 // indirect
+ github.com/hashicorp/go-multierror v1.1.1 // indirect
+ github.com/hashicorp/go-plugin v1.7.0 // indirect
+ github.com/hashicorp/go-uuid v1.0.3 // indirect
+ github.com/hashicorp/go-version v1.7.0 // indirect
+ github.com/hashicorp/hc-install v0.9.2 // indirect
+ github.com/hashicorp/hcl/v2 v2.24.0 // indirect
+ github.com/hashicorp/logutils v1.0.0 // indirect
+ github.com/hashicorp/terraform-exec v0.24.0 // indirect
+ github.com/hashicorp/terraform-json v0.27.2 // indirect
+ github.com/hashicorp/terraform-plugin-sdk/v2 v2.38.1 // indirect
+ github.com/hashicorp/terraform-registry-address v0.4.0 // indirect
+ github.com/hashicorp/terraform-svchost v0.1.1 // indirect
+ github.com/hashicorp/yamux v0.1.2 // indirect
+ github.com/mattn/go-colorable v0.1.14 // indirect
+ github.com/mattn/go-isatty v0.0.20 // indirect
+ github.com/mitchellh/copystructure v1.2.0 // indirect
+ github.com/mitchellh/go-testing-interface v1.14.1 // indirect
+ github.com/mitchellh/go-wordwrap v1.0.1 // indirect
+ github.com/mitchellh/mapstructure v1.5.0 // indirect
+ github.com/mitchellh/reflectwalk v1.0.2 // indirect
+ github.com/oklog/run v1.2.0 // indirect
+ github.com/stackitcloud/stackit-sdk-go/services/authorization v0.9.0
+ github.com/vmihailenco/msgpack v4.0.4+incompatible // indirect
+ github.com/vmihailenco/msgpack/v5 v5.4.1 // indirect
+ github.com/vmihailenco/tagparser/v2 v2.0.0 // indirect
+ github.com/zclconf/go-cty v1.17.0 // indirect
+ golang.org/x/crypto v0.46.0 // indirect
+ golang.org/x/net v0.48.0 // indirect
+ golang.org/x/sync v0.19.0 // indirect
+ golang.org/x/sys v0.39.0 // indirect
+ golang.org/x/text v0.32.0 // indirect
+ golang.org/x/tools v0.40.0 // indirect
+ google.golang.org/appengine v1.6.8 // indirect
+ google.golang.org/genproto/googleapis/rpc v0.0.0-20250707201910-8d1bb00bc6a7 // indirect
+ google.golang.org/grpc v1.75.1 // indirect
+ google.golang.org/protobuf v1.36.9 // indirect
+)
+
+tool golang.org/x/tools/cmd/goimports
diff --git a/go.sum b/go.sum
new file mode 100644
index 00000000..b87cbdf3
--- /dev/null
+++ b/go.sum
@@ -0,0 +1,808 @@
+cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw=
+cloud.google.com/go v0.34.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw=
+cloud.google.com/go/compute/metadata v0.2.0/go.mod h1:zFmK7XCadkQkj6TtorcaGlCW1hT1fIilQDwofLpJ20k=
+dario.cat/mergo v1.0.0 h1:AGCNq9Evsj31mOgNPcLyXc+4PNABt905YmuqPYYpBWk=
+dario.cat/mergo v1.0.0/go.mod h1:uNxQE+84aUszobStD9th8a29P2fMDhsBdgRYvZOxGmk=
+github.com/AlecAivazis/survey/v2 v2.3.7 h1:6I/u8FvytdGsgonrYsVn2t8t4QiRnh6QSTqkkhIiSjQ=
+github.com/AlecAivazis/survey/v2 v2.3.7/go.mod h1:xUTIdE4KCOIjsBAE1JYsUPoCqYdZ1reCfTwbto0Fduo=
+github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
+github.com/BurntSushi/toml v1.2.1 h1:9F2/+DoOYIOksmaJFPw1tGFy1eDnIJXg+UHjuD8lTak=
+github.com/BurntSushi/toml v1.2.1/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ=
+github.com/Kunde21/markdownfmt/v3 v3.1.0 h1:KiZu9LKs+wFFBQKhrZJrFZwtLnCCWJahL+S+E/3VnM0=
+github.com/Kunde21/markdownfmt/v3 v3.1.0/go.mod h1:tPXN1RTyOzJwhfHoon9wUr4HGYmWgVxSQN6VBJDkrVc=
+github.com/Masterminds/goutils v1.1.1 h1:5nUrii3FMTL5diU80unEVvNevw1nH4+ZV4DSLVJLSYI=
+github.com/Masterminds/goutils v1.1.1/go.mod h1:8cTjp+g8YejhMuvIA5y2vz3BpJxksy863GQaJW2MFNU=
+github.com/Masterminds/semver/v3 v3.2.0 h1:3MEsd0SM6jqZojhjLWWeBY+Kcjy9i6MQAeY7YgDP83g=
+github.com/Masterminds/semver/v3 v3.2.0/go.mod h1:qvl/7zhW3nngYb5+80sSMF+FG2BjYrf8m9wsX0PNOMQ=
+github.com/Masterminds/sprig/v3 v3.2.3 h1:eL2fZNezLomi0uOLqjQoN6BfsDD+fyLtgbJMAj9n6YA=
+github.com/Masterminds/sprig/v3 v3.2.3/go.mod h1:rXcFaZ2zZbLRJv/xSysmlgIM1u11eBaRMhvYXJNkGuM=
+github.com/Microsoft/go-winio v0.6.2 h1:F2VQgta7ecxGYO8k3ZZz3RS8fVIXVxONVUPlNERoyfY=
+github.com/Microsoft/go-winio v0.6.2/go.mod h1:yd8OoFMLzJbo9gZq8j5qaps8bJ9aShtEA8Ipt1oGCvU=
+github.com/Netflix/go-expect v0.0.0-20220104043353-73e0943537d2/go.mod h1:HBCaDeC1lPdgDeDbhX8XFpy1jqjK0IBG8W5K+xYqA0w=
+github.com/ProtonMail/go-crypto v0.0.0-20230217124315-7d5c6f04bbb8/go.mod h1:I0gYDMZ6Z5GRU7l58bNFSkPTFN6Yl12dsUlAZ8xy98g=
+github.com/ProtonMail/go-crypto v1.1.6 h1:ZcV+Ropw6Qn0AX9brlQLAUXfqLBc7Bl+f/DmNxpLfdw=
+github.com/ProtonMail/go-crypto v1.1.6/go.mod h1:rA3QumHc/FZ8pAHreoekgiAbzpNsfQAosU5td4SnOrE=
+github.com/agext/levenshtein v1.2.2 h1:0S/Yg6LYmFJ5stwQeRp6EeOcCbj7xiqQSdNelsXvaqE=
+github.com/agext/levenshtein v1.2.2/go.mod h1:JEDfjyjHDjOF/1e4FlBE/PkbqA9OfWu2ki2W0IB5558=
+github.com/alecthomas/template v0.0.0-20160405071501-a0175ee3bccc/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc=
+github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc=
+github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
+github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
+github.com/alecthomas/units v0.0.0-20190924025748-f65c72e2690d/go.mod h1:rBZYJk541a8SKzHPHnH3zbiI+7dagKZ0cgpgrD7Fyho=
+github.com/antihax/optional v1.0.0/go.mod h1:uupD/76wgC+ih3iEmQUL+0Ugr19nfwCT1kdvxnR2qWY=
+github.com/apparentlymart/go-textseg/v12 v12.0.0/go.mod h1:S/4uRK2UtaQttw1GenVJEynmyUenKwP++x/+DdGV/Ec=
+github.com/apparentlymart/go-textseg/v15 v15.0.0 h1:uYvfpb3DyLSCGWnctWKGj857c6ew1u1fNQOlOtuGxQY=
+github.com/apparentlymart/go-textseg/v15 v15.0.0/go.mod h1:K8XmNZdhEBkdlyDdvbmmsvpAG721bKi0joRfFdHIWJ4=
+github.com/armon/circbuf v0.0.0-20150827004946-bbbad097214e/go.mod h1:3U/XgcO3hCbHZ8TKRvWD2dDTCfh9M9ya+I9JpbB7O8o=
+github.com/armon/go-metrics v0.0.0-20180917152333-f0300d1749da/go.mod h1:Q73ZrmVTwzkszR9V5SSuryQ31EELlFMUz1kKyl939pY=
+github.com/armon/go-radix v0.0.0-20180808171621-7fddfc383310/go.mod h1:ufUuZ+zHj4x4TnLV4JWEpy2hxWSpsRywHrMgIH9cCH8=
+github.com/armon/go-radix v1.0.0 h1:F4z6KzEeeQIMeLFa97iZU6vupzoecKdU5TX24SNppXI=
+github.com/armon/go-radix v1.0.0/go.mod h1:ufUuZ+zHj4x4TnLV4JWEpy2hxWSpsRywHrMgIH9cCH8=
+github.com/asaskevich/govalidator v0.0.0-20200907205600-7a23bdc65eef h1:46PFijGLmAjMPwCCCo7Jf0W6f9slllCkkv7vyc1yOSg=
+github.com/asaskevich/govalidator v0.0.0-20200907205600-7a23bdc65eef/go.mod h1:WaHUgvxTVq04UNunO+XhnAqY/wQc+bxr74GqbsZ/Jqw=
+github.com/aws/aws-sdk-go-v2 v1.9.2/go.mod h1:cK/D0BBs0b/oWPIcX/Z/obahJK1TT7IPVjy53i/mX/4=
+github.com/aws/aws-sdk-go-v2/config v1.8.3/go.mod h1:4AEiLtAb8kLs7vgw2ZV3p2VZ1+hBavOc84hqxVNpCyw=
+github.com/aws/aws-sdk-go-v2/credentials v1.4.3/go.mod h1:FNNC6nQZQUuyhq5aE5c7ata8o9e4ECGmS4lAXC7o1mQ=
+github.com/aws/aws-sdk-go-v2/feature/ec2/imds v1.6.0/go.mod h1:gqlclDEZp4aqJOancXK6TN24aKhT0W0Ae9MHk3wzTMM=
+github.com/aws/aws-sdk-go-v2/internal/ini v1.2.4/go.mod h1:ZcBrrI3zBKlhGFNYWvju0I3TR93I7YIgAfy82Fh4lcQ=
+github.com/aws/aws-sdk-go-v2/service/appconfig v1.4.2/go.mod h1:FZ3HkCe+b10uFZZkFdvf98LHW21k49W8o8J366lqVKY=
+github.com/aws/aws-sdk-go-v2/service/internal/presigned-url v1.3.2/go.mod h1:72HRZDLMtmVQiLG2tLfQcaWLCssELvGl+Zf2WVxMmR8=
+github.com/aws/aws-sdk-go-v2/service/sso v1.4.2/go.mod h1:NBvT9R1MEF+Ud6ApJKM0G+IkPchKS7p7c2YPKwHmBOk=
+github.com/aws/aws-sdk-go-v2/service/sts v1.7.2/go.mod h1:8EzeIqfWt2wWT4rJVu3f21TfrhJ8AEMzVybRNSb/b4g=
+github.com/aws/smithy-go v1.8.0/go.mod h1:SObp3lf9smib00L/v3U2eAKG8FyQ7iLrJnQiAmR5n+E=
+github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q=
+github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8=
+github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw=
+github.com/bgentry/speakeasy v0.1.0 h1:ByYyxL9InA1OWqxJqqp2A5pYHUrCiAL6K3J+LKSsQkY=
+github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs=
+github.com/bmatcuk/doublestar/v4 v4.6.0 h1:HTuxyug8GyFbRkrffIpzNCSK4luc0TY3wzXvzIZhEXc=
+github.com/bmatcuk/doublestar/v4 v4.6.0/go.mod h1:xBQ8jztBU6kakFMg+8WGxn0c6z1fTSPVIjEY1Wr7jzc=
+github.com/bmatcuk/doublestar/v4 v4.9.1 h1:X8jg9rRZmJd4yRy7ZeNDRnM+T3ZfHv15JiBJ/avrEXE=
+github.com/bmatcuk/doublestar/v4 v4.9.1/go.mod h1:xBQ8jztBU6kakFMg+8WGxn0c6z1fTSPVIjEY1Wr7jzc=
+github.com/bradleyfalzon/ghinstallation/v2 v2.5.0 h1:yaYcGQ7yEIGbsJfW/9z7v1sLiZg/5rSNNXwmMct5XaE=
+github.com/bradleyfalzon/ghinstallation/v2 v2.5.0/go.mod h1:amcvPQMrRkWNdueWOjPytGL25xQGzox7425qMgzo+Vo=
+github.com/bufbuild/protocompile v0.14.1 h1:iA73zAf/fyljNjQKwYzUHD6AD4R8KMasmwa/FBatYVw=
+github.com/bufbuild/protocompile v0.14.1/go.mod h1:ppVdAIhbr2H8asPk6k4pY7t9zB1OU5DoEw9xY/FUi1c=
+github.com/bwesterb/go-ristretto v1.2.0/go.mod h1:fUIoIZaG73pV5biE2Blr2xEzDoMj7NFEuV9ekS419A0=
+github.com/bwesterb/go-ristretto v1.2.3/go.mod h1:fUIoIZaG73pV5biE2Blr2xEzDoMj7NFEuV9ekS419A0=
+github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
+github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
+github.com/cli/go-gh/v2 v2.11.2 h1:oad1+sESTPNTiTvh3I3t8UmxuovNDxhwLzeMHk45Q9w=
+github.com/cli/go-gh/v2 v2.11.2/go.mod h1:vVFhi3TfjseIW26ED9itAR8gQK0aVThTm8sYrsZ5QTI=
+github.com/cli/safeexec v1.0.0 h1:0VngyaIyqACHdcMNWfo6+KdUYnqEr2Sg+bSP1pdF+dI=
+github.com/cli/safeexec v1.0.0/go.mod h1:Z/D4tTN8Vs5gXYHDCbaM1S/anmEDnJb1iW0+EJ5zx3Q=
+github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw=
+github.com/cloudflare/circl v1.1.0/go.mod h1:prBCrKB9DV4poKZY1l9zBXg2QJY7mvgRvtMxxK7fi4I=
+github.com/cloudflare/circl v1.3.3/go.mod h1:5XYMA4rFBvNIrhs50XuiBJ15vF2pZn4nnUKZrLbUZFA=
+github.com/cloudflare/circl v1.6.1 h1:zqIqSPIndyBh1bjLVVDHMPpVKqp8Su/V+6MeDzzQBQ0=
+github.com/cloudflare/circl v1.6.1/go.mod h1:uddAzsPgqdMAYatqJ0lsjX1oECcQLIlRpzZh3pJrofs=
+github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc=
+github.com/cncf/udpa/go v0.0.0-20201120205902-5459f2c99403/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk=
+github.com/coreos/go-semver v0.3.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk=
+github.com/coreos/go-systemd/v22 v22.3.2/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc=
+github.com/cpuguy83/go-md2man/v2 v2.0.2/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o=
+github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E=
+github.com/creack/pty v1.1.17/go.mod h1:MOBLtS5ELjhRRrroQr9kyvTxUAFNvYEK993ew/Vr4O4=
+github.com/cyphar/filepath-securejoin v0.4.1 h1:JyxxyPEaktOD+GAnqIqTf9A8tHyAG22rowi7HkoSU1s=
+github.com/cyphar/filepath-securejoin v0.4.1/go.mod h1:Sdj7gXlvMcPZsbhwhQ33GguGLDGQL7h7bg04C/+u9jI=
+github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
+github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
+github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc h1:U9qPSI2PIWSS1VwoXQT9A3Wy9MM3WgvqSxFWenqJduM=
+github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
+github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk=
+github.com/emirpasic/gods v1.18.1 h1:FXtiHYKDGKCW2KzwZKx0iC0PQmdlorYgdFG9jPXJ1Bc=
+github.com/emirpasic/gods v1.18.1/go.mod h1:8tpGGwCnJ5H4r6BWwaV6OrWmMoPhUl5jm/FMNAnJvWQ=
+github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4=
+github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4=
+github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98=
+github.com/envoyproxy/go-control-plane v0.9.9-0.20210217033140-668b12f5399d/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk=
+github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c=
+github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4=
+github.com/fatih/color v1.9.0/go.mod h1:eQcE1qtQxscV5RaZvpXrrb8Drkc3/DdQ+uUYCNjL+zU=
+github.com/fatih/color v1.13.0/go.mod h1:kLAiJbzzSOZDVNGyDpeOxJ47H46qBXwg5ILebYFFOfk=
+github.com/fatih/color v1.18.0 h1:S8gINlzdQ840/4pfAwic/ZE0djQEH3wM94VfqLTZcOM=
+github.com/fatih/color v1.18.0/go.mod h1:4FelSpRwEGDpQ12mAdzqdOukCy4u8WUtOY6lkT/6HfU=
+github.com/fatih/structs v1.1.0/go.mod h1:9NiDSp5zOcgEDl+j00MP/WkGVPOlPRLejGD8Ga6PJ7M=
+github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ=
+github.com/fsnotify/fsnotify v1.5.4 h1:jRbGcIw6P2Meqdwuo0H1p6JVLbL5DHKAKlYndzMwVZI=
+github.com/fsnotify/fsnotify v1.5.4/go.mod h1:OVB6XrOHzAwXMpEM7uPOzcehqUV2UqJxmVXmkdnm1bU=
+github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04=
+github.com/go-git/gcfg v1.5.1-0.20230307220236-3a3c6141e376 h1:+zs/tPmkDkHx3U66DAb0lQFJrpS6731Oaa12ikc+DiI=
+github.com/go-git/gcfg v1.5.1-0.20230307220236-3a3c6141e376/go.mod h1:an3vInlBmSxCcxctByoQdvwPiA7DTK7jaaFDBTtu0ic=
+github.com/go-git/go-billy/v5 v5.6.2 h1:6Q86EsPXMa7c3YZ3aLAQsMA0VlWmy43r6FHqa/UNbRM=
+github.com/go-git/go-billy/v5 v5.6.2/go.mod h1:rcFC2rAsp/erv7CMz9GczHcuD0D32fWzH+MJAU+jaUU=
+github.com/go-git/go-git/v5 v5.14.0 h1:/MD3lCrGjCen5WfEAzKg00MJJffKhC8gzS80ycmCi60=
+github.com/go-git/go-git/v5 v5.14.0/go.mod h1:Z5Xhoia5PcWA3NF8vRLURn9E5FRhSl7dGj9ItW3Wk5k=
+github.com/go-kit/kit v0.8.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as=
+github.com/go-kit/kit v0.9.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as=
+github.com/go-kit/log v0.1.0/go.mod h1:zbhenjAZHb184qTLMA9ZjW7ThYL0H2mk7Q6pNt4vbaY=
+github.com/go-ldap/ldap v3.0.2+incompatible/go.mod h1:qfd9rJvER9Q0/D/Sqn1DfHRoBp40uXYvFoEVrNEPqRc=
+github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9GBnD5lWE=
+github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk=
+github.com/go-logfmt/logfmt v0.5.0/go.mod h1:wCYkCAKZfumFQihp8CzCvQ3paCTfi41vtzG1KdI/P7A=
+github.com/go-logr/logr v1.4.3 h1:CjnDlHq8ikf6E492q6eKboGOC0T8CDaOvkHCIg8idEI=
+github.com/go-logr/logr v1.4.3/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY=
+github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag=
+github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE=
+github.com/go-openapi/errors v0.20.2 h1:dxy7PGTqEh94zj2E3h1cUmQQWiM1+aeCROfAr02EmK8=
+github.com/go-openapi/errors v0.20.2/go.mod h1:cM//ZKUKyO06HSwqAelJ5NsEMMcpa6VpXe8DOa1Mi1M=
+github.com/go-openapi/strfmt v0.21.3 h1:xwhj5X6CjXEZZHMWy1zKJxvW9AfHC9pkyUjLvHtKG7o=
+github.com/go-openapi/strfmt v0.21.3/go.mod h1:k+RzNO0Da+k3FrrynSNN8F7n/peCmQQqbbXjtDfvmGg=
+github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY=
+github.com/go-test/deep v1.0.2-0.20181118220953-042da051cf31/go.mod h1:wGDj63lr65AM2AQyKZd/NYHGb0R+1RLqB8NKt3aSFNA=
+github.com/go-test/deep v1.0.3 h1:ZrJSEWsXzPOxaZnFteGEfooLba+ju3FYIbOrS+rQd68=
+github.com/go-test/deep v1.0.3/go.mod h1:wGDj63lr65AM2AQyKZd/NYHGb0R+1RLqB8NKt3aSFNA=
+github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA=
+github.com/gogo/protobuf v1.1.1/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ=
+github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q=
+github.com/golang-jwt/jwt/v4 v4.5.0/go.mod h1:m21LjoU+eqJr34lmDMbreY2eSTRJ1cv77w39/MY0Ch0=
+github.com/golang-jwt/jwt/v4 v4.5.1 h1:JdqV9zKUdtaa9gdPlywC3aeoEsR681PlKC+4F5gQgeo=
+github.com/golang-jwt/jwt/v4 v4.5.1/go.mod h1:m21LjoU+eqJr34lmDMbreY2eSTRJ1cv77w39/MY0Ch0=
+github.com/golang-jwt/jwt/v5 v5.3.0 h1:pv4AsKCKKZuqlgs5sUmn4x8UlGa0kEVt/puTpKx9vvo=
+github.com/golang-jwt/jwt/v5 v5.3.0/go.mod h1:fxCRLWMO43lRc8nhHWY6LGqRcf+1gQWArsqaEUEa5bE=
+github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q=
+github.com/golang/groupcache v0.0.0-20241129210726-2c02b8208cf8 h1:f+oWsMOmNPc8JmEHVZIycC7hBoQxHH9pNKQORJNozsQ=
+github.com/golang/groupcache v0.0.0-20241129210726-2c02b8208cf8/go.mod h1:wcDNUvekVysuuOpQKo3191zZyTpiI6se1N1ULghS0sw=
+github.com/golang/mock v1.1.1/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A=
+github.com/golang/protobuf v1.1.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
+github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
+github.com/golang/protobuf v1.3.1/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
+github.com/golang/protobuf v1.3.2/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
+github.com/golang/protobuf v1.3.3/go.mod h1:vzj43D7+SQXF/4pzW/hwtAqwc6iTitCiVSaWz5lYuqw=
+github.com/golang/protobuf v1.4.0-rc.1/go.mod h1:ceaxUfeHdC40wWswd/P6IGgMaK3YpKi5j83Wpe3EHw8=
+github.com/golang/protobuf v1.4.0-rc.1.0.20200221234624-67d41d38c208/go.mod h1:xKAWHe0F5eneWXFV3EuXVDTCmh+JuBKY0li0aMyXATA=
+github.com/golang/protobuf v1.4.0-rc.2/go.mod h1:LlEzMj4AhA7rCAGe4KMBDvJI+AwstrUpVNzEA03Pprs=
+github.com/golang/protobuf v1.4.0-rc.4.0.20200313231945-b860323f09d0/go.mod h1:WU3c8KckQ9AFe+yFwt9sWVRKCVIyN9cPHBJSNnbL67w=
+github.com/golang/protobuf v1.4.0/go.mod h1:jodUvKwWbYaEsadDk5Fwe5c77LiNKVO9IDvqG2KuDX0=
+github.com/golang/protobuf v1.4.1/go.mod h1:U8fpvMrcmy5pZrNK1lt4xCsGvpyWQ/VVv6QDs8UjoX8=
+github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI=
+github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI=
+github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk=
+github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
+github.com/golang/protobuf v1.5.4 h1:i7eJL8qZTpSEXOPTxNKhASYpMn+8e5Q6AdndVa1dWek=
+github.com/golang/protobuf v1.5.4/go.mod h1:lnTiLA8Wa4RWRcIUkrtSVa5nRhsEGBg48fD6rSs7xps=
+github.com/golang/snappy v0.0.1/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
+github.com/google/btree v0.0.0-20180813153112-4030bb1f1f0c/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ=
+github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5aqRK0M=
+github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
+github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
+github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
+github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
+github.com/google/go-cmp v0.5.2/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
+github.com/google/go-cmp v0.5.4/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
+github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
+github.com/google/go-cmp v0.5.6/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
+github.com/google/go-cmp v0.5.7/go.mod h1:n+brtR0CgQNWTVd5ZUFpTBC8YFBDLK/h/bpaJ8/DtOE=
+github.com/google/go-cmp v0.5.8/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY=
+github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY=
+github.com/google/go-cmp v0.7.0 h1:wk8382ETsv4JYUZwIsn6YpYiWiBsYLSJiTsyBybVuN8=
+github.com/google/go-cmp v0.7.0/go.mod h1:pXiqmnSA92OHEEa9HXL2W4E7lf9JzCmGVUdgjX3N/iU=
+github.com/google/go-github/v45 v45.2.0 h1:5oRLszbrkvxDDqBCNj2hjDZMKmvexaZ1xw/FCD+K3FI=
+github.com/google/go-github/v45 v45.2.0/go.mod h1:FObaZJEDSTa/WGCzZ2Z3eoCDXWJKMenWWTrd8jrta28=
+github.com/google/go-github/v53 v53.0.0 h1:T1RyHbSnpHYnoF0ZYKiIPSgPtuJ8G6vgc0MKodXsQDQ=
+github.com/google/go-github/v53 v53.0.0/go.mod h1:XhFRObz+m/l+UCm9b7KSIC3lT3NWSXGt7mOsAWEloao=
+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/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
+github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
+github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
+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/mux v1.8.1 h1:TuBL49tXwgrFYWhqrNgrUNEY92u81SPhu7sTdzQEiWY=
+github.com/gorilla/mux v1.8.1/go.mod h1:AKf9I4AEqPTmMytcMc0KkNouC66V3BtZ4qD5fmWSiMQ=
+github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0/go.mod h1:8NvIoxWQoOIhqOTXgfV/d3M/q6VIi02HzZEHgUlZvzk=
+github.com/grpc-ecosystem/grpc-gateway v1.16.0/go.mod h1:BDjrQk3hbvj6Nolgz8mAMFbcEtjT1g+wF4CSlocrBnw=
+github.com/hashicorp/cli v1.1.7 h1:/fZJ+hNdwfTSfsxMBa9WWMlfjUZbX8/LnUxgAd7lCVU=
+github.com/hashicorp/cli v1.1.7/go.mod h1:e6Mfpga9OCT1vqzFuoGZiiF/KaG9CbUfO5s3ghU3YgU=
+github.com/hashicorp/consul/api v1.13.0/go.mod h1:ZlVrynguJKcYr54zGaDbaL3fOvKC9m72FhPvA8T35KQ=
+github.com/hashicorp/consul/sdk v0.8.0/go.mod h1:GBvyrGALthsZObzUGsfgHZQDXjg4lOjagTIwIR1vPms=
+github.com/hashicorp/copywrite v0.22.0 h1:mqjMrgP3VptS7aLbu2l39rtznoK+BhphHst6i7HiTAo=
+github.com/hashicorp/copywrite v0.22.0/go.mod h1:FqvGJt2+yoYDpVYgFSdg3R2iyhkCVaBmPMhfso0MR2k=
+github.com/hashicorp/errwrap v1.0.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4=
+github.com/hashicorp/errwrap v1.1.0 h1:OxrOeh75EUXMY8TBjag2fzXGZ40LB6IKw45YeGUDY2I=
+github.com/hashicorp/errwrap v1.1.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4=
+github.com/hashicorp/go-checkpoint v0.5.0 h1:MFYpPZCnQqQTE18jFwSII6eUQrD/oxMFp3mlgcqk5mU=
+github.com/hashicorp/go-checkpoint v0.5.0/go.mod h1:7nfLNL10NsxqO4iWuW6tWW0HjZuDrwkBuEQsVcpCOgg=
+github.com/hashicorp/go-cleanhttp v0.5.0/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80=
+github.com/hashicorp/go-cleanhttp v0.5.1/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80=
+github.com/hashicorp/go-cleanhttp v0.5.2 h1:035FKYIWjmULyFRBKPs8TBQoi0x6d9G4xc9neXJWAZQ=
+github.com/hashicorp/go-cleanhttp v0.5.2/go.mod h1:kO/YDlP8L1346E6Sodw+PrpBSV4/SoxCXGY6BqNFT48=
+github.com/hashicorp/go-cty v1.5.0 h1:EkQ/v+dDNUqnuVpmS5fPqyY71NXVgT5gf32+57xY8g0=
+github.com/hashicorp/go-cty v1.5.0/go.mod h1:lFUCG5kd8exDobgSfyj4ONE/dc822kiYMguVKdHGMLM=
+github.com/hashicorp/go-hclog v0.0.0-20180709165350-ff2cf002a8dd/go.mod h1:9bjs9uLqI8l75knNv3lV1kA55veR+WUPSiKIWcQHudI=
+github.com/hashicorp/go-hclog v0.8.0/go.mod h1:5CU+agLiy3J7N7QjHK5d05KxGsuXiQLrjA0H7acj2lQ=
+github.com/hashicorp/go-hclog v0.12.0/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ=
+github.com/hashicorp/go-hclog v1.6.3 h1:Qr2kF+eVWjTiYmU7Y31tYlP1h0q/X3Nl3tPGdaB11/k=
+github.com/hashicorp/go-hclog v1.6.3/go.mod h1:W4Qnvbt70Wk/zYJryRzDRU/4r0kIg0PVHBcfoyhpF5M=
+github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
+github.com/hashicorp/go-msgpack v0.5.3/go.mod h1:ahLV/dePpqEmjfWmKiqvPkv/twdG7iPBM1vqhUKIvfM=
+github.com/hashicorp/go-multierror v1.0.0/go.mod h1:dHtQlpGsu+cZNNAkkCN/P3hoUDHhCYQXV3UM06sGGrk=
+github.com/hashicorp/go-multierror v1.1.0/go.mod h1:spPvp8C1qA32ftKqdAHm4hHTbPw+vmowP0z+KUhOZdA=
+github.com/hashicorp/go-multierror v1.1.1 h1:H5DkEtf6CXdFp0N0Em5UCwQpXMWke8IA0+lD48awMYo=
+github.com/hashicorp/go-multierror v1.1.1/go.mod h1:iw975J/qwKPdAO1clOe2L8331t/9/fmwbPZ6JB6eMoM=
+github.com/hashicorp/go-plugin v1.0.1/go.mod h1:++UyYGoz3o5w9ZzAdZxtQKrWWP+iqPBn3cQptSMzBuY=
+github.com/hashicorp/go-plugin v1.7.0 h1:YghfQH/0QmPNc/AZMTFE3ac8fipZyZECHdDPshfk+mA=
+github.com/hashicorp/go-plugin v1.7.0/go.mod h1:BExt6KEaIYx804z8k4gRzRLEvxKVb+kn0NMcihqOqb8=
+github.com/hashicorp/go-retryablehttp v0.5.4/go.mod h1:9B5zBasrRhHXnJnui7y6sL7es7NDiJgTc6Er0maI1Xs=
+github.com/hashicorp/go-retryablehttp v0.7.7 h1:C8hUCYzor8PIfXHa4UrZkU4VvK8o9ISHxT2Q8+VepXU=
+github.com/hashicorp/go-retryablehttp v0.7.7/go.mod h1:pkQpWZeYWskR+D1tR2O5OcBFOxfA7DoAO6xtkuQnHTk=
+github.com/hashicorp/go-rootcerts v1.0.1/go.mod h1:pqUvnprVnM5bf7AOirdbb01K4ccR319Vf4pU3K5EGc8=
+github.com/hashicorp/go-rootcerts v1.0.2/go.mod h1:pqUvnprVnM5bf7AOirdbb01K4ccR319Vf4pU3K5EGc8=
+github.com/hashicorp/go-sockaddr v1.0.0/go.mod h1:7Xibr9yA9JjQq1JpNB2Vw7kxv8xerXegt+ozgdvDeDU=
+github.com/hashicorp/go-sockaddr v1.0.2/go.mod h1:rB4wwRAUzs07qva3c5SdrY/NEtAUjGlgmH/UkBUC97A=
+github.com/hashicorp/go-syslog v1.0.0/go.mod h1:qPfqrKkXGihmCqbJM2mZgkZGvKG1dFdvsLplgctolz4=
+github.com/hashicorp/go-uuid v1.0.0/go.mod h1:6SBZvOh/SIDV7/2o3Jml5SYk/TvGqwFJ/bN7x4byOro=
+github.com/hashicorp/go-uuid v1.0.1/go.mod h1:6SBZvOh/SIDV7/2o3Jml5SYk/TvGqwFJ/bN7x4byOro=
+github.com/hashicorp/go-uuid v1.0.3 h1:2gKiV6YVmrJ1i2CKKa9obLvRieoRGviZFL26PcT/Co8=
+github.com/hashicorp/go-uuid v1.0.3/go.mod h1:6SBZvOh/SIDV7/2o3Jml5SYk/TvGqwFJ/bN7x4byOro=
+github.com/hashicorp/go-version v1.1.0/go.mod h1:fltr4n8CU8Ke44wwGCBoEymUuxUHl09ZGVZPK5anwXA=
+github.com/hashicorp/go-version v1.7.0 h1:5tqGy27NaOTB8yJKUZELlFAS/LTKJkrmONwQKeRZfjY=
+github.com/hashicorp/go-version v1.7.0/go.mod h1:fltr4n8CU8Ke44wwGCBoEymUuxUHl09ZGVZPK5anwXA=
+github.com/hashicorp/golang-lru v0.5.0/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8=
+github.com/hashicorp/golang-lru v0.5.1/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8=
+github.com/hashicorp/hc-install v0.9.2 h1:v80EtNX4fCVHqzL9Lg/2xkp62bbvQMnvPQ0G+OmtO24=
+github.com/hashicorp/hc-install v0.9.2/go.mod h1:XUqBQNnuT4RsxoxiM9ZaUk0NX8hi2h+Lb6/c0OZnC/I=
+github.com/hashicorp/hcl v1.0.0 h1:0Anlzjpi4vEasTeNFn2mLJgTSwt0+6sfsiTG8qcWGx4=
+github.com/hashicorp/hcl v1.0.0/go.mod h1:E5yfLk+7swimpb2L/Alb/PJmXilQ/rhwaUYs4T20WEQ=
+github.com/hashicorp/hcl/v2 v2.24.0 h1:2QJdZ454DSsYGoaE6QheQZjtKZSUs9Nh2izTWiwQxvE=
+github.com/hashicorp/hcl/v2 v2.24.0/go.mod h1:oGoO1FIQYfn/AgyOhlg9qLC6/nOJPX3qGbkZpYAcqfM=
+github.com/hashicorp/logutils v1.0.0 h1:dLEQVugN8vlakKOUE3ihGLTZJRB4j+M2cdTm/ORI65Y=
+github.com/hashicorp/logutils v1.0.0/go.mod h1:QIAnNjmIWmVIIkWDTG1z5v++HQmx9WQRO+LraFDTW64=
+github.com/hashicorp/mdns v1.0.4/go.mod h1:mtBihi+LeNXGtG8L9dX59gAEa12BDtBQSp4v/YAJqrc=
+github.com/hashicorp/memberlist v0.3.0/go.mod h1:MS2lj3INKhZjWNqd3N0m3J+Jxf3DAOnAH9VT3Sh9MUE=
+github.com/hashicorp/serf v0.9.6/go.mod h1:TXZNMjZQijwlDvp+r0b63xZ45H7JmCmgg4gpTwn9UV4=
+github.com/hashicorp/terraform-exec v0.24.0 h1:mL0xlk9H5g2bn0pPF6JQZk5YlByqSqrO5VoaNtAf8OE=
+github.com/hashicorp/terraform-exec v0.24.0/go.mod h1:lluc/rDYfAhYdslLJQg3J0oDqo88oGQAdHR+wDqFvo4=
+github.com/hashicorp/terraform-json v0.27.2 h1:BwGuzM6iUPqf9JYM/Z4AF1OJ5VVJEEzoKST/tRDBJKU=
+github.com/hashicorp/terraform-json v0.27.2/go.mod h1:GzPLJ1PLdUG5xL6xn1OXWIjteQRT2CNT9o/6A9mi9hE=
+github.com/hashicorp/terraform-plugin-docs v0.24.0 h1:YNZYd+8cpYclQyXbl1EEngbld8w7/LPOm99GD5nikIU=
+github.com/hashicorp/terraform-plugin-docs v0.24.0/go.mod h1:YLg+7LEwVmRuJc0EuCw0SPLxuQXw5mW8iJ5ml/kvi+o=
+github.com/hashicorp/terraform-plugin-framework v1.17.0 h1:JdX50CFrYcYFY31gkmitAEAzLKoBgsK+iaJjDC8OexY=
+github.com/hashicorp/terraform-plugin-framework v1.17.0/go.mod h1:4OUXKdHNosX+ys6rLgVlgklfxN3WHR5VHSOABeS/BM0=
+github.com/hashicorp/terraform-plugin-framework-validators v0.19.0 h1:Zz3iGgzxe/1XBkooZCewS0nJAaCFPFPHdNJd8FgE4Ow=
+github.com/hashicorp/terraform-plugin-framework-validators v0.19.0/go.mod h1:GBKTNGbGVJohU03dZ7U8wHqc2zYnMUawgCN+gC0itLc=
+github.com/hashicorp/terraform-plugin-go v0.29.0 h1:1nXKl/nSpaYIUBU1IG/EsDOX0vv+9JxAltQyDMpq5mU=
+github.com/hashicorp/terraform-plugin-go v0.29.0/go.mod h1:vYZbIyvxyy0FWSmDHChCqKvI40cFTDGSb3D8D70i9GM=
+github.com/hashicorp/terraform-plugin-log v0.10.0 h1:eu2kW6/QBVdN4P3Ju2WiB2W3ObjkAsyfBsL3Wh1fj3g=
+github.com/hashicorp/terraform-plugin-log v0.10.0/go.mod h1:/9RR5Cv2aAbrqcTSdNmY1NRHP4E3ekrXRGjqORpXyB0=
+github.com/hashicorp/terraform-plugin-sdk/v2 v2.38.1 h1:mlAq/OrMlg04IuJT7NpefI1wwtdpWudnEmjuQs04t/4=
+github.com/hashicorp/terraform-plugin-sdk/v2 v2.38.1/go.mod h1:GQhpKVvvuwzD79e8/NZ+xzj+ZpWovdPAe8nfV/skwNU=
+github.com/hashicorp/terraform-plugin-testing v1.14.0 h1:5t4VKrjOJ0rg0sVuSJ86dz5K7PHsMO6OKrHFzDBerWA=
+github.com/hashicorp/terraform-plugin-testing v1.14.0/go.mod h1:1qfWkecyYe1Do2EEOK/5/WnTyvC8wQucUkkhiGLg5nk=
+github.com/hashicorp/terraform-registry-address v0.4.0 h1:S1yCGomj30Sao4l5BMPjTGZmCNzuv7/GDTDX99E9gTk=
+github.com/hashicorp/terraform-registry-address v0.4.0/go.mod h1:LRS1Ay0+mAiRkUyltGT+UHWkIqTFvigGn/LbMshfflE=
+github.com/hashicorp/terraform-svchost v0.1.1 h1:EZZimZ1GxdqFRinZ1tpJwVxxt49xc/S52uzrw4x0jKQ=
+github.com/hashicorp/terraform-svchost v0.1.1/go.mod h1:mNsjQfZyf/Jhz35v6/0LWcv26+X7JPS+buii2c9/ctc=
+github.com/hashicorp/vault/api v1.0.4/go.mod h1:gDcqh3WGcR1cpF5AJz/B1UFheUEneMoIospckxBxk6Q=
+github.com/hashicorp/vault/sdk v0.1.13/go.mod h1:B+hVj7TpuQY1Y/GPbCpffmgd+tSEwvhkWnjtSYCaS2M=
+github.com/hashicorp/yamux v0.0.0-20180604194846-3520598351bb/go.mod h1:+NfK9FKeTrX5uv1uIXGdwYDTeHna2qgaIlx54MXqjAM=
+github.com/hashicorp/yamux v0.0.0-20181012175058-2f1d1f20f75d/go.mod h1:+NfK9FKeTrX5uv1uIXGdwYDTeHna2qgaIlx54MXqjAM=
+github.com/hashicorp/yamux v0.1.2 h1:XtB8kyFOyHXYVFnwT5C3+Bdo8gArse7j2AQ0DA0Uey8=
+github.com/hashicorp/yamux v0.1.2/go.mod h1:C+zze2n6e/7wshOZep2A70/aQU6QBRWJO/G6FT1wIns=
+github.com/hinshun/vt10x v0.0.0-20220119200601-820417d04eec/go.mod h1:Q48J4R4DvxnHolD5P8pOtXigYlRuPLGl6moFx3ulM68=
+github.com/hjson/hjson-go/v4 v4.0.0/go.mod h1:KaYt3bTw3zhBjYqnXkYywcYctk0A2nxeEFTse3rH13E=
+github.com/huandu/xstrings v1.3.3 h1:/Gcsuc1x8JVbJ9/rlye4xZnVAbEkGauT8lbebqcQws4=
+github.com/huandu/xstrings v1.3.3/go.mod h1:y5/lhBue+AyNmUVz9RLU9xbLR0o4KIIExikq4ovT0aE=
+github.com/imdario/mergo v0.3.11/go.mod h1:jmQim1M+e3UYxmgPu/WyfjB3N3VflVyUjjjwH0dnCYA=
+github.com/imdario/mergo v0.3.15 h1:M8XP7IuFNsqUx6VPK2P9OSmsYsI/YFaGil0uD21V3dM=
+github.com/imdario/mergo v0.3.15/go.mod h1:WBLT9ZmE3lPoWsEzCh9LPo3TiwVN+ZKEjmz+hD27ysY=
+github.com/inconshreveable/mousetrap v1.0.1 h1:U3uMjPSQEBMNp1lFxmllqCPM6P5u/Xq7Pgzkat/bFNc=
+github.com/inconshreveable/mousetrap v1.0.1/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
+github.com/jbenet/go-context v0.0.0-20150711004518-d14ea06fba99 h1:BQSFePA1RWJOlocH6Fxy8MmwDt+yVQYULKfN0RoTN8A=
+github.com/jbenet/go-context v0.0.0-20150711004518-d14ea06fba99/go.mod h1:1lJo3i6rXxKeerYnT8Nvf0QmHCRC1n8sfWVwXF2Frvo=
+github.com/jedib0t/go-pretty v4.3.0+incompatible h1:CGs8AVhEKg/n9YbUenWmNStRW2PHJzaeDodcfvRAbIo=
+github.com/jedib0t/go-pretty v4.3.0+incompatible/go.mod h1:XemHduiw8R651AF9Pt4FwCTKeG3oo7hrHJAoznj9nag=
+github.com/jedib0t/go-pretty/v6 v6.4.6 h1:v6aG9h6Uby3IusSSEjHaZNXpHFhzqMmjXcPq1Rjl9Jw=
+github.com/jedib0t/go-pretty/v6 v6.4.6/go.mod h1:Ndk3ase2CkQbXLLNf5QDHoYb6J9WtVfmHZu9n8rk2xs=
+github.com/jhump/protoreflect v1.17.0 h1:qOEr613fac2lOuTgWN4tPAtLL7fUSbuJL5X5XumQh94=
+github.com/jhump/protoreflect v1.17.0/go.mod h1:h9+vUUL38jiBzck8ck+6G/aeMX8Z4QUY/NiJPwPNi+8=
+github.com/jmespath/go-jmespath v0.4.0/go.mod h1:T8mJZnbsbmF+m6zOOFylbeCJqk5+pHWvzYPziyZiYoo=
+github.com/jmespath/go-jmespath/internal/testify v1.5.1/go.mod h1:L3OGu8Wl2/fWfCI6z80xFu9LTZmf1ZRjMHUOPmWr69U=
+github.com/joho/godotenv v1.3.0 h1:Zjp+RcGpHhGlrMbJzXTrZZPrWj+1vfm90La1wgB6Bhc=
+github.com/joho/godotenv v1.3.0/go.mod h1:7hK45KPybAkOC6peb+G5yklZfMxEjkZhHbwpqxOKXbg=
+github.com/jpillora/backoff v1.0.0/go.mod h1:J/6gKK9jxlEcS3zixgDgUAsiuZ7yrSoa/FX5e0EB2j4=
+github.com/json-iterator/go v1.1.6/go.mod h1:+SdeFBvtyEkXs7REEP0seUULqWtbJapLOCVDaaPEHmU=
+github.com/json-iterator/go v1.1.10/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
+github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
+github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w=
+github.com/julienschmidt/httprouter v1.3.0/go.mod h1:JR6WtHb+2LUe8TCKY3cZOxFyyO8IZAc4RVcycCCAKdM=
+github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51 h1:Z9n2FFNUXsshfwJMBgNA0RU6/i7WVaAegv3PtuIHPMs=
+github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51/go.mod h1:CzGEWj7cYgsdH8dAjBGEr58BoE7ScuLd+fwFZ44+/x8=
+github.com/kevinburke/ssh_config v1.2.0 h1:x584FjTGwHzMwvHx18PXxbBVzfnxogHaAReU4gf13a4=
+github.com/kevinburke/ssh_config v1.2.0/go.mod h1:CT57kijsi8u/K/BOFA39wgDQJ9CxiF4nAY/ojJ6r6mM=
+github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8=
+github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck=
+github.com/klauspost/compress v1.13.6/go.mod h1:/3/Vjq9QcHkK5uEr5lBEmyoZ1iFhe47etQ6QUkpK6sk=
+github.com/knadh/koanf v1.5.0 h1:q2TSd/3Pyc/5yP9ldIrSdIz26MCcyNQzW0pEAugLPNs=
+github.com/knadh/koanf v1.5.0/go.mod h1:Hgyjp4y8v44hpZtPzs7JZfRAW5AhN7KfZcwv1RYggDs=
+github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
+github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
+github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFBFZlji/RkVcI2GknAs/DXo4wKdlNEc=
+github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo=
+github.com/kr/pretty v0.2.0/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI=
+github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE=
+github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk=
+github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ=
+github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
+github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
+github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE=
+github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU=
+github.com/mattn/go-colorable v0.1.2/go.mod h1:U0ppj6V5qS13XJ6of8GYAs25YV2eR4EVcfRqFIhoBtE=
+github.com/mattn/go-colorable v0.1.4/go.mod h1:U0ppj6V5qS13XJ6of8GYAs25YV2eR4EVcfRqFIhoBtE=
+github.com/mattn/go-colorable v0.1.6/go.mod h1:u6P/XSegPjTcexA+o6vUJrdnUu04hMope9wVRipJSqc=
+github.com/mattn/go-colorable v0.1.9/go.mod h1:u6P/XSegPjTcexA+o6vUJrdnUu04hMope9wVRipJSqc=
+github.com/mattn/go-colorable v0.1.12/go.mod h1:u5H1YNBxpqRaxsYJYSkiCWKzEfiAb1Gb520KVy5xxl4=
+github.com/mattn/go-colorable v0.1.14 h1:9A9LHSqF/7dyVVX6g0U9cwm9pG3kP9gSzcuIPHPsaIE=
+github.com/mattn/go-colorable v0.1.14/go.mod h1:6LmQG8QLFO4G5z1gPvYEzlUgJ2wF+stgPZH1UqBm1s8=
+github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4=
+github.com/mattn/go-isatty v0.0.8/go.mod h1:Iq45c/XA43vh69/j3iqttzPXn0bhXyGjM0Hdxcsrc5s=
+github.com/mattn/go-isatty v0.0.10/go.mod h1:qgIWMr58cqv1PHHyhnkY9lrL7etaEgOFcMEpPG5Rm84=
+github.com/mattn/go-isatty v0.0.11/go.mod h1:PhnuNfih5lzO57/f3n+odYbM4JtupLOxQOAqxQCu2WE=
+github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU=
+github.com/mattn/go-isatty v0.0.14/go.mod h1:7GGIvUiUoEMVVmxf/4nioHXj79iQHKdU27kJ6hsGG94=
+github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY=
+github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y=
+github.com/mattn/go-runewidth v0.0.13/go.mod h1:Jdepj2loyihRzMpdS35Xk/zdY8IAYHsh153qUoGf23w=
+github.com/mattn/go-runewidth v0.0.15 h1:UNAjwbU9l54TA3KzvqLGxwWjHmMgBUVhBiTjelZgg3U=
+github.com/mattn/go-runewidth v0.0.15/go.mod h1:Jdepj2loyihRzMpdS35Xk/zdY8IAYHsh153qUoGf23w=
+github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0=
+github.com/mergestat/timediff v0.0.3 h1:ucCNh4/ZrTPjFZ081PccNbhx9spymCJkFxSzgVuPU+Y=
+github.com/mergestat/timediff v0.0.3/go.mod h1:yvMUaRu2oetc+9IbPLYBJviz6sA7xz8OXMDfhBl7YSI=
+github.com/mgutz/ansi v0.0.0-20170206155736-9520e82c474b/go.mod h1:01TrycV0kFyexm33Z7vhZRXopbI8J3TDReVlkTgMUxE=
+github.com/mgutz/ansi v0.0.0-20200706080929-d51e80ef957d h1:5PJl274Y63IEHC+7izoQE9x6ikvDFZS2mDVS3drnohI=
+github.com/mgutz/ansi v0.0.0-20200706080929-d51e80ef957d/go.mod h1:01TrycV0kFyexm33Z7vhZRXopbI8J3TDReVlkTgMUxE=
+github.com/miekg/dns v1.1.26/go.mod h1:bPDLeHnStXmXAq1m/Ch/hvfNHr14JKNPMBo3VZKjuso=
+github.com/miekg/dns v1.1.41/go.mod h1:p6aan82bvRIyn+zDIv9xYNUpwa73JcSh9BKwknJysuI=
+github.com/mitchellh/cli v1.0.0/go.mod h1:hNIlj7HEI86fIcpObd7a0FcrxTWetlwJDGcceTlRvqc=
+github.com/mitchellh/cli v1.1.0/go.mod h1:xcISNoH86gajksDmfB23e/pu+B+GeFRMYmoHXxx3xhI=
+github.com/mitchellh/copystructure v1.0.0/go.mod h1:SNtv71yrdKgLRyLFxmLdkAbkKEFWgYaq1OVrnRcwhnw=
+github.com/mitchellh/copystructure v1.2.0 h1:vpKXTN4ewci03Vljg/q9QvCGUDttBOGBIa15WveJJGw=
+github.com/mitchellh/copystructure v1.2.0/go.mod h1:qLl+cE2AmVv+CoeAwDPye/v+N2HKCj9FbZEVFJRxO9s=
+github.com/mitchellh/go-homedir v1.1.0 h1:lukF9ziXFxDFPkA1vsr5zpc1XuPDn/wFntq5mG+4E0Y=
+github.com/mitchellh/go-homedir v1.1.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0=
+github.com/mitchellh/go-testing-interface v0.0.0-20171004221916-a61a99592b77/go.mod h1:kRemZodwjscx+RGhAo8eIhFbs2+BFgRtFPeD/KE+zxI=
+github.com/mitchellh/go-testing-interface v1.0.0/go.mod h1:kRemZodwjscx+RGhAo8eIhFbs2+BFgRtFPeD/KE+zxI=
+github.com/mitchellh/go-testing-interface v1.14.1 h1:jrgshOhYAUVNMAJiKbEu7EqAwgJJ2JqpQmpLJOu07cU=
+github.com/mitchellh/go-testing-interface v1.14.1/go.mod h1:gfgS7OtZj6MA4U1UrDRp04twqAjfvlZyCfX3sDjEym8=
+github.com/mitchellh/go-wordwrap v1.0.0/go.mod h1:ZXFpozHsX6DPmq2I0TCekCxypsnAUbP2oI0UX1GXzOo=
+github.com/mitchellh/go-wordwrap v1.0.1 h1:TLuKupo69TCn6TQSyGxwI1EblZZEsQ0vMlAFQflz0v0=
+github.com/mitchellh/go-wordwrap v1.0.1/go.mod h1:R62XHJLzvMFRBbcrT7m7WgmE1eOyTSsCt+hzestvNj0=
+github.com/mitchellh/mapstructure v0.0.0-20160808181253-ca63d7c062ee/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y=
+github.com/mitchellh/mapstructure v1.1.2/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y=
+github.com/mitchellh/mapstructure v1.3.3/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo=
+github.com/mitchellh/mapstructure v1.5.0 h1:jeMsZIYE/09sWLaz43PL7Gy6RuMjD2eJVyuac5Z2hdY=
+github.com/mitchellh/mapstructure v1.5.0/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo=
+github.com/mitchellh/reflectwalk v1.0.0/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx0jmZXqmk4esnw=
+github.com/mitchellh/reflectwalk v1.0.2 h1:G2LzWKi524PWgd3mLHV8Y5k7s6XUvT0Gef6zxSIeXaQ=
+github.com/mitchellh/reflectwalk v1.0.2/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx0jmZXqmk4esnw=
+github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
+github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
+github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
+github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
+github.com/montanaflynn/stats v0.0.0-20171201202039-1bf9dbcd8cbe/go.mod h1:wL8QJuTMNUDYhXwkmfOly8iTdp5TEcJFWZD2D7SIkUc=
+github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U=
+github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U=
+github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno=
+github.com/npillmayer/nestext v0.1.3/go.mod h1:h2lrijH8jpicr25dFY+oAJLyzlya6jhnuG+zWp9L0Uk=
+github.com/oklog/run v1.0.0/go.mod h1:dlhp/R75TPv97u0XWUtDeV/lRKWPKSdTuV0TZvrmrQA=
+github.com/oklog/run v1.2.0 h1:O8x3yXwah4A73hJdlrwo/2X6J62gE5qTMusH0dvz60E=
+github.com/oklog/run v1.2.0/go.mod h1:mgDbKRSwPhJfesJ4PntqFUbKQRZ50NgmZTSPlFA0YFk=
+github.com/oklog/ulid v1.3.1 h1:EGfNDEx6MqHz8B3uNV6QAib1UR2Lm97sHi3ocA6ESJ4=
+github.com/oklog/ulid v1.3.1/go.mod h1:CirwcVhetQ6Lv90oh/F+FBtV6XMibvdAFo93nm5qn4U=
+github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc=
+github.com/pascaldekloe/goe v0.1.0/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc=
+github.com/pelletier/go-toml v1.7.0/go.mod h1:vwGMzjaWMwyfHwgIBhI2YUM4fB6nL6lVAvS1LBMMhTE=
+github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY=
+github.com/pjbgf/sha1cd v0.3.2 h1:a9wb0bp1oC2TGwStyn0Umc/IGKQnEgF0vVaZ8QF8eo4=
+github.com/pjbgf/sha1cd v0.3.2/go.mod h1:zQWigSxVmsHEZow5qaLtPYxpcKMMQpa09ixqBxuCS6A=
+github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
+github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
+github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
+github.com/pkg/profile v1.6.0/go.mod h1:qBsxPvzyUincmltOk6iyRVxHYg4adc0OFOv72ZdLa18=
+github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
+github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 h1:Jamvg5psRIccs7FGNTlIRMkT8wgtp5eCXdBlqhYGL6U=
+github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
+github.com/posener/complete v1.1.1/go.mod h1:em0nMJCgc9GFtwrmVmEMR/ZL6WyhyjMBndrE9hABlRI=
+github.com/posener/complete v1.2.3 h1:NP0eAhjcjImqslEwo/1hq7gpajME0fTLTezBKDqfXqo=
+github.com/posener/complete v1.2.3/go.mod h1:WZIdtGGp+qx0sLrYKtIRAruyNpv6hFCicSgv7Sy7s/s=
+github.com/prometheus/client_golang v0.9.1/go.mod h1:7SWBe2y4D6OKWSNQJUaRYU/AaXPKyh/dDVn+NZz0KFw=
+github.com/prometheus/client_golang v1.0.0/go.mod h1:db9x61etRT2tGnBNRi70OPL5FsnadC4Ky3P0J6CfImo=
+github.com/prometheus/client_golang v1.7.1/go.mod h1:PY5Wy2awLA44sXw4AOSfFBetzPP4j5+D6mVACh+pe2M=
+github.com/prometheus/client_golang v1.11.1/go.mod h1:Z6t4BnS23TR94PD6BsDNk8yVqroYurpAkEiz0P2BEV0=
+github.com/prometheus/client_model v0.0.0-20180712105110-5c3871d89910/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
+github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
+github.com/prometheus/client_model v0.0.0-20190812154241-14fe0d1b01d4/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
+github.com/prometheus/client_model v0.2.0/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
+github.com/prometheus/common v0.4.1/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4=
+github.com/prometheus/common v0.10.0/go.mod h1:Tlit/dnDKsSWFlCLTWaA1cyBgKHSMdTB80sz/V91rCo=
+github.com/prometheus/common v0.26.0/go.mod h1:M7rCNAaPfAosfx8veZJCuw84e35h3Cfd9VFqTh1DIvc=
+github.com/prometheus/procfs v0.0.0-20181005140218-185b4288413d/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
+github.com/prometheus/procfs v0.0.2/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA=
+github.com/prometheus/procfs v0.1.3/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4OA4YeYWdaU=
+github.com/prometheus/procfs v0.6.0/go.mod h1:cz+aTbrPOrUb4q7XlbU9ygM+/jj0fzG6c1xBZuNvfVA=
+github.com/rhnvrm/simples3 v0.6.1/go.mod h1:Y+3vYm2V7Y4VijFoJHHTrja6OgPrJ2cBti8dPGkC3sA=
+github.com/rivo/uniseg v0.2.0/go.mod h1:J6wj4VEh+S6ZtnVlnTBMWIodfgj8LQOQFoIToxlJtxc=
+github.com/rivo/uniseg v0.4.7 h1:WUdvkW8uEhrYfLC4ZzdpI2ztxP1I582+49Oc5Mq64VQ=
+github.com/rivo/uniseg v0.4.7/go.mod h1:FN3SvrM+Zdj16jyLfmOkMNblXMcoc8DfTHruCPUcx88=
+github.com/rogpeppe/fastuuid v1.2.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ=
+github.com/rogpeppe/go-internal v1.14.1 h1:UQB4HGPB6osV0SQTLymcB4TgvyWu6ZyliaW0tI/otEQ=
+github.com/rogpeppe/go-internal v1.14.1/go.mod h1:MaRKkUm5W0goXpeCfT7UZI6fk/L7L7so1lCWt35ZSgc=
+github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM=
+github.com/ryanuber/columnize v0.0.0-20160712163229-9b3edd62028f/go.mod h1:sm1tb6uqfes/u+d4ooFouqFdy9/2g9QGwK3SQygK0Ts=
+github.com/ryanuber/columnize v2.1.0+incompatible/go.mod h1:sm1tb6uqfes/u+d4ooFouqFdy9/2g9QGwK3SQygK0Ts=
+github.com/ryanuber/go-glob v1.0.0/go.mod h1:807d1WSdnB0XRJzKNil9Om6lcp/3a0v4qIHxIXzX/Yc=
+github.com/samber/lo v1.37.0 h1:XjVcB8g6tgUp8rsPsJ2CvhClfImrpL04YpQHXeHPhRw=
+github.com/samber/lo v1.37.0/go.mod h1:9vaz2O4o8oOnK23pd2TrXufcbdbJIa3b6cstBWKpopA=
+github.com/sean-/seed v0.0.0-20170313163322-e2103e2c3529/go.mod h1:DxrIzT+xaE7yg65j358z/aeFdxmN0P9QXhEzd20vsDc=
+github.com/sergi/go-diff v1.3.2-0.20230802210424-5b0b94c5c0d3 h1:n661drycOFuPLCN3Uc8sB6B/s6Z4t2xvBgU1htSHuq8=
+github.com/sergi/go-diff v1.3.2-0.20230802210424-5b0b94c5c0d3/go.mod h1:A0bzQcvG0E7Rwjx0REVgAGH58e96+X0MeOfepqsbeW4=
+github.com/shopspring/decimal v1.2.0/go.mod h1:DKyhrW/HYNuLGql+MJL6WCR6knT2jwCFRcu2hWCYk4o=
+github.com/shopspring/decimal v1.3.1 h1:2Usl1nmF/WZucqkFZhnfFYxxxu8LG21F6nPQBE5gKV8=
+github.com/shopspring/decimal v1.3.1/go.mod h1:DKyhrW/HYNuLGql+MJL6WCR6knT2jwCFRcu2hWCYk4o=
+github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo=
+github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE=
+github.com/sirupsen/logrus v1.6.0/go.mod h1:7uNnSEd1DgxDLC74fIahvMZmmYsHGZGEOFrfsX/uA88=
+github.com/skeema/knownhosts v1.3.1 h1:X2osQ+RAjK76shCbvhHHHVl3ZlgDm8apHEHFqRjnBY8=
+github.com/skeema/knownhosts v1.3.1/go.mod h1:r7KTdC8l4uxWRyK2TpQZ/1o5HaSzh06ePQNxPwTcfiY=
+github.com/spf13/cast v1.3.1/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE=
+github.com/spf13/cast v1.5.0 h1:rj3WzYc11XZaIZMPKmwP96zkFEnnAmV8s6XbB2aY32w=
+github.com/spf13/cast v1.5.0/go.mod h1:SpXXQ5YoyJw6s3/6cMTQuxvgRl3PCJiyaX9p6b155UU=
+github.com/spf13/cobra v1.6.1 h1:o94oiPyS4KD1mPy2fmcYYHHfCxLqYjJOhGsCHFZtEzA=
+github.com/spf13/cobra v1.6.1/go.mod h1:IOw/AERYS7UzyrGinqmz6HLUo219MORXGxhbaJUqzrY=
+github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA=
+github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg=
+github.com/stackitcloud/stackit-sdk-go/core v0.20.1 h1:odiuhhRXmxvEvnVTeZSN9u98edvw2Cd3DcnkepncP3M=
+github.com/stackitcloud/stackit-sdk-go/core v0.20.1/go.mod h1:fqto7M82ynGhEnpZU6VkQKYWYoFG5goC076JWXTUPRQ=
+github.com/stackitcloud/stackit-sdk-go/services/authorization v0.9.0 h1:7ZKd3b+E/R4TEVShLTXxx5FrsuDuJBOyuVOuKTMa4mo=
+github.com/stackitcloud/stackit-sdk-go/services/authorization v0.9.0/go.mod h1:/FoXa6hF77Gv8brrvLBCKa5ie1Xy9xn39yfHwaln9Tw=
+github.com/stackitcloud/stackit-sdk-go/services/cdn v1.6.0 h1:Q+qIdejeMsYMkbtVoI9BpGlKGdSVFRBhH/zj44SP8TM=
+github.com/stackitcloud/stackit-sdk-go/services/cdn v1.6.0/go.mod h1:YGadfhuy8yoseczTxF7vN4t9ES2WxGQr0Pug14ii7y4=
+github.com/stackitcloud/stackit-sdk-go/services/dns v0.17.1 h1:CnhAMLql0MNmAeq4roQKN8OpSKX4FSgTU6Eu6detB4I=
+github.com/stackitcloud/stackit-sdk-go/services/dns v0.17.1/go.mod h1:7Bx85knfNSBxulPdJUFuBePXNee3cO+sOTYnUG6M+iQ=
+github.com/stackitcloud/stackit-sdk-go/services/git v0.8.0 h1:/weT7P5Uwy1Qlhw0NidqtQBlbbb/dQehweDV/I9ShXg=
+github.com/stackitcloud/stackit-sdk-go/services/git v0.8.0/go.mod h1:AXFfYBJZIW1o0W0zZEb/proQMhMsb3Nn5E1htS8NDPE=
+github.com/stackitcloud/stackit-sdk-go/services/iaas v1.3.0 h1:U/x0tc487X9msMS5yZYjrBAAKrCx87Trmt0kh8JiARA=
+github.com/stackitcloud/stackit-sdk-go/services/iaas v1.3.0/go.mod h1:6+5+RCDfU7eQN3+/SGdOtx7Bq9dEa2FrHz/jflgY1M4=
+github.com/stackitcloud/stackit-sdk-go/services/iaasalpha v0.1.21-alpha h1:m1jq6a8dbUe+suFuUNdHmM/cSehpGLUtDbK1CqLqydg=
+github.com/stackitcloud/stackit-sdk-go/services/iaasalpha v0.1.21-alpha/go.mod h1:Nu1b5Phsv8plgZ51+fkxPVsU91ZJ5Ayz+cthilxdmQ8=
+github.com/stackitcloud/stackit-sdk-go/services/kms v1.0.0 h1:zxoOv7Fu+FmdsvTKiKkbmLItrMKfL+QoVtz9ReEF30E=
+github.com/stackitcloud/stackit-sdk-go/services/kms v1.0.0/go.mod h1:KEPVoO21pC4bjy5l0nyhjUJ0+uVwVWb+k2TYrzJ8xYw=
+github.com/stackitcloud/stackit-sdk-go/services/loadbalancer v1.6.0 h1:q33ZaCBVEBUsnMDxYyuJKtJvGcE5nKgvuPed3s8zXNI=
+github.com/stackitcloud/stackit-sdk-go/services/loadbalancer v1.6.0/go.mod h1:20QOZ3rBC9wTGgzXzLz9M6YheX0VaxWE0/JI+s8On7k=
+github.com/stackitcloud/stackit-sdk-go/services/logme v0.25.1 h1:hv5WrRU9rN6Jx4OwdOGJRyaQrfA9p1tzEoQK6/CDyoA=
+github.com/stackitcloud/stackit-sdk-go/services/logme v0.25.1/go.mod h1:ivt8lvnAoBZsde2jSAuicyn6RgTmHvvNAJ3whaUbAD4=
+github.com/stackitcloud/stackit-sdk-go/services/mariadb v0.25.1 h1:Db/ebOL2vbpIeh5XB2Ews2B9Lj5DJlMWIEJh60FfZ4Y=
+github.com/stackitcloud/stackit-sdk-go/services/mariadb v0.25.1/go.mod h1:8jdN4v2euK3f9gfdzbRi8e4nBJ8g/Q5YF9aPB4M4fCQ=
+github.com/stackitcloud/stackit-sdk-go/services/modelserving v0.6.0 h1:JZI+3sLVAtTFk4QJ/ao2bAumzBq+iV6dUvDoIrOKTcw=
+github.com/stackitcloud/stackit-sdk-go/services/modelserving v0.6.0/go.mod h1:DvNLTENxoJEQ8AwUvcVBoWqVtdZNS4vEJppTKfvfeec=
+github.com/stackitcloud/stackit-sdk-go/services/mongodbflex v1.5.2 h1:BQ+qAkVS/aGHepE/+gVsvSg1sRkPOyIUI/jkCyUOrWg=
+github.com/stackitcloud/stackit-sdk-go/services/mongodbflex v1.5.2/go.mod h1:oc8Mpwl7O6EZwG0YxfhOzNCJwNQBWK5rFh764OtxoMY=
+github.com/stackitcloud/stackit-sdk-go/services/objectstorage v1.4.0 h1:g3yNDUc3JydAikezUrI9bQ4nuMJpVeAQ35jOFfFmq1U=
+github.com/stackitcloud/stackit-sdk-go/services/objectstorage v1.4.0/go.mod h1:foslkEiICdtHR3v0A/i/Rgo6EP9MMula9XNC9luNOgw=
+github.com/stackitcloud/stackit-sdk-go/services/observability v0.15.0 h1:MA5i1ScjXLWe5CYeFCLHeZzNS1AH4mbx1kUyiVbxKjI=
+github.com/stackitcloud/stackit-sdk-go/services/observability v0.15.0/go.mod h1:tJEOi6L0le4yQZPGwalup/PZ13gqs1aCQDqlUs2cYW0=
+github.com/stackitcloud/stackit-sdk-go/services/opensearch v0.24.1 h1:50n87uZn0EvSP9hJGLqd3Wm2hfqbyh7BMGGCk7axgqA=
+github.com/stackitcloud/stackit-sdk-go/services/opensearch v0.24.1/go.mod h1:jfguuSPa56Z5Bzs/Xg/CI37XzPo5Zn5lzC5LhfuT8Qc=
+github.com/stackitcloud/stackit-sdk-go/services/postgresflex v1.2.1 h1:K8vXele3U6b5urcSIpq21EkVblWfPDY3eMPSuQ48TkI=
+github.com/stackitcloud/stackit-sdk-go/services/postgresflex v1.2.1/go.mod h1:hyhw+I19NtjKmRLcUkY4boaTxnYSPFGbpn4RxvGqH2s=
+github.com/stackitcloud/stackit-sdk-go/services/rabbitmq v0.25.1 h1:ALrDCBih8Fu8e6530KdOjuH0iMxOLntO381BbKFlTFY=
+github.com/stackitcloud/stackit-sdk-go/services/rabbitmq v0.25.1/go.mod h1:+qGWSehoV0Js3FalgvT/bOgPj+UqW4I7lP5s8uAxP+o=
+github.com/stackitcloud/stackit-sdk-go/services/redis v0.25.1 h1:8uPt82Ez34OYMOijjEYxB1zUW6kiybkt6veQKl0AL68=
+github.com/stackitcloud/stackit-sdk-go/services/redis v0.25.1/go.mod h1:1Y2GEICmZDt+kr8aGnBx/sjYVAIYHmtfC8xYi9oxNEE=
+github.com/stackitcloud/stackit-sdk-go/services/resourcemanager v0.18.2 h1:VDIXOvRNmSYMeF0qQ2+w4/ez04YutVDz73hSMuuOJ54=
+github.com/stackitcloud/stackit-sdk-go/services/resourcemanager v0.18.2/go.mod h1:9zyEzPL4DnmU/SHq+SuMWTSO5BPxM1Z4g8Fp28n00ds=
+github.com/stackitcloud/stackit-sdk-go/services/scf v0.2.1 h1:OdofRB6uj6lwN/TXLVHVrEOwNMG34MlFNwkiHD+eOts=
+github.com/stackitcloud/stackit-sdk-go/services/scf v0.2.1/go.mod h1:5p7Xi8jadpJNDYr0t+07DXS104/RJLfhhA1r6P7PlGs=
+github.com/stackitcloud/stackit-sdk-go/services/secretsmanager v0.13.1 h1:WKFzlHllql3JsVcAq+Y1m5pSMkvwp1qH3Vf2N7i8CPg=
+github.com/stackitcloud/stackit-sdk-go/services/secretsmanager v0.13.1/go.mod h1:WGMFtGugBmUxI+nibI7eUZIQk4AGlDvwqX+m17W1y5w=
+github.com/stackitcloud/stackit-sdk-go/services/serverbackup v1.3.2 h1:tfKC4Z6Uah9AQZrtCn/ytqOgc//ChQRfJ6ozxovgads=
+github.com/stackitcloud/stackit-sdk-go/services/serverbackup v1.3.2/go.mod h1:wV7/BUV3BCLq5+E1bHXrKKt/eOPVdWgLArWLAq7rZ/U=
+github.com/stackitcloud/stackit-sdk-go/services/serverupdate v1.2.1 h1:hcHX2n5pUsOcv2PPPbSJph1fQ/I6P7g7781T1f1ycEI=
+github.com/stackitcloud/stackit-sdk-go/services/serverupdate v1.2.1/go.mod h1:jZwTg3wU4/UxgNJ7TKlFZ3dTIlnfvppnW8kJTc4UXy8=
+github.com/stackitcloud/stackit-sdk-go/services/serviceaccount v0.11.1 h1:crKlHl7QVF97A8CTBK3PBtVpO9c/7qwFvRJi5UN/F7Y=
+github.com/stackitcloud/stackit-sdk-go/services/serviceaccount v0.11.1/go.mod h1:QCrAW/Rmf+styT25ke8cUV6hDHpdKNmAY14kkJ3+Fd8=
+github.com/stackitcloud/stackit-sdk-go/services/serviceenablement v1.2.2 h1:s2iag/Gc4tuQH7x5I0n4mQWVhpfl/cj+SVNAFAB5ck0=
+github.com/stackitcloud/stackit-sdk-go/services/serviceenablement v1.2.2/go.mod h1:DFEamKVoOjm/rjMwzfZK0Zg/hwsSkXOibdA4HcC6swk=
+github.com/stackitcloud/stackit-sdk-go/services/ske v1.4.0 h1:V6RFvybDeJvvmT3g7/BZodF0gozz3TEpahbpiTftbeY=
+github.com/stackitcloud/stackit-sdk-go/services/ske v1.4.0/go.mod h1:xRBgpJ8P5Nf1T5tD0tGAeNg1FNQzx5VF7qqOXt2Fp3s=
+github.com/stackitcloud/stackit-sdk-go/services/sqlserverflex v1.3.3 h1:TFefEGGxvcI7euqyosbLS/zSEOy+3JMGOirW3vNj/84=
+github.com/stackitcloud/stackit-sdk-go/services/sqlserverflex v1.3.3/go.mod h1:Jsry+gfhuXv2P0ldfa48BaL605NhDjdQMgaoV8czlbo=
+github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
+github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
+github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw=
+github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
+github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
+github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
+github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA=
+github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
+github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
+github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
+github.com/stretchr/testify v1.7.2/go.mod h1:R6va5+xMeoiuVRoj+gSkQ7d3FALtqAAGI1FQKckRals=
+github.com/stretchr/testify v1.7.4/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
+github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
+github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
+github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
+github.com/teambition/rrule-go v1.8.2 h1:lIjpjvWTj9fFUZCmuoVDrKVOtdiyzbzc93qTmRVe/J8=
+github.com/teambition/rrule-go v1.8.2/go.mod h1:Ieq5AbrKGciP1V//Wq8ktsTXwSwJHDD5mD/wLBGl3p4=
+github.com/thanhpk/randstr v1.0.4 h1:IN78qu/bR+My+gHCvMEXhR/i5oriVHcTB/BJJIRTsNo=
+github.com/thanhpk/randstr v1.0.4/go.mod h1:M/H2P1eNLZzlDwAzpkkkUvoyNNMbzRGhESZuEQk3r0U=
+github.com/tidwall/pretty v1.0.0/go.mod h1:XNkn88O1ChpSDQmQeStsy+sBenx6DDtFZJxhVysOjyk=
+github.com/vmihailenco/msgpack v3.3.3+incompatible/go.mod h1:fy3FlTQTDXWkZ7Bh6AcGMlsjHatGryHQYUTf1ShIgkk=
+github.com/vmihailenco/msgpack v4.0.4+incompatible h1:dSLoQfGFAo3F6OoNhwUmLwVgaUXK79GlxNBwueZn0xI=
+github.com/vmihailenco/msgpack v4.0.4+incompatible/go.mod h1:fy3FlTQTDXWkZ7Bh6AcGMlsjHatGryHQYUTf1ShIgkk=
+github.com/vmihailenco/msgpack/v5 v5.4.1 h1:cQriyiUvjTwOHg8QZaPihLWeRAAVoCpE00IUPn0Bjt8=
+github.com/vmihailenco/msgpack/v5 v5.4.1/go.mod h1:GaZTsDaehaPpQVyxrf5mtQlH+pc21PIudVV/E3rRQok=
+github.com/vmihailenco/tagparser/v2 v2.0.0 h1:y09buUbR+b5aycVFQs/g70pqKVZNBmxwAhO7/IwNM9g=
+github.com/vmihailenco/tagparser/v2 v2.0.0/go.mod h1:Wri+At7QHww0WTrCBeu4J6bNtoV6mEfg5OIWRZA9qds=
+github.com/xanzy/ssh-agent v0.3.3 h1:+/15pJfg/RsTxqYcX6fHqOXZwwMP+2VyYWJeWM2qQFM=
+github.com/xanzy/ssh-agent v0.3.3/go.mod h1:6dzNDKs0J9rVPHPhaGCukekBHKqfl+L3KghI1Bc68Uw=
+github.com/xdg-go/pbkdf2 v1.0.0/go.mod h1:jrpuAogTd400dnrH08LKmI/xc1MbPOebTwRqcT5RDeI=
+github.com/xdg-go/scram v1.1.1/go.mod h1:RaEWvsqvNKKvBPvcKeFjrG2cJqOkHTiyTpzz23ni57g=
+github.com/xdg-go/stringprep v1.0.3/go.mod h1:W3f5j4i+9rC0kuIEJL0ky1VpHXQU3ocBgklLGvcBnW8=
+github.com/youmark/pkcs8 v0.0.0-20181117223130-1be2e3e5546d/go.mod h1:rHwXgn7JulP+udvsHwJoVG1YGAP6VLg4y9I5dyZdqmA=
+github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
+github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
+github.com/yuin/goldmark v1.3.5/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1Zlc8k=
+github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY=
+github.com/yuin/goldmark v1.7.7 h1:5m9rrB1sW3JUMToKFQfb+FGt1U7r57IHu5GrYrG2nqU=
+github.com/yuin/goldmark v1.7.7/go.mod h1:uzxRWxtg69N339t3louHJ7+O03ezfj6PlliRlaOzY1E=
+github.com/yuin/goldmark-meta v1.1.0 h1:pWw+JLHGZe8Rk0EGsMVssiNb/AaPMHfSRszZeUeiOUc=
+github.com/yuin/goldmark-meta v1.1.0/go.mod h1:U4spWENafuA7Zyg+Lj5RqK/MF+ovMYtBvXi1lBb2VP0=
+github.com/zclconf/go-cty v1.17.0 h1:seZvECve6XX4tmnvRzWtJNHdscMtYEx5R7bnnVyd/d0=
+github.com/zclconf/go-cty v1.17.0/go.mod h1:wqFzcImaLTI6A5HfsRwB0nj5n0MRZFwmey8YoFPPs3U=
+github.com/zclconf/go-cty-debug v0.0.0-20240509010212-0d6042c53940 h1:4r45xpDWB6ZMSMNJFMOjqrGHynW3DIBuR2H9j0ug+Mo=
+github.com/zclconf/go-cty-debug v0.0.0-20240509010212-0d6042c53940/go.mod h1:CmBdvvj3nqzfzJ6nTCIwDTPZ56aVGvDrmztiO5g3qrM=
+go.abhg.dev/goldmark/frontmatter v0.2.0 h1:P8kPG0YkL12+aYk2yU3xHv4tcXzeVnN+gU0tJ5JnxRw=
+go.abhg.dev/goldmark/frontmatter v0.2.0/go.mod h1:XqrEkZuM57djk7zrlRUB02x8I5J0px76YjkOzhB4YlU=
+go.etcd.io/etcd/api/v3 v3.5.4/go.mod h1:5GB2vv4A4AOn3yk7MftYGHkUfGtDHnEraIjym4dYz5A=
+go.etcd.io/etcd/client/pkg/v3 v3.5.4/go.mod h1:IJHfcCEKxYu1Os13ZdwCwIUTUVGYTSAM3YSwc9/Ac1g=
+go.etcd.io/etcd/client/v3 v3.5.4/go.mod h1:ZaRkVgBZC+L+dLCjTcF1hRXpgZXQPOvnA/Ak/gq3kiY=
+go.mongodb.org/mongo-driver v1.10.0 h1:UtV6N5k14upNp4LTduX0QCufG124fSu25Wz9tu94GLg=
+go.mongodb.org/mongo-driver v1.10.0/go.mod h1:wsihk0Kdgv8Kqu1Anit4sfK+22vSFbUrAVEYRhCXrA8=
+go.opentelemetry.io/auto/sdk v1.1.0 h1:cH53jehLUN6UFLY71z+NDOiNJqDdPRaXzTel0sJySYA=
+go.opentelemetry.io/auto/sdk v1.1.0/go.mod h1:3wSPjt5PWp2RhlCcmmOial7AvC4DQqZb7a7wCow3W8A=
+go.opentelemetry.io/otel v1.37.0 h1:9zhNfelUvx0KBfu/gb+ZgeAfAgtWrfHJZcAqFC228wQ=
+go.opentelemetry.io/otel v1.37.0/go.mod h1:ehE/umFRLnuLa/vSccNq9oS1ErUlkkK71gMcN34UG8I=
+go.opentelemetry.io/otel/metric v1.37.0 h1:mvwbQS5m0tbmqML4NqK+e3aDiO02vsf/WgbsdpcPoZE=
+go.opentelemetry.io/otel/metric v1.37.0/go.mod h1:04wGrZurHYKOc+RKeye86GwKiTb9FKm1WHtO+4EVr2E=
+go.opentelemetry.io/otel/sdk v1.37.0 h1:ItB0QUqnjesGRvNcmAcU0LyvkVyGJ2xftD29bWdDvKI=
+go.opentelemetry.io/otel/sdk v1.37.0/go.mod h1:VredYzxUvuo2q3WRcDnKDjbdvmO0sCzOvVAiY+yUkAg=
+go.opentelemetry.io/otel/sdk/metric v1.37.0 h1:90lI228XrB9jCMuSdA0673aubgRobVZFhbjxHHspCPc=
+go.opentelemetry.io/otel/sdk/metric v1.37.0/go.mod h1:cNen4ZWfiD37l5NhS+Keb5RXVWZWpRE+9WyVCpbo5ps=
+go.opentelemetry.io/otel/trace v1.37.0 h1:HLdcFNbRQBE2imdSEgm/kwqmQj1Or1l/7bW6mxVK7z4=
+go.opentelemetry.io/otel/trace v1.37.0/go.mod h1:TlgrlQ+PtQO5XFerSPUYG0JSgGyryXewPGyayAWSBS0=
+go.uber.org/atomic v1.7.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc=
+go.uber.org/multierr v1.6.0/go.mod h1:cdWPpRnG4AhwMwsgIHip0KRBQjJy5kYEpYjJxpXp9iU=
+go.uber.org/zap v1.17.0/go.mod h1:MXVU+bhUf/A7Xi2HNOnopQOrmycQ5Ih87HtOu4q5SSo=
+golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
+golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
+golang.org/x/crypto v0.0.0-20190923035154-9ee001bba392/go.mod h1:/lpIB1dKB+9EgE3H3cr1v9wB50oz8l4C4h62xy7jSTY=
+golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
+golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
+golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=
+golang.org/x/crypto v0.0.0-20220622213112-05595931fe9d/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4=
+golang.org/x/crypto v0.3.0/go.mod h1:hebNnKkNXi2UzZN1eVRvBB7co0a+JxK6XbPiWVs/3J4=
+golang.org/x/crypto v0.3.1-0.20221117191849-2c476679df9a/go.mod h1:hebNnKkNXi2UzZN1eVRvBB7co0a+JxK6XbPiWVs/3J4=
+golang.org/x/crypto v0.7.0/go.mod h1:pYwdfH91IfpZVANVyUOhSIPZaFoJGxTFbZhFTx+dXZU=
+golang.org/x/crypto v0.46.0 h1:cKRW/pmt1pKAfetfu+RCEvjvZkA9RimPbh7bhFjGVBU=
+golang.org/x/crypto v0.46.0/go.mod h1:Evb/oLKmMraqjZ2iQTwDwvCtJkczlDuTmdJXoZVzqU0=
+golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA=
+golang.org/x/exp v0.0.0-20220303212507-bbda1eaf7a17 h1:3MTrJm4PyNL9NBqvYDSj3DHl46qQakyfqfWo4jgfaEM=
+golang.org/x/exp v0.0.0-20220303212507-bbda1eaf7a17/go.mod h1:lgLbSvA5ygNOMpwM/9anMpWVlVJ7Z+cHWq/eFuinpGE=
+golang.org/x/exp v0.0.0-20230626212559-97b1e661b5df h1:UA2aFVmmsIlefxMk29Dp2juaUSth8Pyn3Tq5Y5mJGME=
+golang.org/x/exp v0.0.0-20230626212559-97b1e661b5df/go.mod h1:FXUEEKJgO7OQYeo8N01OfiKP8RXMtf6e8aTskBGqWdc=
+golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE=
+golang.org/x/lint v0.0.0-20190227174305-5b3e6a55c961/go.mod h1:wehouNa3lNwaWXcvxsM5YxQ5yQlVC4a0KAMCusXpPoU=
+golang.org/x/lint v0.0.0-20190313153728-d0100b6bd8b3/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc=
+golang.org/x/lint v0.0.0-20210508222113-6edffad5e616/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY=
+golang.org/x/mod v0.1.1-0.20191105210325-c90efee705ee/go.mod h1:QqPTAvyqsEbceGzBzNggFXnrqF1CaUcvgkdR5Ot7KZg=
+golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
+golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
+golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
+golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4=
+golang.org/x/mod v0.8.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs=
+golang.org/x/mod v0.31.0 h1:HaW9xtz0+kOcWKwli0ZXy79Ix+UW/vOfmWI5QVd2tgI=
+golang.org/x/mod v0.31.0/go.mod h1:43JraMp9cGx1Rx3AqioxrbrhNsLl2l/iNAvuBkrezpg=
+golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20181114220301-adae6a3d119a/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20190108225652-1e06a53dbb7e/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20190213061140-3a22650c66bd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
+golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
+golang.org/x/net v0.0.0-20190603091049-60506f45cf65/go.mod h1:HSz+uSET+XFnRR8LxR5pz3Of3rY3CfYBVs4xY44aLks=
+golang.org/x/net v0.0.0-20190613194153-d28f0bde5980/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/net v0.0.0-20190923162816-aa69164e4478/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/net v0.0.0-20200625001655-4c5254603344/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
+golang.org/x/net v0.0.0-20200822124328-c89045814202/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
+golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
+golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg=
+golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM=
+golang.org/x/net v0.0.0-20210410081132-afb366fc7cd1/go.mod h1:9tjilg8BloeKEkVJvy7fQ90B1CfIiPueXVOjqfkSzI8=
+golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
+golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c=
+golang.org/x/net v0.2.0/go.mod h1:KqCZLdyyvdV855qA2rE3GC2aiw5xGR5TEjj8smXukLY=
+golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs=
+golang.org/x/net v0.8.0/go.mod h1:QVkue5JL9kW//ek3r6jTKnTFis1tRmNAW2P1shuFdJc=
+golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg=
+golang.org/x/net v0.48.0 h1:zyQRTTrjc33Lhh0fBgT/H3oZq9WuvRR5gPC70xpDiQU=
+golang.org/x/net v0.48.0/go.mod h1:+ndRgGjkh8FGtu1w1FGbEC31if4VrNVMuKTgcAAnQRY=
+golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
+golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
+golang.org/x/oauth2 v0.0.0-20200107190931-bf48bf16ab8d/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
+golang.org/x/oauth2 v0.8.0/go.mod h1:yr7u4HXZRm1R1kBWqr/xKNqewf0plRYoB7sla+BCIXE=
+golang.org/x/oauth2 v0.30.0 h1:dnDm7JmhM45NNpd8FDDeLhK6FwqbOf4MLCM9zb1BOHI=
+golang.org/x/oauth2 v0.30.0/go.mod h1:B++QgG3ZKulg6sRPGD/mqlHQs5rB3Ml9erfeDY7xKlU=
+golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20190227155943-e225da77a7e6/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20201207232520-09787c993a3a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.19.0 h1:vV+1eWNmZ5geRlYjzm2adRgW2/mcpevXNg50YZtPCE4=
+golang.org/x/sync v0.19.0/go.mod h1:9KTHXmSnoGruLpwFjVSX0lNNA75CykiMECbovNTZqGI=
+golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20181116152217-5ac8a444bdc5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20190129075346-302c3dd5f1cc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20190222072716-a9d3bda3a223/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20190403152447-81d4e9dc473e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20190922100055-0a153f010e69/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20190924154521-2837fb4f24fe/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20191005200804-aed5e4c7ecf9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20191008105621-543471e840be/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20191026070338-33540a1f6037/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200106162015-b016eb3dc98e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200124204421-9fbb57f87de9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200223170610-d5e6a3e2c0ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200615200032-f1bc736245b1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200625212154-ddb9806d33ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20210303074136-134d130e1a04/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20210403161142-5e06dd20ab57/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20210603081109-ebe580a85c40/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20210927094055-39ccf1dd6fa6/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20211007075335-d3039528d8ac/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20220412211240-33da011f77ad/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20220503163025-988cb79eb6c6/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.1.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.2.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.3.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.39.0 h1:CvCKL8MeisomCi6qNZ+wbb0DN9E5AATixKsvNtMoMFk=
+golang.org/x/sys v0.39.0/go.mod h1:OgkHotnGiDImocRcuBABYBEXf8A9a87e/uXjp9XT3ks=
+golang.org/x/telemetry v0.0.0-20251203150158-8fff8a5912fc h1:bH6xUXay0AIFMElXG2rQ4uiE+7ncwtiOdPfYK1NK2XA=
+golang.org/x/telemetry v0.0.0-20251203150158-8fff8a5912fc/go.mod h1:hKdjCMrbv9skySur+Nek8Hd0uJ0GuxJIoIX2payrIdQ=
+golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
+golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
+golang.org/x/term v0.2.0/go.mod h1:TVmDHMZPmdnySmBfhjOoOdhjzdE1h4u1VwSiw2l1Nuc=
+golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k=
+golang.org/x/term v0.6.0/go.mod h1:m6U89DPEgQRMq3DNkDClhWw02AUbt2daBVO4cn4Hv9U=
+golang.org/x/term v0.8.0/go.mod h1:xPskH00ivmX89bAKVGSKKtLOWNx2+17Eiy94tnKShWo=
+golang.org/x/term v0.38.0 h1:PQ5pkm/rLO6HnxFR7N2lJHOZX6Kez5Y1gDSJla6jo7Q=
+golang.org/x/term v0.38.0/go.mod h1:bSEAKrOT1W+VSu9TSCMtoGEOUcKxOKgl3LE5QEF/xVg=
+golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
+golang.org/x/text v0.3.1-0.20181227161524-e6919f6577db/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk=
+golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk=
+golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
+golang.org/x/text v0.3.5/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
+golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
+golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ=
+golang.org/x/text v0.3.8/go.mod h1:E6s5w1FMmriuDzIBO73fBruAKo1PCIq6d2Q6DHfQ8WQ=
+golang.org/x/text v0.4.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8=
+golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8=
+golang.org/x/text v0.8.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8=
+golang.org/x/text v0.9.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8=
+golang.org/x/text v0.32.0 h1:ZD01bjUt1FQ9WJ0ClOL5vxgxOI/sVCNgX1YtKwcY0mU=
+golang.org/x/text v0.32.0/go.mod h1:o/rUWzghvpD5TXrTIBuJU77MTaN0ljMWE47kxGJQ7jY=
+golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
+golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
+golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
+golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY=
+golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs=
+golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q=
+golang.org/x/tools v0.0.0-20190907020128-2ca718005c18/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
+golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
+golang.org/x/tools v0.0.0-20200130002326-2f3ba24bd6e7/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28=
+golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
+golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
+golang.org/x/tools v0.1.2/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk=
+golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc=
+golang.org/x/tools v0.6.0/go.mod h1:Xwgl3UAJ/d3gWutnCtw505GrjyAbvKui8lOU390QaIU=
+golang.org/x/tools v0.40.0 h1:yLkxfA+Qnul4cs9QA3KnlFu0lVmd8JJfoq+E41uSutA=
+golang.org/x/tools v0.40.0/go.mod h1:Ik/tzLRlbscWpqqMRjyWYDisX8bG13FrdXp3o4Sr9lc=
+golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+gonum.org/v1/gonum v0.16.0 h1:5+ul4Swaf3ESvrOnidPp4GZbzf0mxVQpDCYUQE7OJfk=
+gonum.org/v1/gonum v0.16.0/go.mod h1:fef3am4MQ93R2HHpKnLk4/Tbh/s0+wqD5nfa6Pnwy4E=
+google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM=
+google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4=
+google.golang.org/appengine v1.6.7/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc=
+google.golang.org/appengine v1.6.8 h1:IhEN5q69dyKagZPYMSdIjS2HqprW324FRQZJcGqPAsM=
+google.golang.org/appengine v1.6.8/go.mod h1:1jJ3jBArFh5pcgW8gCtRJnepW8FzD1V44FJffLiz/Ds=
+google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc=
+google.golang.org/genproto v0.0.0-20190404172233-64821d5d2107/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE=
+google.golang.org/genproto v0.0.0-20190819201941-24fa4b261c55/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc=
+google.golang.org/genproto v0.0.0-20200513103714-09dca8ec2884/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
+google.golang.org/genproto v0.0.0-20200526211855-cb27e3aa2013/go.mod h1:NbSheEEYHJ7i3ixzK3sjbqSGDJWnxyFXZblF3eUsNvo=
+google.golang.org/genproto v0.0.0-20210602131652-f16073e35f0c/go.mod h1:UODoCrxHCcBojKKwX1terBiRUaqAsFqJiF615XL43r0=
+google.golang.org/genproto/googleapis/rpc v0.0.0-20250707201910-8d1bb00bc6a7 h1:pFyd6EwwL2TqFf8emdthzeX+gZE1ElRq3iM8pui4KBY=
+google.golang.org/genproto/googleapis/rpc v0.0.0-20250707201910-8d1bb00bc6a7/go.mod h1:qQ0YXyHHx3XkvlzUtpXDkS29lDSafHMZBAZDc03LQ3A=
+google.golang.org/grpc v1.14.0/go.mod h1:yo6s7OP7yaDglbqo1J04qKzAhqBH6lvTonzMVmEdcZw=
+google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c=
+google.golang.org/grpc v1.22.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg=
+google.golang.org/grpc v1.23.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg=
+google.golang.org/grpc v1.25.1/go.mod h1:c3i+UQWmh7LiEpx4sFZnkU36qjEYZ0imhYfXVyQciAY=
+google.golang.org/grpc v1.27.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk=
+google.golang.org/grpc v1.33.1/go.mod h1:fr5YgcSWrqhRRxogOsw7RzIpsmvOZ6IcH4kBYTpR3n0=
+google.golang.org/grpc v1.38.0/go.mod h1:NREThFqKR1f3iQ6oBuvc5LadQuXVGo9rkm5ZGrQdJfM=
+google.golang.org/grpc v1.75.1 h1:/ODCNEuf9VghjgO3rqLcfg8fiOP0nSluljWFlDxELLI=
+google.golang.org/grpc v1.75.1/go.mod h1:JtPAzKiq4v1xcAB2hydNlWI2RnF85XXcV0mhKXr2ecQ=
+google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8=
+google.golang.org/protobuf v0.0.0-20200221191635-4d8936d0db64/go.mod h1:kwYJMbMJ01Woi6D6+Kah6886xMZcty6N08ah7+eCXa0=
+google.golang.org/protobuf v0.0.0-20200228230310-ab0ca4ff8a60/go.mod h1:cfTl7dwQJ+fmap5saPgwCLgHXTUD7jkjRqWcaiX5VyM=
+google.golang.org/protobuf v1.20.1-0.20200309200217-e05f789c0967/go.mod h1:A+miEFZTKqfCUM6K7xSMQL9OKL/b6hQv+e19PK+JZNE=
+google.golang.org/protobuf v1.21.0/go.mod h1:47Nbq4nVaFHyn7ilMalzfO3qCViNmqZ2kzikPIcrTAo=
+google.golang.org/protobuf v1.22.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
+google.golang.org/protobuf v1.23.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
+google.golang.org/protobuf v1.23.1-0.20200526195155-81db48ad09cc/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
+google.golang.org/protobuf v1.25.0/go.mod h1:9JNX74DMeImyA3h4bdi1ymwjUzf21/xIlbajtzgsN7c=
+google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw=
+google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
+google.golang.org/protobuf v1.28.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
+google.golang.org/protobuf v1.36.9 h1:w2gp2mA27hUeUzj9Ex9FBjsBm40zfaDtEWow293U7Iw=
+google.golang.org/protobuf v1.36.9/go.mod h1:fuxRtAxBytpl4zzqUh6/eyUujkJdNiuEkXntxiD/uRU=
+gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw=
+gopkg.in/asn1-ber.v1 v1.0.0-20181015200546-f715ec2f112d/go.mod h1:cuepJuh7vyXfUyUwEgHQXw849cJrilpS5NeIjOWESAw=
+gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
+gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
+gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
+gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
+gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk=
+gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c/go.mod h1:JHkPIbrfpd72SG/EVd6muEfDQjcINNoR0C8j2r3qZ4Q=
+gopkg.in/square/go-jose.v2 v2.3.1/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI=
+gopkg.in/warnings.v0 v0.1.2 h1:wFXVbFY8DY5/xOe1ECiWdKCzZlxgshcYVNkBHstARME=
+gopkg.in/warnings.v0 v0.1.2/go.mod h1:jksf8JmL6Qr/oQM2OXTHunEvvTAsrWBLb6OOjuVWRNI=
+gopkg.in/yaml.v2 v2.2.1/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
+gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
+gopkg.in/yaml.v2 v2.2.3/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
+gopkg.in/yaml.v2 v2.2.4/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
+gopkg.in/yaml.v2 v2.2.5/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
+gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
+gopkg.in/yaml.v2 v2.3.0/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
+gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY=
+gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ=
+gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
+gopkg.in/yaml.v3 v3.0.0-20200605160147-a5ece683394c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
+gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
+gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
+gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
+honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
+honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
+sigs.k8s.io/yaml v1.2.0/go.mod h1:yfXDCHCao9+ENCvLSE62v9VSji2MKu5jeNfTrofGhJc=
diff --git a/golang-ci.yaml b/golang-ci.yaml
new file mode 100644
index 00000000..d134590b
--- /dev/null
+++ b/golang-ci.yaml
@@ -0,0 +1,97 @@
+# Copyright (c) STACKIT
+
+# This file contains all available configuration options
+# with their default values.
+
+# options for analysis running
+run:
+ # default concurrency is a available CPU number
+ concurrency: 4
+
+ # timeout for analysis, e.g. 30s, 5m, default is 1m
+ timeout: 5m
+linters-settings:
+ goimports:
+ # put imports beginning with prefix after 3rd-party packages;
+ # it's a comma-separated list of prefixes
+ local-prefixes: github.com/freiheit-com/nmww
+ depguard:
+ rules:
+ main:
+ list-mode: lax # Everything is allowed unless it is denied
+ deny:
+ - pkg: "github.com/stretchr/testify"
+ desc: Do not use a testing framework
+ misspell:
+ # Correct spellings using locale preferences for US or UK.
+ # Default is to use a neutral variety of English.
+ # Setting locale to US will correct the British spelling of 'colour' to 'color'.
+ locale: US
+ golint:
+ min-confidence: 0.8
+ gosec:
+ excludes:
+ # Suppressions: (see https://github.com/securego/gosec#available-rules for details)
+ - G104 # "Audit errors not checked" -> which we don't need and is a badly implemented version of errcheck
+ - G102 # "Bind to all interfaces" -> since this is normal in k8s
+ - G304 # "File path provided as taint input" -> too many false positives
+ - G307 # "Deferring unsafe method "Close" on type "io.ReadCloser" -> false positive when calling defer resp.Body.Close()
+ nakedret:
+ max-func-lines: 0
+ revive:
+ ignore-generated-header: true
+ severity: error
+ # https://github.com/mgechev/revive
+ rules:
+ - name: errorf
+ - name: context-as-argument
+ - name: error-return
+ - name: increment-decrement
+ - name: indent-error-flow
+ - name: superfluous-else
+ - name: unused-parameter
+ - name: unreachable-code
+ - name: atomic
+ - name: empty-lines
+ - name: early-return
+ gocritic:
+ enabled-tags:
+ - performance
+ - style
+ - experimental
+ disabled-checks:
+ - wrapperFunc
+ - typeDefFirst
+ - ifElseChain
+ - dupImport # https://github.com/go-critic/go-critic/issues/845
+linters:
+ enable:
+ # https://golangci-lint.run/usage/linters/
+ # default linters
+ - gosimple
+ - govet
+ - ineffassign
+ - staticcheck
+ - typecheck
+ - unused
+ # additional linters
+ - errorlint
+ - gochecknoinits
+ - gocritic
+ - gofmt
+ - goimports
+ - gosec
+ - misspell
+ - nakedret
+ - revive
+ - depguard
+ - bodyclose
+ - sqlclosecheck
+ - wastedassign
+ - forcetypeassert
+ - errcheck
+ disable:
+ - noctx # false positive: finds errors with http.NewRequest that dont make sense
+ - unparam # false positives
+issues:
+ exclude-use-default: false
diff --git a/main.go b/main.go
new file mode 100644
index 00000000..a059652c
--- /dev/null
+++ b/main.go
@@ -0,0 +1,30 @@
+// Copyright (c) STACKIT
+
+package main
+
+import (
+ "context"
+ "flag"
+ "log"
+
+ "github.com/hashicorp/terraform-plugin-framework/providerserver"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit"
+)
+
+var (
+ // goreleaser configuration will override this value
+ version string = "dev"
+)
+
+func main() {
+ var debug bool
+ flag.BoolVar(&debug, "debug", false, "allows debugging the provider")
+ flag.Parse()
+ err := providerserver.Serve(context.Background(), stackit.New(version), providerserver.ServeOpts{
+ Address: "registry.terraform.io/stackitcloud/stackit",
+ Debug: debug,
+ })
+ if err != nil {
+ log.Fatal(err.Error())
+ }
+}
diff --git a/pkg/postgresflexalpha/.openapi-generator/VERSION b/pkg/postgresflexalpha/.openapi-generator/VERSION
new file mode 100644
index 00000000..cd802a1e
--- /dev/null
+++ b/pkg/postgresflexalpha/.openapi-generator/VERSION
@@ -0,0 +1 @@
+6.6.0
\ No newline at end of file
diff --git a/pkg/postgresflexalpha/api_default.go b/pkg/postgresflexalpha/api_default.go
new file mode 100644
index 00000000..ca3987aa
--- /dev/null
+++ b/pkg/postgresflexalpha/api_default.go
@@ -0,0 +1,6257 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "bytes"
+ "context"
+ "fmt"
+ "io"
+ "net/http"
+ "net/url"
+ "strings"
+
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+ "github.com/stackitcloud/stackit-sdk-go/core/oapierror"
+)
+
+type DefaultApi interface {
+ /*
+ CreateDatabaseRequest Create Database
+ Create database for a user. Note: The name of a valid user must be provided in the 'options' map field using the key 'owner'
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiCreateDatabaseRequestRequest
+ */
+ CreateDatabaseRequest(ctx context.Context, projectId string, region string, instanceId string) ApiCreateDatabaseRequestRequest
+ /*
+ CreateDatabaseRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return CreateDatabaseResponse
+
+ */
+ CreateDatabaseRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*CreateDatabaseResponse, error)
+ /*
+ CreateInstanceRequest Create Instance
+ Create a new instance of a postgres database instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiCreateInstanceRequestRequest
+ */
+ CreateInstanceRequest(ctx context.Context, projectId string, region string) ApiCreateInstanceRequestRequest
+ /*
+ CreateInstanceRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return CreateInstanceResponse
+
+ */
+ CreateInstanceRequestExecute(ctx context.Context, projectId string, region string) (*CreateInstanceResponse, error)
+ /*
+ CreateUserRequest Create User
+ Create user for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiCreateUserRequestRequest
+ */
+ CreateUserRequest(ctx context.Context, projectId string, region string, instanceId string) ApiCreateUserRequestRequest
+ /*
+ CreateUserRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return CreateUserResponse
+
+ */
+ CreateUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*CreateUserResponse, error)
+ /*
+ DeleteDatabaseRequest Delete Database
+ Delete database for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseId The ID of the database.
+ @return ApiDeleteDatabaseRequestRequest
+ */
+ DeleteDatabaseRequest(ctx context.Context, projectId string, region string, instanceId string, databaseId int64) ApiDeleteDatabaseRequestRequest
+ /*
+ DeleteDatabaseRequestExecute executes the request
+
+ */
+ DeleteDatabaseRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseId int64) error
+ /*
+ DeleteInstanceRequest Delete Instance
+ Delete an available postgres instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiDeleteInstanceRequestRequest
+ */
+ DeleteInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiDeleteInstanceRequestRequest
+ /*
+ DeleteInstanceRequestExecute executes the request
+
+ */
+ DeleteInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) error
+ /*
+ DeleteUserRequest Delete User
+ Delete an user from a specific instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiDeleteUserRequestRequest
+ */
+ DeleteUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiDeleteUserRequestRequest
+ /*
+ DeleteUserRequestExecute executes the request
+
+ */
+ DeleteUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) error
+ /*
+ GetBackupRequest Get specific backup
+ Get information about a specific backup for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param backupId The ID of the backup.
+ @return ApiGetBackupRequestRequest
+ */
+ GetBackupRequest(ctx context.Context, projectId string, region string, instanceId string, backupId int64) ApiGetBackupRequestRequest
+ /*
+ GetBackupRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param backupId The ID of the backup.
+ @return GetBackupResponse
+
+ */
+ GetBackupRequestExecute(ctx context.Context, projectId string, region string, instanceId string, backupId int64) (*GetBackupResponse, error)
+ /*
+ GetCollationsRequest Get Collations for an Instance
+ Get available collations for an instance
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiGetCollationsRequestRequest
+ */
+ GetCollationsRequest(ctx context.Context, projectId string, region string, instanceId string) ApiGetCollationsRequestRequest
+ /*
+ GetCollationsRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return GetCollationsResponse
+
+ */
+ GetCollationsRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*GetCollationsResponse, error)
+ /*
+ GetFlavorsRequest Get Flavors
+ Get all available flavors for a project.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiGetFlavorsRequestRequest
+ */
+ GetFlavorsRequest(ctx context.Context, projectId string, region string) ApiGetFlavorsRequestRequest
+ /*
+ GetFlavorsRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return GetFlavorsResponse
+
+ */
+ GetFlavorsRequestExecute(ctx context.Context, projectId string, region string) (*GetFlavorsResponse, error)
+ /*
+ GetInstanceRequest Get Specific Instance
+ Get information about a specific available instance
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiGetInstanceRequestRequest
+ */
+ GetInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiGetInstanceRequestRequest
+ /*
+ GetInstanceRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return GetInstanceResponse
+
+ */
+ GetInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*GetInstanceResponse, error)
+ /*
+ GetUserRequest Get User
+ Get a specific available user for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiGetUserRequestRequest
+ */
+ GetUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiGetUserRequestRequest
+ /*
+ GetUserRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return GetUserResponse
+
+ */
+ GetUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) (*GetUserResponse, error)
+ /*
+ GetVersionsRequest Get Versions
+ Get available postgres versions for the project.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiGetVersionsRequestRequest
+ */
+ GetVersionsRequest(ctx context.Context, projectId string, region string) ApiGetVersionsRequestRequest
+ /*
+ GetVersionsRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return GetVersionsResponse
+
+ */
+ GetVersionsRequestExecute(ctx context.Context, projectId string, region string) (*GetVersionsResponse, error)
+ /*
+ ListBackupsRequest List backups
+ List all backups which are available for a specific instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListBackupsRequestRequest
+ */
+ ListBackupsRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListBackupsRequestRequest
+ /*
+ ListBackupsRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ListBackupResponse
+
+ */
+ ListBackupsRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListBackupResponse, error)
+ /*
+ ListDatabasesRequest List Databases
+ List available databases for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListDatabasesRequestRequest
+ */
+ ListDatabasesRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListDatabasesRequestRequest
+ /*
+ ListDatabasesRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ListDatabasesResponse
+
+ */
+ ListDatabasesRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListDatabasesResponse, error)
+ /*
+ ListInstancesRequest List Instances
+ List all available instances for your project.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiListInstancesRequestRequest
+ */
+ ListInstancesRequest(ctx context.Context, projectId string, region string) ApiListInstancesRequestRequest
+ /*
+ ListInstancesRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ListInstancesResponse
+
+ */
+ ListInstancesRequestExecute(ctx context.Context, projectId string, region string) (*ListInstancesResponse, error)
+ /*
+ ListRolesRequest List Roles
+ List available roles for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListRolesRequestRequest
+ */
+ ListRolesRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListRolesRequestRequest
+ /*
+ ListRolesRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ListRolesResponse
+
+ */
+ ListRolesRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListRolesResponse, error)
+ /*
+ ListUsersRequest List Users
+ List available users for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListUsersRequestRequest
+ */
+ ListUsersRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListUsersRequestRequest
+ /*
+ ListUsersRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ListUserResponse
+
+ */
+ ListUsersRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListUserResponse, error)
+ /*
+ PointInTimeRecoveryRequest Point in Time Recovery
+ Point in Time Recovery
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiPointInTimeRecoveryRequestRequest
+ */
+ PointInTimeRecoveryRequest(ctx context.Context, projectId string, region string, instanceId string) ApiPointInTimeRecoveryRequestRequest
+ /*
+ PointInTimeRecoveryRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return RecoveryResponse
+
+ */
+ PointInTimeRecoveryRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*RecoveryResponse, error)
+ /*
+ ProtectInstanceRequest Protect Instance
+ Toggle the deletion protection for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiProtectInstanceRequestRequest
+ */
+ ProtectInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiProtectInstanceRequestRequest
+ /*
+ ProtectInstanceRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ProtectInstanceResponse
+
+ */
+ ProtectInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ProtectInstanceResponse, error)
+ /*
+ ResetUserRequest Reset User
+ Reset an user from an specific instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiResetUserRequestRequest
+ */
+ ResetUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiResetUserRequestRequest
+ /*
+ ResetUserRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ResetUserResponse
+
+ */
+ ResetUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) (*ResetUserResponse, error)
+ /*
+ RestoreInstanceRequest Restore Instance
+ Restore an Instance from an existing backup. Instance is not reachable during the process of restore
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param backupId The ID of the backup.
+ @return ApiRestoreInstanceRequestRequest
+ */
+ RestoreInstanceRequest(ctx context.Context, projectId string, region string, instanceId string, backupId int64) ApiRestoreInstanceRequestRequest
+ /*
+ RestoreInstanceRequestExecute executes the request
+
+ */
+ RestoreInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string, backupId int64) error
+ /*
+ UpdateDatabasePartiallyRequest Update Database partially
+ Update a database partially in an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseId The ID of the database.
+ @return ApiUpdateDatabasePartiallyRequestRequest
+ */
+ UpdateDatabasePartiallyRequest(ctx context.Context, projectId string, region string, instanceId string, databaseId int64) ApiUpdateDatabasePartiallyRequestRequest
+ /*
+ UpdateDatabasePartiallyRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseId The ID of the database.
+ @return UpdateDatabasePartiallyResponse
+
+ */
+ UpdateDatabasePartiallyRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseId int64) (*UpdateDatabasePartiallyResponse, error)
+ /*
+ UpdateDatabaseRequest Update Database
+ Update a database in an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseId The ID of the database.
+ @return ApiUpdateDatabaseRequestRequest
+ */
+ UpdateDatabaseRequest(ctx context.Context, projectId string, region string, instanceId string, databaseId int64) ApiUpdateDatabaseRequestRequest
+ /*
+ UpdateDatabaseRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseId The ID of the database.
+ @return UpdateDatabaseResponse
+
+ */
+ UpdateDatabaseRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseId int64) (*UpdateDatabaseResponse, error)
+ /*
+ UpdateInstancePartiallyRequest Update Instance Partially
+ Update an available instance of a postgres database. No fields are required.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiUpdateInstancePartiallyRequestRequest
+ */
+ UpdateInstancePartiallyRequest(ctx context.Context, projectId string, region string, instanceId string) ApiUpdateInstancePartiallyRequestRequest
+ /*
+ UpdateInstancePartiallyRequestExecute executes the request
+
+ */
+ UpdateInstancePartiallyRequestExecute(ctx context.Context, projectId string, region string, instanceId string) error
+ /*
+ UpdateInstanceRequest Update Instance
+ Updates an available instance of a postgres database
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiUpdateInstanceRequestRequest
+ */
+ UpdateInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiUpdateInstanceRequestRequest
+ /*
+ UpdateInstanceRequestExecute executes the request
+
+ */
+ UpdateInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) error
+ /*
+ UpdateUserPartiallyRequest Update User Partially
+ Update an user partially for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiUpdateUserPartiallyRequestRequest
+ */
+ UpdateUserPartiallyRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiUpdateUserPartiallyRequestRequest
+ /*
+ UpdateUserPartiallyRequestExecute executes the request
+
+ */
+ UpdateUserPartiallyRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) error
+ /*
+ UpdateUserRequest Update User
+ Update user for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiUpdateUserRequestRequest
+ */
+ UpdateUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiUpdateUserRequestRequest
+ /*
+ UpdateUserRequestExecute executes the request
+
+ */
+ UpdateUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) error
+}
+
+type ApiCreateDatabaseRequestRequest interface {
+ // The request body containing the information for the new database.
+ CreateDatabaseRequestPayload(createDatabaseRequestPayload CreateDatabaseRequestPayload) ApiCreateDatabaseRequestRequest
+ Execute() (*CreateDatabaseResponse, error)
+}
+
+type ApiCreateInstanceRequestRequest interface {
+ // The request body with the parameters for the instance creation. Every parameter is required.
+ CreateInstanceRequestPayload(createInstanceRequestPayload CreateInstanceRequestPayload) ApiCreateInstanceRequestRequest
+ Execute() (*CreateInstanceResponse, error)
+}
+
+type ApiCreateUserRequestRequest interface {
+ // The request body containing the user details.
+ CreateUserRequestPayload(createUserRequestPayload CreateUserRequestPayload) ApiCreateUserRequestRequest
+ Execute() (*CreateUserResponse, error)
+}
+
+type ApiDeleteDatabaseRequestRequest interface {
+ Execute() error
+}
+
+type ApiDeleteInstanceRequestRequest interface {
+ Execute() error
+}
+
+type ApiDeleteUserRequestRequest interface {
+ Execute() error
+}
+
+type ApiGetBackupRequestRequest interface {
+ Execute() (*GetBackupResponse, error)
+}
+
+type ApiGetCollationsRequestRequest interface {
+ Execute() (*GetCollationsResponse, error)
+}
+
+type ApiGetFlavorsRequestRequest interface {
+ // Number of the page of items list to be returned.
+ Page(page int64) ApiGetFlavorsRequestRequest
+ // Number of items to be returned on each page.
+ Size(size int64) ApiGetFlavorsRequestRequest
+ // Sorting of the flavors to be returned on each page.
+ Sort(sort FlavorSort) ApiGetFlavorsRequestRequest
+ Execute() (*GetFlavorsResponse, error)
+}
+
+type ApiGetInstanceRequestRequest interface {
+ Execute() (*GetInstanceResponse, error)
+}
+
+type ApiGetUserRequestRequest interface {
+ Execute() (*GetUserResponse, error)
+}
+
+type ApiGetVersionsRequestRequest interface {
+ Execute() (*GetVersionsResponse, error)
+}
+
+type ApiListBackupsRequestRequest interface {
+ // Number of the page of items list to be returned.
+ Page(page int64) ApiListBackupsRequestRequest
+ // Number of items to be returned on each page.
+ Size(size int64) ApiListBackupsRequestRequest
+ // Sorting of the backups to be returned on each page.
+ Sort(sort BackupSort) ApiListBackupsRequestRequest
+ Execute() (*ListBackupResponse, error)
+}
+
+type ApiListDatabasesRequestRequest interface {
+ // Number of the page of items list to be returned.
+ Page(page int64) ApiListDatabasesRequestRequest
+ // Number of items to be returned on each page.
+ Size(size int64) ApiListDatabasesRequestRequest
+ // Sorting of the databases to be returned on each page.
+ Sort(sort DatabaseSort) ApiListDatabasesRequestRequest
+ Execute() (*ListDatabasesResponse, error)
+}
+
+type ApiListInstancesRequestRequest interface {
+ // Number of the page of items list to be returned.
+ Page(page int64) ApiListInstancesRequestRequest
+ // Number of items to be returned on each page.
+ Size(size int64) ApiListInstancesRequestRequest
+ // Sorting of the items to be returned on each page.
+ Sort(sort InstanceSort) ApiListInstancesRequestRequest
+ Execute() (*ListInstancesResponse, error)
+}
+
+type ApiListRolesRequestRequest interface {
+ Execute() (*ListRolesResponse, error)
+}
+
+type ApiListUsersRequestRequest interface {
+ // Number of the page of items list to be returned.
+ Page(page int64) ApiListUsersRequestRequest
+ // Number of items to be returned on each page.
+ Size(size int64) ApiListUsersRequestRequest
+ // Sorting of the users to be returned on each page.
+ Sort(sort UserSort) ApiListUsersRequestRequest
+ Execute() (*ListUserResponse, error)
+}
+
+type ApiPointInTimeRecoveryRequestRequest interface {
+ // The request body with the parameters for recover an instance by a point in time into a new instance.
+ PointInTimeRecoveryRequestPayload(pointInTimeRecoveryRequestPayload PointInTimeRecoveryRequestPayload) ApiPointInTimeRecoveryRequestRequest
+ Execute() (*RecoveryResponse, error)
+}
+
+type ApiProtectInstanceRequestRequest interface {
+ // The request body with flag isDeletable. Parameter is required.
+ ProtectInstanceRequestPayload(protectInstanceRequestPayload ProtectInstanceRequestPayload) ApiProtectInstanceRequestRequest
+ Execute() (*ProtectInstanceResponse, error)
+}
+
+type ApiResetUserRequestRequest interface {
+ Execute() (*ResetUserResponse, error)
+}
+
+type ApiRestoreInstanceRequestRequest interface {
+ Execute() error
+}
+
+type ApiUpdateDatabasePartiallyRequestRequest interface {
+ // The request body containing the information for the database update.
+ UpdateDatabasePartiallyRequestPayload(updateDatabasePartiallyRequestPayload UpdateDatabasePartiallyRequestPayload) ApiUpdateDatabasePartiallyRequestRequest
+ Execute() (*UpdateDatabasePartiallyResponse, error)
+}
+
+type ApiUpdateDatabaseRequestRequest interface {
+ // The request body containing the information for the database update.
+ UpdateDatabaseRequestPayload(updateDatabaseRequestPayload UpdateDatabaseRequestPayload) ApiUpdateDatabaseRequestRequest
+ Execute() (*UpdateDatabaseResponse, error)
+}
+
+type ApiUpdateInstancePartiallyRequestRequest interface {
+ // The request body with the parameters for updating the instance.
+ UpdateInstancePartiallyRequestPayload(updateInstancePartiallyRequestPayload UpdateInstancePartiallyRequestPayload) ApiUpdateInstancePartiallyRequestRequest
+ Execute() error
+}
+
+type ApiUpdateInstanceRequestRequest interface {
+ // The request body with the parameters for updating the instance
+ UpdateInstanceRequestPayload(updateInstanceRequestPayload UpdateInstanceRequestPayload) ApiUpdateInstanceRequestRequest
+ Execute() error
+}
+
+type ApiUpdateUserPartiallyRequestRequest interface {
+ // The Request body containing the new information for the user. If empty request body is send via patch, then login and createdb roles are removed from user.
+ UpdateUserPartiallyRequestPayload(updateUserPartiallyRequestPayload UpdateUserPartiallyRequestPayload) ApiUpdateUserPartiallyRequestRequest
+ Execute() error
+}
+
+type ApiUpdateUserRequestRequest interface {
+ // The Request body containing the updated infos for the user.
+ UpdateUserRequestPayload(updateUserRequestPayload UpdateUserRequestPayload) ApiUpdateUserRequestRequest
+ Execute() error
+}
+
+// DefaultApiService DefaultApi service
+type DefaultApiService service
+
+type CreateDatabaseRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ createDatabaseRequestPayload *CreateDatabaseRequestPayload
+}
+
+// The request body containing the information for the new database.
+
+func (r CreateDatabaseRequestRequest) CreateDatabaseRequestPayload(createDatabaseRequestPayload CreateDatabaseRequestPayload) ApiCreateDatabaseRequestRequest {
+ r.createDatabaseRequestPayload = &createDatabaseRequestPayload
+ return r
+}
+
+func (r CreateDatabaseRequestRequest) Execute() (*CreateDatabaseResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *CreateDatabaseResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.CreateDatabaseRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.createDatabaseRequestPayload == nil {
+ return localVarReturnValue, fmt.Errorf("createDatabaseRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.createDatabaseRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 409 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+CreateDatabaseRequest: Create Database
+
+Create database for a user. Note: The name of a valid user must be provided in the 'options' map field using the key 'owner'
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiCreateDatabaseRequestRequest
+*/
+func (a *APIClient) CreateDatabaseRequest(ctx context.Context, projectId string, region string, instanceId string) ApiCreateDatabaseRequestRequest {
+ return CreateDatabaseRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) CreateDatabaseRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*CreateDatabaseResponse, error) {
+ r := CreateDatabaseRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type CreateInstanceRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ createInstanceRequestPayload *CreateInstanceRequestPayload
+}
+
+// The request body with the parameters for the instance creation. Every parameter is required.
+
+func (r CreateInstanceRequestRequest) CreateInstanceRequestPayload(createInstanceRequestPayload CreateInstanceRequestPayload) ApiCreateInstanceRequestRequest {
+ r.createInstanceRequestPayload = &createInstanceRequestPayload
+ return r
+}
+
+func (r CreateInstanceRequestRequest) Execute() (*CreateInstanceResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *CreateInstanceResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.CreateInstanceRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.createInstanceRequestPayload == nil {
+ return localVarReturnValue, fmt.Errorf("createInstanceRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.createInstanceRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+CreateInstanceRequest: Create Instance
+
+Create a new instance of a postgres database instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiCreateInstanceRequestRequest
+*/
+func (a *APIClient) CreateInstanceRequest(ctx context.Context, projectId string, region string) ApiCreateInstanceRequestRequest {
+ return CreateInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+}
+
+func (a *APIClient) CreateInstanceRequestExecute(ctx context.Context, projectId string, region string) (*CreateInstanceResponse, error) {
+ r := CreateInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+ return r.Execute()
+}
+
+type CreateUserRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ createUserRequestPayload *CreateUserRequestPayload
+}
+
+// The request body containing the user details.
+
+func (r CreateUserRequestRequest) CreateUserRequestPayload(createUserRequestPayload CreateUserRequestPayload) ApiCreateUserRequestRequest {
+ r.createUserRequestPayload = &createUserRequestPayload
+ return r
+}
+
+func (r CreateUserRequestRequest) Execute() (*CreateUserResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *CreateUserResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.CreateUserRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.createUserRequestPayload == nil {
+ return localVarReturnValue, fmt.Errorf("createUserRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.createUserRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+CreateUserRequest: Create User
+
+Create user for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiCreateUserRequestRequest
+*/
+func (a *APIClient) CreateUserRequest(ctx context.Context, projectId string, region string, instanceId string) ApiCreateUserRequestRequest {
+ return CreateUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) CreateUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*CreateUserResponse, error) {
+ r := CreateUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type DeleteDatabaseRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ databaseId int64
+}
+
+func (r DeleteDatabaseRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodDelete
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.DeleteDatabaseRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases/{databaseId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"databaseId"+"}", url.PathEscape(ParameterValueToString(r.databaseId, "databaseId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+DeleteDatabaseRequest: Delete Database
+
+Delete database for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseId The ID of the database.
+ @return ApiDeleteDatabaseRequestRequest
+*/
+func (a *APIClient) DeleteDatabaseRequest(ctx context.Context, projectId string, region string, instanceId string, databaseId int64) ApiDeleteDatabaseRequestRequest {
+ return DeleteDatabaseRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseId: databaseId,
+ }
+}
+
+func (a *APIClient) DeleteDatabaseRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseId int64) error {
+ r := DeleteDatabaseRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseId: databaseId,
+ }
+ return r.Execute()
+}
+
+type DeleteInstanceRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+}
+
+func (r DeleteInstanceRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodDelete
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.DeleteInstanceRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 412 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+DeleteInstanceRequest: Delete Instance
+
+Delete an available postgres instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiDeleteInstanceRequestRequest
+*/
+func (a *APIClient) DeleteInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiDeleteInstanceRequestRequest {
+ return DeleteInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) DeleteInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) error {
+ r := DeleteInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type DeleteUserRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ userId int64
+}
+
+func (r DeleteUserRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodDelete
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.DeleteUserRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(r.userId, "userId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+DeleteUserRequest: Delete User
+
+Delete an user from a specific instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiDeleteUserRequestRequest
+*/
+func (a *APIClient) DeleteUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiDeleteUserRequestRequest {
+ return DeleteUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+}
+
+func (a *APIClient) DeleteUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) error {
+ r := DeleteUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+ return r.Execute()
+}
+
+type GetBackupRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ backupId int64
+}
+
+func (r GetBackupRequestRequest) Execute() (*GetBackupResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetBackupResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetBackupRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups/{backupId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"backupId"+"}", url.PathEscape(ParameterValueToString(r.backupId, "backupId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetBackupRequest: Get specific backup
+
+Get information about a specific backup for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param backupId The ID of the backup.
+ @return ApiGetBackupRequestRequest
+*/
+func (a *APIClient) GetBackupRequest(ctx context.Context, projectId string, region string, instanceId string, backupId int64) ApiGetBackupRequestRequest {
+ return GetBackupRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ backupId: backupId,
+ }
+}
+
+func (a *APIClient) GetBackupRequestExecute(ctx context.Context, projectId string, region string, instanceId string, backupId int64) (*GetBackupResponse, error) {
+ r := GetBackupRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ backupId: backupId,
+ }
+ return r.Execute()
+}
+
+type GetCollationsRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+}
+
+func (r GetCollationsRequestRequest) Execute() (*GetCollationsResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetCollationsResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetCollationsRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/collations"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetCollationsRequest: Get Collations for an Instance
+
+Get available collations for an instance
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiGetCollationsRequestRequest
+*/
+func (a *APIClient) GetCollationsRequest(ctx context.Context, projectId string, region string, instanceId string) ApiGetCollationsRequestRequest {
+ return GetCollationsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) GetCollationsRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*GetCollationsResponse, error) {
+ r := GetCollationsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type GetFlavorsRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ page *int64
+ size *int64
+ sort *FlavorSort
+}
+
+// Number of the page of items list to be returned.
+
+func (r GetFlavorsRequestRequest) Page(page int64) ApiGetFlavorsRequestRequest {
+ r.page = &page
+ return r
+}
+
+// Number of items to be returned on each page.
+
+func (r GetFlavorsRequestRequest) Size(size int64) ApiGetFlavorsRequestRequest {
+ r.size = &size
+ return r
+}
+
+// Sorting of the flavors to be returned on each page.
+
+func (r GetFlavorsRequestRequest) Sort(sort FlavorSort) ApiGetFlavorsRequestRequest {
+ r.sort = &sort
+ return r
+}
+
+func (r GetFlavorsRequestRequest) Execute() (*GetFlavorsResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetFlavorsResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetFlavorsRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/flavors"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ if r.page != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "page", r.page, "")
+ }
+ if r.size != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "size", r.size, "")
+ }
+ if r.sort != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "sort", r.sort, "")
+ }
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetFlavorsRequest: Get Flavors
+
+Get all available flavors for a project.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiGetFlavorsRequestRequest
+*/
+func (a *APIClient) GetFlavorsRequest(ctx context.Context, projectId string, region string) ApiGetFlavorsRequestRequest {
+ return GetFlavorsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+}
+
+func (a *APIClient) GetFlavorsRequestExecute(ctx context.Context, projectId string, region string) (*GetFlavorsResponse, error) {
+ r := GetFlavorsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+ return r.Execute()
+}
+
+type GetInstanceRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+}
+
+func (r GetInstanceRequestRequest) Execute() (*GetInstanceResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetInstanceResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetInstanceRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetInstanceRequest: Get Specific Instance
+
+Get information about a specific available instance
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiGetInstanceRequestRequest
+*/
+func (a *APIClient) GetInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiGetInstanceRequestRequest {
+ return GetInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) GetInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*GetInstanceResponse, error) {
+ r := GetInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type GetUserRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ userId int64
+}
+
+func (r GetUserRequestRequest) Execute() (*GetUserResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetUserResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetUserRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(r.userId, "userId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetUserRequest: Get User
+
+Get a specific available user for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiGetUserRequestRequest
+*/
+func (a *APIClient) GetUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiGetUserRequestRequest {
+ return GetUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+}
+
+func (a *APIClient) GetUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) (*GetUserResponse, error) {
+ r := GetUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+ return r.Execute()
+}
+
+type GetVersionsRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+}
+
+func (r GetVersionsRequestRequest) Execute() (*GetVersionsResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetVersionsResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetVersionsRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/versions"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetVersionsRequest: Get Versions
+
+Get available postgres versions for the project.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiGetVersionsRequestRequest
+*/
+func (a *APIClient) GetVersionsRequest(ctx context.Context, projectId string, region string) ApiGetVersionsRequestRequest {
+ return GetVersionsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+}
+
+func (a *APIClient) GetVersionsRequestExecute(ctx context.Context, projectId string, region string) (*GetVersionsResponse, error) {
+ r := GetVersionsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+ return r.Execute()
+}
+
+type ListBackupsRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ page *int64
+ size *int64
+ sort *BackupSort
+}
+
+// Number of the page of items list to be returned.
+
+func (r ListBackupsRequestRequest) Page(page int64) ApiListBackupsRequestRequest {
+ r.page = &page
+ return r
+}
+
+// Number of items to be returned on each page.
+
+func (r ListBackupsRequestRequest) Size(size int64) ApiListBackupsRequestRequest {
+ r.size = &size
+ return r
+}
+
+// Sorting of the backups to be returned on each page.
+
+func (r ListBackupsRequestRequest) Sort(sort BackupSort) ApiListBackupsRequestRequest {
+ r.sort = &sort
+ return r
+}
+
+func (r ListBackupsRequestRequest) Execute() (*ListBackupResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ListBackupResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ListBackupsRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ if r.page != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "page", r.page, "")
+ }
+ if r.size != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "size", r.size, "")
+ }
+ if r.sort != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "sort", r.sort, "")
+ }
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ListBackupsRequest: List backups
+
+List all backups which are available for a specific instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListBackupsRequestRequest
+*/
+func (a *APIClient) ListBackupsRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListBackupsRequestRequest {
+ return ListBackupsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) ListBackupsRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListBackupResponse, error) {
+ r := ListBackupsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type ListDatabasesRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ page *int64
+ size *int64
+ sort *DatabaseSort
+}
+
+// Number of the page of items list to be returned.
+
+func (r ListDatabasesRequestRequest) Page(page int64) ApiListDatabasesRequestRequest {
+ r.page = &page
+ return r
+}
+
+// Number of items to be returned on each page.
+
+func (r ListDatabasesRequestRequest) Size(size int64) ApiListDatabasesRequestRequest {
+ r.size = &size
+ return r
+}
+
+// Sorting of the databases to be returned on each page.
+
+func (r ListDatabasesRequestRequest) Sort(sort DatabaseSort) ApiListDatabasesRequestRequest {
+ r.sort = &sort
+ return r
+}
+
+func (r ListDatabasesRequestRequest) Execute() (*ListDatabasesResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ListDatabasesResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ListDatabasesRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ if r.page != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "page", r.page, "")
+ }
+ if r.size != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "size", r.size, "")
+ }
+ if r.sort != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "sort", r.sort, "")
+ }
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ListDatabasesRequest: List Databases
+
+List available databases for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListDatabasesRequestRequest
+*/
+func (a *APIClient) ListDatabasesRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListDatabasesRequestRequest {
+ return ListDatabasesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) ListDatabasesRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListDatabasesResponse, error) {
+ r := ListDatabasesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type ListInstancesRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ page *int64
+ size *int64
+ sort *InstanceSort
+}
+
+// Number of the page of items list to be returned.
+
+func (r ListInstancesRequestRequest) Page(page int64) ApiListInstancesRequestRequest {
+ r.page = &page
+ return r
+}
+
+// Number of items to be returned on each page.
+
+func (r ListInstancesRequestRequest) Size(size int64) ApiListInstancesRequestRequest {
+ r.size = &size
+ return r
+}
+
+// Sorting of the items to be returned on each page.
+
+func (r ListInstancesRequestRequest) Sort(sort InstanceSort) ApiListInstancesRequestRequest {
+ r.sort = &sort
+ return r
+}
+
+func (r ListInstancesRequestRequest) Execute() (*ListInstancesResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ListInstancesResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ListInstancesRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ if r.page != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "page", r.page, "")
+ }
+ if r.size != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "size", r.size, "")
+ }
+ if r.sort != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "sort", r.sort, "")
+ }
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ListInstancesRequest: List Instances
+
+List all available instances for your project.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiListInstancesRequestRequest
+*/
+func (a *APIClient) ListInstancesRequest(ctx context.Context, projectId string, region string) ApiListInstancesRequestRequest {
+ return ListInstancesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+}
+
+func (a *APIClient) ListInstancesRequestExecute(ctx context.Context, projectId string, region string) (*ListInstancesResponse, error) {
+ r := ListInstancesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+ return r.Execute()
+}
+
+type ListRolesRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+}
+
+func (r ListRolesRequestRequest) Execute() (*ListRolesResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ListRolesResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ListRolesRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/roles"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ListRolesRequest: List Roles
+
+List available roles for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListRolesRequestRequest
+*/
+func (a *APIClient) ListRolesRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListRolesRequestRequest {
+ return ListRolesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) ListRolesRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListRolesResponse, error) {
+ r := ListRolesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type ListUsersRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ page *int64
+ size *int64
+ sort *UserSort
+}
+
+// Number of the page of items list to be returned.
+
+func (r ListUsersRequestRequest) Page(page int64) ApiListUsersRequestRequest {
+ r.page = &page
+ return r
+}
+
+// Number of items to be returned on each page.
+
+func (r ListUsersRequestRequest) Size(size int64) ApiListUsersRequestRequest {
+ r.size = &size
+ return r
+}
+
+// Sorting of the users to be returned on each page.
+
+func (r ListUsersRequestRequest) Sort(sort UserSort) ApiListUsersRequestRequest {
+ r.sort = &sort
+ return r
+}
+
+func (r ListUsersRequestRequest) Execute() (*ListUserResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ListUserResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ListUsersRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ if r.page != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "page", r.page, "")
+ }
+ if r.size != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "size", r.size, "")
+ }
+ if r.sort != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "sort", r.sort, "")
+ }
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ListUsersRequest: List Users
+
+List available users for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListUsersRequestRequest
+*/
+func (a *APIClient) ListUsersRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListUsersRequestRequest {
+ return ListUsersRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) ListUsersRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListUserResponse, error) {
+ r := ListUsersRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type PointInTimeRecoveryRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ pointInTimeRecoveryRequestPayload *PointInTimeRecoveryRequestPayload
+}
+
+// The request body with the parameters for recover an instance by a point in time into a new instance.
+
+func (r PointInTimeRecoveryRequestRequest) PointInTimeRecoveryRequestPayload(pointInTimeRecoveryRequestPayload PointInTimeRecoveryRequestPayload) ApiPointInTimeRecoveryRequestRequest {
+ r.pointInTimeRecoveryRequestPayload = &pointInTimeRecoveryRequestPayload
+ return r
+}
+
+func (r PointInTimeRecoveryRequestRequest) Execute() (*RecoveryResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *RecoveryResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.PointInTimeRecoveryRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups/recoveries"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.pointInTimeRecoveryRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+PointInTimeRecoveryRequest: Point in Time Recovery
+
+Point in Time Recovery
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiPointInTimeRecoveryRequestRequest
+*/
+func (a *APIClient) PointInTimeRecoveryRequest(ctx context.Context, projectId string, region string, instanceId string) ApiPointInTimeRecoveryRequestRequest {
+ return PointInTimeRecoveryRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) PointInTimeRecoveryRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*RecoveryResponse, error) {
+ r := PointInTimeRecoveryRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type ProtectInstanceRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ protectInstanceRequestPayload *ProtectInstanceRequestPayload
+}
+
+// The request body with flag isDeletable. Parameter is required.
+
+func (r ProtectInstanceRequestRequest) ProtectInstanceRequestPayload(protectInstanceRequestPayload ProtectInstanceRequestPayload) ApiProtectInstanceRequestRequest {
+ r.protectInstanceRequestPayload = &protectInstanceRequestPayload
+ return r
+}
+
+func (r ProtectInstanceRequestRequest) Execute() (*ProtectInstanceResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ProtectInstanceResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ProtectInstanceRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/protections"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.protectInstanceRequestPayload == nil {
+ return localVarReturnValue, fmt.Errorf("protectInstanceRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.protectInstanceRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ProtectInstanceRequest: Protect Instance
+
+Toggle the deletion protection for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiProtectInstanceRequestRequest
+*/
+func (a *APIClient) ProtectInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiProtectInstanceRequestRequest {
+ return ProtectInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) ProtectInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ProtectInstanceResponse, error) {
+ r := ProtectInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type ResetUserRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ userId int64
+}
+
+func (r ResetUserRequestRequest) Execute() (*ResetUserResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ResetUserResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ResetUserRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}/reset"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(r.userId, "userId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ResetUserRequest: Reset User
+
+Reset an user from an specific instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiResetUserRequestRequest
+*/
+func (a *APIClient) ResetUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiResetUserRequestRequest {
+ return ResetUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+}
+
+func (a *APIClient) ResetUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) (*ResetUserResponse, error) {
+ r := ResetUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+ return r.Execute()
+}
+
+type RestoreInstanceRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ backupId int64
+}
+
+func (r RestoreInstanceRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.RestoreInstanceRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups/{backupId}/restores"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"backupId"+"}", url.PathEscape(ParameterValueToString(r.backupId, "backupId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+RestoreInstanceRequest: Restore Instance
+
+Restore an Instance from an existing backup. Instance is not reachable during the process of restore
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param backupId The ID of the backup.
+ @return ApiRestoreInstanceRequestRequest
+*/
+func (a *APIClient) RestoreInstanceRequest(ctx context.Context, projectId string, region string, instanceId string, backupId int64) ApiRestoreInstanceRequestRequest {
+ return RestoreInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ backupId: backupId,
+ }
+}
+
+func (a *APIClient) RestoreInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string, backupId int64) error {
+ r := RestoreInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ backupId: backupId,
+ }
+ return r.Execute()
+}
+
+type UpdateDatabasePartiallyRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ databaseId int64
+ updateDatabasePartiallyRequestPayload *UpdateDatabasePartiallyRequestPayload
+}
+
+// The request body containing the information for the database update.
+
+func (r UpdateDatabasePartiallyRequestRequest) UpdateDatabasePartiallyRequestPayload(updateDatabasePartiallyRequestPayload UpdateDatabasePartiallyRequestPayload) ApiUpdateDatabasePartiallyRequestRequest {
+ r.updateDatabasePartiallyRequestPayload = &updateDatabasePartiallyRequestPayload
+ return r
+}
+
+func (r UpdateDatabasePartiallyRequestRequest) Execute() (*UpdateDatabasePartiallyResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPatch
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *UpdateDatabasePartiallyResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.UpdateDatabasePartiallyRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases/{databaseId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"databaseId"+"}", url.PathEscape(ParameterValueToString(r.databaseId, "databaseId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.updateDatabasePartiallyRequestPayload == nil {
+ return localVarReturnValue, fmt.Errorf("updateDatabasePartiallyRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.updateDatabasePartiallyRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+UpdateDatabasePartiallyRequest: Update Database partially
+
+Update a database partially in an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseId The ID of the database.
+ @return ApiUpdateDatabasePartiallyRequestRequest
+*/
+func (a *APIClient) UpdateDatabasePartiallyRequest(ctx context.Context, projectId string, region string, instanceId string, databaseId int64) ApiUpdateDatabasePartiallyRequestRequest {
+ return UpdateDatabasePartiallyRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseId: databaseId,
+ }
+}
+
+func (a *APIClient) UpdateDatabasePartiallyRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseId int64) (*UpdateDatabasePartiallyResponse, error) {
+ r := UpdateDatabasePartiallyRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseId: databaseId,
+ }
+ return r.Execute()
+}
+
+type UpdateDatabaseRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ databaseId int64
+ updateDatabaseRequestPayload *UpdateDatabaseRequestPayload
+}
+
+// The request body containing the information for the database update.
+
+func (r UpdateDatabaseRequestRequest) UpdateDatabaseRequestPayload(updateDatabaseRequestPayload UpdateDatabaseRequestPayload) ApiUpdateDatabaseRequestRequest {
+ r.updateDatabaseRequestPayload = &updateDatabaseRequestPayload
+ return r
+}
+
+func (r UpdateDatabaseRequestRequest) Execute() (*UpdateDatabaseResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPut
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *UpdateDatabaseResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.UpdateDatabaseRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases/{databaseId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"databaseId"+"}", url.PathEscape(ParameterValueToString(r.databaseId, "databaseId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.updateDatabaseRequestPayload == nil {
+ return localVarReturnValue, fmt.Errorf("updateDatabaseRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.updateDatabaseRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+UpdateDatabaseRequest: Update Database
+
+Update a database in an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseId The ID of the database.
+ @return ApiUpdateDatabaseRequestRequest
+*/
+func (a *APIClient) UpdateDatabaseRequest(ctx context.Context, projectId string, region string, instanceId string, databaseId int64) ApiUpdateDatabaseRequestRequest {
+ return UpdateDatabaseRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseId: databaseId,
+ }
+}
+
+func (a *APIClient) UpdateDatabaseRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseId int64) (*UpdateDatabaseResponse, error) {
+ r := UpdateDatabaseRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseId: databaseId,
+ }
+ return r.Execute()
+}
+
+type UpdateInstancePartiallyRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ updateInstancePartiallyRequestPayload *UpdateInstancePartiallyRequestPayload
+}
+
+// The request body with the parameters for updating the instance.
+
+func (r UpdateInstancePartiallyRequestRequest) UpdateInstancePartiallyRequestPayload(updateInstancePartiallyRequestPayload UpdateInstancePartiallyRequestPayload) ApiUpdateInstancePartiallyRequestRequest {
+ r.updateInstancePartiallyRequestPayload = &updateInstancePartiallyRequestPayload
+ return r
+}
+
+func (r UpdateInstancePartiallyRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodPatch
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.UpdateInstancePartiallyRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.updateInstancePartiallyRequestPayload == nil {
+ return fmt.Errorf("updateInstancePartiallyRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.updateInstancePartiallyRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 412 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+UpdateInstancePartiallyRequest: Update Instance Partially
+
+Update an available instance of a postgres database. No fields are required.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiUpdateInstancePartiallyRequestRequest
+*/
+func (a *APIClient) UpdateInstancePartiallyRequest(ctx context.Context, projectId string, region string, instanceId string) ApiUpdateInstancePartiallyRequestRequest {
+ return UpdateInstancePartiallyRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) UpdateInstancePartiallyRequestExecute(ctx context.Context, projectId string, region string, instanceId string) error {
+ r := UpdateInstancePartiallyRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type UpdateInstanceRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ updateInstanceRequestPayload *UpdateInstanceRequestPayload
+}
+
+// The request body with the parameters for updating the instance
+
+func (r UpdateInstanceRequestRequest) UpdateInstanceRequestPayload(updateInstanceRequestPayload UpdateInstanceRequestPayload) ApiUpdateInstanceRequestRequest {
+ r.updateInstanceRequestPayload = &updateInstanceRequestPayload
+ return r
+}
+
+func (r UpdateInstanceRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodPut
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.UpdateInstanceRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.updateInstanceRequestPayload == nil {
+ return fmt.Errorf("updateInstanceRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.updateInstanceRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 412 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+UpdateInstanceRequest: Update Instance
+
+Updates an available instance of a postgres database
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiUpdateInstanceRequestRequest
+*/
+func (a *APIClient) UpdateInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiUpdateInstanceRequestRequest {
+ return UpdateInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) UpdateInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) error {
+ r := UpdateInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type UpdateUserPartiallyRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ userId int64
+ updateUserPartiallyRequestPayload *UpdateUserPartiallyRequestPayload
+}
+
+// The Request body containing the new information for the user. If empty request body is send via patch, then login and createdb roles are removed from user.
+
+func (r UpdateUserPartiallyRequestRequest) UpdateUserPartiallyRequestPayload(updateUserPartiallyRequestPayload UpdateUserPartiallyRequestPayload) ApiUpdateUserPartiallyRequestRequest {
+ r.updateUserPartiallyRequestPayload = &updateUserPartiallyRequestPayload
+ return r
+}
+
+func (r UpdateUserPartiallyRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodPatch
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.UpdateUserPartiallyRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(r.userId, "userId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.updateUserPartiallyRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+UpdateUserPartiallyRequest: Update User Partially
+
+Update an user partially for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiUpdateUserPartiallyRequestRequest
+*/
+func (a *APIClient) UpdateUserPartiallyRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiUpdateUserPartiallyRequestRequest {
+ return UpdateUserPartiallyRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+}
+
+func (a *APIClient) UpdateUserPartiallyRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) error {
+ r := UpdateUserPartiallyRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+ return r.Execute()
+}
+
+type UpdateUserRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ userId int64
+ updateUserRequestPayload *UpdateUserRequestPayload
+}
+
+// The Request body containing the updated infos for the user.
+
+func (r UpdateUserRequestRequest) UpdateUserRequestPayload(updateUserRequestPayload UpdateUserRequestPayload) ApiUpdateUserRequestRequest {
+ r.updateUserRequestPayload = &updateUserRequestPayload
+ return r
+}
+
+func (r UpdateUserRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodPut
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.UpdateUserRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(r.userId, "userId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.updateUserRequestPayload == nil {
+ return fmt.Errorf("updateUserRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.updateUserRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+UpdateUserRequest: Update User
+
+Update user for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiUpdateUserRequestRequest
+*/
+func (a *APIClient) UpdateUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiUpdateUserRequestRequest {
+ return UpdateUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+}
+
+func (a *APIClient) UpdateUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) error {
+ r := UpdateUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+ return r.Execute()
+}
diff --git a/pkg/postgresflexalpha/api_default_test.go b/pkg/postgresflexalpha/api_default_test.go
new file mode 100644
index 00000000..81f31fc1
--- /dev/null
+++ b/pkg/postgresflexalpha/api_default_test.go
@@ -0,0 +1,1571 @@
+/*
+PostgreSQL Flex API
+
+Testing DefaultApiService
+
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech);
+
+package postgresflexalpha
+
+import (
+ "context"
+ "encoding/json"
+ "net/http"
+ "net/http/httptest"
+ "net/url"
+ "strings"
+ "testing"
+
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+)
+
+func Test_postgresflexalpha_DefaultApiService(t *testing.T) {
+
+ t.Run("Test DefaultApiService CreateDatabaseRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := CreateDatabaseResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ createDatabaseRequestPayload := CreateDatabaseRequestPayload{}
+
+ resp, reqErr := apiClient.CreateDatabaseRequest(context.Background(), projectId, region, instanceId).CreateDatabaseRequestPayload(createDatabaseRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService CreateInstanceRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := CreateInstanceResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ createInstanceRequestPayload := CreateInstanceRequestPayload{}
+
+ resp, reqErr := apiClient.CreateInstanceRequest(context.Background(), projectId, region).CreateInstanceRequestPayload(createInstanceRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService CreateUserRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := CreateUserResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ createUserRequestPayload := CreateUserRequestPayload{}
+
+ resp, reqErr := apiClient.CreateUserRequest(context.Background(), projectId, region, instanceId).CreateUserRequestPayload(createUserRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService DeleteDatabaseRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases/{databaseId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ databaseIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"databaseId"+"}", url.PathEscape(ParameterValueToString(databaseIdValue, "databaseId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ databaseId := databaseIdValue
+
+ reqErr := apiClient.DeleteDatabaseRequest(context.Background(), projectId, region, instanceId, databaseId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService DeleteInstanceRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ reqErr := apiClient.DeleteInstanceRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService DeleteUserRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ userIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(userIdValue, "userId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ userId := userIdValue
+
+ reqErr := apiClient.DeleteUserRequest(context.Background(), projectId, region, instanceId, userId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService GetBackupRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups/{backupId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ backupIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"backupId"+"}", url.PathEscape(ParameterValueToString(backupIdValue, "backupId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetBackupResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ backupId := backupIdValue
+
+ resp, reqErr := apiClient.GetBackupRequest(context.Background(), projectId, region, instanceId, backupId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService GetCollationsRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/collations"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetCollationsResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.GetCollationsRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService GetFlavorsRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/flavors"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetFlavorsResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+
+ resp, reqErr := apiClient.GetFlavorsRequest(context.Background(), projectId, region).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService GetInstanceRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetInstanceResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.GetInstanceRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService GetUserRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ userIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(userIdValue, "userId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetUserResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ userId := userIdValue
+
+ resp, reqErr := apiClient.GetUserRequest(context.Background(), projectId, region, instanceId, userId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService GetVersionsRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/versions"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetVersionsResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+
+ resp, reqErr := apiClient.GetVersionsRequest(context.Background(), projectId, region).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ListBackupsRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ListBackupResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.ListBackupsRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ListDatabasesRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ListDatabasesResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.ListDatabasesRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ListInstancesRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ListInstancesResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+
+ resp, reqErr := apiClient.ListInstancesRequest(context.Background(), projectId, region).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ListRolesRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/roles"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ListRolesResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.ListRolesRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ListUsersRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ListUserResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.ListUsersRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService PointInTimeRecoveryRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups/recoveries"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := RecoveryResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.PointInTimeRecoveryRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ProtectInstanceRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/protections"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ProtectInstanceResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ protectInstanceRequestPayload := ProtectInstanceRequestPayload{}
+
+ resp, reqErr := apiClient.ProtectInstanceRequest(context.Background(), projectId, region, instanceId).ProtectInstanceRequestPayload(protectInstanceRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ResetUserRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}/reset"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ userIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(userIdValue, "userId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ResetUserResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ userId := userIdValue
+
+ resp, reqErr := apiClient.ResetUserRequest(context.Background(), projectId, region, instanceId, userId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService RestoreInstanceRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups/{backupId}/restores"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ backupIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"backupId"+"}", url.PathEscape(ParameterValueToString(backupIdValue, "backupId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ backupId := backupIdValue
+
+ reqErr := apiClient.RestoreInstanceRequest(context.Background(), projectId, region, instanceId, backupId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService UpdateDatabasePartiallyRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases/{databaseId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ databaseIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"databaseId"+"}", url.PathEscape(ParameterValueToString(databaseIdValue, "databaseId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := UpdateDatabasePartiallyResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ databaseId := databaseIdValue
+ updateDatabasePartiallyRequestPayload := UpdateDatabasePartiallyRequestPayload{}
+
+ resp, reqErr := apiClient.UpdateDatabasePartiallyRequest(context.Background(), projectId, region, instanceId, databaseId).UpdateDatabasePartiallyRequestPayload(updateDatabasePartiallyRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService UpdateDatabaseRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases/{databaseId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ databaseIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"databaseId"+"}", url.PathEscape(ParameterValueToString(databaseIdValue, "databaseId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := UpdateDatabaseResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ databaseId := databaseIdValue
+ updateDatabaseRequestPayload := UpdateDatabaseRequestPayload{}
+
+ resp, reqErr := apiClient.UpdateDatabaseRequest(context.Background(), projectId, region, instanceId, databaseId).UpdateDatabaseRequestPayload(updateDatabaseRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService UpdateInstancePartiallyRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ updateInstancePartiallyRequestPayload := UpdateInstancePartiallyRequestPayload{}
+
+ reqErr := apiClient.UpdateInstancePartiallyRequest(context.Background(), projectId, region, instanceId).UpdateInstancePartiallyRequestPayload(updateInstancePartiallyRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService UpdateInstanceRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ updateInstanceRequestPayload := UpdateInstanceRequestPayload{}
+
+ reqErr := apiClient.UpdateInstanceRequest(context.Background(), projectId, region, instanceId).UpdateInstanceRequestPayload(updateInstanceRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService UpdateUserPartiallyRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ userIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(userIdValue, "userId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ userId := userIdValue
+
+ reqErr := apiClient.UpdateUserPartiallyRequest(context.Background(), projectId, region, instanceId, userId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService UpdateUserRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ userIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(userIdValue, "userId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for postgresflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ userId := userIdValue
+ updateUserRequestPayload := UpdateUserRequestPayload{}
+
+ reqErr := apiClient.UpdateUserRequest(context.Background(), projectId, region, instanceId, userId).UpdateUserRequestPayload(updateUserRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+}
diff --git a/pkg/postgresflexalpha/client.go b/pkg/postgresflexalpha/client.go
new file mode 100644
index 00000000..f5ab16f9
--- /dev/null
+++ b/pkg/postgresflexalpha/client.go
@@ -0,0 +1,631 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "bytes"
+ "context"
+ "encoding/json"
+ "encoding/xml"
+ "fmt"
+ "io"
+ "log"
+ "mime/multipart"
+ "net/http"
+ "net/http/httputil"
+ "net/url"
+ "os"
+ "path/filepath"
+ "reflect"
+ "regexp"
+ "strconv"
+ "strings"
+ "time"
+ "unicode/utf8"
+
+ "github.com/stackitcloud/stackit-sdk-go/core/auth"
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+)
+
+var (
+ jsonCheck = regexp.MustCompile(`(?i:(?:application|text)/(?:vnd\.[^;]+\+)?json)`)
+ xmlCheck = regexp.MustCompile(`(?i:(?:application|text)/xml)`)
+ queryParamSplit = regexp.MustCompile(`(^|&)([^&]+)`)
+ queryDescape = strings.NewReplacer("%5B", "[", "%5D", "]")
+)
+
+// APIClient manages communication with the PostgreSQL Flex API API v3alpha1
+// In most cases there should be only one, shared, APIClient.
+type APIClient struct {
+ cfg *config.Configuration
+ common service // Reuse a single struct instead of allocating one for each service on the heap.
+ defaultApi *DefaultApiService
+}
+
+type service struct {
+ client DefaultApi
+}
+
+// NewAPIClient creates a new API client.
+// Optionally receives configuration options
+func NewAPIClient(opts ...config.ConfigurationOption) (*APIClient, error) {
+ cfg := NewConfiguration()
+
+ for _, option := range opts {
+ err := option(cfg)
+ if err != nil {
+ return nil, fmt.Errorf("configuring the client: %w", err)
+ }
+ }
+
+ err := config.ConfigureRegion(cfg)
+ if err != nil {
+ return nil, fmt.Errorf("configuring region: %w", err)
+ }
+
+ if cfg.HTTPClient == nil {
+ cfg.HTTPClient = &http.Client{}
+ }
+
+ authRoundTripper, err := auth.SetupAuth(cfg)
+ if err != nil {
+ return nil, fmt.Errorf("setting up authentication: %w", err)
+ }
+
+ roundTripper := authRoundTripper
+ if cfg.Middleware != nil {
+ roundTripper = config.ChainMiddleware(roundTripper, cfg.Middleware...)
+ }
+
+ cfg.HTTPClient.Transport = roundTripper
+
+ c := &APIClient{}
+ c.cfg = cfg
+ c.common.client = c
+ c.defaultApi = (*DefaultApiService)(&c.common)
+
+ return c, nil
+}
+
+func atoi(in string) (int, error) {
+ return strconv.Atoi(in)
+}
+
+// selectHeaderContentType select a content type from the available list.
+func selectHeaderContentType(contentTypes []string) string {
+ if len(contentTypes) == 0 {
+ return ""
+ }
+ if contains(contentTypes, "application/json") {
+ return "application/json"
+ }
+ return contentTypes[0] // use the first content type specified in 'consumes'
+}
+
+// selectHeaderAccept join all accept types and return
+func selectHeaderAccept(accepts []string) string {
+ if len(accepts) == 0 {
+ return ""
+ }
+
+ if contains(accepts, "application/json") {
+ return "application/json"
+ }
+
+ return strings.Join(accepts, ",")
+}
+
+// contains is a case insensitive match, finding needle in a haystack
+func contains(haystack []string, needle string) bool {
+ for _, a := range haystack {
+ if strings.EqualFold(a, needle) {
+ return true
+ }
+ }
+ return false
+}
+
+// Verify optional parameters are of the correct type.
+func typeCheckParameter(obj interface{}, expected string, name string) error {
+ // Make sure there is an object.
+ if obj == nil {
+ return nil
+ }
+
+ // Check the type is as expected.
+ if reflect.TypeOf(obj).String() != expected {
+ return fmt.Errorf("expected %s to be of type %s but received %s", name, expected, reflect.TypeOf(obj).String())
+ }
+ return nil
+}
+
+func ParameterValueToString(obj interface{}, key string) string {
+ if reflect.TypeOf(obj).Kind() != reflect.Ptr {
+ return fmt.Sprintf("%v", obj)
+ }
+ var param, ok = obj.(MappedNullable)
+ if !ok {
+ return ""
+ }
+ dataMap, err := param.ToMap()
+ if err != nil {
+ return ""
+ }
+ return fmt.Sprintf("%v", dataMap[key])
+}
+
+// parameterAddToHeaderOrQuery adds the provided object to the request header or url query
+// supporting deep object syntax
+func parameterAddToHeaderOrQuery(headerOrQueryParams interface{}, keyPrefix string, obj interface{}, collectionType string) {
+ var v = reflect.ValueOf(obj)
+ var value = ""
+ if v == reflect.ValueOf(nil) {
+ value = "null"
+ } else {
+ switch v.Kind() {
+ case reflect.Invalid:
+ value = "invalid"
+
+ case reflect.Struct:
+ if t, ok := obj.(MappedNullable); ok {
+ dataMap, err := t.ToMap()
+ if err != nil {
+ return
+ }
+ parameterAddToHeaderOrQuery(headerOrQueryParams, keyPrefix, dataMap, collectionType)
+ return
+ }
+ if t, ok := obj.(time.Time); ok {
+ parameterAddToHeaderOrQuery(headerOrQueryParams, keyPrefix, t.Format(time.RFC3339), collectionType)
+ return
+ }
+ value = v.Type().String() + " value"
+ case reflect.Slice:
+ var indValue = reflect.ValueOf(obj)
+ if indValue == reflect.ValueOf(nil) {
+ return
+ }
+ var lenIndValue = indValue.Len()
+ for i := 0; i < lenIndValue; i++ {
+ var arrayValue = indValue.Index(i)
+ parameterAddToHeaderOrQuery(headerOrQueryParams, keyPrefix, arrayValue.Interface(), collectionType)
+ }
+ return
+
+ case reflect.Map:
+ var indValue = reflect.ValueOf(obj)
+ if indValue == reflect.ValueOf(nil) {
+ return
+ }
+ iter := indValue.MapRange()
+ for iter.Next() {
+ k, v := iter.Key(), iter.Value()
+ parameterAddToHeaderOrQuery(headerOrQueryParams, fmt.Sprintf("%s[%s]", keyPrefix, k.String()), v.Interface(), collectionType)
+ }
+ return
+
+ case reflect.Interface:
+ fallthrough
+ case reflect.Ptr:
+ parameterAddToHeaderOrQuery(headerOrQueryParams, keyPrefix, v.Elem().Interface(), collectionType)
+ return
+
+ case reflect.Int, reflect.Int8, reflect.Int16,
+ reflect.Int32, reflect.Int64:
+ value = strconv.FormatInt(v.Int(), 10)
+ case reflect.Uint, reflect.Uint8, reflect.Uint16,
+ reflect.Uint32, reflect.Uint64, reflect.Uintptr:
+ value = strconv.FormatUint(v.Uint(), 10)
+ case reflect.Float32, reflect.Float64:
+ value = strconv.FormatFloat(v.Float(), 'g', -1, 32)
+ case reflect.Bool:
+ value = strconv.FormatBool(v.Bool())
+ case reflect.String:
+ value = v.String()
+ default:
+ value = v.Type().String() + " value"
+ }
+ }
+
+ switch valuesMap := headerOrQueryParams.(type) {
+ case url.Values:
+ if collectionType == "csv" && valuesMap.Get(keyPrefix) != "" {
+ valuesMap.Set(keyPrefix, valuesMap.Get(keyPrefix)+","+value)
+ } else {
+ valuesMap.Add(keyPrefix, value)
+ }
+ break
+ case map[string]string:
+ valuesMap[keyPrefix] = value
+ break
+ }
+}
+
+// helper for converting interface{} parameters to json strings
+func parameterToJson(obj interface{}) (string, error) {
+ jsonBuf, err := json.Marshal(obj)
+ if err != nil {
+ return "", err
+ }
+ return string(jsonBuf), err
+}
+
+// callAPI do the request.
+func (c *APIClient) callAPI(request *http.Request) (*http.Response, error) {
+ if c.cfg.Debug {
+ dump, err := httputil.DumpRequestOut(request, true)
+ if err != nil {
+ return nil, err
+ }
+ log.Printf("\n%s\n", string(dump))
+ }
+
+ resp, err := c.cfg.HTTPClient.Do(request)
+ if err != nil {
+ return resp, err
+ }
+
+ if c.cfg.Debug {
+ dump, err := httputil.DumpResponse(resp, true)
+ if err != nil {
+ return resp, err
+ }
+ log.Printf("\n%s\n", string(dump))
+ }
+ return resp, err
+}
+
+// Allow modification of underlying config for alternate implementations and testing
+// Caution: modifying the configuration while live can cause data races and potentially unwanted behavior
+func (c *APIClient) GetConfig() *config.Configuration {
+ return c.cfg
+}
+
+type formFile struct {
+ fileBytes []byte
+ fileName string
+ formFileName string
+}
+
+// prepareRequest build the request
+func (c *APIClient) prepareRequest(
+ ctx context.Context,
+ path string, method string,
+ postBody interface{},
+ headerParams map[string]string,
+ queryParams url.Values,
+ formParams url.Values,
+ formFiles []formFile) (localVarRequest *http.Request, err error) {
+
+ var body *bytes.Buffer
+
+ // Detect postBody type and post.
+ if !IsNil(postBody) {
+ contentType := headerParams["Content-Type"]
+ if contentType == "" {
+ contentType = detectContentType(postBody)
+ headerParams["Content-Type"] = contentType
+ }
+
+ body, err = setBody(postBody, contentType)
+ if err != nil {
+ return nil, err
+ }
+ }
+
+ // add form parameters and file if available.
+ if strings.HasPrefix(headerParams["Content-Type"], "multipart/form-data") && len(formParams) > 0 || (len(formFiles) > 0) {
+ if body != nil {
+ return nil, fmt.Errorf("cannot specify postBody and multipart form at the same time.")
+ }
+ body = &bytes.Buffer{}
+ w := multipart.NewWriter(body)
+
+ for k, v := range formParams {
+ for _, iv := range v {
+ if strings.HasPrefix(k, "@") { // file
+ err = addFile(w, k[1:], iv)
+ if err != nil {
+ return nil, err
+ }
+ } else { // form value
+ w.WriteField(k, iv)
+ }
+ }
+ }
+ for _, formFile := range formFiles {
+ if len(formFile.fileBytes) > 0 && formFile.fileName != "" {
+ w.Boundary()
+ part, err := w.CreateFormFile(formFile.formFileName, filepath.Base(formFile.fileName))
+ if err != nil {
+ return nil, err
+ }
+ _, err = part.Write(formFile.fileBytes)
+ if err != nil {
+ return nil, err
+ }
+ }
+ }
+
+ // Set the Boundary in the Content-Type
+ headerParams["Content-Type"] = w.FormDataContentType()
+
+ // Set Content-Length
+ headerParams["Content-Length"] = fmt.Sprintf("%d", body.Len())
+ w.Close()
+ }
+
+ if strings.HasPrefix(headerParams["Content-Type"], "application/x-www-form-urlencoded") && len(formParams) > 0 {
+ if body != nil {
+ return nil, fmt.Errorf("cannot specify postBody and x-www-form-urlencoded form at the same time.")
+ }
+ body = &bytes.Buffer{}
+ body.WriteString(formParams.Encode())
+ // Set Content-Length
+ headerParams["Content-Length"] = fmt.Sprintf("%d", body.Len())
+ }
+
+ // Setup path and query parameters
+ url, err := url.Parse(path)
+ if err != nil {
+ return nil, err
+ }
+
+ // Override request host, if applicable
+ if c.cfg.Host != "" {
+ url.Host = c.cfg.Host
+ }
+
+ // Override request scheme, if applicable
+ if c.cfg.Scheme != "" {
+ url.Scheme = c.cfg.Scheme
+ }
+
+ // Adding Query Param
+ query := url.Query()
+ for k, v := range queryParams {
+ for _, iv := range v {
+ query.Add(k, iv)
+ }
+ }
+
+ // Encode the parameters.
+ url.RawQuery = queryParamSplit.ReplaceAllStringFunc(query.Encode(), func(s string) string {
+ pieces := strings.Split(s, "=")
+ pieces[0] = queryDescape.Replace(pieces[0])
+ return strings.Join(pieces, "=")
+ })
+
+ // Generate a new request
+ if body != nil {
+ localVarRequest, err = http.NewRequest(method, url.String(), body)
+ } else {
+ localVarRequest, err = http.NewRequest(method, url.String(), nil)
+ }
+ if err != nil {
+ return nil, err
+ }
+
+ // add header parameters, if any
+ if len(headerParams) > 0 {
+ headers := http.Header{}
+ for h, v := range headerParams {
+ headers[h] = []string{v}
+ }
+ localVarRequest.Header = headers
+ }
+
+ // Add the user agent to the request.
+ localVarRequest.Header.Add("User-Agent", c.cfg.UserAgent)
+
+ if ctx != nil {
+ // add context to the request
+ localVarRequest = localVarRequest.WithContext(ctx)
+
+ // Walk through any authentication.
+
+ }
+
+ for header, value := range c.cfg.DefaultHeader {
+ localVarRequest.Header.Add(header, value)
+ }
+ return localVarRequest, nil
+}
+
+func (c *APIClient) decode(v interface{}, b []byte, contentType string) (err error) {
+ if len(b) == 0 {
+ return nil
+ }
+ if s, ok := v.(*string); ok {
+ *s = string(b)
+ return nil
+ }
+ if f, ok := v.(*os.File); ok {
+ f, err = os.CreateTemp("", "HttpClientFile")
+ if err != nil {
+ return
+ }
+ _, err = f.Write(b)
+ if err != nil {
+ return
+ }
+ _, err = f.Seek(0, io.SeekStart)
+ return
+ }
+ if f, ok := v.(**os.File); ok {
+ *f, err = os.CreateTemp("", "HttpClientFile")
+ if err != nil {
+ return
+ }
+ _, err = (*f).Write(b)
+ if err != nil {
+ return
+ }
+ _, err = (*f).Seek(0, io.SeekStart)
+ return
+ }
+ if xmlCheck.MatchString(contentType) {
+ if err = xml.Unmarshal(b, v); err != nil {
+ return err
+ }
+ return nil
+ }
+ if jsonCheck.MatchString(contentType) {
+ if actualObj, ok := v.(interface{ GetActualInstance() interface{} }); ok { // oneOf, anyOf schemas
+ if unmarshalObj, ok := actualObj.(interface{ UnmarshalJSON([]byte) error }); ok { // make sure it has UnmarshalJSON defined
+ if err = unmarshalObj.UnmarshalJSON(b); err != nil {
+ return err
+ }
+ } else {
+ return fmt.Errorf("unknown type with GetActualInstance but no unmarshalObj.UnmarshalJSON defined")
+ }
+ } else if err = json.Unmarshal(b, v); err != nil { // simple model
+ return err
+ }
+ return nil
+ }
+ return fmt.Errorf("undefined response type")
+}
+
+// Add a file to the multipart request
+func addFile(w *multipart.Writer, fieldName, path string) error {
+ file, err := os.Open(filepath.Clean(path))
+ if err != nil {
+ return err
+ }
+ err = file.Close()
+ if err != nil {
+ return err
+ }
+
+ part, err := w.CreateFormFile(fieldName, filepath.Base(path))
+ if err != nil {
+ return err
+ }
+ _, err = io.Copy(part, file)
+
+ return err
+}
+
+// A wrapper for strict JSON decoding
+func newStrictDecoder(data []byte) *json.Decoder {
+ dec := json.NewDecoder(bytes.NewBuffer(data))
+ dec.DisallowUnknownFields()
+ return dec
+}
+
+// Set request body from an interface{}
+func setBody(body interface{}, contentType string) (bodyBuf *bytes.Buffer, err error) {
+ if bodyBuf == nil {
+ bodyBuf = &bytes.Buffer{}
+ }
+
+ if reader, ok := body.(io.Reader); ok {
+ _, err = bodyBuf.ReadFrom(reader)
+ } else if fp, ok := body.(*os.File); ok {
+ _, err = bodyBuf.ReadFrom(fp)
+ } else if b, ok := body.([]byte); ok {
+ _, err = bodyBuf.Write(b)
+ } else if s, ok := body.(string); ok {
+ _, err = bodyBuf.WriteString(s)
+ } else if s, ok := body.(*string); ok {
+ _, err = bodyBuf.WriteString(*s)
+ } else if jsonCheck.MatchString(contentType) {
+ err = json.NewEncoder(bodyBuf).Encode(body)
+ } else if xmlCheck.MatchString(contentType) {
+ err = xml.NewEncoder(bodyBuf).Encode(body)
+ }
+
+ if err != nil {
+ return nil, err
+ }
+
+ if bodyBuf.Len() == 0 {
+ err = fmt.Errorf("invalid body type %s", contentType)
+ return nil, err
+ }
+ return bodyBuf, nil
+}
+
+// detectContentType method is used to figure out `Request.Body` content type for request header
+func detectContentType(body interface{}) string {
+ contentType := "text/plain; charset=utf-8"
+ kind := reflect.TypeOf(body).Kind()
+
+ switch kind {
+ case reflect.Struct, reflect.Map, reflect.Ptr:
+ contentType = "application/json; charset=utf-8"
+ case reflect.String:
+ contentType = "text/plain; charset=utf-8"
+ default:
+ if b, ok := body.([]byte); ok {
+ contentType = http.DetectContentType(b)
+ } else if kind == reflect.Slice {
+ contentType = "application/json; charset=utf-8"
+ }
+ }
+
+ return contentType
+}
+
+// Ripped from https://github.com/gregjones/httpcache/blob/master/httpcache.go
+type cacheControl map[string]string
+
+func parseCacheControl(headers http.Header) cacheControl {
+ cc := cacheControl{}
+ ccHeader := headers.Get("Cache-Control")
+ for _, part := range strings.Split(ccHeader, ",") {
+ part = strings.Trim(part, " ")
+ if part == "" {
+ continue
+ }
+ if strings.ContainsRune(part, '=') {
+ keyval := strings.Split(part, "=")
+ cc[strings.Trim(keyval[0], " ")] = strings.Trim(keyval[1], ",")
+ } else {
+ cc[part] = ""
+ }
+ }
+ return cc
+}
+
+// CacheExpires helper function to determine remaining time before repeating a request.
+func CacheExpires(r *http.Response) time.Time {
+ // Figure out when the cache expires.
+ var expires time.Time
+ now, err := time.Parse(time.RFC1123, r.Header.Get("date"))
+ if err != nil {
+ return time.Now()
+ }
+ respCacheControl := parseCacheControl(r.Header)
+
+ if maxAge, ok := respCacheControl["max-age"]; ok {
+ lifetime, err := time.ParseDuration(maxAge + "s")
+ if err != nil {
+ expires = now
+ } else {
+ expires = now.Add(lifetime)
+ }
+ } else {
+ expiresHeader := r.Header.Get("Expires")
+ if expiresHeader != "" {
+ expires, err = time.Parse(time.RFC1123, expiresHeader)
+ if err != nil {
+ expires = now
+ }
+ }
+ }
+ return expires
+}
+
+func strlen(s string) int {
+ return utf8.RuneCountInString(s)
+}
diff --git a/pkg/postgresflexalpha/configuration.go b/pkg/postgresflexalpha/configuration.go
new file mode 100644
index 00000000..3ef4635d
--- /dev/null
+++ b/pkg/postgresflexalpha/configuration.go
@@ -0,0 +1,41 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+)
+
+// NewConfiguration returns a new Configuration object
+func NewConfiguration() *config.Configuration {
+ cfg := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "stackit-sdk-go/postgresflexalpha",
+ Debug: false,
+ Servers: config.ServerConfigurations{
+ {
+ URL: "https://postgres-flex-service.api.{region}stackit.cloud",
+ Description: "No description provided",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ Description: "No description provided",
+ DefaultValue: "eu01.",
+ EnumValues: []string{
+ "eu01.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ return cfg
+}
diff --git a/pkg/postgresflexalpha/model_backup_sort.go b/pkg/postgresflexalpha/model_backup_sort.go
new file mode 100644
index 00000000..9eba78ee
--- /dev/null
+++ b/pkg/postgresflexalpha/model_backup_sort.go
@@ -0,0 +1,139 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// BackupSort the model 'BackupSort'
+type BackupSort string
+
+// List of backup.sort
+const (
+ BACKUPSORT_COMPLETION_TIME_DESC BackupSort = "completion_time.desc"
+ BACKUPSORT_COMPLETION_TIME_ASC BackupSort = "completion_time.asc"
+ BACKUPSORT_END_TIME_DESC BackupSort = "end_time.desc"
+ BACKUPSORT_END_TIME_ASC BackupSort = "end_time.asc"
+ BACKUPSORT_INDEX_DESC BackupSort = "index.desc"
+ BACKUPSORT_INDEX_ASC BackupSort = "index.asc"
+ BACKUPSORT_NAME_DESC BackupSort = "name.desc"
+ BACKUPSORT_NAME_ASC BackupSort = "name.asc"
+ BACKUPSORT_RETAINED_UNTIL_DESC BackupSort = "retained_until.desc"
+ BACKUPSORT_RETAINED_UNTIL_ASC BackupSort = "retained_until.asc"
+ BACKUPSORT_SIZE_DESC BackupSort = "size.desc"
+ BACKUPSORT_SIZE_ASC BackupSort = "size.asc"
+ BACKUPSORT_TYPE_DESC BackupSort = "type.desc"
+ BACKUPSORT_TYPE_ASC BackupSort = "type.asc"
+)
+
+// All allowed values of BackupSort enum
+var AllowedBackupSortEnumValues = []BackupSort{
+ "completion_time.desc",
+ "completion_time.asc",
+ "end_time.desc",
+ "end_time.asc",
+ "index.desc",
+ "index.asc",
+ "name.desc",
+ "name.asc",
+ "retained_until.desc",
+ "retained_until.asc",
+ "size.desc",
+ "size.asc",
+ "type.desc",
+ "type.asc",
+}
+
+func (v *BackupSort) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := BackupSort(value)
+ for _, existing := range AllowedBackupSortEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid BackupSort", value)
+}
+
+// NewBackupSortFromValue returns a pointer to a valid BackupSort
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewBackupSortFromValue(v string) (*BackupSort, error) {
+ ev := BackupSort(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for BackupSort: valid values are %v", v, AllowedBackupSortEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v BackupSort) IsValid() bool {
+ for _, existing := range AllowedBackupSortEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to backup.sort value
+func (v BackupSort) Ptr() *BackupSort {
+ return &v
+}
+
+type NullableBackupSort struct {
+ value *BackupSort
+ isSet bool
+}
+
+func (v NullableBackupSort) Get() *BackupSort {
+ return v.value
+}
+
+func (v *NullableBackupSort) Set(val *BackupSort) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableBackupSort) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableBackupSort) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableBackupSort(val *BackupSort) *NullableBackupSort {
+ return &NullableBackupSort{value: val, isSet: true}
+}
+
+func (v NullableBackupSort) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableBackupSort) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_backup_sort_test.go b/pkg/postgresflexalpha/model_backup_sort_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_backup_sort_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_create_database_request_payload.go b/pkg/postgresflexalpha/model_create_database_request_payload.go
new file mode 100644
index 00000000..48083fd8
--- /dev/null
+++ b/pkg/postgresflexalpha/model_create_database_request_payload.go
@@ -0,0 +1,176 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateDatabaseRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateDatabaseRequestPayload{}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type CreateDatabaseRequestPayloadGetNameAttributeType = *string
+
+func getCreateDatabaseRequestPayloadGetNameAttributeTypeOk(arg CreateDatabaseRequestPayloadGetNameAttributeType) (ret CreateDatabaseRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateDatabaseRequestPayloadGetNameAttributeType(arg *CreateDatabaseRequestPayloadGetNameAttributeType, val CreateDatabaseRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type CreateDatabaseRequestPayloadGetNameArgType = string
+type CreateDatabaseRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for owner
+*/
+
+// isNotNullableString
+type CreateDatabaseRequestPayloadGetOwnerAttributeType = *string
+
+func getCreateDatabaseRequestPayloadGetOwnerAttributeTypeOk(arg CreateDatabaseRequestPayloadGetOwnerAttributeType) (ret CreateDatabaseRequestPayloadGetOwnerRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateDatabaseRequestPayloadGetOwnerAttributeType(arg *CreateDatabaseRequestPayloadGetOwnerAttributeType, val CreateDatabaseRequestPayloadGetOwnerRetType) {
+ *arg = &val
+}
+
+type CreateDatabaseRequestPayloadGetOwnerArgType = string
+type CreateDatabaseRequestPayloadGetOwnerRetType = string
+
+// CreateDatabaseRequestPayload struct for CreateDatabaseRequestPayload
+type CreateDatabaseRequestPayload struct {
+ // The name of the database.
+ // REQUIRED
+ Name CreateDatabaseRequestPayloadGetNameAttributeType `json:"name" required:"true"`
+ // The owner of the database.
+ Owner CreateDatabaseRequestPayloadGetOwnerAttributeType `json:"owner,omitempty"`
+}
+
+type _CreateDatabaseRequestPayload CreateDatabaseRequestPayload
+
+// NewCreateDatabaseRequestPayload instantiates a new CreateDatabaseRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateDatabaseRequestPayload(name CreateDatabaseRequestPayloadGetNameArgType) *CreateDatabaseRequestPayload {
+ this := CreateDatabaseRequestPayload{}
+ setCreateDatabaseRequestPayloadGetNameAttributeType(&this.Name, name)
+ return &this
+}
+
+// NewCreateDatabaseRequestPayloadWithDefaults instantiates a new CreateDatabaseRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateDatabaseRequestPayloadWithDefaults() *CreateDatabaseRequestPayload {
+ this := CreateDatabaseRequestPayload{}
+ return &this
+}
+
+// GetName returns the Name field value
+func (o *CreateDatabaseRequestPayload) GetName() (ret CreateDatabaseRequestPayloadGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *CreateDatabaseRequestPayload) GetNameOk() (ret CreateDatabaseRequestPayloadGetNameRetType, ok bool) {
+ return getCreateDatabaseRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *CreateDatabaseRequestPayload) SetName(v CreateDatabaseRequestPayloadGetNameRetType) {
+ setCreateDatabaseRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetOwner returns the Owner field value if set, zero value otherwise.
+func (o *CreateDatabaseRequestPayload) GetOwner() (res CreateDatabaseRequestPayloadGetOwnerRetType) {
+ res, _ = o.GetOwnerOk()
+ return
+}
+
+// GetOwnerOk returns a tuple with the Owner field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *CreateDatabaseRequestPayload) GetOwnerOk() (ret CreateDatabaseRequestPayloadGetOwnerRetType, ok bool) {
+ return getCreateDatabaseRequestPayloadGetOwnerAttributeTypeOk(o.Owner)
+}
+
+// HasOwner returns a boolean if a field has been set.
+func (o *CreateDatabaseRequestPayload) HasOwner() bool {
+ _, ok := o.GetOwnerOk()
+ return ok
+}
+
+// SetOwner gets a reference to the given string and assigns it to the Owner field.
+func (o *CreateDatabaseRequestPayload) SetOwner(v CreateDatabaseRequestPayloadGetOwnerRetType) {
+ setCreateDatabaseRequestPayloadGetOwnerAttributeType(&o.Owner, v)
+}
+
+func (o CreateDatabaseRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateDatabaseRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getCreateDatabaseRequestPayloadGetOwnerAttributeTypeOk(o.Owner); ok {
+ toSerialize["Owner"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateDatabaseRequestPayload struct {
+ value *CreateDatabaseRequestPayload
+ isSet bool
+}
+
+func (v NullableCreateDatabaseRequestPayload) Get() *CreateDatabaseRequestPayload {
+ return v.value
+}
+
+func (v *NullableCreateDatabaseRequestPayload) Set(val *CreateDatabaseRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateDatabaseRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateDatabaseRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateDatabaseRequestPayload(val *CreateDatabaseRequestPayload) *NullableCreateDatabaseRequestPayload {
+ return &NullableCreateDatabaseRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableCreateDatabaseRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateDatabaseRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_create_database_request_payload_test.go b/pkg/postgresflexalpha/model_create_database_request_payload_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_create_database_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_create_database_response.go b/pkg/postgresflexalpha/model_create_database_response.go
new file mode 100644
index 00000000..fc450876
--- /dev/null
+++ b/pkg/postgresflexalpha/model_create_database_response.go
@@ -0,0 +1,126 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateDatabaseResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateDatabaseResponse{}
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type CreateDatabaseResponseGetIdAttributeType = *int64
+type CreateDatabaseResponseGetIdArgType = int64
+type CreateDatabaseResponseGetIdRetType = int64
+
+func getCreateDatabaseResponseGetIdAttributeTypeOk(arg CreateDatabaseResponseGetIdAttributeType) (ret CreateDatabaseResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateDatabaseResponseGetIdAttributeType(arg *CreateDatabaseResponseGetIdAttributeType, val CreateDatabaseResponseGetIdRetType) {
+ *arg = &val
+}
+
+// CreateDatabaseResponse struct for CreateDatabaseResponse
+type CreateDatabaseResponse struct {
+ // The id of the database.
+ // REQUIRED
+ Id CreateDatabaseResponseGetIdAttributeType `json:"id" required:"true"`
+}
+
+type _CreateDatabaseResponse CreateDatabaseResponse
+
+// NewCreateDatabaseResponse instantiates a new CreateDatabaseResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateDatabaseResponse(id CreateDatabaseResponseGetIdArgType) *CreateDatabaseResponse {
+ this := CreateDatabaseResponse{}
+ setCreateDatabaseResponseGetIdAttributeType(&this.Id, id)
+ return &this
+}
+
+// NewCreateDatabaseResponseWithDefaults instantiates a new CreateDatabaseResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateDatabaseResponseWithDefaults() *CreateDatabaseResponse {
+ this := CreateDatabaseResponse{}
+ return &this
+}
+
+// GetId returns the Id field value
+func (o *CreateDatabaseResponse) GetId() (ret CreateDatabaseResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *CreateDatabaseResponse) GetIdOk() (ret CreateDatabaseResponseGetIdRetType, ok bool) {
+ return getCreateDatabaseResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *CreateDatabaseResponse) SetId(v CreateDatabaseResponseGetIdRetType) {
+ setCreateDatabaseResponseGetIdAttributeType(&o.Id, v)
+}
+
+func (o CreateDatabaseResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateDatabaseResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateDatabaseResponse struct {
+ value *CreateDatabaseResponse
+ isSet bool
+}
+
+func (v NullableCreateDatabaseResponse) Get() *CreateDatabaseResponse {
+ return v.value
+}
+
+func (v *NullableCreateDatabaseResponse) Set(val *CreateDatabaseResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateDatabaseResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateDatabaseResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateDatabaseResponse(val *CreateDatabaseResponse) *NullableCreateDatabaseResponse {
+ return &NullableCreateDatabaseResponse{value: val, isSet: true}
+}
+
+func (v NullableCreateDatabaseResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateDatabaseResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_create_database_response_test.go b/pkg/postgresflexalpha/model_create_database_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_create_database_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_create_instance_request_payload.go b/pkg/postgresflexalpha/model_create_instance_request_payload.go
new file mode 100644
index 00000000..8ddd24a0
--- /dev/null
+++ b/pkg/postgresflexalpha/model_create_instance_request_payload.go
@@ -0,0 +1,531 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateInstanceRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateInstanceRequestPayload{}
+
+/*
+ types and functions for acl
+*/
+
+// isArray
+type CreateInstanceRequestPayloadGetAclAttributeType = *[]string
+type CreateInstanceRequestPayloadGetAclArgType = []string
+type CreateInstanceRequestPayloadGetAclRetType = []string
+
+func getCreateInstanceRequestPayloadGetAclAttributeTypeOk(arg CreateInstanceRequestPayloadGetAclAttributeType) (ret CreateInstanceRequestPayloadGetAclRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetAclAttributeType(arg *CreateInstanceRequestPayloadGetAclAttributeType, val CreateInstanceRequestPayloadGetAclRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for backupSchedule
+*/
+
+// isNotNullableString
+type CreateInstanceRequestPayloadGetBackupScheduleAttributeType = *string
+
+func getCreateInstanceRequestPayloadGetBackupScheduleAttributeTypeOk(arg CreateInstanceRequestPayloadGetBackupScheduleAttributeType) (ret CreateInstanceRequestPayloadGetBackupScheduleRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetBackupScheduleAttributeType(arg *CreateInstanceRequestPayloadGetBackupScheduleAttributeType, val CreateInstanceRequestPayloadGetBackupScheduleRetType) {
+ *arg = &val
+}
+
+type CreateInstanceRequestPayloadGetBackupScheduleArgType = string
+type CreateInstanceRequestPayloadGetBackupScheduleRetType = string
+
+/*
+ types and functions for encryption
+*/
+
+// isModel
+type CreateInstanceRequestPayloadGetEncryptionAttributeType = *InstanceEncryption
+type CreateInstanceRequestPayloadGetEncryptionArgType = InstanceEncryption
+type CreateInstanceRequestPayloadGetEncryptionRetType = InstanceEncryption
+
+func getCreateInstanceRequestPayloadGetEncryptionAttributeTypeOk(arg CreateInstanceRequestPayloadGetEncryptionAttributeType) (ret CreateInstanceRequestPayloadGetEncryptionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetEncryptionAttributeType(arg *CreateInstanceRequestPayloadGetEncryptionAttributeType, val CreateInstanceRequestPayloadGetEncryptionRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for flavorId
+*/
+
+// isNotNullableString
+type CreateInstanceRequestPayloadGetFlavorIdAttributeType = *string
+
+func getCreateInstanceRequestPayloadGetFlavorIdAttributeTypeOk(arg CreateInstanceRequestPayloadGetFlavorIdAttributeType) (ret CreateInstanceRequestPayloadGetFlavorIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetFlavorIdAttributeType(arg *CreateInstanceRequestPayloadGetFlavorIdAttributeType, val CreateInstanceRequestPayloadGetFlavorIdRetType) {
+ *arg = &val
+}
+
+type CreateInstanceRequestPayloadGetFlavorIdArgType = string
+type CreateInstanceRequestPayloadGetFlavorIdRetType = string
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type CreateInstanceRequestPayloadGetNameAttributeType = *string
+
+func getCreateInstanceRequestPayloadGetNameAttributeTypeOk(arg CreateInstanceRequestPayloadGetNameAttributeType) (ret CreateInstanceRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetNameAttributeType(arg *CreateInstanceRequestPayloadGetNameAttributeType, val CreateInstanceRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type CreateInstanceRequestPayloadGetNameArgType = string
+type CreateInstanceRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for network
+*/
+
+// isModel
+type CreateInstanceRequestPayloadGetNetworkAttributeType = *InstanceNetwork
+type CreateInstanceRequestPayloadGetNetworkArgType = InstanceNetwork
+type CreateInstanceRequestPayloadGetNetworkRetType = InstanceNetwork
+
+func getCreateInstanceRequestPayloadGetNetworkAttributeTypeOk(arg CreateInstanceRequestPayloadGetNetworkAttributeType) (ret CreateInstanceRequestPayloadGetNetworkRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetNetworkAttributeType(arg *CreateInstanceRequestPayloadGetNetworkAttributeType, val CreateInstanceRequestPayloadGetNetworkRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for replicas
+*/
+
+// isEnumRef
+type CreateInstanceRequestPayloadGetReplicasAttributeType = *Replicas
+type CreateInstanceRequestPayloadGetReplicasArgType = Replicas
+type CreateInstanceRequestPayloadGetReplicasRetType = Replicas
+
+func getCreateInstanceRequestPayloadGetReplicasAttributeTypeOk(arg CreateInstanceRequestPayloadGetReplicasAttributeType) (ret CreateInstanceRequestPayloadGetReplicasRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetReplicasAttributeType(arg *CreateInstanceRequestPayloadGetReplicasAttributeType, val CreateInstanceRequestPayloadGetReplicasRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for retentionDays
+*/
+
+// isInteger
+type CreateInstanceRequestPayloadGetRetentionDaysAttributeType = *int64
+type CreateInstanceRequestPayloadGetRetentionDaysArgType = int64
+type CreateInstanceRequestPayloadGetRetentionDaysRetType = int64
+
+func getCreateInstanceRequestPayloadGetRetentionDaysAttributeTypeOk(arg CreateInstanceRequestPayloadGetRetentionDaysAttributeType) (ret CreateInstanceRequestPayloadGetRetentionDaysRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetRetentionDaysAttributeType(arg *CreateInstanceRequestPayloadGetRetentionDaysAttributeType, val CreateInstanceRequestPayloadGetRetentionDaysRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for storage
+*/
+
+// isModel
+type CreateInstanceRequestPayloadGetStorageAttributeType = *StorageCreate
+type CreateInstanceRequestPayloadGetStorageArgType = StorageCreate
+type CreateInstanceRequestPayloadGetStorageRetType = StorageCreate
+
+func getCreateInstanceRequestPayloadGetStorageAttributeTypeOk(arg CreateInstanceRequestPayloadGetStorageAttributeType) (ret CreateInstanceRequestPayloadGetStorageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetStorageAttributeType(arg *CreateInstanceRequestPayloadGetStorageAttributeType, val CreateInstanceRequestPayloadGetStorageRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for version
+*/
+
+// isNotNullableString
+type CreateInstanceRequestPayloadGetVersionAttributeType = *string
+
+func getCreateInstanceRequestPayloadGetVersionAttributeTypeOk(arg CreateInstanceRequestPayloadGetVersionAttributeType) (ret CreateInstanceRequestPayloadGetVersionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetVersionAttributeType(arg *CreateInstanceRequestPayloadGetVersionAttributeType, val CreateInstanceRequestPayloadGetVersionRetType) {
+ *arg = &val
+}
+
+type CreateInstanceRequestPayloadGetVersionArgType = string
+type CreateInstanceRequestPayloadGetVersionRetType = string
+
+// CreateInstanceRequestPayload struct for CreateInstanceRequestPayload
+type CreateInstanceRequestPayload struct {
+ // List of IPV4 cidr.
+ // REQUIRED
+ Acl CreateInstanceRequestPayloadGetAclAttributeType `json:"acl" required:"true"`
+ // The schedule for on what time and how often the database backup will be created. The schedule is written as a cron schedule.
+ // REQUIRED
+ BackupSchedule CreateInstanceRequestPayloadGetBackupScheduleAttributeType `json:"backupSchedule" required:"true"`
+ Encryption CreateInstanceRequestPayloadGetEncryptionAttributeType `json:"encryption,omitempty"`
+ // The id of the instance flavor.
+ // REQUIRED
+ FlavorId CreateInstanceRequestPayloadGetFlavorIdAttributeType `json:"flavorId" required:"true"`
+ // The name of the instance.
+ // REQUIRED
+ Name CreateInstanceRequestPayloadGetNameAttributeType `json:"name" required:"true"`
+ Network CreateInstanceRequestPayloadGetNetworkAttributeType `json:"network,omitempty"`
+ // REQUIRED
+ Replicas CreateInstanceRequestPayloadGetReplicasAttributeType `json:"replicas" required:"true"`
+ // How long backups are retained. The value can only be between 32 and 365 days.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ RetentionDays CreateInstanceRequestPayloadGetRetentionDaysAttributeType `json:"retentionDays" required:"true"`
+ // REQUIRED
+ Storage CreateInstanceRequestPayloadGetStorageAttributeType `json:"storage" required:"true"`
+ // The Postgres version used for the instance. See [Versions Endpoint](/documentation/postgres-flex-service/version/v3alpha1#tag/Version) for supported version parameters.
+ // REQUIRED
+ Version CreateInstanceRequestPayloadGetVersionAttributeType `json:"version" required:"true"`
+}
+
+type _CreateInstanceRequestPayload CreateInstanceRequestPayload
+
+// NewCreateInstanceRequestPayload instantiates a new CreateInstanceRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateInstanceRequestPayload(acl CreateInstanceRequestPayloadGetAclArgType, backupSchedule CreateInstanceRequestPayloadGetBackupScheduleArgType, flavorId CreateInstanceRequestPayloadGetFlavorIdArgType, name CreateInstanceRequestPayloadGetNameArgType, replicas CreateInstanceRequestPayloadGetReplicasArgType, retentionDays CreateInstanceRequestPayloadGetRetentionDaysArgType, storage CreateInstanceRequestPayloadGetStorageArgType, version CreateInstanceRequestPayloadGetVersionArgType) *CreateInstanceRequestPayload {
+ this := CreateInstanceRequestPayload{}
+ setCreateInstanceRequestPayloadGetAclAttributeType(&this.Acl, acl)
+ setCreateInstanceRequestPayloadGetBackupScheduleAttributeType(&this.BackupSchedule, backupSchedule)
+ setCreateInstanceRequestPayloadGetFlavorIdAttributeType(&this.FlavorId, flavorId)
+ setCreateInstanceRequestPayloadGetNameAttributeType(&this.Name, name)
+ setCreateInstanceRequestPayloadGetReplicasAttributeType(&this.Replicas, replicas)
+ setCreateInstanceRequestPayloadGetRetentionDaysAttributeType(&this.RetentionDays, retentionDays)
+ setCreateInstanceRequestPayloadGetStorageAttributeType(&this.Storage, storage)
+ setCreateInstanceRequestPayloadGetVersionAttributeType(&this.Version, version)
+ return &this
+}
+
+// NewCreateInstanceRequestPayloadWithDefaults instantiates a new CreateInstanceRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateInstanceRequestPayloadWithDefaults() *CreateInstanceRequestPayload {
+ this := CreateInstanceRequestPayload{}
+ return &this
+}
+
+// GetAcl returns the Acl field value
+func (o *CreateInstanceRequestPayload) GetAcl() (ret CreateInstanceRequestPayloadGetAclRetType) {
+ ret, _ = o.GetAclOk()
+ return ret
+}
+
+// GetAclOk returns a tuple with the Acl field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetAclOk() (ret CreateInstanceRequestPayloadGetAclRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetAclAttributeTypeOk(o.Acl)
+}
+
+// SetAcl sets field value
+func (o *CreateInstanceRequestPayload) SetAcl(v CreateInstanceRequestPayloadGetAclRetType) {
+ setCreateInstanceRequestPayloadGetAclAttributeType(&o.Acl, v)
+}
+
+// GetBackupSchedule returns the BackupSchedule field value
+func (o *CreateInstanceRequestPayload) GetBackupSchedule() (ret CreateInstanceRequestPayloadGetBackupScheduleRetType) {
+ ret, _ = o.GetBackupScheduleOk()
+ return ret
+}
+
+// GetBackupScheduleOk returns a tuple with the BackupSchedule field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetBackupScheduleOk() (ret CreateInstanceRequestPayloadGetBackupScheduleRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetBackupScheduleAttributeTypeOk(o.BackupSchedule)
+}
+
+// SetBackupSchedule sets field value
+func (o *CreateInstanceRequestPayload) SetBackupSchedule(v CreateInstanceRequestPayloadGetBackupScheduleRetType) {
+ setCreateInstanceRequestPayloadGetBackupScheduleAttributeType(&o.BackupSchedule, v)
+}
+
+// GetEncryption returns the Encryption field value if set, zero value otherwise.
+func (o *CreateInstanceRequestPayload) GetEncryption() (res CreateInstanceRequestPayloadGetEncryptionRetType) {
+ res, _ = o.GetEncryptionOk()
+ return
+}
+
+// GetEncryptionOk returns a tuple with the Encryption field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetEncryptionOk() (ret CreateInstanceRequestPayloadGetEncryptionRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetEncryptionAttributeTypeOk(o.Encryption)
+}
+
+// HasEncryption returns a boolean if a field has been set.
+func (o *CreateInstanceRequestPayload) HasEncryption() bool {
+ _, ok := o.GetEncryptionOk()
+ return ok
+}
+
+// SetEncryption gets a reference to the given InstanceEncryption and assigns it to the Encryption field.
+func (o *CreateInstanceRequestPayload) SetEncryption(v CreateInstanceRequestPayloadGetEncryptionRetType) {
+ setCreateInstanceRequestPayloadGetEncryptionAttributeType(&o.Encryption, v)
+}
+
+// GetFlavorId returns the FlavorId field value
+func (o *CreateInstanceRequestPayload) GetFlavorId() (ret CreateInstanceRequestPayloadGetFlavorIdRetType) {
+ ret, _ = o.GetFlavorIdOk()
+ return ret
+}
+
+// GetFlavorIdOk returns a tuple with the FlavorId field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetFlavorIdOk() (ret CreateInstanceRequestPayloadGetFlavorIdRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetFlavorIdAttributeTypeOk(o.FlavorId)
+}
+
+// SetFlavorId sets field value
+func (o *CreateInstanceRequestPayload) SetFlavorId(v CreateInstanceRequestPayloadGetFlavorIdRetType) {
+ setCreateInstanceRequestPayloadGetFlavorIdAttributeType(&o.FlavorId, v)
+}
+
+// GetName returns the Name field value
+func (o *CreateInstanceRequestPayload) GetName() (ret CreateInstanceRequestPayloadGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetNameOk() (ret CreateInstanceRequestPayloadGetNameRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *CreateInstanceRequestPayload) SetName(v CreateInstanceRequestPayloadGetNameRetType) {
+ setCreateInstanceRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetNetwork returns the Network field value if set, zero value otherwise.
+func (o *CreateInstanceRequestPayload) GetNetwork() (res CreateInstanceRequestPayloadGetNetworkRetType) {
+ res, _ = o.GetNetworkOk()
+ return
+}
+
+// GetNetworkOk returns a tuple with the Network field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetNetworkOk() (ret CreateInstanceRequestPayloadGetNetworkRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetNetworkAttributeTypeOk(o.Network)
+}
+
+// HasNetwork returns a boolean if a field has been set.
+func (o *CreateInstanceRequestPayload) HasNetwork() bool {
+ _, ok := o.GetNetworkOk()
+ return ok
+}
+
+// SetNetwork gets a reference to the given InstanceNetwork and assigns it to the Network field.
+func (o *CreateInstanceRequestPayload) SetNetwork(v CreateInstanceRequestPayloadGetNetworkRetType) {
+ setCreateInstanceRequestPayloadGetNetworkAttributeType(&o.Network, v)
+}
+
+// GetReplicas returns the Replicas field value
+func (o *CreateInstanceRequestPayload) GetReplicas() (ret CreateInstanceRequestPayloadGetReplicasRetType) {
+ ret, _ = o.GetReplicasOk()
+ return ret
+}
+
+// GetReplicasOk returns a tuple with the Replicas field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetReplicasOk() (ret CreateInstanceRequestPayloadGetReplicasRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetReplicasAttributeTypeOk(o.Replicas)
+}
+
+// SetReplicas sets field value
+func (o *CreateInstanceRequestPayload) SetReplicas(v CreateInstanceRequestPayloadGetReplicasRetType) {
+ setCreateInstanceRequestPayloadGetReplicasAttributeType(&o.Replicas, v)
+}
+
+// GetRetentionDays returns the RetentionDays field value
+func (o *CreateInstanceRequestPayload) GetRetentionDays() (ret CreateInstanceRequestPayloadGetRetentionDaysRetType) {
+ ret, _ = o.GetRetentionDaysOk()
+ return ret
+}
+
+// GetRetentionDaysOk returns a tuple with the RetentionDays field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetRetentionDaysOk() (ret CreateInstanceRequestPayloadGetRetentionDaysRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetRetentionDaysAttributeTypeOk(o.RetentionDays)
+}
+
+// SetRetentionDays sets field value
+func (o *CreateInstanceRequestPayload) SetRetentionDays(v CreateInstanceRequestPayloadGetRetentionDaysRetType) {
+ setCreateInstanceRequestPayloadGetRetentionDaysAttributeType(&o.RetentionDays, v)
+}
+
+// GetStorage returns the Storage field value
+func (o *CreateInstanceRequestPayload) GetStorage() (ret CreateInstanceRequestPayloadGetStorageRetType) {
+ ret, _ = o.GetStorageOk()
+ return ret
+}
+
+// GetStorageOk returns a tuple with the Storage field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetStorageOk() (ret CreateInstanceRequestPayloadGetStorageRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetStorageAttributeTypeOk(o.Storage)
+}
+
+// SetStorage sets field value
+func (o *CreateInstanceRequestPayload) SetStorage(v CreateInstanceRequestPayloadGetStorageRetType) {
+ setCreateInstanceRequestPayloadGetStorageAttributeType(&o.Storage, v)
+}
+
+// GetVersion returns the Version field value
+func (o *CreateInstanceRequestPayload) GetVersion() (ret CreateInstanceRequestPayloadGetVersionRetType) {
+ ret, _ = o.GetVersionOk()
+ return ret
+}
+
+// GetVersionOk returns a tuple with the Version field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetVersionOk() (ret CreateInstanceRequestPayloadGetVersionRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetVersionAttributeTypeOk(o.Version)
+}
+
+// SetVersion sets field value
+func (o *CreateInstanceRequestPayload) SetVersion(v CreateInstanceRequestPayloadGetVersionRetType) {
+ setCreateInstanceRequestPayloadGetVersionAttributeType(&o.Version, v)
+}
+
+func (o CreateInstanceRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateInstanceRequestPayloadGetAclAttributeTypeOk(o.Acl); ok {
+ toSerialize["Acl"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetBackupScheduleAttributeTypeOk(o.BackupSchedule); ok {
+ toSerialize["BackupSchedule"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetEncryptionAttributeTypeOk(o.Encryption); ok {
+ toSerialize["Encryption"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetFlavorIdAttributeTypeOk(o.FlavorId); ok {
+ toSerialize["FlavorId"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetNetworkAttributeTypeOk(o.Network); ok {
+ toSerialize["Network"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetReplicasAttributeTypeOk(o.Replicas); ok {
+ toSerialize["Replicas"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetRetentionDaysAttributeTypeOk(o.RetentionDays); ok {
+ toSerialize["RetentionDays"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetStorageAttributeTypeOk(o.Storage); ok {
+ toSerialize["Storage"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetVersionAttributeTypeOk(o.Version); ok {
+ toSerialize["Version"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateInstanceRequestPayload struct {
+ value *CreateInstanceRequestPayload
+ isSet bool
+}
+
+func (v NullableCreateInstanceRequestPayload) Get() *CreateInstanceRequestPayload {
+ return v.value
+}
+
+func (v *NullableCreateInstanceRequestPayload) Set(val *CreateInstanceRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateInstanceRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateInstanceRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateInstanceRequestPayload(val *CreateInstanceRequestPayload) *NullableCreateInstanceRequestPayload {
+ return &NullableCreateInstanceRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableCreateInstanceRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateInstanceRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_create_instance_request_payload_test.go b/pkg/postgresflexalpha/model_create_instance_request_payload_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_create_instance_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_create_instance_response.go b/pkg/postgresflexalpha/model_create_instance_response.go
new file mode 100644
index 00000000..def4f984
--- /dev/null
+++ b/pkg/postgresflexalpha/model_create_instance_response.go
@@ -0,0 +1,127 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateInstanceResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateInstanceResponse{}
+
+/*
+ types and functions for id
+*/
+
+// isNotNullableString
+type CreateInstanceResponseGetIdAttributeType = *string
+
+func getCreateInstanceResponseGetIdAttributeTypeOk(arg CreateInstanceResponseGetIdAttributeType) (ret CreateInstanceResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceResponseGetIdAttributeType(arg *CreateInstanceResponseGetIdAttributeType, val CreateInstanceResponseGetIdRetType) {
+ *arg = &val
+}
+
+type CreateInstanceResponseGetIdArgType = string
+type CreateInstanceResponseGetIdRetType = string
+
+// CreateInstanceResponse struct for CreateInstanceResponse
+type CreateInstanceResponse struct {
+ // The ID of the instance.
+ // REQUIRED
+ Id CreateInstanceResponseGetIdAttributeType `json:"id" required:"true"`
+}
+
+type _CreateInstanceResponse CreateInstanceResponse
+
+// NewCreateInstanceResponse instantiates a new CreateInstanceResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateInstanceResponse(id CreateInstanceResponseGetIdArgType) *CreateInstanceResponse {
+ this := CreateInstanceResponse{}
+ setCreateInstanceResponseGetIdAttributeType(&this.Id, id)
+ return &this
+}
+
+// NewCreateInstanceResponseWithDefaults instantiates a new CreateInstanceResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateInstanceResponseWithDefaults() *CreateInstanceResponse {
+ this := CreateInstanceResponse{}
+ return &this
+}
+
+// GetId returns the Id field value
+func (o *CreateInstanceResponse) GetId() (ret CreateInstanceResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceResponse) GetIdOk() (ret CreateInstanceResponseGetIdRetType, ok bool) {
+ return getCreateInstanceResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *CreateInstanceResponse) SetId(v CreateInstanceResponseGetIdRetType) {
+ setCreateInstanceResponseGetIdAttributeType(&o.Id, v)
+}
+
+func (o CreateInstanceResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateInstanceResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateInstanceResponse struct {
+ value *CreateInstanceResponse
+ isSet bool
+}
+
+func (v NullableCreateInstanceResponse) Get() *CreateInstanceResponse {
+ return v.value
+}
+
+func (v *NullableCreateInstanceResponse) Set(val *CreateInstanceResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateInstanceResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateInstanceResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateInstanceResponse(val *CreateInstanceResponse) *NullableCreateInstanceResponse {
+ return &NullableCreateInstanceResponse{value: val, isSet: true}
+}
+
+func (v NullableCreateInstanceResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateInstanceResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_create_instance_response_test.go b/pkg/postgresflexalpha/model_create_instance_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_create_instance_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_create_user_request_payload.go b/pkg/postgresflexalpha/model_create_user_request_payload.go
new file mode 100644
index 00000000..b1a1c92b
--- /dev/null
+++ b/pkg/postgresflexalpha/model_create_user_request_payload.go
@@ -0,0 +1,175 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateUserRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateUserRequestPayload{}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type CreateUserRequestPayloadGetNameAttributeType = *string
+
+func getCreateUserRequestPayloadGetNameAttributeTypeOk(arg CreateUserRequestPayloadGetNameAttributeType) (ret CreateUserRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserRequestPayloadGetNameAttributeType(arg *CreateUserRequestPayloadGetNameAttributeType, val CreateUserRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type CreateUserRequestPayloadGetNameArgType = string
+type CreateUserRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for roles
+*/
+
+// isArray
+type CreateUserRequestPayloadGetRolesAttributeType = *[]UserRole
+type CreateUserRequestPayloadGetRolesArgType = []UserRole
+type CreateUserRequestPayloadGetRolesRetType = []UserRole
+
+func getCreateUserRequestPayloadGetRolesAttributeTypeOk(arg CreateUserRequestPayloadGetRolesAttributeType) (ret CreateUserRequestPayloadGetRolesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserRequestPayloadGetRolesAttributeType(arg *CreateUserRequestPayloadGetRolesAttributeType, val CreateUserRequestPayloadGetRolesRetType) {
+ *arg = &val
+}
+
+// CreateUserRequestPayload struct for CreateUserRequestPayload
+type CreateUserRequestPayload struct {
+ // The name of the user.
+ // REQUIRED
+ Name CreateUserRequestPayloadGetNameAttributeType `json:"name" required:"true"`
+ // A list containing the user roles for the instance.
+ Roles CreateUserRequestPayloadGetRolesAttributeType `json:"roles,omitempty"`
+}
+
+type _CreateUserRequestPayload CreateUserRequestPayload
+
+// NewCreateUserRequestPayload instantiates a new CreateUserRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateUserRequestPayload(name CreateUserRequestPayloadGetNameArgType) *CreateUserRequestPayload {
+ this := CreateUserRequestPayload{}
+ setCreateUserRequestPayloadGetNameAttributeType(&this.Name, name)
+ return &this
+}
+
+// NewCreateUserRequestPayloadWithDefaults instantiates a new CreateUserRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateUserRequestPayloadWithDefaults() *CreateUserRequestPayload {
+ this := CreateUserRequestPayload{}
+ return &this
+}
+
+// GetName returns the Name field value
+func (o *CreateUserRequestPayload) GetName() (ret CreateUserRequestPayloadGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserRequestPayload) GetNameOk() (ret CreateUserRequestPayloadGetNameRetType, ok bool) {
+ return getCreateUserRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *CreateUserRequestPayload) SetName(v CreateUserRequestPayloadGetNameRetType) {
+ setCreateUserRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetRoles returns the Roles field value if set, zero value otherwise.
+func (o *CreateUserRequestPayload) GetRoles() (res CreateUserRequestPayloadGetRolesRetType) {
+ res, _ = o.GetRolesOk()
+ return
+}
+
+// GetRolesOk returns a tuple with the Roles field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *CreateUserRequestPayload) GetRolesOk() (ret CreateUserRequestPayloadGetRolesRetType, ok bool) {
+ return getCreateUserRequestPayloadGetRolesAttributeTypeOk(o.Roles)
+}
+
+// HasRoles returns a boolean if a field has been set.
+func (o *CreateUserRequestPayload) HasRoles() bool {
+ _, ok := o.GetRolesOk()
+ return ok
+}
+
+// SetRoles gets a reference to the given []UserRole and assigns it to the Roles field.
+func (o *CreateUserRequestPayload) SetRoles(v CreateUserRequestPayloadGetRolesRetType) {
+ setCreateUserRequestPayloadGetRolesAttributeType(&o.Roles, v)
+}
+
+func (o CreateUserRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateUserRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getCreateUserRequestPayloadGetRolesAttributeTypeOk(o.Roles); ok {
+ toSerialize["Roles"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateUserRequestPayload struct {
+ value *CreateUserRequestPayload
+ isSet bool
+}
+
+func (v NullableCreateUserRequestPayload) Get() *CreateUserRequestPayload {
+ return v.value
+}
+
+func (v *NullableCreateUserRequestPayload) Set(val *CreateUserRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateUserRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateUserRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateUserRequestPayload(val *CreateUserRequestPayload) *NullableCreateUserRequestPayload {
+ return &NullableCreateUserRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableCreateUserRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateUserRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_create_user_request_payload_test.go b/pkg/postgresflexalpha/model_create_user_request_payload_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_create_user_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_create_user_response.go b/pkg/postgresflexalpha/model_create_user_response.go
new file mode 100644
index 00000000..66367782
--- /dev/null
+++ b/pkg/postgresflexalpha/model_create_user_response.go
@@ -0,0 +1,306 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateUserResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateUserResponse{}
+
+/*
+ types and functions for connectionString
+*/
+
+// isNotNullableString
+type CreateUserResponseGetConnectionStringAttributeType = *string
+
+func getCreateUserResponseGetConnectionStringAttributeTypeOk(arg CreateUserResponseGetConnectionStringAttributeType) (ret CreateUserResponseGetConnectionStringRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetConnectionStringAttributeType(arg *CreateUserResponseGetConnectionStringAttributeType, val CreateUserResponseGetConnectionStringRetType) {
+ *arg = &val
+}
+
+type CreateUserResponseGetConnectionStringArgType = string
+type CreateUserResponseGetConnectionStringRetType = string
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type CreateUserResponseGetIdAttributeType = *int64
+type CreateUserResponseGetIdArgType = int64
+type CreateUserResponseGetIdRetType = int64
+
+func getCreateUserResponseGetIdAttributeTypeOk(arg CreateUserResponseGetIdAttributeType) (ret CreateUserResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetIdAttributeType(arg *CreateUserResponseGetIdAttributeType, val CreateUserResponseGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type CreateUserResponseGetNameAttributeType = *string
+
+func getCreateUserResponseGetNameAttributeTypeOk(arg CreateUserResponseGetNameAttributeType) (ret CreateUserResponseGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetNameAttributeType(arg *CreateUserResponseGetNameAttributeType, val CreateUserResponseGetNameRetType) {
+ *arg = &val
+}
+
+type CreateUserResponseGetNameArgType = string
+type CreateUserResponseGetNameRetType = string
+
+/*
+ types and functions for password
+*/
+
+// isNotNullableString
+type CreateUserResponseGetPasswordAttributeType = *string
+
+func getCreateUserResponseGetPasswordAttributeTypeOk(arg CreateUserResponseGetPasswordAttributeType) (ret CreateUserResponseGetPasswordRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetPasswordAttributeType(arg *CreateUserResponseGetPasswordAttributeType, val CreateUserResponseGetPasswordRetType) {
+ *arg = &val
+}
+
+type CreateUserResponseGetPasswordArgType = string
+type CreateUserResponseGetPasswordRetType = string
+
+/*
+ types and functions for status
+*/
+
+// isNotNullableString
+type CreateUserResponseGetStatusAttributeType = *string
+
+func getCreateUserResponseGetStatusAttributeTypeOk(arg CreateUserResponseGetStatusAttributeType) (ret CreateUserResponseGetStatusRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetStatusAttributeType(arg *CreateUserResponseGetStatusAttributeType, val CreateUserResponseGetStatusRetType) {
+ *arg = &val
+}
+
+type CreateUserResponseGetStatusArgType = string
+type CreateUserResponseGetStatusRetType = string
+
+// CreateUserResponse struct for CreateUserResponse
+type CreateUserResponse struct {
+ // The connection string for the user to the instance.
+ // REQUIRED
+ ConnectionString CreateUserResponseGetConnectionStringAttributeType `json:"connectionString" required:"true"`
+ // The ID of the user.
+ // REQUIRED
+ Id CreateUserResponseGetIdAttributeType `json:"id" required:"true"`
+ // The name of the user.
+ // REQUIRED
+ Name CreateUserResponseGetNameAttributeType `json:"name" required:"true"`
+ // The password for the user.
+ // REQUIRED
+ Password CreateUserResponseGetPasswordAttributeType `json:"password" required:"true"`
+ // The current status of the user.
+ // REQUIRED
+ Status CreateUserResponseGetStatusAttributeType `json:"status" required:"true"`
+}
+
+type _CreateUserResponse CreateUserResponse
+
+// NewCreateUserResponse instantiates a new CreateUserResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateUserResponse(connectionString CreateUserResponseGetConnectionStringArgType, id CreateUserResponseGetIdArgType, name CreateUserResponseGetNameArgType, password CreateUserResponseGetPasswordArgType, status CreateUserResponseGetStatusArgType) *CreateUserResponse {
+ this := CreateUserResponse{}
+ setCreateUserResponseGetConnectionStringAttributeType(&this.ConnectionString, connectionString)
+ setCreateUserResponseGetIdAttributeType(&this.Id, id)
+ setCreateUserResponseGetNameAttributeType(&this.Name, name)
+ setCreateUserResponseGetPasswordAttributeType(&this.Password, password)
+ setCreateUserResponseGetStatusAttributeType(&this.Status, status)
+ return &this
+}
+
+// NewCreateUserResponseWithDefaults instantiates a new CreateUserResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateUserResponseWithDefaults() *CreateUserResponse {
+ this := CreateUserResponse{}
+ return &this
+}
+
+// GetConnectionString returns the ConnectionString field value
+func (o *CreateUserResponse) GetConnectionString() (ret CreateUserResponseGetConnectionStringRetType) {
+ ret, _ = o.GetConnectionStringOk()
+ return ret
+}
+
+// GetConnectionStringOk returns a tuple with the ConnectionString field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetConnectionStringOk() (ret CreateUserResponseGetConnectionStringRetType, ok bool) {
+ return getCreateUserResponseGetConnectionStringAttributeTypeOk(o.ConnectionString)
+}
+
+// SetConnectionString sets field value
+func (o *CreateUserResponse) SetConnectionString(v CreateUserResponseGetConnectionStringRetType) {
+ setCreateUserResponseGetConnectionStringAttributeType(&o.ConnectionString, v)
+}
+
+// GetId returns the Id field value
+func (o *CreateUserResponse) GetId() (ret CreateUserResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetIdOk() (ret CreateUserResponseGetIdRetType, ok bool) {
+ return getCreateUserResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *CreateUserResponse) SetId(v CreateUserResponseGetIdRetType) {
+ setCreateUserResponseGetIdAttributeType(&o.Id, v)
+}
+
+// GetName returns the Name field value
+func (o *CreateUserResponse) GetName() (ret CreateUserResponseGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetNameOk() (ret CreateUserResponseGetNameRetType, ok bool) {
+ return getCreateUserResponseGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *CreateUserResponse) SetName(v CreateUserResponseGetNameRetType) {
+ setCreateUserResponseGetNameAttributeType(&o.Name, v)
+}
+
+// GetPassword returns the Password field value
+func (o *CreateUserResponse) GetPassword() (ret CreateUserResponseGetPasswordRetType) {
+ ret, _ = o.GetPasswordOk()
+ return ret
+}
+
+// GetPasswordOk returns a tuple with the Password field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetPasswordOk() (ret CreateUserResponseGetPasswordRetType, ok bool) {
+ return getCreateUserResponseGetPasswordAttributeTypeOk(o.Password)
+}
+
+// SetPassword sets field value
+func (o *CreateUserResponse) SetPassword(v CreateUserResponseGetPasswordRetType) {
+ setCreateUserResponseGetPasswordAttributeType(&o.Password, v)
+}
+
+// GetStatus returns the Status field value
+func (o *CreateUserResponse) GetStatus() (ret CreateUserResponseGetStatusRetType) {
+ ret, _ = o.GetStatusOk()
+ return ret
+}
+
+// GetStatusOk returns a tuple with the Status field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetStatusOk() (ret CreateUserResponseGetStatusRetType, ok bool) {
+ return getCreateUserResponseGetStatusAttributeTypeOk(o.Status)
+}
+
+// SetStatus sets field value
+func (o *CreateUserResponse) SetStatus(v CreateUserResponseGetStatusRetType) {
+ setCreateUserResponseGetStatusAttributeType(&o.Status, v)
+}
+
+func (o CreateUserResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateUserResponseGetConnectionStringAttributeTypeOk(o.ConnectionString); ok {
+ toSerialize["ConnectionString"] = val
+ }
+ if val, ok := getCreateUserResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getCreateUserResponseGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getCreateUserResponseGetPasswordAttributeTypeOk(o.Password); ok {
+ toSerialize["Password"] = val
+ }
+ if val, ok := getCreateUserResponseGetStatusAttributeTypeOk(o.Status); ok {
+ toSerialize["Status"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateUserResponse struct {
+ value *CreateUserResponse
+ isSet bool
+}
+
+func (v NullableCreateUserResponse) Get() *CreateUserResponse {
+ return v.value
+}
+
+func (v *NullableCreateUserResponse) Set(val *CreateUserResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateUserResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateUserResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateUserResponse(val *CreateUserResponse) *NullableCreateUserResponse {
+ return &NullableCreateUserResponse{value: val, isSet: true}
+}
+
+func (v NullableCreateUserResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateUserResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_create_user_response_test.go b/pkg/postgresflexalpha/model_create_user_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_create_user_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_database_roles.go b/pkg/postgresflexalpha/model_database_roles.go
new file mode 100644
index 00000000..39d89310
--- /dev/null
+++ b/pkg/postgresflexalpha/model_database_roles.go
@@ -0,0 +1,171 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the DatabaseRoles type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &DatabaseRoles{}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type DatabaseRolesGetNameAttributeType = *string
+
+func getDatabaseRolesGetNameAttributeTypeOk(arg DatabaseRolesGetNameAttributeType) (ret DatabaseRolesGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setDatabaseRolesGetNameAttributeType(arg *DatabaseRolesGetNameAttributeType, val DatabaseRolesGetNameRetType) {
+ *arg = &val
+}
+
+type DatabaseRolesGetNameArgType = string
+type DatabaseRolesGetNameRetType = string
+
+/*
+ types and functions for roles
+*/
+
+// isArray
+type DatabaseRolesGetRolesAttributeType = *[]string
+type DatabaseRolesGetRolesArgType = []string
+type DatabaseRolesGetRolesRetType = []string
+
+func getDatabaseRolesGetRolesAttributeTypeOk(arg DatabaseRolesGetRolesAttributeType) (ret DatabaseRolesGetRolesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setDatabaseRolesGetRolesAttributeType(arg *DatabaseRolesGetRolesAttributeType, val DatabaseRolesGetRolesRetType) {
+ *arg = &val
+}
+
+// DatabaseRoles The name and the roles for a database for a user.
+type DatabaseRoles struct {
+ // The name of the database.
+ // REQUIRED
+ Name DatabaseRolesGetNameAttributeType `json:"name" required:"true"`
+ // The name and the roles for a database
+ // REQUIRED
+ Roles DatabaseRolesGetRolesAttributeType `json:"roles" required:"true"`
+}
+
+type _DatabaseRoles DatabaseRoles
+
+// NewDatabaseRoles instantiates a new DatabaseRoles object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewDatabaseRoles(name DatabaseRolesGetNameArgType, roles DatabaseRolesGetRolesArgType) *DatabaseRoles {
+ this := DatabaseRoles{}
+ setDatabaseRolesGetNameAttributeType(&this.Name, name)
+ setDatabaseRolesGetRolesAttributeType(&this.Roles, roles)
+ return &this
+}
+
+// NewDatabaseRolesWithDefaults instantiates a new DatabaseRoles object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewDatabaseRolesWithDefaults() *DatabaseRoles {
+ this := DatabaseRoles{}
+ return &this
+}
+
+// GetName returns the Name field value
+func (o *DatabaseRoles) GetName() (ret DatabaseRolesGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *DatabaseRoles) GetNameOk() (ret DatabaseRolesGetNameRetType, ok bool) {
+ return getDatabaseRolesGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *DatabaseRoles) SetName(v DatabaseRolesGetNameRetType) {
+ setDatabaseRolesGetNameAttributeType(&o.Name, v)
+}
+
+// GetRoles returns the Roles field value
+func (o *DatabaseRoles) GetRoles() (ret DatabaseRolesGetRolesRetType) {
+ ret, _ = o.GetRolesOk()
+ return ret
+}
+
+// GetRolesOk returns a tuple with the Roles field value
+// and a boolean to check if the value has been set.
+func (o *DatabaseRoles) GetRolesOk() (ret DatabaseRolesGetRolesRetType, ok bool) {
+ return getDatabaseRolesGetRolesAttributeTypeOk(o.Roles)
+}
+
+// SetRoles sets field value
+func (o *DatabaseRoles) SetRoles(v DatabaseRolesGetRolesRetType) {
+ setDatabaseRolesGetRolesAttributeType(&o.Roles, v)
+}
+
+func (o DatabaseRoles) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getDatabaseRolesGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getDatabaseRolesGetRolesAttributeTypeOk(o.Roles); ok {
+ toSerialize["Roles"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableDatabaseRoles struct {
+ value *DatabaseRoles
+ isSet bool
+}
+
+func (v NullableDatabaseRoles) Get() *DatabaseRoles {
+ return v.value
+}
+
+func (v *NullableDatabaseRoles) Set(val *DatabaseRoles) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableDatabaseRoles) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableDatabaseRoles) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableDatabaseRoles(val *DatabaseRoles) *NullableDatabaseRoles {
+ return &NullableDatabaseRoles{value: val, isSet: true}
+}
+
+func (v NullableDatabaseRoles) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableDatabaseRoles) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_database_roles_test.go b/pkg/postgresflexalpha/model_database_roles_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_database_roles_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_database_sort.go b/pkg/postgresflexalpha/model_database_sort.go
new file mode 100644
index 00000000..29f4c390
--- /dev/null
+++ b/pkg/postgresflexalpha/model_database_sort.go
@@ -0,0 +1,131 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// DatabaseSort the model 'DatabaseSort'
+type DatabaseSort string
+
+// List of database.sort
+const (
+ DATABASESORT_CREATED_AT_DESC DatabaseSort = "created_at.desc"
+ DATABASESORT_CREATED_AT_ASC DatabaseSort = "created_at.asc"
+ DATABASESORT_DATABASE_ID_DESC DatabaseSort = "database_id.desc"
+ DATABASESORT_DATABASE_ID_ASC DatabaseSort = "database_id.asc"
+ DATABASESORT_DATABASE_NAME_DESC DatabaseSort = "database_name.desc"
+ DATABASESORT_DATABASE_NAME_ASC DatabaseSort = "database_name.asc"
+ DATABASESORT_DATABASE_OWNER_DESC DatabaseSort = "database_owner.desc"
+ DATABASESORT_DATABASE_OWNER_ASC DatabaseSort = "database_owner.asc"
+ DATABASESORT_INDEX_ASC DatabaseSort = "index.asc"
+ DATABASESORT_INDEX_DESC DatabaseSort = "index.desc"
+)
+
+// All allowed values of DatabaseSort enum
+var AllowedDatabaseSortEnumValues = []DatabaseSort{
+ "created_at.desc",
+ "created_at.asc",
+ "database_id.desc",
+ "database_id.asc",
+ "database_name.desc",
+ "database_name.asc",
+ "database_owner.desc",
+ "database_owner.asc",
+ "index.asc",
+ "index.desc",
+}
+
+func (v *DatabaseSort) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := DatabaseSort(value)
+ for _, existing := range AllowedDatabaseSortEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid DatabaseSort", value)
+}
+
+// NewDatabaseSortFromValue returns a pointer to a valid DatabaseSort
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewDatabaseSortFromValue(v string) (*DatabaseSort, error) {
+ ev := DatabaseSort(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for DatabaseSort: valid values are %v", v, AllowedDatabaseSortEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v DatabaseSort) IsValid() bool {
+ for _, existing := range AllowedDatabaseSortEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to database.sort value
+func (v DatabaseSort) Ptr() *DatabaseSort {
+ return &v
+}
+
+type NullableDatabaseSort struct {
+ value *DatabaseSort
+ isSet bool
+}
+
+func (v NullableDatabaseSort) Get() *DatabaseSort {
+ return v.value
+}
+
+func (v *NullableDatabaseSort) Set(val *DatabaseSort) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableDatabaseSort) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableDatabaseSort) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableDatabaseSort(val *DatabaseSort) *NullableDatabaseSort {
+ return &NullableDatabaseSort{value: val, isSet: true}
+}
+
+func (v NullableDatabaseSort) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableDatabaseSort) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_database_sort_test.go b/pkg/postgresflexalpha/model_database_sort_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_database_sort_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_error.go b/pkg/postgresflexalpha/model_error.go
new file mode 100644
index 00000000..a9722ada
--- /dev/null
+++ b/pkg/postgresflexalpha/model_error.go
@@ -0,0 +1,262 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the Error type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &Error{}
+
+/*
+ types and functions for code
+*/
+
+// isInteger
+type ErrorGetCodeAttributeType = *int64
+type ErrorGetCodeArgType = int64
+type ErrorGetCodeRetType = int64
+
+func getErrorGetCodeAttributeTypeOk(arg ErrorGetCodeAttributeType) (ret ErrorGetCodeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setErrorGetCodeAttributeType(arg *ErrorGetCodeAttributeType, val ErrorGetCodeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for message
+*/
+
+// isNotNullableString
+type ErrorGetMessageAttributeType = *string
+
+func getErrorGetMessageAttributeTypeOk(arg ErrorGetMessageAttributeType) (ret ErrorGetMessageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setErrorGetMessageAttributeType(arg *ErrorGetMessageAttributeType, val ErrorGetMessageRetType) {
+ *arg = &val
+}
+
+type ErrorGetMessageArgType = string
+type ErrorGetMessageRetType = string
+
+/*
+ types and functions for traceId
+*/
+
+// isNotNullableString
+type ErrorGetTraceIdAttributeType = *string
+
+func getErrorGetTraceIdAttributeTypeOk(arg ErrorGetTraceIdAttributeType) (ret ErrorGetTraceIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setErrorGetTraceIdAttributeType(arg *ErrorGetTraceIdAttributeType, val ErrorGetTraceIdRetType) {
+ *arg = &val
+}
+
+type ErrorGetTraceIdArgType = string
+type ErrorGetTraceIdRetType = string
+
+/*
+ types and functions for type
+*/
+
+// isNotNullableString
+type ErrorGetTypeAttributeType = *string
+
+func getErrorGetTypeAttributeTypeOk(arg ErrorGetTypeAttributeType) (ret ErrorGetTypeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setErrorGetTypeAttributeType(arg *ErrorGetTypeAttributeType, val ErrorGetTypeRetType) {
+ *arg = &val
+}
+
+type ErrorGetTypeArgType = string
+type ErrorGetTypeRetType = string
+
+// Error struct for Error
+type Error struct {
+ // The http error code of the error.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ Code ErrorGetCodeAttributeType `json:"code" required:"true"`
+ // More detailed information about the error.
+ // REQUIRED
+ Message ErrorGetMessageAttributeType `json:"message" required:"true"`
+ // The trace id of the request.
+ // REQUIRED
+ TraceId ErrorGetTraceIdAttributeType `json:"traceId" required:"true"`
+ // Describes in which state the api was when the error happened.
+ // REQUIRED
+ Type ErrorGetTypeAttributeType `json:"type" required:"true"`
+}
+
+type _Error Error
+
+// NewError instantiates a new Error object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewError(code ErrorGetCodeArgType, message ErrorGetMessageArgType, traceId ErrorGetTraceIdArgType, types ErrorGetTypeArgType) *Error {
+ this := Error{}
+ setErrorGetCodeAttributeType(&this.Code, code)
+ setErrorGetMessageAttributeType(&this.Message, message)
+ setErrorGetTraceIdAttributeType(&this.TraceId, traceId)
+ setErrorGetTypeAttributeType(&this.Type, types)
+ return &this
+}
+
+// NewErrorWithDefaults instantiates a new Error object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewErrorWithDefaults() *Error {
+ this := Error{}
+ return &this
+}
+
+// GetCode returns the Code field value
+func (o *Error) GetCode() (ret ErrorGetCodeRetType) {
+ ret, _ = o.GetCodeOk()
+ return ret
+}
+
+// GetCodeOk returns a tuple with the Code field value
+// and a boolean to check if the value has been set.
+func (o *Error) GetCodeOk() (ret ErrorGetCodeRetType, ok bool) {
+ return getErrorGetCodeAttributeTypeOk(o.Code)
+}
+
+// SetCode sets field value
+func (o *Error) SetCode(v ErrorGetCodeRetType) {
+ setErrorGetCodeAttributeType(&o.Code, v)
+}
+
+// GetMessage returns the Message field value
+func (o *Error) GetMessage() (ret ErrorGetMessageRetType) {
+ ret, _ = o.GetMessageOk()
+ return ret
+}
+
+// GetMessageOk returns a tuple with the Message field value
+// and a boolean to check if the value has been set.
+func (o *Error) GetMessageOk() (ret ErrorGetMessageRetType, ok bool) {
+ return getErrorGetMessageAttributeTypeOk(o.Message)
+}
+
+// SetMessage sets field value
+func (o *Error) SetMessage(v ErrorGetMessageRetType) {
+ setErrorGetMessageAttributeType(&o.Message, v)
+}
+
+// GetTraceId returns the TraceId field value
+func (o *Error) GetTraceId() (ret ErrorGetTraceIdRetType) {
+ ret, _ = o.GetTraceIdOk()
+ return ret
+}
+
+// GetTraceIdOk returns a tuple with the TraceId field value
+// and a boolean to check if the value has been set.
+func (o *Error) GetTraceIdOk() (ret ErrorGetTraceIdRetType, ok bool) {
+ return getErrorGetTraceIdAttributeTypeOk(o.TraceId)
+}
+
+// SetTraceId sets field value
+func (o *Error) SetTraceId(v ErrorGetTraceIdRetType) {
+ setErrorGetTraceIdAttributeType(&o.TraceId, v)
+}
+
+// GetType returns the Type field value
+func (o *Error) GetType() (ret ErrorGetTypeRetType) {
+ ret, _ = o.GetTypeOk()
+ return ret
+}
+
+// GetTypeOk returns a tuple with the Type field value
+// and a boolean to check if the value has been set.
+func (o *Error) GetTypeOk() (ret ErrorGetTypeRetType, ok bool) {
+ return getErrorGetTypeAttributeTypeOk(o.Type)
+}
+
+// SetType sets field value
+func (o *Error) SetType(v ErrorGetTypeRetType) {
+ setErrorGetTypeAttributeType(&o.Type, v)
+}
+
+func (o Error) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getErrorGetCodeAttributeTypeOk(o.Code); ok {
+ toSerialize["Code"] = val
+ }
+ if val, ok := getErrorGetMessageAttributeTypeOk(o.Message); ok {
+ toSerialize["Message"] = val
+ }
+ if val, ok := getErrorGetTraceIdAttributeTypeOk(o.TraceId); ok {
+ toSerialize["TraceId"] = val
+ }
+ if val, ok := getErrorGetTypeAttributeTypeOk(o.Type); ok {
+ toSerialize["Type"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableError struct {
+ value *Error
+ isSet bool
+}
+
+func (v NullableError) Get() *Error {
+ return v.value
+}
+
+func (v *NullableError) Set(val *Error) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableError) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableError) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableError(val *Error) *NullableError {
+ return &NullableError{value: val, isSet: true}
+}
+
+func (v NullableError) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableError) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_error_test.go b/pkg/postgresflexalpha/model_error_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_error_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_flavor_sort.go b/pkg/postgresflexalpha/model_flavor_sort.go
new file mode 100644
index 00000000..aadbef23
--- /dev/null
+++ b/pkg/postgresflexalpha/model_flavor_sort.go
@@ -0,0 +1,147 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// FlavorSort the model 'FlavorSort'
+type FlavorSort string
+
+// List of flavor.sort
+const (
+ FLAVORSORT_INDEX_DESC FlavorSort = "index.desc"
+ FLAVORSORT_INDEX_ASC FlavorSort = "index.asc"
+ FLAVORSORT_CPU_DESC FlavorSort = "cpu.desc"
+ FLAVORSORT_CPU_ASC FlavorSort = "cpu.asc"
+ FLAVORSORT_FLAVOR_DESCRIPTION_ASC FlavorSort = "flavor_description.asc"
+ FLAVORSORT_FLAVOR_DESCRIPTION_DESC FlavorSort = "flavor_description.desc"
+ FLAVORSORT_ID_DESC FlavorSort = "id.desc"
+ FLAVORSORT_ID_ASC FlavorSort = "id.asc"
+ FLAVORSORT_SIZE_MAX_DESC FlavorSort = "size_max.desc"
+ FLAVORSORT_SIZE_MAX_ASC FlavorSort = "size_max.asc"
+ FLAVORSORT_RAM_DESC FlavorSort = "ram.desc"
+ FLAVORSORT_RAM_ASC FlavorSort = "ram.asc"
+ FLAVORSORT_SIZE_MIN_DESC FlavorSort = "size_min.desc"
+ FLAVORSORT_SIZE_MIN_ASC FlavorSort = "size_min.asc"
+ FLAVORSORT_STORAGE_CLASS_ASC FlavorSort = "storage_class.asc"
+ FLAVORSORT_STORAGE_CLASS_DESC FlavorSort = "storage_class.desc"
+ FLAVORSORT_NODE_TYPE_ASC FlavorSort = "node_type.asc"
+ FLAVORSORT_NODE_TYPE_DESC FlavorSort = "node_type.desc"
+)
+
+// All allowed values of FlavorSort enum
+var AllowedFlavorSortEnumValues = []FlavorSort{
+ "index.desc",
+ "index.asc",
+ "cpu.desc",
+ "cpu.asc",
+ "flavor_description.asc",
+ "flavor_description.desc",
+ "id.desc",
+ "id.asc",
+ "size_max.desc",
+ "size_max.asc",
+ "ram.desc",
+ "ram.asc",
+ "size_min.desc",
+ "size_min.asc",
+ "storage_class.asc",
+ "storage_class.desc",
+ "node_type.asc",
+ "node_type.desc",
+}
+
+func (v *FlavorSort) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := FlavorSort(value)
+ for _, existing := range AllowedFlavorSortEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid FlavorSort", value)
+}
+
+// NewFlavorSortFromValue returns a pointer to a valid FlavorSort
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewFlavorSortFromValue(v string) (*FlavorSort, error) {
+ ev := FlavorSort(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for FlavorSort: valid values are %v", v, AllowedFlavorSortEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v FlavorSort) IsValid() bool {
+ for _, existing := range AllowedFlavorSortEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to flavor.sort value
+func (v FlavorSort) Ptr() *FlavorSort {
+ return &v
+}
+
+type NullableFlavorSort struct {
+ value *FlavorSort
+ isSet bool
+}
+
+func (v NullableFlavorSort) Get() *FlavorSort {
+ return v.value
+}
+
+func (v *NullableFlavorSort) Set(val *FlavorSort) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableFlavorSort) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableFlavorSort) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableFlavorSort(val *FlavorSort) *NullableFlavorSort {
+ return &NullableFlavorSort{value: val, isSet: true}
+}
+
+func (v NullableFlavorSort) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableFlavorSort) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_flavor_sort_test.go b/pkg/postgresflexalpha/model_flavor_sort_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_flavor_sort_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_flavor_storage_classes_storage_class.go b/pkg/postgresflexalpha/model_flavor_storage_classes_storage_class.go
new file mode 100644
index 00000000..0ae4bbec
--- /dev/null
+++ b/pkg/postgresflexalpha/model_flavor_storage_classes_storage_class.go
@@ -0,0 +1,214 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the FlavorStorageClassesStorageClass type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &FlavorStorageClassesStorageClass{}
+
+/*
+ types and functions for class
+*/
+
+// isNotNullableString
+type FlavorStorageClassesStorageClassGetClassAttributeType = *string
+
+func getFlavorStorageClassesStorageClassGetClassAttributeTypeOk(arg FlavorStorageClassesStorageClassGetClassAttributeType) (ret FlavorStorageClassesStorageClassGetClassRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setFlavorStorageClassesStorageClassGetClassAttributeType(arg *FlavorStorageClassesStorageClassGetClassAttributeType, val FlavorStorageClassesStorageClassGetClassRetType) {
+ *arg = &val
+}
+
+type FlavorStorageClassesStorageClassGetClassArgType = string
+type FlavorStorageClassesStorageClassGetClassRetType = string
+
+/*
+ types and functions for maxIoPerSec
+*/
+
+// isInteger
+type FlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType = *int64
+type FlavorStorageClassesStorageClassGetMaxIoPerSecArgType = int64
+type FlavorStorageClassesStorageClassGetMaxIoPerSecRetType = int64
+
+func getFlavorStorageClassesStorageClassGetMaxIoPerSecAttributeTypeOk(arg FlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType) (ret FlavorStorageClassesStorageClassGetMaxIoPerSecRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setFlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType(arg *FlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType, val FlavorStorageClassesStorageClassGetMaxIoPerSecRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for maxThroughInMb
+*/
+
+// isInteger
+type FlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType = *int64
+type FlavorStorageClassesStorageClassGetMaxThroughInMbArgType = int64
+type FlavorStorageClassesStorageClassGetMaxThroughInMbRetType = int64
+
+func getFlavorStorageClassesStorageClassGetMaxThroughInMbAttributeTypeOk(arg FlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType) (ret FlavorStorageClassesStorageClassGetMaxThroughInMbRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setFlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType(arg *FlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType, val FlavorStorageClassesStorageClassGetMaxThroughInMbRetType) {
+ *arg = &val
+}
+
+// FlavorStorageClassesStorageClass a storageClass defines how efficient the storage can work
+type FlavorStorageClassesStorageClass struct {
+ // REQUIRED
+ Class FlavorStorageClassesStorageClassGetClassAttributeType `json:"class" required:"true"`
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ MaxIoPerSec FlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType `json:"maxIoPerSec" required:"true"`
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ MaxThroughInMb FlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType `json:"maxThroughInMb" required:"true"`
+}
+
+type _FlavorStorageClassesStorageClass FlavorStorageClassesStorageClass
+
+// NewFlavorStorageClassesStorageClass instantiates a new FlavorStorageClassesStorageClass object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewFlavorStorageClassesStorageClass(class FlavorStorageClassesStorageClassGetClassArgType, maxIoPerSec FlavorStorageClassesStorageClassGetMaxIoPerSecArgType, maxThroughInMb FlavorStorageClassesStorageClassGetMaxThroughInMbArgType) *FlavorStorageClassesStorageClass {
+ this := FlavorStorageClassesStorageClass{}
+ setFlavorStorageClassesStorageClassGetClassAttributeType(&this.Class, class)
+ setFlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType(&this.MaxIoPerSec, maxIoPerSec)
+ setFlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType(&this.MaxThroughInMb, maxThroughInMb)
+ return &this
+}
+
+// NewFlavorStorageClassesStorageClassWithDefaults instantiates a new FlavorStorageClassesStorageClass object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewFlavorStorageClassesStorageClassWithDefaults() *FlavorStorageClassesStorageClass {
+ this := FlavorStorageClassesStorageClass{}
+ return &this
+}
+
+// GetClass returns the Class field value
+func (o *FlavorStorageClassesStorageClass) GetClass() (ret FlavorStorageClassesStorageClassGetClassRetType) {
+ ret, _ = o.GetClassOk()
+ return ret
+}
+
+// GetClassOk returns a tuple with the Class field value
+// and a boolean to check if the value has been set.
+func (o *FlavorStorageClassesStorageClass) GetClassOk() (ret FlavorStorageClassesStorageClassGetClassRetType, ok bool) {
+ return getFlavorStorageClassesStorageClassGetClassAttributeTypeOk(o.Class)
+}
+
+// SetClass sets field value
+func (o *FlavorStorageClassesStorageClass) SetClass(v FlavorStorageClassesStorageClassGetClassRetType) {
+ setFlavorStorageClassesStorageClassGetClassAttributeType(&o.Class, v)
+}
+
+// GetMaxIoPerSec returns the MaxIoPerSec field value
+func (o *FlavorStorageClassesStorageClass) GetMaxIoPerSec() (ret FlavorStorageClassesStorageClassGetMaxIoPerSecRetType) {
+ ret, _ = o.GetMaxIoPerSecOk()
+ return ret
+}
+
+// GetMaxIoPerSecOk returns a tuple with the MaxIoPerSec field value
+// and a boolean to check if the value has been set.
+func (o *FlavorStorageClassesStorageClass) GetMaxIoPerSecOk() (ret FlavorStorageClassesStorageClassGetMaxIoPerSecRetType, ok bool) {
+ return getFlavorStorageClassesStorageClassGetMaxIoPerSecAttributeTypeOk(o.MaxIoPerSec)
+}
+
+// SetMaxIoPerSec sets field value
+func (o *FlavorStorageClassesStorageClass) SetMaxIoPerSec(v FlavorStorageClassesStorageClassGetMaxIoPerSecRetType) {
+ setFlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType(&o.MaxIoPerSec, v)
+}
+
+// GetMaxThroughInMb returns the MaxThroughInMb field value
+func (o *FlavorStorageClassesStorageClass) GetMaxThroughInMb() (ret FlavorStorageClassesStorageClassGetMaxThroughInMbRetType) {
+ ret, _ = o.GetMaxThroughInMbOk()
+ return ret
+}
+
+// GetMaxThroughInMbOk returns a tuple with the MaxThroughInMb field value
+// and a boolean to check if the value has been set.
+func (o *FlavorStorageClassesStorageClass) GetMaxThroughInMbOk() (ret FlavorStorageClassesStorageClassGetMaxThroughInMbRetType, ok bool) {
+ return getFlavorStorageClassesStorageClassGetMaxThroughInMbAttributeTypeOk(o.MaxThroughInMb)
+}
+
+// SetMaxThroughInMb sets field value
+func (o *FlavorStorageClassesStorageClass) SetMaxThroughInMb(v FlavorStorageClassesStorageClassGetMaxThroughInMbRetType) {
+ setFlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType(&o.MaxThroughInMb, v)
+}
+
+func (o FlavorStorageClassesStorageClass) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getFlavorStorageClassesStorageClassGetClassAttributeTypeOk(o.Class); ok {
+ toSerialize["Class"] = val
+ }
+ if val, ok := getFlavorStorageClassesStorageClassGetMaxIoPerSecAttributeTypeOk(o.MaxIoPerSec); ok {
+ toSerialize["MaxIoPerSec"] = val
+ }
+ if val, ok := getFlavorStorageClassesStorageClassGetMaxThroughInMbAttributeTypeOk(o.MaxThroughInMb); ok {
+ toSerialize["MaxThroughInMb"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableFlavorStorageClassesStorageClass struct {
+ value *FlavorStorageClassesStorageClass
+ isSet bool
+}
+
+func (v NullableFlavorStorageClassesStorageClass) Get() *FlavorStorageClassesStorageClass {
+ return v.value
+}
+
+func (v *NullableFlavorStorageClassesStorageClass) Set(val *FlavorStorageClassesStorageClass) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableFlavorStorageClassesStorageClass) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableFlavorStorageClassesStorageClass) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableFlavorStorageClassesStorageClass(val *FlavorStorageClassesStorageClass) *NullableFlavorStorageClassesStorageClass {
+ return &NullableFlavorStorageClassesStorageClass{value: val, isSet: true}
+}
+
+func (v NullableFlavorStorageClassesStorageClass) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableFlavorStorageClassesStorageClass) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_flavor_storage_classes_storage_class_test.go b/pkg/postgresflexalpha/model_flavor_storage_classes_storage_class_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_flavor_storage_classes_storage_class_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_get_backup_response.go b/pkg/postgresflexalpha/model_get_backup_response.go
new file mode 100644
index 00000000..9432ade1
--- /dev/null
+++ b/pkg/postgresflexalpha/model_get_backup_response.go
@@ -0,0 +1,350 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetBackupResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetBackupResponse{}
+
+/*
+ types and functions for completionTime
+*/
+
+// isNotNullableString
+type GetBackupResponseGetCompletionTimeAttributeType = *string
+
+func getGetBackupResponseGetCompletionTimeAttributeTypeOk(arg GetBackupResponseGetCompletionTimeAttributeType) (ret GetBackupResponseGetCompletionTimeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetBackupResponseGetCompletionTimeAttributeType(arg *GetBackupResponseGetCompletionTimeAttributeType, val GetBackupResponseGetCompletionTimeRetType) {
+ *arg = &val
+}
+
+type GetBackupResponseGetCompletionTimeArgType = string
+type GetBackupResponseGetCompletionTimeRetType = string
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type GetBackupResponseGetIdAttributeType = *int64
+type GetBackupResponseGetIdArgType = int64
+type GetBackupResponseGetIdRetType = int64
+
+func getGetBackupResponseGetIdAttributeTypeOk(arg GetBackupResponseGetIdAttributeType) (ret GetBackupResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetBackupResponseGetIdAttributeType(arg *GetBackupResponseGetIdAttributeType, val GetBackupResponseGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type GetBackupResponseGetNameAttributeType = *string
+
+func getGetBackupResponseGetNameAttributeTypeOk(arg GetBackupResponseGetNameAttributeType) (ret GetBackupResponseGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetBackupResponseGetNameAttributeType(arg *GetBackupResponseGetNameAttributeType, val GetBackupResponseGetNameRetType) {
+ *arg = &val
+}
+
+type GetBackupResponseGetNameArgType = string
+type GetBackupResponseGetNameRetType = string
+
+/*
+ types and functions for retainedUntil
+*/
+
+// isNotNullableString
+type GetBackupResponseGetRetainedUntilAttributeType = *string
+
+func getGetBackupResponseGetRetainedUntilAttributeTypeOk(arg GetBackupResponseGetRetainedUntilAttributeType) (ret GetBackupResponseGetRetainedUntilRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetBackupResponseGetRetainedUntilAttributeType(arg *GetBackupResponseGetRetainedUntilAttributeType, val GetBackupResponseGetRetainedUntilRetType) {
+ *arg = &val
+}
+
+type GetBackupResponseGetRetainedUntilArgType = string
+type GetBackupResponseGetRetainedUntilRetType = string
+
+/*
+ types and functions for size
+*/
+
+// isLong
+type GetBackupResponseGetSizeAttributeType = *int64
+type GetBackupResponseGetSizeArgType = int64
+type GetBackupResponseGetSizeRetType = int64
+
+func getGetBackupResponseGetSizeAttributeTypeOk(arg GetBackupResponseGetSizeAttributeType) (ret GetBackupResponseGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetBackupResponseGetSizeAttributeType(arg *GetBackupResponseGetSizeAttributeType, val GetBackupResponseGetSizeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for type
+*/
+
+// isNotNullableString
+type GetBackupResponseGetTypeAttributeType = *string
+
+func getGetBackupResponseGetTypeAttributeTypeOk(arg GetBackupResponseGetTypeAttributeType) (ret GetBackupResponseGetTypeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetBackupResponseGetTypeAttributeType(arg *GetBackupResponseGetTypeAttributeType, val GetBackupResponseGetTypeRetType) {
+ *arg = &val
+}
+
+type GetBackupResponseGetTypeArgType = string
+type GetBackupResponseGetTypeRetType = string
+
+// GetBackupResponse struct for GetBackupResponse
+type GetBackupResponse struct {
+ // The time when the backup was completed in RFC3339 format.
+ // REQUIRED
+ CompletionTime GetBackupResponseGetCompletionTimeAttributeType `json:"completionTime" required:"true"`
+ // The ID of the backup.
+ // REQUIRED
+ Id GetBackupResponseGetIdAttributeType `json:"id" required:"true"`
+ // The name of the backup.
+ // REQUIRED
+ Name GetBackupResponseGetNameAttributeType `json:"name" required:"true"`
+ // The time until the backup will be retained.
+ // REQUIRED
+ RetainedUntil GetBackupResponseGetRetainedUntilAttributeType `json:"retainedUntil" required:"true"`
+ // The size of the backup in bytes.
+ // REQUIRED
+ Size GetBackupResponseGetSizeAttributeType `json:"size" required:"true"`
+ // The type of the backup, which can be automated or manual triggered.
+ // REQUIRED
+ Type GetBackupResponseGetTypeAttributeType `json:"type" required:"true"`
+}
+
+type _GetBackupResponse GetBackupResponse
+
+// NewGetBackupResponse instantiates a new GetBackupResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetBackupResponse(completionTime GetBackupResponseGetCompletionTimeArgType, id GetBackupResponseGetIdArgType, name GetBackupResponseGetNameArgType, retainedUntil GetBackupResponseGetRetainedUntilArgType, size GetBackupResponseGetSizeArgType, types GetBackupResponseGetTypeArgType) *GetBackupResponse {
+ this := GetBackupResponse{}
+ setGetBackupResponseGetCompletionTimeAttributeType(&this.CompletionTime, completionTime)
+ setGetBackupResponseGetIdAttributeType(&this.Id, id)
+ setGetBackupResponseGetNameAttributeType(&this.Name, name)
+ setGetBackupResponseGetRetainedUntilAttributeType(&this.RetainedUntil, retainedUntil)
+ setGetBackupResponseGetSizeAttributeType(&this.Size, size)
+ setGetBackupResponseGetTypeAttributeType(&this.Type, types)
+ return &this
+}
+
+// NewGetBackupResponseWithDefaults instantiates a new GetBackupResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetBackupResponseWithDefaults() *GetBackupResponse {
+ this := GetBackupResponse{}
+ return &this
+}
+
+// GetCompletionTime returns the CompletionTime field value
+func (o *GetBackupResponse) GetCompletionTime() (ret GetBackupResponseGetCompletionTimeRetType) {
+ ret, _ = o.GetCompletionTimeOk()
+ return ret
+}
+
+// GetCompletionTimeOk returns a tuple with the CompletionTime field value
+// and a boolean to check if the value has been set.
+func (o *GetBackupResponse) GetCompletionTimeOk() (ret GetBackupResponseGetCompletionTimeRetType, ok bool) {
+ return getGetBackupResponseGetCompletionTimeAttributeTypeOk(o.CompletionTime)
+}
+
+// SetCompletionTime sets field value
+func (o *GetBackupResponse) SetCompletionTime(v GetBackupResponseGetCompletionTimeRetType) {
+ setGetBackupResponseGetCompletionTimeAttributeType(&o.CompletionTime, v)
+}
+
+// GetId returns the Id field value
+func (o *GetBackupResponse) GetId() (ret GetBackupResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *GetBackupResponse) GetIdOk() (ret GetBackupResponseGetIdRetType, ok bool) {
+ return getGetBackupResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *GetBackupResponse) SetId(v GetBackupResponseGetIdRetType) {
+ setGetBackupResponseGetIdAttributeType(&o.Id, v)
+}
+
+// GetName returns the Name field value
+func (o *GetBackupResponse) GetName() (ret GetBackupResponseGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *GetBackupResponse) GetNameOk() (ret GetBackupResponseGetNameRetType, ok bool) {
+ return getGetBackupResponseGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *GetBackupResponse) SetName(v GetBackupResponseGetNameRetType) {
+ setGetBackupResponseGetNameAttributeType(&o.Name, v)
+}
+
+// GetRetainedUntil returns the RetainedUntil field value
+func (o *GetBackupResponse) GetRetainedUntil() (ret GetBackupResponseGetRetainedUntilRetType) {
+ ret, _ = o.GetRetainedUntilOk()
+ return ret
+}
+
+// GetRetainedUntilOk returns a tuple with the RetainedUntil field value
+// and a boolean to check if the value has been set.
+func (o *GetBackupResponse) GetRetainedUntilOk() (ret GetBackupResponseGetRetainedUntilRetType, ok bool) {
+ return getGetBackupResponseGetRetainedUntilAttributeTypeOk(o.RetainedUntil)
+}
+
+// SetRetainedUntil sets field value
+func (o *GetBackupResponse) SetRetainedUntil(v GetBackupResponseGetRetainedUntilRetType) {
+ setGetBackupResponseGetRetainedUntilAttributeType(&o.RetainedUntil, v)
+}
+
+// GetSize returns the Size field value
+func (o *GetBackupResponse) GetSize() (ret GetBackupResponseGetSizeRetType) {
+ ret, _ = o.GetSizeOk()
+ return ret
+}
+
+// GetSizeOk returns a tuple with the Size field value
+// and a boolean to check if the value has been set.
+func (o *GetBackupResponse) GetSizeOk() (ret GetBackupResponseGetSizeRetType, ok bool) {
+ return getGetBackupResponseGetSizeAttributeTypeOk(o.Size)
+}
+
+// SetSize sets field value
+func (o *GetBackupResponse) SetSize(v GetBackupResponseGetSizeRetType) {
+ setGetBackupResponseGetSizeAttributeType(&o.Size, v)
+}
+
+// GetType returns the Type field value
+func (o *GetBackupResponse) GetType() (ret GetBackupResponseGetTypeRetType) {
+ ret, _ = o.GetTypeOk()
+ return ret
+}
+
+// GetTypeOk returns a tuple with the Type field value
+// and a boolean to check if the value has been set.
+func (o *GetBackupResponse) GetTypeOk() (ret GetBackupResponseGetTypeRetType, ok bool) {
+ return getGetBackupResponseGetTypeAttributeTypeOk(o.Type)
+}
+
+// SetType sets field value
+func (o *GetBackupResponse) SetType(v GetBackupResponseGetTypeRetType) {
+ setGetBackupResponseGetTypeAttributeType(&o.Type, v)
+}
+
+func (o GetBackupResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetBackupResponseGetCompletionTimeAttributeTypeOk(o.CompletionTime); ok {
+ toSerialize["CompletionTime"] = val
+ }
+ if val, ok := getGetBackupResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getGetBackupResponseGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getGetBackupResponseGetRetainedUntilAttributeTypeOk(o.RetainedUntil); ok {
+ toSerialize["RetainedUntil"] = val
+ }
+ if val, ok := getGetBackupResponseGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ if val, ok := getGetBackupResponseGetTypeAttributeTypeOk(o.Type); ok {
+ toSerialize["Type"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetBackupResponse struct {
+ value *GetBackupResponse
+ isSet bool
+}
+
+func (v NullableGetBackupResponse) Get() *GetBackupResponse {
+ return v.value
+}
+
+func (v *NullableGetBackupResponse) Set(val *GetBackupResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetBackupResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetBackupResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetBackupResponse(val *GetBackupResponse) *NullableGetBackupResponse {
+ return &NullableGetBackupResponse{value: val, isSet: true}
+}
+
+func (v NullableGetBackupResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetBackupResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_get_backup_response_test.go b/pkg/postgresflexalpha/model_get_backup_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_get_backup_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_get_collations_response.go b/pkg/postgresflexalpha/model_get_collations_response.go
new file mode 100644
index 00000000..cc2750db
--- /dev/null
+++ b/pkg/postgresflexalpha/model_get_collations_response.go
@@ -0,0 +1,126 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetCollationsResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetCollationsResponse{}
+
+/*
+ types and functions for collations
+*/
+
+// isArray
+type GetCollationsResponseGetCollationsAttributeType = *[]string
+type GetCollationsResponseGetCollationsArgType = []string
+type GetCollationsResponseGetCollationsRetType = []string
+
+func getGetCollationsResponseGetCollationsAttributeTypeOk(arg GetCollationsResponseGetCollationsAttributeType) (ret GetCollationsResponseGetCollationsRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetCollationsResponseGetCollationsAttributeType(arg *GetCollationsResponseGetCollationsAttributeType, val GetCollationsResponseGetCollationsRetType) {
+ *arg = &val
+}
+
+// GetCollationsResponse struct for GetCollationsResponse
+type GetCollationsResponse struct {
+ // List of collations available for the instance.
+ // REQUIRED
+ Collations GetCollationsResponseGetCollationsAttributeType `json:"collations" required:"true"`
+}
+
+type _GetCollationsResponse GetCollationsResponse
+
+// NewGetCollationsResponse instantiates a new GetCollationsResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetCollationsResponse(collations GetCollationsResponseGetCollationsArgType) *GetCollationsResponse {
+ this := GetCollationsResponse{}
+ setGetCollationsResponseGetCollationsAttributeType(&this.Collations, collations)
+ return &this
+}
+
+// NewGetCollationsResponseWithDefaults instantiates a new GetCollationsResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetCollationsResponseWithDefaults() *GetCollationsResponse {
+ this := GetCollationsResponse{}
+ return &this
+}
+
+// GetCollations returns the Collations field value
+func (o *GetCollationsResponse) GetCollations() (ret GetCollationsResponseGetCollationsRetType) {
+ ret, _ = o.GetCollationsOk()
+ return ret
+}
+
+// GetCollationsOk returns a tuple with the Collations field value
+// and a boolean to check if the value has been set.
+func (o *GetCollationsResponse) GetCollationsOk() (ret GetCollationsResponseGetCollationsRetType, ok bool) {
+ return getGetCollationsResponseGetCollationsAttributeTypeOk(o.Collations)
+}
+
+// SetCollations sets field value
+func (o *GetCollationsResponse) SetCollations(v GetCollationsResponseGetCollationsRetType) {
+ setGetCollationsResponseGetCollationsAttributeType(&o.Collations, v)
+}
+
+func (o GetCollationsResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetCollationsResponseGetCollationsAttributeTypeOk(o.Collations); ok {
+ toSerialize["Collations"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetCollationsResponse struct {
+ value *GetCollationsResponse
+ isSet bool
+}
+
+func (v NullableGetCollationsResponse) Get() *GetCollationsResponse {
+ return v.value
+}
+
+func (v *NullableGetCollationsResponse) Set(val *GetCollationsResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetCollationsResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetCollationsResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetCollationsResponse(val *GetCollationsResponse) *NullableGetCollationsResponse {
+ return &NullableGetCollationsResponse{value: val, isSet: true}
+}
+
+func (v NullableGetCollationsResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetCollationsResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_get_collations_response_test.go b/pkg/postgresflexalpha/model_get_collations_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_get_collations_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_get_flavors_response.go b/pkg/postgresflexalpha/model_get_flavors_response.go
new file mode 100644
index 00000000..685c6bd5
--- /dev/null
+++ b/pkg/postgresflexalpha/model_get_flavors_response.go
@@ -0,0 +1,169 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetFlavorsResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetFlavorsResponse{}
+
+/*
+ types and functions for flavors
+*/
+
+// isArray
+type GetFlavorsResponseGetFlavorsAttributeType = *[]ListFlavors
+type GetFlavorsResponseGetFlavorsArgType = []ListFlavors
+type GetFlavorsResponseGetFlavorsRetType = []ListFlavors
+
+func getGetFlavorsResponseGetFlavorsAttributeTypeOk(arg GetFlavorsResponseGetFlavorsAttributeType) (ret GetFlavorsResponseGetFlavorsRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetFlavorsResponseGetFlavorsAttributeType(arg *GetFlavorsResponseGetFlavorsAttributeType, val GetFlavorsResponseGetFlavorsRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for pagination
+*/
+
+// isModel
+type GetFlavorsResponseGetPaginationAttributeType = *Pagination
+type GetFlavorsResponseGetPaginationArgType = Pagination
+type GetFlavorsResponseGetPaginationRetType = Pagination
+
+func getGetFlavorsResponseGetPaginationAttributeTypeOk(arg GetFlavorsResponseGetPaginationAttributeType) (ret GetFlavorsResponseGetPaginationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetFlavorsResponseGetPaginationAttributeType(arg *GetFlavorsResponseGetPaginationAttributeType, val GetFlavorsResponseGetPaginationRetType) {
+ *arg = &val
+}
+
+// GetFlavorsResponse struct for GetFlavorsResponse
+type GetFlavorsResponse struct {
+ // List of flavors available for the project.
+ // REQUIRED
+ Flavors GetFlavorsResponseGetFlavorsAttributeType `json:"flavors" required:"true"`
+ // REQUIRED
+ Pagination GetFlavorsResponseGetPaginationAttributeType `json:"pagination" required:"true"`
+}
+
+type _GetFlavorsResponse GetFlavorsResponse
+
+// NewGetFlavorsResponse instantiates a new GetFlavorsResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetFlavorsResponse(flavors GetFlavorsResponseGetFlavorsArgType, pagination GetFlavorsResponseGetPaginationArgType) *GetFlavorsResponse {
+ this := GetFlavorsResponse{}
+ setGetFlavorsResponseGetFlavorsAttributeType(&this.Flavors, flavors)
+ setGetFlavorsResponseGetPaginationAttributeType(&this.Pagination, pagination)
+ return &this
+}
+
+// NewGetFlavorsResponseWithDefaults instantiates a new GetFlavorsResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetFlavorsResponseWithDefaults() *GetFlavorsResponse {
+ this := GetFlavorsResponse{}
+ return &this
+}
+
+// GetFlavors returns the Flavors field value
+func (o *GetFlavorsResponse) GetFlavors() (ret GetFlavorsResponseGetFlavorsRetType) {
+ ret, _ = o.GetFlavorsOk()
+ return ret
+}
+
+// GetFlavorsOk returns a tuple with the Flavors field value
+// and a boolean to check if the value has been set.
+func (o *GetFlavorsResponse) GetFlavorsOk() (ret GetFlavorsResponseGetFlavorsRetType, ok bool) {
+ return getGetFlavorsResponseGetFlavorsAttributeTypeOk(o.Flavors)
+}
+
+// SetFlavors sets field value
+func (o *GetFlavorsResponse) SetFlavors(v GetFlavorsResponseGetFlavorsRetType) {
+ setGetFlavorsResponseGetFlavorsAttributeType(&o.Flavors, v)
+}
+
+// GetPagination returns the Pagination field value
+func (o *GetFlavorsResponse) GetPagination() (ret GetFlavorsResponseGetPaginationRetType) {
+ ret, _ = o.GetPaginationOk()
+ return ret
+}
+
+// GetPaginationOk returns a tuple with the Pagination field value
+// and a boolean to check if the value has been set.
+func (o *GetFlavorsResponse) GetPaginationOk() (ret GetFlavorsResponseGetPaginationRetType, ok bool) {
+ return getGetFlavorsResponseGetPaginationAttributeTypeOk(o.Pagination)
+}
+
+// SetPagination sets field value
+func (o *GetFlavorsResponse) SetPagination(v GetFlavorsResponseGetPaginationRetType) {
+ setGetFlavorsResponseGetPaginationAttributeType(&o.Pagination, v)
+}
+
+func (o GetFlavorsResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetFlavorsResponseGetFlavorsAttributeTypeOk(o.Flavors); ok {
+ toSerialize["Flavors"] = val
+ }
+ if val, ok := getGetFlavorsResponseGetPaginationAttributeTypeOk(o.Pagination); ok {
+ toSerialize["Pagination"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetFlavorsResponse struct {
+ value *GetFlavorsResponse
+ isSet bool
+}
+
+func (v NullableGetFlavorsResponse) Get() *GetFlavorsResponse {
+ return v.value
+}
+
+func (v *NullableGetFlavorsResponse) Set(val *GetFlavorsResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetFlavorsResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetFlavorsResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetFlavorsResponse(val *GetFlavorsResponse) *NullableGetFlavorsResponse {
+ return &NullableGetFlavorsResponse{value: val, isSet: true}
+}
+
+func (v NullableGetFlavorsResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetFlavorsResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_get_flavors_response_test.go b/pkg/postgresflexalpha/model_get_flavors_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_get_flavors_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_get_instance_response.go b/pkg/postgresflexalpha/model_get_instance_response.go
new file mode 100644
index 00000000..f30ec04b
--- /dev/null
+++ b/pkg/postgresflexalpha/model_get_instance_response.go
@@ -0,0 +1,569 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetInstanceResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetInstanceResponse{}
+
+/*
+ types and functions for acl
+*/
+
+// isArray
+type GetInstanceResponseGetAclAttributeType = *[]string
+type GetInstanceResponseGetAclArgType = []string
+type GetInstanceResponseGetAclRetType = []string
+
+func getGetInstanceResponseGetAclAttributeTypeOk(arg GetInstanceResponseGetAclAttributeType) (ret GetInstanceResponseGetAclRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetAclAttributeType(arg *GetInstanceResponseGetAclAttributeType, val GetInstanceResponseGetAclRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for backupSchedule
+*/
+
+// isNotNullableString
+type GetInstanceResponseGetBackupScheduleAttributeType = *string
+
+func getGetInstanceResponseGetBackupScheduleAttributeTypeOk(arg GetInstanceResponseGetBackupScheduleAttributeType) (ret GetInstanceResponseGetBackupScheduleRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetBackupScheduleAttributeType(arg *GetInstanceResponseGetBackupScheduleAttributeType, val GetInstanceResponseGetBackupScheduleRetType) {
+ *arg = &val
+}
+
+type GetInstanceResponseGetBackupScheduleArgType = string
+type GetInstanceResponseGetBackupScheduleRetType = string
+
+/*
+ types and functions for flavorId
+*/
+
+// isNotNullableString
+type GetInstanceResponseGetFlavorIdAttributeType = *string
+
+func getGetInstanceResponseGetFlavorIdAttributeTypeOk(arg GetInstanceResponseGetFlavorIdAttributeType) (ret GetInstanceResponseGetFlavorIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetFlavorIdAttributeType(arg *GetInstanceResponseGetFlavorIdAttributeType, val GetInstanceResponseGetFlavorIdRetType) {
+ *arg = &val
+}
+
+type GetInstanceResponseGetFlavorIdArgType = string
+type GetInstanceResponseGetFlavorIdRetType = string
+
+/*
+ types and functions for id
+*/
+
+// isNotNullableString
+type GetInstanceResponseGetIdAttributeType = *string
+
+func getGetInstanceResponseGetIdAttributeTypeOk(arg GetInstanceResponseGetIdAttributeType) (ret GetInstanceResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetIdAttributeType(arg *GetInstanceResponseGetIdAttributeType, val GetInstanceResponseGetIdRetType) {
+ *arg = &val
+}
+
+type GetInstanceResponseGetIdArgType = string
+type GetInstanceResponseGetIdRetType = string
+
+/*
+ types and functions for isDeletable
+*/
+
+// isBoolean
+type GetInstanceResponsegetIsDeletableAttributeType = *bool
+type GetInstanceResponsegetIsDeletableArgType = bool
+type GetInstanceResponsegetIsDeletableRetType = bool
+
+func getGetInstanceResponsegetIsDeletableAttributeTypeOk(arg GetInstanceResponsegetIsDeletableAttributeType) (ret GetInstanceResponsegetIsDeletableRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponsegetIsDeletableAttributeType(arg *GetInstanceResponsegetIsDeletableAttributeType, val GetInstanceResponsegetIsDeletableRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type GetInstanceResponseGetNameAttributeType = *string
+
+func getGetInstanceResponseGetNameAttributeTypeOk(arg GetInstanceResponseGetNameAttributeType) (ret GetInstanceResponseGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetNameAttributeType(arg *GetInstanceResponseGetNameAttributeType, val GetInstanceResponseGetNameRetType) {
+ *arg = &val
+}
+
+type GetInstanceResponseGetNameArgType = string
+type GetInstanceResponseGetNameRetType = string
+
+/*
+ types and functions for replicas
+*/
+
+// isEnumRef
+type GetInstanceResponseGetReplicasAttributeType = *Replicas
+type GetInstanceResponseGetReplicasArgType = Replicas
+type GetInstanceResponseGetReplicasRetType = Replicas
+
+func getGetInstanceResponseGetReplicasAttributeTypeOk(arg GetInstanceResponseGetReplicasAttributeType) (ret GetInstanceResponseGetReplicasRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetReplicasAttributeType(arg *GetInstanceResponseGetReplicasAttributeType, val GetInstanceResponseGetReplicasRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for retentionDays
+*/
+
+// isInteger
+type GetInstanceResponseGetRetentionDaysAttributeType = *int64
+type GetInstanceResponseGetRetentionDaysArgType = int64
+type GetInstanceResponseGetRetentionDaysRetType = int64
+
+func getGetInstanceResponseGetRetentionDaysAttributeTypeOk(arg GetInstanceResponseGetRetentionDaysAttributeType) (ret GetInstanceResponseGetRetentionDaysRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetRetentionDaysAttributeType(arg *GetInstanceResponseGetRetentionDaysAttributeType, val GetInstanceResponseGetRetentionDaysRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for status
+*/
+
+// isEnumRef
+type GetInstanceResponseGetStatusAttributeType = *Status
+type GetInstanceResponseGetStatusArgType = Status
+type GetInstanceResponseGetStatusRetType = Status
+
+func getGetInstanceResponseGetStatusAttributeTypeOk(arg GetInstanceResponseGetStatusAttributeType) (ret GetInstanceResponseGetStatusRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetStatusAttributeType(arg *GetInstanceResponseGetStatusAttributeType, val GetInstanceResponseGetStatusRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for storage
+*/
+
+// isModel
+type GetInstanceResponseGetStorageAttributeType = *Storage
+type GetInstanceResponseGetStorageArgType = Storage
+type GetInstanceResponseGetStorageRetType = Storage
+
+func getGetInstanceResponseGetStorageAttributeTypeOk(arg GetInstanceResponseGetStorageAttributeType) (ret GetInstanceResponseGetStorageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetStorageAttributeType(arg *GetInstanceResponseGetStorageAttributeType, val GetInstanceResponseGetStorageRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for version
+*/
+
+// isNotNullableString
+type GetInstanceResponseGetVersionAttributeType = *string
+
+func getGetInstanceResponseGetVersionAttributeTypeOk(arg GetInstanceResponseGetVersionAttributeType) (ret GetInstanceResponseGetVersionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetVersionAttributeType(arg *GetInstanceResponseGetVersionAttributeType, val GetInstanceResponseGetVersionRetType) {
+ *arg = &val
+}
+
+type GetInstanceResponseGetVersionArgType = string
+type GetInstanceResponseGetVersionRetType = string
+
+// GetInstanceResponse struct for GetInstanceResponse
+type GetInstanceResponse struct {
+ // List of IPV4 cidr.
+ // REQUIRED
+ Acl GetInstanceResponseGetAclAttributeType `json:"acl" required:"true"`
+ // The schedule for on what time and how often the database backup will be created. The schedule is written as a cron schedule.
+ // REQUIRED
+ BackupSchedule GetInstanceResponseGetBackupScheduleAttributeType `json:"backupSchedule" required:"true"`
+ // The id of the instance flavor.
+ // REQUIRED
+ FlavorId GetInstanceResponseGetFlavorIdAttributeType `json:"flavorId" required:"true"`
+ // The ID of the instance.
+ // REQUIRED
+ Id GetInstanceResponseGetIdAttributeType `json:"id" required:"true"`
+ // Whether the instance can be deleted or not.
+ // REQUIRED
+ IsDeletable GetInstanceResponsegetIsDeletableAttributeType `json:"isDeletable" required:"true"`
+ // The name of the instance.
+ // REQUIRED
+ Name GetInstanceResponseGetNameAttributeType `json:"name" required:"true"`
+ // REQUIRED
+ Replicas GetInstanceResponseGetReplicasAttributeType `json:"replicas" required:"true"`
+ // How long backups are retained. The value can only be between 32 and 365 days.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ RetentionDays GetInstanceResponseGetRetentionDaysAttributeType `json:"retentionDays" required:"true"`
+ // REQUIRED
+ Status GetInstanceResponseGetStatusAttributeType `json:"status" required:"true"`
+ // REQUIRED
+ Storage GetInstanceResponseGetStorageAttributeType `json:"storage" required:"true"`
+ // The Postgres version used for the instance. See [Versions Endpoint](/documentation/postgres-flex-service/version/v3alpha1#tag/Version) for supported version parameters.
+ // REQUIRED
+ Version GetInstanceResponseGetVersionAttributeType `json:"version" required:"true"`
+}
+
+type _GetInstanceResponse GetInstanceResponse
+
+// NewGetInstanceResponse instantiates a new GetInstanceResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetInstanceResponse(acl GetInstanceResponseGetAclArgType, backupSchedule GetInstanceResponseGetBackupScheduleArgType, flavorId GetInstanceResponseGetFlavorIdArgType, id GetInstanceResponseGetIdArgType, isDeletable GetInstanceResponsegetIsDeletableArgType, name GetInstanceResponseGetNameArgType, replicas GetInstanceResponseGetReplicasArgType, retentionDays GetInstanceResponseGetRetentionDaysArgType, status GetInstanceResponseGetStatusArgType, storage GetInstanceResponseGetStorageArgType, version GetInstanceResponseGetVersionArgType) *GetInstanceResponse {
+ this := GetInstanceResponse{}
+ setGetInstanceResponseGetAclAttributeType(&this.Acl, acl)
+ setGetInstanceResponseGetBackupScheduleAttributeType(&this.BackupSchedule, backupSchedule)
+ setGetInstanceResponseGetFlavorIdAttributeType(&this.FlavorId, flavorId)
+ setGetInstanceResponseGetIdAttributeType(&this.Id, id)
+ setGetInstanceResponsegetIsDeletableAttributeType(&this.IsDeletable, isDeletable)
+ setGetInstanceResponseGetNameAttributeType(&this.Name, name)
+ setGetInstanceResponseGetReplicasAttributeType(&this.Replicas, replicas)
+ setGetInstanceResponseGetRetentionDaysAttributeType(&this.RetentionDays, retentionDays)
+ setGetInstanceResponseGetStatusAttributeType(&this.Status, status)
+ setGetInstanceResponseGetStorageAttributeType(&this.Storage, storage)
+ setGetInstanceResponseGetVersionAttributeType(&this.Version, version)
+ return &this
+}
+
+// NewGetInstanceResponseWithDefaults instantiates a new GetInstanceResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetInstanceResponseWithDefaults() *GetInstanceResponse {
+ this := GetInstanceResponse{}
+ return &this
+}
+
+// GetAcl returns the Acl field value
+func (o *GetInstanceResponse) GetAcl() (ret GetInstanceResponseGetAclRetType) {
+ ret, _ = o.GetAclOk()
+ return ret
+}
+
+// GetAclOk returns a tuple with the Acl field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetAclOk() (ret GetInstanceResponseGetAclRetType, ok bool) {
+ return getGetInstanceResponseGetAclAttributeTypeOk(o.Acl)
+}
+
+// SetAcl sets field value
+func (o *GetInstanceResponse) SetAcl(v GetInstanceResponseGetAclRetType) {
+ setGetInstanceResponseGetAclAttributeType(&o.Acl, v)
+}
+
+// GetBackupSchedule returns the BackupSchedule field value
+func (o *GetInstanceResponse) GetBackupSchedule() (ret GetInstanceResponseGetBackupScheduleRetType) {
+ ret, _ = o.GetBackupScheduleOk()
+ return ret
+}
+
+// GetBackupScheduleOk returns a tuple with the BackupSchedule field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetBackupScheduleOk() (ret GetInstanceResponseGetBackupScheduleRetType, ok bool) {
+ return getGetInstanceResponseGetBackupScheduleAttributeTypeOk(o.BackupSchedule)
+}
+
+// SetBackupSchedule sets field value
+func (o *GetInstanceResponse) SetBackupSchedule(v GetInstanceResponseGetBackupScheduleRetType) {
+ setGetInstanceResponseGetBackupScheduleAttributeType(&o.BackupSchedule, v)
+}
+
+// GetFlavorId returns the FlavorId field value
+func (o *GetInstanceResponse) GetFlavorId() (ret GetInstanceResponseGetFlavorIdRetType) {
+ ret, _ = o.GetFlavorIdOk()
+ return ret
+}
+
+// GetFlavorIdOk returns a tuple with the FlavorId field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetFlavorIdOk() (ret GetInstanceResponseGetFlavorIdRetType, ok bool) {
+ return getGetInstanceResponseGetFlavorIdAttributeTypeOk(o.FlavorId)
+}
+
+// SetFlavorId sets field value
+func (o *GetInstanceResponse) SetFlavorId(v GetInstanceResponseGetFlavorIdRetType) {
+ setGetInstanceResponseGetFlavorIdAttributeType(&o.FlavorId, v)
+}
+
+// GetId returns the Id field value
+func (o *GetInstanceResponse) GetId() (ret GetInstanceResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetIdOk() (ret GetInstanceResponseGetIdRetType, ok bool) {
+ return getGetInstanceResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *GetInstanceResponse) SetId(v GetInstanceResponseGetIdRetType) {
+ setGetInstanceResponseGetIdAttributeType(&o.Id, v)
+}
+
+// GetIsDeletable returns the IsDeletable field value
+func (o *GetInstanceResponse) GetIsDeletable() (ret GetInstanceResponsegetIsDeletableRetType) {
+ ret, _ = o.GetIsDeletableOk()
+ return ret
+}
+
+// GetIsDeletableOk returns a tuple with the IsDeletable field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetIsDeletableOk() (ret GetInstanceResponsegetIsDeletableRetType, ok bool) {
+ return getGetInstanceResponsegetIsDeletableAttributeTypeOk(o.IsDeletable)
+}
+
+// SetIsDeletable sets field value
+func (o *GetInstanceResponse) SetIsDeletable(v GetInstanceResponsegetIsDeletableRetType) {
+ setGetInstanceResponsegetIsDeletableAttributeType(&o.IsDeletable, v)
+}
+
+// GetName returns the Name field value
+func (o *GetInstanceResponse) GetName() (ret GetInstanceResponseGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetNameOk() (ret GetInstanceResponseGetNameRetType, ok bool) {
+ return getGetInstanceResponseGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *GetInstanceResponse) SetName(v GetInstanceResponseGetNameRetType) {
+ setGetInstanceResponseGetNameAttributeType(&o.Name, v)
+}
+
+// GetReplicas returns the Replicas field value
+func (o *GetInstanceResponse) GetReplicas() (ret GetInstanceResponseGetReplicasRetType) {
+ ret, _ = o.GetReplicasOk()
+ return ret
+}
+
+// GetReplicasOk returns a tuple with the Replicas field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetReplicasOk() (ret GetInstanceResponseGetReplicasRetType, ok bool) {
+ return getGetInstanceResponseGetReplicasAttributeTypeOk(o.Replicas)
+}
+
+// SetReplicas sets field value
+func (o *GetInstanceResponse) SetReplicas(v GetInstanceResponseGetReplicasRetType) {
+ setGetInstanceResponseGetReplicasAttributeType(&o.Replicas, v)
+}
+
+// GetRetentionDays returns the RetentionDays field value
+func (o *GetInstanceResponse) GetRetentionDays() (ret GetInstanceResponseGetRetentionDaysRetType) {
+ ret, _ = o.GetRetentionDaysOk()
+ return ret
+}
+
+// GetRetentionDaysOk returns a tuple with the RetentionDays field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetRetentionDaysOk() (ret GetInstanceResponseGetRetentionDaysRetType, ok bool) {
+ return getGetInstanceResponseGetRetentionDaysAttributeTypeOk(o.RetentionDays)
+}
+
+// SetRetentionDays sets field value
+func (o *GetInstanceResponse) SetRetentionDays(v GetInstanceResponseGetRetentionDaysRetType) {
+ setGetInstanceResponseGetRetentionDaysAttributeType(&o.RetentionDays, v)
+}
+
+// GetStatus returns the Status field value
+func (o *GetInstanceResponse) GetStatus() (ret GetInstanceResponseGetStatusRetType) {
+ ret, _ = o.GetStatusOk()
+ return ret
+}
+
+// GetStatusOk returns a tuple with the Status field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetStatusOk() (ret GetInstanceResponseGetStatusRetType, ok bool) {
+ return getGetInstanceResponseGetStatusAttributeTypeOk(o.Status)
+}
+
+// SetStatus sets field value
+func (o *GetInstanceResponse) SetStatus(v GetInstanceResponseGetStatusRetType) {
+ setGetInstanceResponseGetStatusAttributeType(&o.Status, v)
+}
+
+// GetStorage returns the Storage field value
+func (o *GetInstanceResponse) GetStorage() (ret GetInstanceResponseGetStorageRetType) {
+ ret, _ = o.GetStorageOk()
+ return ret
+}
+
+// GetStorageOk returns a tuple with the Storage field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetStorageOk() (ret GetInstanceResponseGetStorageRetType, ok bool) {
+ return getGetInstanceResponseGetStorageAttributeTypeOk(o.Storage)
+}
+
+// SetStorage sets field value
+func (o *GetInstanceResponse) SetStorage(v GetInstanceResponseGetStorageRetType) {
+ setGetInstanceResponseGetStorageAttributeType(&o.Storage, v)
+}
+
+// GetVersion returns the Version field value
+func (o *GetInstanceResponse) GetVersion() (ret GetInstanceResponseGetVersionRetType) {
+ ret, _ = o.GetVersionOk()
+ return ret
+}
+
+// GetVersionOk returns a tuple with the Version field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetVersionOk() (ret GetInstanceResponseGetVersionRetType, ok bool) {
+ return getGetInstanceResponseGetVersionAttributeTypeOk(o.Version)
+}
+
+// SetVersion sets field value
+func (o *GetInstanceResponse) SetVersion(v GetInstanceResponseGetVersionRetType) {
+ setGetInstanceResponseGetVersionAttributeType(&o.Version, v)
+}
+
+func (o GetInstanceResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetInstanceResponseGetAclAttributeTypeOk(o.Acl); ok {
+ toSerialize["Acl"] = val
+ }
+ if val, ok := getGetInstanceResponseGetBackupScheduleAttributeTypeOk(o.BackupSchedule); ok {
+ toSerialize["BackupSchedule"] = val
+ }
+ if val, ok := getGetInstanceResponseGetFlavorIdAttributeTypeOk(o.FlavorId); ok {
+ toSerialize["FlavorId"] = val
+ }
+ if val, ok := getGetInstanceResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getGetInstanceResponsegetIsDeletableAttributeTypeOk(o.IsDeletable); ok {
+ toSerialize["IsDeletable"] = val
+ }
+ if val, ok := getGetInstanceResponseGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getGetInstanceResponseGetReplicasAttributeTypeOk(o.Replicas); ok {
+ toSerialize["Replicas"] = val
+ }
+ if val, ok := getGetInstanceResponseGetRetentionDaysAttributeTypeOk(o.RetentionDays); ok {
+ toSerialize["RetentionDays"] = val
+ }
+ if val, ok := getGetInstanceResponseGetStatusAttributeTypeOk(o.Status); ok {
+ toSerialize["Status"] = val
+ }
+ if val, ok := getGetInstanceResponseGetStorageAttributeTypeOk(o.Storage); ok {
+ toSerialize["Storage"] = val
+ }
+ if val, ok := getGetInstanceResponseGetVersionAttributeTypeOk(o.Version); ok {
+ toSerialize["Version"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetInstanceResponse struct {
+ value *GetInstanceResponse
+ isSet bool
+}
+
+func (v NullableGetInstanceResponse) Get() *GetInstanceResponse {
+ return v.value
+}
+
+func (v *NullableGetInstanceResponse) Set(val *GetInstanceResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetInstanceResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetInstanceResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetInstanceResponse(val *GetInstanceResponse) *NullableGetInstanceResponse {
+ return &NullableGetInstanceResponse{value: val, isSet: true}
+}
+
+func (v NullableGetInstanceResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetInstanceResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_get_instance_response_test.go b/pkg/postgresflexalpha/model_get_instance_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_get_instance_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_get_user_response.go b/pkg/postgresflexalpha/model_get_user_response.go
new file mode 100644
index 00000000..f2ca7808
--- /dev/null
+++ b/pkg/postgresflexalpha/model_get_user_response.go
@@ -0,0 +1,395 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetUserResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetUserResponse{}
+
+/*
+ types and functions for connectionString
+*/
+
+// isNotNullableString
+type GetUserResponseGetConnectionStringAttributeType = *string
+
+func getGetUserResponseGetConnectionStringAttributeTypeOk(arg GetUserResponseGetConnectionStringAttributeType) (ret GetUserResponseGetConnectionStringRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetConnectionStringAttributeType(arg *GetUserResponseGetConnectionStringAttributeType, val GetUserResponseGetConnectionStringRetType) {
+ *arg = &val
+}
+
+type GetUserResponseGetConnectionStringArgType = string
+type GetUserResponseGetConnectionStringRetType = string
+
+/*
+ types and functions for host
+*/
+
+// isNotNullableString
+type GetUserResponseGetHostAttributeType = *string
+
+func getGetUserResponseGetHostAttributeTypeOk(arg GetUserResponseGetHostAttributeType) (ret GetUserResponseGetHostRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetHostAttributeType(arg *GetUserResponseGetHostAttributeType, val GetUserResponseGetHostRetType) {
+ *arg = &val
+}
+
+type GetUserResponseGetHostArgType = string
+type GetUserResponseGetHostRetType = string
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type GetUserResponseGetIdAttributeType = *int64
+type GetUserResponseGetIdArgType = int64
+type GetUserResponseGetIdRetType = int64
+
+func getGetUserResponseGetIdAttributeTypeOk(arg GetUserResponseGetIdAttributeType) (ret GetUserResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetIdAttributeType(arg *GetUserResponseGetIdAttributeType, val GetUserResponseGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type GetUserResponseGetNameAttributeType = *string
+
+func getGetUserResponseGetNameAttributeTypeOk(arg GetUserResponseGetNameAttributeType) (ret GetUserResponseGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetNameAttributeType(arg *GetUserResponseGetNameAttributeType, val GetUserResponseGetNameRetType) {
+ *arg = &val
+}
+
+type GetUserResponseGetNameArgType = string
+type GetUserResponseGetNameRetType = string
+
+/*
+ types and functions for port
+*/
+
+// isInteger
+type GetUserResponseGetPortAttributeType = *int64
+type GetUserResponseGetPortArgType = int64
+type GetUserResponseGetPortRetType = int64
+
+func getGetUserResponseGetPortAttributeTypeOk(arg GetUserResponseGetPortAttributeType) (ret GetUserResponseGetPortRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetPortAttributeType(arg *GetUserResponseGetPortAttributeType, val GetUserResponseGetPortRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for roles
+*/
+
+// isArray
+type GetUserResponseGetRolesAttributeType = *[]UserRole
+type GetUserResponseGetRolesArgType = []UserRole
+type GetUserResponseGetRolesRetType = []UserRole
+
+func getGetUserResponseGetRolesAttributeTypeOk(arg GetUserResponseGetRolesAttributeType) (ret GetUserResponseGetRolesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetRolesAttributeType(arg *GetUserResponseGetRolesAttributeType, val GetUserResponseGetRolesRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for status
+*/
+
+// isNotNullableString
+type GetUserResponseGetStatusAttributeType = *string
+
+func getGetUserResponseGetStatusAttributeTypeOk(arg GetUserResponseGetStatusAttributeType) (ret GetUserResponseGetStatusRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetStatusAttributeType(arg *GetUserResponseGetStatusAttributeType, val GetUserResponseGetStatusRetType) {
+ *arg = &val
+}
+
+type GetUserResponseGetStatusArgType = string
+type GetUserResponseGetStatusRetType = string
+
+// GetUserResponse struct for GetUserResponse
+type GetUserResponse struct {
+ // The connection string for the user to the instance.
+ // REQUIRED
+ ConnectionString GetUserResponseGetConnectionStringAttributeType `json:"connectionString" required:"true"`
+ // The host of the instance in which the user belongs to.
+ // REQUIRED
+ Host GetUserResponseGetHostAttributeType `json:"host" required:"true"`
+ // The ID of the user.
+ // REQUIRED
+ Id GetUserResponseGetIdAttributeType `json:"id" required:"true"`
+ // The name of the user.
+ // REQUIRED
+ Name GetUserResponseGetNameAttributeType `json:"name" required:"true"`
+ // The port of the instance in which the user belongs to.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ Port GetUserResponseGetPortAttributeType `json:"port" required:"true"`
+ // A list of user roles.
+ // REQUIRED
+ Roles GetUserResponseGetRolesAttributeType `json:"roles" required:"true"`
+ // The current status of the user.
+ // REQUIRED
+ Status GetUserResponseGetStatusAttributeType `json:"status" required:"true"`
+}
+
+type _GetUserResponse GetUserResponse
+
+// NewGetUserResponse instantiates a new GetUserResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetUserResponse(connectionString GetUserResponseGetConnectionStringArgType, host GetUserResponseGetHostArgType, id GetUserResponseGetIdArgType, name GetUserResponseGetNameArgType, port GetUserResponseGetPortArgType, roles GetUserResponseGetRolesArgType, status GetUserResponseGetStatusArgType) *GetUserResponse {
+ this := GetUserResponse{}
+ setGetUserResponseGetConnectionStringAttributeType(&this.ConnectionString, connectionString)
+ setGetUserResponseGetHostAttributeType(&this.Host, host)
+ setGetUserResponseGetIdAttributeType(&this.Id, id)
+ setGetUserResponseGetNameAttributeType(&this.Name, name)
+ setGetUserResponseGetPortAttributeType(&this.Port, port)
+ setGetUserResponseGetRolesAttributeType(&this.Roles, roles)
+ setGetUserResponseGetStatusAttributeType(&this.Status, status)
+ return &this
+}
+
+// NewGetUserResponseWithDefaults instantiates a new GetUserResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetUserResponseWithDefaults() *GetUserResponse {
+ this := GetUserResponse{}
+ return &this
+}
+
+// GetConnectionString returns the ConnectionString field value
+func (o *GetUserResponse) GetConnectionString() (ret GetUserResponseGetConnectionStringRetType) {
+ ret, _ = o.GetConnectionStringOk()
+ return ret
+}
+
+// GetConnectionStringOk returns a tuple with the ConnectionString field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetConnectionStringOk() (ret GetUserResponseGetConnectionStringRetType, ok bool) {
+ return getGetUserResponseGetConnectionStringAttributeTypeOk(o.ConnectionString)
+}
+
+// SetConnectionString sets field value
+func (o *GetUserResponse) SetConnectionString(v GetUserResponseGetConnectionStringRetType) {
+ setGetUserResponseGetConnectionStringAttributeType(&o.ConnectionString, v)
+}
+
+// GetHost returns the Host field value
+func (o *GetUserResponse) GetHost() (ret GetUserResponseGetHostRetType) {
+ ret, _ = o.GetHostOk()
+ return ret
+}
+
+// GetHostOk returns a tuple with the Host field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetHostOk() (ret GetUserResponseGetHostRetType, ok bool) {
+ return getGetUserResponseGetHostAttributeTypeOk(o.Host)
+}
+
+// SetHost sets field value
+func (o *GetUserResponse) SetHost(v GetUserResponseGetHostRetType) {
+ setGetUserResponseGetHostAttributeType(&o.Host, v)
+}
+
+// GetId returns the Id field value
+func (o *GetUserResponse) GetId() (ret GetUserResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetIdOk() (ret GetUserResponseGetIdRetType, ok bool) {
+ return getGetUserResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *GetUserResponse) SetId(v GetUserResponseGetIdRetType) {
+ setGetUserResponseGetIdAttributeType(&o.Id, v)
+}
+
+// GetName returns the Name field value
+func (o *GetUserResponse) GetName() (ret GetUserResponseGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetNameOk() (ret GetUserResponseGetNameRetType, ok bool) {
+ return getGetUserResponseGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *GetUserResponse) SetName(v GetUserResponseGetNameRetType) {
+ setGetUserResponseGetNameAttributeType(&o.Name, v)
+}
+
+// GetPort returns the Port field value
+func (o *GetUserResponse) GetPort() (ret GetUserResponseGetPortRetType) {
+ ret, _ = o.GetPortOk()
+ return ret
+}
+
+// GetPortOk returns a tuple with the Port field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetPortOk() (ret GetUserResponseGetPortRetType, ok bool) {
+ return getGetUserResponseGetPortAttributeTypeOk(o.Port)
+}
+
+// SetPort sets field value
+func (o *GetUserResponse) SetPort(v GetUserResponseGetPortRetType) {
+ setGetUserResponseGetPortAttributeType(&o.Port, v)
+}
+
+// GetRoles returns the Roles field value
+func (o *GetUserResponse) GetRoles() (ret GetUserResponseGetRolesRetType) {
+ ret, _ = o.GetRolesOk()
+ return ret
+}
+
+// GetRolesOk returns a tuple with the Roles field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetRolesOk() (ret GetUserResponseGetRolesRetType, ok bool) {
+ return getGetUserResponseGetRolesAttributeTypeOk(o.Roles)
+}
+
+// SetRoles sets field value
+func (o *GetUserResponse) SetRoles(v GetUserResponseGetRolesRetType) {
+ setGetUserResponseGetRolesAttributeType(&o.Roles, v)
+}
+
+// GetStatus returns the Status field value
+func (o *GetUserResponse) GetStatus() (ret GetUserResponseGetStatusRetType) {
+ ret, _ = o.GetStatusOk()
+ return ret
+}
+
+// GetStatusOk returns a tuple with the Status field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetStatusOk() (ret GetUserResponseGetStatusRetType, ok bool) {
+ return getGetUserResponseGetStatusAttributeTypeOk(o.Status)
+}
+
+// SetStatus sets field value
+func (o *GetUserResponse) SetStatus(v GetUserResponseGetStatusRetType) {
+ setGetUserResponseGetStatusAttributeType(&o.Status, v)
+}
+
+func (o GetUserResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetUserResponseGetConnectionStringAttributeTypeOk(o.ConnectionString); ok {
+ toSerialize["ConnectionString"] = val
+ }
+ if val, ok := getGetUserResponseGetHostAttributeTypeOk(o.Host); ok {
+ toSerialize["Host"] = val
+ }
+ if val, ok := getGetUserResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getGetUserResponseGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getGetUserResponseGetPortAttributeTypeOk(o.Port); ok {
+ toSerialize["Port"] = val
+ }
+ if val, ok := getGetUserResponseGetRolesAttributeTypeOk(o.Roles); ok {
+ toSerialize["Roles"] = val
+ }
+ if val, ok := getGetUserResponseGetStatusAttributeTypeOk(o.Status); ok {
+ toSerialize["Status"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetUserResponse struct {
+ value *GetUserResponse
+ isSet bool
+}
+
+func (v NullableGetUserResponse) Get() *GetUserResponse {
+ return v.value
+}
+
+func (v *NullableGetUserResponse) Set(val *GetUserResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetUserResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetUserResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetUserResponse(val *GetUserResponse) *NullableGetUserResponse {
+ return &NullableGetUserResponse{value: val, isSet: true}
+}
+
+func (v NullableGetUserResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetUserResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_get_user_response_test.go b/pkg/postgresflexalpha/model_get_user_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_get_user_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_get_versions_response.go b/pkg/postgresflexalpha/model_get_versions_response.go
new file mode 100644
index 00000000..e61f1cc0
--- /dev/null
+++ b/pkg/postgresflexalpha/model_get_versions_response.go
@@ -0,0 +1,126 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetVersionsResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetVersionsResponse{}
+
+/*
+ types and functions for versions
+*/
+
+// isArray
+type GetVersionsResponseGetVersionsAttributeType = *[]Version
+type GetVersionsResponseGetVersionsArgType = []Version
+type GetVersionsResponseGetVersionsRetType = []Version
+
+func getGetVersionsResponseGetVersionsAttributeTypeOk(arg GetVersionsResponseGetVersionsAttributeType) (ret GetVersionsResponseGetVersionsRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetVersionsResponseGetVersionsAttributeType(arg *GetVersionsResponseGetVersionsAttributeType, val GetVersionsResponseGetVersionsRetType) {
+ *arg = &val
+}
+
+// GetVersionsResponse struct for GetVersionsResponse
+type GetVersionsResponse struct {
+ // A list containing available postgres versions.
+ // REQUIRED
+ Versions GetVersionsResponseGetVersionsAttributeType `json:"versions" required:"true"`
+}
+
+type _GetVersionsResponse GetVersionsResponse
+
+// NewGetVersionsResponse instantiates a new GetVersionsResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetVersionsResponse(versions GetVersionsResponseGetVersionsArgType) *GetVersionsResponse {
+ this := GetVersionsResponse{}
+ setGetVersionsResponseGetVersionsAttributeType(&this.Versions, versions)
+ return &this
+}
+
+// NewGetVersionsResponseWithDefaults instantiates a new GetVersionsResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetVersionsResponseWithDefaults() *GetVersionsResponse {
+ this := GetVersionsResponse{}
+ return &this
+}
+
+// GetVersions returns the Versions field value
+func (o *GetVersionsResponse) GetVersions() (ret GetVersionsResponseGetVersionsRetType) {
+ ret, _ = o.GetVersionsOk()
+ return ret
+}
+
+// GetVersionsOk returns a tuple with the Versions field value
+// and a boolean to check if the value has been set.
+func (o *GetVersionsResponse) GetVersionsOk() (ret GetVersionsResponseGetVersionsRetType, ok bool) {
+ return getGetVersionsResponseGetVersionsAttributeTypeOk(o.Versions)
+}
+
+// SetVersions sets field value
+func (o *GetVersionsResponse) SetVersions(v GetVersionsResponseGetVersionsRetType) {
+ setGetVersionsResponseGetVersionsAttributeType(&o.Versions, v)
+}
+
+func (o GetVersionsResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetVersionsResponseGetVersionsAttributeTypeOk(o.Versions); ok {
+ toSerialize["Versions"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetVersionsResponse struct {
+ value *GetVersionsResponse
+ isSet bool
+}
+
+func (v NullableGetVersionsResponse) Get() *GetVersionsResponse {
+ return v.value
+}
+
+func (v *NullableGetVersionsResponse) Set(val *GetVersionsResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetVersionsResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetVersionsResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetVersionsResponse(val *GetVersionsResponse) *NullableGetVersionsResponse {
+ return &NullableGetVersionsResponse{value: val, isSet: true}
+}
+
+func (v NullableGetVersionsResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetVersionsResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_get_versions_response_test.go b/pkg/postgresflexalpha/model_get_versions_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_get_versions_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_instance_encryption.go b/pkg/postgresflexalpha/model_instance_encryption.go
new file mode 100644
index 00000000..529fcbff
--- /dev/null
+++ b/pkg/postgresflexalpha/model_instance_encryption.go
@@ -0,0 +1,261 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the InstanceEncryption type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &InstanceEncryption{}
+
+/*
+ types and functions for kekKeyId
+*/
+
+// isNotNullableString
+type InstanceEncryptionGetKekKeyIdAttributeType = *string
+
+func getInstanceEncryptionGetKekKeyIdAttributeTypeOk(arg InstanceEncryptionGetKekKeyIdAttributeType) (ret InstanceEncryptionGetKekKeyIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceEncryptionGetKekKeyIdAttributeType(arg *InstanceEncryptionGetKekKeyIdAttributeType, val InstanceEncryptionGetKekKeyIdRetType) {
+ *arg = &val
+}
+
+type InstanceEncryptionGetKekKeyIdArgType = string
+type InstanceEncryptionGetKekKeyIdRetType = string
+
+/*
+ types and functions for kekKeyRingId
+*/
+
+// isNotNullableString
+type InstanceEncryptionGetKekKeyRingIdAttributeType = *string
+
+func getInstanceEncryptionGetKekKeyRingIdAttributeTypeOk(arg InstanceEncryptionGetKekKeyRingIdAttributeType) (ret InstanceEncryptionGetKekKeyRingIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceEncryptionGetKekKeyRingIdAttributeType(arg *InstanceEncryptionGetKekKeyRingIdAttributeType, val InstanceEncryptionGetKekKeyRingIdRetType) {
+ *arg = &val
+}
+
+type InstanceEncryptionGetKekKeyRingIdArgType = string
+type InstanceEncryptionGetKekKeyRingIdRetType = string
+
+/*
+ types and functions for kekKeyVersion
+*/
+
+// isNotNullableString
+type InstanceEncryptionGetKekKeyVersionAttributeType = *string
+
+func getInstanceEncryptionGetKekKeyVersionAttributeTypeOk(arg InstanceEncryptionGetKekKeyVersionAttributeType) (ret InstanceEncryptionGetKekKeyVersionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceEncryptionGetKekKeyVersionAttributeType(arg *InstanceEncryptionGetKekKeyVersionAttributeType, val InstanceEncryptionGetKekKeyVersionRetType) {
+ *arg = &val
+}
+
+type InstanceEncryptionGetKekKeyVersionArgType = string
+type InstanceEncryptionGetKekKeyVersionRetType = string
+
+/*
+ types and functions for serviceAccount
+*/
+
+// isNotNullableString
+type InstanceEncryptionGetServiceAccountAttributeType = *string
+
+func getInstanceEncryptionGetServiceAccountAttributeTypeOk(arg InstanceEncryptionGetServiceAccountAttributeType) (ret InstanceEncryptionGetServiceAccountRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceEncryptionGetServiceAccountAttributeType(arg *InstanceEncryptionGetServiceAccountAttributeType, val InstanceEncryptionGetServiceAccountRetType) {
+ *arg = &val
+}
+
+type InstanceEncryptionGetServiceAccountArgType = string
+type InstanceEncryptionGetServiceAccountRetType = string
+
+// InstanceEncryption The configuration for instance's volume and backup storage encryption. ⚠️ **Note:** This feature is in private preview. Supplying this object is only permitted for enabled accounts. If your account does not have access, the request will be rejected.
+type InstanceEncryption struct {
+ // The encryption-key key identifier
+ // REQUIRED
+ KekKeyId InstanceEncryptionGetKekKeyIdAttributeType `json:"kekKeyId" required:"true"`
+ // The encryption-key keyring identifier
+ // REQUIRED
+ KekKeyRingId InstanceEncryptionGetKekKeyRingIdAttributeType `json:"kekKeyRingId" required:"true"`
+ // The encryption-key version
+ // REQUIRED
+ KekKeyVersion InstanceEncryptionGetKekKeyVersionAttributeType `json:"kekKeyVersion" required:"true"`
+ // REQUIRED
+ ServiceAccount InstanceEncryptionGetServiceAccountAttributeType `json:"serviceAccount" required:"true"`
+}
+
+type _InstanceEncryption InstanceEncryption
+
+// NewInstanceEncryption instantiates a new InstanceEncryption object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewInstanceEncryption(kekKeyId InstanceEncryptionGetKekKeyIdArgType, kekKeyRingId InstanceEncryptionGetKekKeyRingIdArgType, kekKeyVersion InstanceEncryptionGetKekKeyVersionArgType, serviceAccount InstanceEncryptionGetServiceAccountArgType) *InstanceEncryption {
+ this := InstanceEncryption{}
+ setInstanceEncryptionGetKekKeyIdAttributeType(&this.KekKeyId, kekKeyId)
+ setInstanceEncryptionGetKekKeyRingIdAttributeType(&this.KekKeyRingId, kekKeyRingId)
+ setInstanceEncryptionGetKekKeyVersionAttributeType(&this.KekKeyVersion, kekKeyVersion)
+ setInstanceEncryptionGetServiceAccountAttributeType(&this.ServiceAccount, serviceAccount)
+ return &this
+}
+
+// NewInstanceEncryptionWithDefaults instantiates a new InstanceEncryption object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewInstanceEncryptionWithDefaults() *InstanceEncryption {
+ this := InstanceEncryption{}
+ return &this
+}
+
+// GetKekKeyId returns the KekKeyId field value
+func (o *InstanceEncryption) GetKekKeyId() (ret InstanceEncryptionGetKekKeyIdRetType) {
+ ret, _ = o.GetKekKeyIdOk()
+ return ret
+}
+
+// GetKekKeyIdOk returns a tuple with the KekKeyId field value
+// and a boolean to check if the value has been set.
+func (o *InstanceEncryption) GetKekKeyIdOk() (ret InstanceEncryptionGetKekKeyIdRetType, ok bool) {
+ return getInstanceEncryptionGetKekKeyIdAttributeTypeOk(o.KekKeyId)
+}
+
+// SetKekKeyId sets field value
+func (o *InstanceEncryption) SetKekKeyId(v InstanceEncryptionGetKekKeyIdRetType) {
+ setInstanceEncryptionGetKekKeyIdAttributeType(&o.KekKeyId, v)
+}
+
+// GetKekKeyRingId returns the KekKeyRingId field value
+func (o *InstanceEncryption) GetKekKeyRingId() (ret InstanceEncryptionGetKekKeyRingIdRetType) {
+ ret, _ = o.GetKekKeyRingIdOk()
+ return ret
+}
+
+// GetKekKeyRingIdOk returns a tuple with the KekKeyRingId field value
+// and a boolean to check if the value has been set.
+func (o *InstanceEncryption) GetKekKeyRingIdOk() (ret InstanceEncryptionGetKekKeyRingIdRetType, ok bool) {
+ return getInstanceEncryptionGetKekKeyRingIdAttributeTypeOk(o.KekKeyRingId)
+}
+
+// SetKekKeyRingId sets field value
+func (o *InstanceEncryption) SetKekKeyRingId(v InstanceEncryptionGetKekKeyRingIdRetType) {
+ setInstanceEncryptionGetKekKeyRingIdAttributeType(&o.KekKeyRingId, v)
+}
+
+// GetKekKeyVersion returns the KekKeyVersion field value
+func (o *InstanceEncryption) GetKekKeyVersion() (ret InstanceEncryptionGetKekKeyVersionRetType) {
+ ret, _ = o.GetKekKeyVersionOk()
+ return ret
+}
+
+// GetKekKeyVersionOk returns a tuple with the KekKeyVersion field value
+// and a boolean to check if the value has been set.
+func (o *InstanceEncryption) GetKekKeyVersionOk() (ret InstanceEncryptionGetKekKeyVersionRetType, ok bool) {
+ return getInstanceEncryptionGetKekKeyVersionAttributeTypeOk(o.KekKeyVersion)
+}
+
+// SetKekKeyVersion sets field value
+func (o *InstanceEncryption) SetKekKeyVersion(v InstanceEncryptionGetKekKeyVersionRetType) {
+ setInstanceEncryptionGetKekKeyVersionAttributeType(&o.KekKeyVersion, v)
+}
+
+// GetServiceAccount returns the ServiceAccount field value
+func (o *InstanceEncryption) GetServiceAccount() (ret InstanceEncryptionGetServiceAccountRetType) {
+ ret, _ = o.GetServiceAccountOk()
+ return ret
+}
+
+// GetServiceAccountOk returns a tuple with the ServiceAccount field value
+// and a boolean to check if the value has been set.
+func (o *InstanceEncryption) GetServiceAccountOk() (ret InstanceEncryptionGetServiceAccountRetType, ok bool) {
+ return getInstanceEncryptionGetServiceAccountAttributeTypeOk(o.ServiceAccount)
+}
+
+// SetServiceAccount sets field value
+func (o *InstanceEncryption) SetServiceAccount(v InstanceEncryptionGetServiceAccountRetType) {
+ setInstanceEncryptionGetServiceAccountAttributeType(&o.ServiceAccount, v)
+}
+
+func (o InstanceEncryption) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getInstanceEncryptionGetKekKeyIdAttributeTypeOk(o.KekKeyId); ok {
+ toSerialize["KekKeyId"] = val
+ }
+ if val, ok := getInstanceEncryptionGetKekKeyRingIdAttributeTypeOk(o.KekKeyRingId); ok {
+ toSerialize["KekKeyRingId"] = val
+ }
+ if val, ok := getInstanceEncryptionGetKekKeyVersionAttributeTypeOk(o.KekKeyVersion); ok {
+ toSerialize["KekKeyVersion"] = val
+ }
+ if val, ok := getInstanceEncryptionGetServiceAccountAttributeTypeOk(o.ServiceAccount); ok {
+ toSerialize["ServiceAccount"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableInstanceEncryption struct {
+ value *InstanceEncryption
+ isSet bool
+}
+
+func (v NullableInstanceEncryption) Get() *InstanceEncryption {
+ return v.value
+}
+
+func (v *NullableInstanceEncryption) Set(val *InstanceEncryption) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInstanceEncryption) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInstanceEncryption) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInstanceEncryption(val *InstanceEncryption) *NullableInstanceEncryption {
+ return &NullableInstanceEncryption{value: val, isSet: true}
+}
+
+func (v NullableInstanceEncryption) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInstanceEncryption) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_instance_encryption_test.go b/pkg/postgresflexalpha/model_instance_encryption_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_instance_encryption_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_instance_network.go b/pkg/postgresflexalpha/model_instance_network.go
new file mode 100644
index 00000000..c3672861
--- /dev/null
+++ b/pkg/postgresflexalpha/model_instance_network.go
@@ -0,0 +1,233 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// checks if the InstanceNetwork type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &InstanceNetwork{}
+
+/*
+ types and functions for accessScope
+*/
+
+// isEnum
+
+// InstanceNetworkAccessScope The access scope of the instance. It defines if the instance is public or airgapped.
+// value type for enums
+type InstanceNetworkAccessScope string
+
+// List of AccessScope
+const (
+ INSTANCENETWORKACCESS_SCOPE_PUBLIC InstanceNetworkAccessScope = "PUBLIC"
+ INSTANCENETWORKACCESS_SCOPE_SNA InstanceNetworkAccessScope = "SNA"
+)
+
+// All allowed values of InstanceNetwork enum
+var AllowedInstanceNetworkAccessScopeEnumValues = []InstanceNetworkAccessScope{
+ "PUBLIC",
+ "SNA",
+}
+
+func (v *InstanceNetworkAccessScope) UnmarshalJSON(src []byte) error {
+ // use a type alias to prevent infinite recursion during unmarshal,
+ // see https://biscuit.ninja/posts/go-avoid-an-infitine-loop-with-custom-json-unmarshallers
+ type TmpJson InstanceNetworkAccessScope
+ var value TmpJson
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue TmpJson
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := InstanceNetworkAccessScope(value)
+ for _, existing := range AllowedInstanceNetworkAccessScopeEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid InstanceNetwork", value)
+}
+
+// NewInstanceNetworkAccessScopeFromValue returns a pointer to a valid InstanceNetworkAccessScope
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewInstanceNetworkAccessScopeFromValue(v InstanceNetworkAccessScope) (*InstanceNetworkAccessScope, error) {
+ ev := InstanceNetworkAccessScope(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for InstanceNetworkAccessScope: valid values are %v", v, AllowedInstanceNetworkAccessScopeEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v InstanceNetworkAccessScope) IsValid() bool {
+ for _, existing := range AllowedInstanceNetworkAccessScopeEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to AccessScopeAccessScope value
+func (v InstanceNetworkAccessScope) Ptr() *InstanceNetworkAccessScope {
+ return &v
+}
+
+type NullableInstanceNetworkAccessScope struct {
+ value *InstanceNetworkAccessScope
+ isSet bool
+}
+
+func (v NullableInstanceNetworkAccessScope) Get() *InstanceNetworkAccessScope {
+ return v.value
+}
+
+func (v *NullableInstanceNetworkAccessScope) Set(val *InstanceNetworkAccessScope) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInstanceNetworkAccessScope) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInstanceNetworkAccessScope) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInstanceNetworkAccessScope(val *InstanceNetworkAccessScope) *NullableInstanceNetworkAccessScope {
+ return &NullableInstanceNetworkAccessScope{value: val, isSet: true}
+}
+
+func (v NullableInstanceNetworkAccessScope) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInstanceNetworkAccessScope) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type InstanceNetworkGetAccessScopeAttributeType = *InstanceNetworkAccessScope
+type InstanceNetworkGetAccessScopeArgType = InstanceNetworkAccessScope
+type InstanceNetworkGetAccessScopeRetType = InstanceNetworkAccessScope
+
+func getInstanceNetworkGetAccessScopeAttributeTypeOk(arg InstanceNetworkGetAccessScopeAttributeType) (ret InstanceNetworkGetAccessScopeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceNetworkGetAccessScopeAttributeType(arg *InstanceNetworkGetAccessScopeAttributeType, val InstanceNetworkGetAccessScopeRetType) {
+ *arg = &val
+}
+
+// InstanceNetwork The network configuration of the instance. ⚠️ **Note:** This feature is in private preview. Supplying this object is only permitted for enabled accounts. If your account does not have access, the request will be rejected.
+type InstanceNetwork struct {
+ // The access scope of the instance. It defines if the instance is public or airgapped.
+ // REQUIRED
+ AccessScope InstanceNetworkGetAccessScopeAttributeType `json:"accessScope" required:"true"`
+}
+
+type _InstanceNetwork InstanceNetwork
+
+// NewInstanceNetwork instantiates a new InstanceNetwork object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewInstanceNetwork(accessScope InstanceNetworkGetAccessScopeArgType) *InstanceNetwork {
+ this := InstanceNetwork{}
+ setInstanceNetworkGetAccessScopeAttributeType(&this.AccessScope, accessScope)
+ return &this
+}
+
+// NewInstanceNetworkWithDefaults instantiates a new InstanceNetwork object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewInstanceNetworkWithDefaults() *InstanceNetwork {
+ this := InstanceNetwork{}
+ var accessScope InstanceNetworkAccessScope = "PUBLIC"
+ this.AccessScope = &accessScope
+ return &this
+}
+
+// GetAccessScope returns the AccessScope field value
+func (o *InstanceNetwork) GetAccessScope() (ret InstanceNetworkGetAccessScopeRetType) {
+ ret, _ = o.GetAccessScopeOk()
+ return ret
+}
+
+// GetAccessScopeOk returns a tuple with the AccessScope field value
+// and a boolean to check if the value has been set.
+func (o *InstanceNetwork) GetAccessScopeOk() (ret InstanceNetworkGetAccessScopeRetType, ok bool) {
+ return getInstanceNetworkGetAccessScopeAttributeTypeOk(o.AccessScope)
+}
+
+// SetAccessScope sets field value
+func (o *InstanceNetwork) SetAccessScope(v InstanceNetworkGetAccessScopeRetType) {
+ setInstanceNetworkGetAccessScopeAttributeType(&o.AccessScope, v)
+}
+
+func (o InstanceNetwork) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getInstanceNetworkGetAccessScopeAttributeTypeOk(o.AccessScope); ok {
+ toSerialize["AccessScope"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableInstanceNetwork struct {
+ value *InstanceNetwork
+ isSet bool
+}
+
+func (v NullableInstanceNetwork) Get() *InstanceNetwork {
+ return v.value
+}
+
+func (v *NullableInstanceNetwork) Set(val *InstanceNetwork) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInstanceNetwork) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInstanceNetwork) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInstanceNetwork(val *InstanceNetwork) *NullableInstanceNetwork {
+ return &NullableInstanceNetwork{value: val, isSet: true}
+}
+
+func (v NullableInstanceNetwork) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInstanceNetwork) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_instance_network_test.go b/pkg/postgresflexalpha/model_instance_network_test.go
new file mode 100644
index 00000000..cc6e3fa5
--- /dev/null
+++ b/pkg/postgresflexalpha/model_instance_network_test.go
@@ -0,0 +1,58 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "testing"
+)
+
+// isEnum
+
+func TestInstanceNetworkAccessScope_UnmarshalJSON(t *testing.T) {
+ type args struct {
+ src []byte
+ }
+ tests := []struct {
+ name string
+ args args
+ wantErr bool
+ }{
+ {
+ name: `success - possible enum value no. 1`,
+ args: args{
+ src: []byte(`"PUBLIC"`),
+ },
+ wantErr: false,
+ },
+ {
+ name: `success - possible enum value no. 2`,
+ args: args{
+ src: []byte(`"SNA"`),
+ },
+ wantErr: false,
+ },
+ {
+ name: "fail",
+ args: args{
+ src: []byte("\"FOOBAR\""),
+ },
+ wantErr: true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ v := InstanceNetworkAccessScope("")
+ if err := v.UnmarshalJSON(tt.args.src); (err != nil) != tt.wantErr {
+ t.Errorf("UnmarshalJSON() error = %v, wantErr %v", err, tt.wantErr)
+ }
+ })
+ }
+}
diff --git a/pkg/postgresflexalpha/model_instance_sort.go b/pkg/postgresflexalpha/model_instance_sort.go
new file mode 100644
index 00000000..aefc2891
--- /dev/null
+++ b/pkg/postgresflexalpha/model_instance_sort.go
@@ -0,0 +1,131 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// InstanceSort the model 'InstanceSort'
+type InstanceSort string
+
+// List of instance.sort
+const (
+ INSTANCESORT_INDEX_DESC InstanceSort = "index.desc"
+ INSTANCESORT_INDEX_ASC InstanceSort = "index.asc"
+ INSTANCESORT_ID_DESC InstanceSort = "id.desc"
+ INSTANCESORT_ID_ASC InstanceSort = "id.asc"
+ INSTANCESORT_IS_DELETABLE_DESC InstanceSort = "is_deletable.desc"
+ INSTANCESORT_IS_DELETABLE_ASC InstanceSort = "is_deletable.asc"
+ INSTANCESORT_NAME_ASC InstanceSort = "name.asc"
+ INSTANCESORT_NAME_DESC InstanceSort = "name.desc"
+ INSTANCESORT_STATUS_ASC InstanceSort = "status.asc"
+ INSTANCESORT_STATUS_DESC InstanceSort = "status.desc"
+)
+
+// All allowed values of InstanceSort enum
+var AllowedInstanceSortEnumValues = []InstanceSort{
+ "index.desc",
+ "index.asc",
+ "id.desc",
+ "id.asc",
+ "is_deletable.desc",
+ "is_deletable.asc",
+ "name.asc",
+ "name.desc",
+ "status.asc",
+ "status.desc",
+}
+
+func (v *InstanceSort) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := InstanceSort(value)
+ for _, existing := range AllowedInstanceSortEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid InstanceSort", value)
+}
+
+// NewInstanceSortFromValue returns a pointer to a valid InstanceSort
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewInstanceSortFromValue(v string) (*InstanceSort, error) {
+ ev := InstanceSort(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for InstanceSort: valid values are %v", v, AllowedInstanceSortEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v InstanceSort) IsValid() bool {
+ for _, existing := range AllowedInstanceSortEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to instance.sort value
+func (v InstanceSort) Ptr() *InstanceSort {
+ return &v
+}
+
+type NullableInstanceSort struct {
+ value *InstanceSort
+ isSet bool
+}
+
+func (v NullableInstanceSort) Get() *InstanceSort {
+ return v.value
+}
+
+func (v *NullableInstanceSort) Set(val *InstanceSort) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInstanceSort) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInstanceSort) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInstanceSort(val *InstanceSort) *NullableInstanceSort {
+ return &NullableInstanceSort{value: val, isSet: true}
+}
+
+func (v NullableInstanceSort) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInstanceSort) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_instance_sort_test.go b/pkg/postgresflexalpha/model_instance_sort_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_instance_sort_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_instance_storage_range.go b/pkg/postgresflexalpha/model_instance_storage_range.go
new file mode 100644
index 00000000..cf5ee0f7
--- /dev/null
+++ b/pkg/postgresflexalpha/model_instance_storage_range.go
@@ -0,0 +1,172 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the InstanceStorageRange type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &InstanceStorageRange{}
+
+/*
+ types and functions for max
+*/
+
+// isInteger
+type InstanceStorageRangeGetMaxAttributeType = *int64
+type InstanceStorageRangeGetMaxArgType = int64
+type InstanceStorageRangeGetMaxRetType = int64
+
+func getInstanceStorageRangeGetMaxAttributeTypeOk(arg InstanceStorageRangeGetMaxAttributeType) (ret InstanceStorageRangeGetMaxRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceStorageRangeGetMaxAttributeType(arg *InstanceStorageRangeGetMaxAttributeType, val InstanceStorageRangeGetMaxRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for min
+*/
+
+// isInteger
+type InstanceStorageRangeGetMinAttributeType = *int64
+type InstanceStorageRangeGetMinArgType = int64
+type InstanceStorageRangeGetMinRetType = int64
+
+func getInstanceStorageRangeGetMinAttributeTypeOk(arg InstanceStorageRangeGetMinAttributeType) (ret InstanceStorageRangeGetMinRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceStorageRangeGetMinAttributeType(arg *InstanceStorageRangeGetMinAttributeType, val InstanceStorageRangeGetMinRetType) {
+ *arg = &val
+}
+
+// InstanceStorageRange Contains the minimum and maximum storage space.
+type InstanceStorageRange struct {
+ // The maximum available amount of storage.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ Max InstanceStorageRangeGetMaxAttributeType `json:"max" required:"true"`
+ // The minimum available amount of storage.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ Min InstanceStorageRangeGetMinAttributeType `json:"min" required:"true"`
+}
+
+type _InstanceStorageRange InstanceStorageRange
+
+// NewInstanceStorageRange instantiates a new InstanceStorageRange object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewInstanceStorageRange(max InstanceStorageRangeGetMaxArgType, min InstanceStorageRangeGetMinArgType) *InstanceStorageRange {
+ this := InstanceStorageRange{}
+ setInstanceStorageRangeGetMaxAttributeType(&this.Max, max)
+ setInstanceStorageRangeGetMinAttributeType(&this.Min, min)
+ return &this
+}
+
+// NewInstanceStorageRangeWithDefaults instantiates a new InstanceStorageRange object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewInstanceStorageRangeWithDefaults() *InstanceStorageRange {
+ this := InstanceStorageRange{}
+ return &this
+}
+
+// GetMax returns the Max field value
+func (o *InstanceStorageRange) GetMax() (ret InstanceStorageRangeGetMaxRetType) {
+ ret, _ = o.GetMaxOk()
+ return ret
+}
+
+// GetMaxOk returns a tuple with the Max field value
+// and a boolean to check if the value has been set.
+func (o *InstanceStorageRange) GetMaxOk() (ret InstanceStorageRangeGetMaxRetType, ok bool) {
+ return getInstanceStorageRangeGetMaxAttributeTypeOk(o.Max)
+}
+
+// SetMax sets field value
+func (o *InstanceStorageRange) SetMax(v InstanceStorageRangeGetMaxRetType) {
+ setInstanceStorageRangeGetMaxAttributeType(&o.Max, v)
+}
+
+// GetMin returns the Min field value
+func (o *InstanceStorageRange) GetMin() (ret InstanceStorageRangeGetMinRetType) {
+ ret, _ = o.GetMinOk()
+ return ret
+}
+
+// GetMinOk returns a tuple with the Min field value
+// and a boolean to check if the value has been set.
+func (o *InstanceStorageRange) GetMinOk() (ret InstanceStorageRangeGetMinRetType, ok bool) {
+ return getInstanceStorageRangeGetMinAttributeTypeOk(o.Min)
+}
+
+// SetMin sets field value
+func (o *InstanceStorageRange) SetMin(v InstanceStorageRangeGetMinRetType) {
+ setInstanceStorageRangeGetMinAttributeType(&o.Min, v)
+}
+
+func (o InstanceStorageRange) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getInstanceStorageRangeGetMaxAttributeTypeOk(o.Max); ok {
+ toSerialize["Max"] = val
+ }
+ if val, ok := getInstanceStorageRangeGetMinAttributeTypeOk(o.Min); ok {
+ toSerialize["Min"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableInstanceStorageRange struct {
+ value *InstanceStorageRange
+ isSet bool
+}
+
+func (v NullableInstanceStorageRange) Get() *InstanceStorageRange {
+ return v.value
+}
+
+func (v *NullableInstanceStorageRange) Set(val *InstanceStorageRange) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInstanceStorageRange) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInstanceStorageRange) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInstanceStorageRange(val *InstanceStorageRange) *NullableInstanceStorageRange {
+ return &NullableInstanceStorageRange{value: val, isSet: true}
+}
+
+func (v NullableInstanceStorageRange) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInstanceStorageRange) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_instance_storage_range_test.go b/pkg/postgresflexalpha/model_instance_storage_range_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_instance_storage_range_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_list_backup.go b/pkg/postgresflexalpha/model_list_backup.go
new file mode 100644
index 00000000..819fcb08
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_backup.go
@@ -0,0 +1,350 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListBackup type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListBackup{}
+
+/*
+ types and functions for completionTime
+*/
+
+// isNotNullableString
+type ListBackupGetCompletionTimeAttributeType = *string
+
+func getListBackupGetCompletionTimeAttributeTypeOk(arg ListBackupGetCompletionTimeAttributeType) (ret ListBackupGetCompletionTimeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupGetCompletionTimeAttributeType(arg *ListBackupGetCompletionTimeAttributeType, val ListBackupGetCompletionTimeRetType) {
+ *arg = &val
+}
+
+type ListBackupGetCompletionTimeArgType = string
+type ListBackupGetCompletionTimeRetType = string
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type ListBackupGetIdAttributeType = *int64
+type ListBackupGetIdArgType = int64
+type ListBackupGetIdRetType = int64
+
+func getListBackupGetIdAttributeTypeOk(arg ListBackupGetIdAttributeType) (ret ListBackupGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupGetIdAttributeType(arg *ListBackupGetIdAttributeType, val ListBackupGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type ListBackupGetNameAttributeType = *string
+
+func getListBackupGetNameAttributeTypeOk(arg ListBackupGetNameAttributeType) (ret ListBackupGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupGetNameAttributeType(arg *ListBackupGetNameAttributeType, val ListBackupGetNameRetType) {
+ *arg = &val
+}
+
+type ListBackupGetNameArgType = string
+type ListBackupGetNameRetType = string
+
+/*
+ types and functions for retainedUntil
+*/
+
+// isNotNullableString
+type ListBackupGetRetainedUntilAttributeType = *string
+
+func getListBackupGetRetainedUntilAttributeTypeOk(arg ListBackupGetRetainedUntilAttributeType) (ret ListBackupGetRetainedUntilRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupGetRetainedUntilAttributeType(arg *ListBackupGetRetainedUntilAttributeType, val ListBackupGetRetainedUntilRetType) {
+ *arg = &val
+}
+
+type ListBackupGetRetainedUntilArgType = string
+type ListBackupGetRetainedUntilRetType = string
+
+/*
+ types and functions for size
+*/
+
+// isLong
+type ListBackupGetSizeAttributeType = *int64
+type ListBackupGetSizeArgType = int64
+type ListBackupGetSizeRetType = int64
+
+func getListBackupGetSizeAttributeTypeOk(arg ListBackupGetSizeAttributeType) (ret ListBackupGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupGetSizeAttributeType(arg *ListBackupGetSizeAttributeType, val ListBackupGetSizeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for type
+*/
+
+// isNotNullableString
+type ListBackupGetTypeAttributeType = *string
+
+func getListBackupGetTypeAttributeTypeOk(arg ListBackupGetTypeAttributeType) (ret ListBackupGetTypeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupGetTypeAttributeType(arg *ListBackupGetTypeAttributeType, val ListBackupGetTypeRetType) {
+ *arg = &val
+}
+
+type ListBackupGetTypeArgType = string
+type ListBackupGetTypeRetType = string
+
+// ListBackup struct for ListBackup
+type ListBackup struct {
+ // The time when the backup was completed in RFC3339 format.
+ // REQUIRED
+ CompletionTime ListBackupGetCompletionTimeAttributeType `json:"completionTime" required:"true"`
+ // The ID of the backup.
+ // REQUIRED
+ Id ListBackupGetIdAttributeType `json:"id" required:"true"`
+ // The name of the backup.
+ // REQUIRED
+ Name ListBackupGetNameAttributeType `json:"name" required:"true"`
+ // The time until the backup will be retained.
+ // REQUIRED
+ RetainedUntil ListBackupGetRetainedUntilAttributeType `json:"retainedUntil" required:"true"`
+ // The size of the backup in bytes.
+ // REQUIRED
+ Size ListBackupGetSizeAttributeType `json:"size" required:"true"`
+ // The type of the backup, which can be automated or manual triggered.
+ // REQUIRED
+ Type ListBackupGetTypeAttributeType `json:"type" required:"true"`
+}
+
+type _ListBackup ListBackup
+
+// NewListBackup instantiates a new ListBackup object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListBackup(completionTime ListBackupGetCompletionTimeArgType, id ListBackupGetIdArgType, name ListBackupGetNameArgType, retainedUntil ListBackupGetRetainedUntilArgType, size ListBackupGetSizeArgType, types ListBackupGetTypeArgType) *ListBackup {
+ this := ListBackup{}
+ setListBackupGetCompletionTimeAttributeType(&this.CompletionTime, completionTime)
+ setListBackupGetIdAttributeType(&this.Id, id)
+ setListBackupGetNameAttributeType(&this.Name, name)
+ setListBackupGetRetainedUntilAttributeType(&this.RetainedUntil, retainedUntil)
+ setListBackupGetSizeAttributeType(&this.Size, size)
+ setListBackupGetTypeAttributeType(&this.Type, types)
+ return &this
+}
+
+// NewListBackupWithDefaults instantiates a new ListBackup object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListBackupWithDefaults() *ListBackup {
+ this := ListBackup{}
+ return &this
+}
+
+// GetCompletionTime returns the CompletionTime field value
+func (o *ListBackup) GetCompletionTime() (ret ListBackupGetCompletionTimeRetType) {
+ ret, _ = o.GetCompletionTimeOk()
+ return ret
+}
+
+// GetCompletionTimeOk returns a tuple with the CompletionTime field value
+// and a boolean to check if the value has been set.
+func (o *ListBackup) GetCompletionTimeOk() (ret ListBackupGetCompletionTimeRetType, ok bool) {
+ return getListBackupGetCompletionTimeAttributeTypeOk(o.CompletionTime)
+}
+
+// SetCompletionTime sets field value
+func (o *ListBackup) SetCompletionTime(v ListBackupGetCompletionTimeRetType) {
+ setListBackupGetCompletionTimeAttributeType(&o.CompletionTime, v)
+}
+
+// GetId returns the Id field value
+func (o *ListBackup) GetId() (ret ListBackupGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *ListBackup) GetIdOk() (ret ListBackupGetIdRetType, ok bool) {
+ return getListBackupGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *ListBackup) SetId(v ListBackupGetIdRetType) {
+ setListBackupGetIdAttributeType(&o.Id, v)
+}
+
+// GetName returns the Name field value
+func (o *ListBackup) GetName() (ret ListBackupGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *ListBackup) GetNameOk() (ret ListBackupGetNameRetType, ok bool) {
+ return getListBackupGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *ListBackup) SetName(v ListBackupGetNameRetType) {
+ setListBackupGetNameAttributeType(&o.Name, v)
+}
+
+// GetRetainedUntil returns the RetainedUntil field value
+func (o *ListBackup) GetRetainedUntil() (ret ListBackupGetRetainedUntilRetType) {
+ ret, _ = o.GetRetainedUntilOk()
+ return ret
+}
+
+// GetRetainedUntilOk returns a tuple with the RetainedUntil field value
+// and a boolean to check if the value has been set.
+func (o *ListBackup) GetRetainedUntilOk() (ret ListBackupGetRetainedUntilRetType, ok bool) {
+ return getListBackupGetRetainedUntilAttributeTypeOk(o.RetainedUntil)
+}
+
+// SetRetainedUntil sets field value
+func (o *ListBackup) SetRetainedUntil(v ListBackupGetRetainedUntilRetType) {
+ setListBackupGetRetainedUntilAttributeType(&o.RetainedUntil, v)
+}
+
+// GetSize returns the Size field value
+func (o *ListBackup) GetSize() (ret ListBackupGetSizeRetType) {
+ ret, _ = o.GetSizeOk()
+ return ret
+}
+
+// GetSizeOk returns a tuple with the Size field value
+// and a boolean to check if the value has been set.
+func (o *ListBackup) GetSizeOk() (ret ListBackupGetSizeRetType, ok bool) {
+ return getListBackupGetSizeAttributeTypeOk(o.Size)
+}
+
+// SetSize sets field value
+func (o *ListBackup) SetSize(v ListBackupGetSizeRetType) {
+ setListBackupGetSizeAttributeType(&o.Size, v)
+}
+
+// GetType returns the Type field value
+func (o *ListBackup) GetType() (ret ListBackupGetTypeRetType) {
+ ret, _ = o.GetTypeOk()
+ return ret
+}
+
+// GetTypeOk returns a tuple with the Type field value
+// and a boolean to check if the value has been set.
+func (o *ListBackup) GetTypeOk() (ret ListBackupGetTypeRetType, ok bool) {
+ return getListBackupGetTypeAttributeTypeOk(o.Type)
+}
+
+// SetType sets field value
+func (o *ListBackup) SetType(v ListBackupGetTypeRetType) {
+ setListBackupGetTypeAttributeType(&o.Type, v)
+}
+
+func (o ListBackup) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListBackupGetCompletionTimeAttributeTypeOk(o.CompletionTime); ok {
+ toSerialize["CompletionTime"] = val
+ }
+ if val, ok := getListBackupGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getListBackupGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getListBackupGetRetainedUntilAttributeTypeOk(o.RetainedUntil); ok {
+ toSerialize["RetainedUntil"] = val
+ }
+ if val, ok := getListBackupGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ if val, ok := getListBackupGetTypeAttributeTypeOk(o.Type); ok {
+ toSerialize["Type"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListBackup struct {
+ value *ListBackup
+ isSet bool
+}
+
+func (v NullableListBackup) Get() *ListBackup {
+ return v.value
+}
+
+func (v *NullableListBackup) Set(val *ListBackup) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListBackup) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListBackup) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListBackup(val *ListBackup) *NullableListBackup {
+ return &NullableListBackup{value: val, isSet: true}
+}
+
+func (v NullableListBackup) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListBackup) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_list_backup_response.go b/pkg/postgresflexalpha/model_list_backup_response.go
new file mode 100644
index 00000000..7fcd2bce
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_backup_response.go
@@ -0,0 +1,169 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListBackupResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListBackupResponse{}
+
+/*
+ types and functions for backups
+*/
+
+// isArray
+type ListBackupResponseGetBackupsAttributeType = *[]ListBackup
+type ListBackupResponseGetBackupsArgType = []ListBackup
+type ListBackupResponseGetBackupsRetType = []ListBackup
+
+func getListBackupResponseGetBackupsAttributeTypeOk(arg ListBackupResponseGetBackupsAttributeType) (ret ListBackupResponseGetBackupsRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupResponseGetBackupsAttributeType(arg *ListBackupResponseGetBackupsAttributeType, val ListBackupResponseGetBackupsRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for pagination
+*/
+
+// isModel
+type ListBackupResponseGetPaginationAttributeType = *Pagination
+type ListBackupResponseGetPaginationArgType = Pagination
+type ListBackupResponseGetPaginationRetType = Pagination
+
+func getListBackupResponseGetPaginationAttributeTypeOk(arg ListBackupResponseGetPaginationAttributeType) (ret ListBackupResponseGetPaginationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupResponseGetPaginationAttributeType(arg *ListBackupResponseGetPaginationAttributeType, val ListBackupResponseGetPaginationRetType) {
+ *arg = &val
+}
+
+// ListBackupResponse struct for ListBackupResponse
+type ListBackupResponse struct {
+ // The list containing the information about the backups.
+ // REQUIRED
+ Backups ListBackupResponseGetBackupsAttributeType `json:"backups" required:"true"`
+ // REQUIRED
+ Pagination ListBackupResponseGetPaginationAttributeType `json:"pagination" required:"true"`
+}
+
+type _ListBackupResponse ListBackupResponse
+
+// NewListBackupResponse instantiates a new ListBackupResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListBackupResponse(backups ListBackupResponseGetBackupsArgType, pagination ListBackupResponseGetPaginationArgType) *ListBackupResponse {
+ this := ListBackupResponse{}
+ setListBackupResponseGetBackupsAttributeType(&this.Backups, backups)
+ setListBackupResponseGetPaginationAttributeType(&this.Pagination, pagination)
+ return &this
+}
+
+// NewListBackupResponseWithDefaults instantiates a new ListBackupResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListBackupResponseWithDefaults() *ListBackupResponse {
+ this := ListBackupResponse{}
+ return &this
+}
+
+// GetBackups returns the Backups field value
+func (o *ListBackupResponse) GetBackups() (ret ListBackupResponseGetBackupsRetType) {
+ ret, _ = o.GetBackupsOk()
+ return ret
+}
+
+// GetBackupsOk returns a tuple with the Backups field value
+// and a boolean to check if the value has been set.
+func (o *ListBackupResponse) GetBackupsOk() (ret ListBackupResponseGetBackupsRetType, ok bool) {
+ return getListBackupResponseGetBackupsAttributeTypeOk(o.Backups)
+}
+
+// SetBackups sets field value
+func (o *ListBackupResponse) SetBackups(v ListBackupResponseGetBackupsRetType) {
+ setListBackupResponseGetBackupsAttributeType(&o.Backups, v)
+}
+
+// GetPagination returns the Pagination field value
+func (o *ListBackupResponse) GetPagination() (ret ListBackupResponseGetPaginationRetType) {
+ ret, _ = o.GetPaginationOk()
+ return ret
+}
+
+// GetPaginationOk returns a tuple with the Pagination field value
+// and a boolean to check if the value has been set.
+func (o *ListBackupResponse) GetPaginationOk() (ret ListBackupResponseGetPaginationRetType, ok bool) {
+ return getListBackupResponseGetPaginationAttributeTypeOk(o.Pagination)
+}
+
+// SetPagination sets field value
+func (o *ListBackupResponse) SetPagination(v ListBackupResponseGetPaginationRetType) {
+ setListBackupResponseGetPaginationAttributeType(&o.Pagination, v)
+}
+
+func (o ListBackupResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListBackupResponseGetBackupsAttributeTypeOk(o.Backups); ok {
+ toSerialize["Backups"] = val
+ }
+ if val, ok := getListBackupResponseGetPaginationAttributeTypeOk(o.Pagination); ok {
+ toSerialize["Pagination"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListBackupResponse struct {
+ value *ListBackupResponse
+ isSet bool
+}
+
+func (v NullableListBackupResponse) Get() *ListBackupResponse {
+ return v.value
+}
+
+func (v *NullableListBackupResponse) Set(val *ListBackupResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListBackupResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListBackupResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListBackupResponse(val *ListBackupResponse) *NullableListBackupResponse {
+ return &NullableListBackupResponse{value: val, isSet: true}
+}
+
+func (v NullableListBackupResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListBackupResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_list_backup_response_test.go b/pkg/postgresflexalpha/model_list_backup_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_backup_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_list_backup_test.go b/pkg/postgresflexalpha/model_list_backup_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_backup_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_list_database.go b/pkg/postgresflexalpha/model_list_database.go
new file mode 100644
index 00000000..f3410fc9
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_database.go
@@ -0,0 +1,261 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListDatabase type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListDatabase{}
+
+/*
+ types and functions for created
+*/
+
+// isNotNullableString
+type ListDatabaseGetCreatedAttributeType = *string
+
+func getListDatabaseGetCreatedAttributeTypeOk(arg ListDatabaseGetCreatedAttributeType) (ret ListDatabaseGetCreatedRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListDatabaseGetCreatedAttributeType(arg *ListDatabaseGetCreatedAttributeType, val ListDatabaseGetCreatedRetType) {
+ *arg = &val
+}
+
+type ListDatabaseGetCreatedArgType = string
+type ListDatabaseGetCreatedRetType = string
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type ListDatabaseGetIdAttributeType = *int64
+type ListDatabaseGetIdArgType = int64
+type ListDatabaseGetIdRetType = int64
+
+func getListDatabaseGetIdAttributeTypeOk(arg ListDatabaseGetIdAttributeType) (ret ListDatabaseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListDatabaseGetIdAttributeType(arg *ListDatabaseGetIdAttributeType, val ListDatabaseGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type ListDatabaseGetNameAttributeType = *string
+
+func getListDatabaseGetNameAttributeTypeOk(arg ListDatabaseGetNameAttributeType) (ret ListDatabaseGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListDatabaseGetNameAttributeType(arg *ListDatabaseGetNameAttributeType, val ListDatabaseGetNameRetType) {
+ *arg = &val
+}
+
+type ListDatabaseGetNameArgType = string
+type ListDatabaseGetNameRetType = string
+
+/*
+ types and functions for owner
+*/
+
+// isNotNullableString
+type ListDatabaseGetOwnerAttributeType = *string
+
+func getListDatabaseGetOwnerAttributeTypeOk(arg ListDatabaseGetOwnerAttributeType) (ret ListDatabaseGetOwnerRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListDatabaseGetOwnerAttributeType(arg *ListDatabaseGetOwnerAttributeType, val ListDatabaseGetOwnerRetType) {
+ *arg = &val
+}
+
+type ListDatabaseGetOwnerArgType = string
+type ListDatabaseGetOwnerRetType = string
+
+// ListDatabase struct for ListDatabase
+type ListDatabase struct {
+ // The data when the database was created in RFC3339 format.
+ // REQUIRED
+ Created ListDatabaseGetCreatedAttributeType `json:"created" required:"true"`
+ // The id of the database.
+ // REQUIRED
+ Id ListDatabaseGetIdAttributeType `json:"id" required:"true"`
+ // The name of the database.
+ // REQUIRED
+ Name ListDatabaseGetNameAttributeType `json:"name" required:"true"`
+ // The owner of the database.
+ // REQUIRED
+ Owner ListDatabaseGetOwnerAttributeType `json:"owner" required:"true"`
+}
+
+type _ListDatabase ListDatabase
+
+// NewListDatabase instantiates a new ListDatabase object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListDatabase(created ListDatabaseGetCreatedArgType, id ListDatabaseGetIdArgType, name ListDatabaseGetNameArgType, owner ListDatabaseGetOwnerArgType) *ListDatabase {
+ this := ListDatabase{}
+ setListDatabaseGetCreatedAttributeType(&this.Created, created)
+ setListDatabaseGetIdAttributeType(&this.Id, id)
+ setListDatabaseGetNameAttributeType(&this.Name, name)
+ setListDatabaseGetOwnerAttributeType(&this.Owner, owner)
+ return &this
+}
+
+// NewListDatabaseWithDefaults instantiates a new ListDatabase object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListDatabaseWithDefaults() *ListDatabase {
+ this := ListDatabase{}
+ return &this
+}
+
+// GetCreated returns the Created field value
+func (o *ListDatabase) GetCreated() (ret ListDatabaseGetCreatedRetType) {
+ ret, _ = o.GetCreatedOk()
+ return ret
+}
+
+// GetCreatedOk returns a tuple with the Created field value
+// and a boolean to check if the value has been set.
+func (o *ListDatabase) GetCreatedOk() (ret ListDatabaseGetCreatedRetType, ok bool) {
+ return getListDatabaseGetCreatedAttributeTypeOk(o.Created)
+}
+
+// SetCreated sets field value
+func (o *ListDatabase) SetCreated(v ListDatabaseGetCreatedRetType) {
+ setListDatabaseGetCreatedAttributeType(&o.Created, v)
+}
+
+// GetId returns the Id field value
+func (o *ListDatabase) GetId() (ret ListDatabaseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *ListDatabase) GetIdOk() (ret ListDatabaseGetIdRetType, ok bool) {
+ return getListDatabaseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *ListDatabase) SetId(v ListDatabaseGetIdRetType) {
+ setListDatabaseGetIdAttributeType(&o.Id, v)
+}
+
+// GetName returns the Name field value
+func (o *ListDatabase) GetName() (ret ListDatabaseGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *ListDatabase) GetNameOk() (ret ListDatabaseGetNameRetType, ok bool) {
+ return getListDatabaseGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *ListDatabase) SetName(v ListDatabaseGetNameRetType) {
+ setListDatabaseGetNameAttributeType(&o.Name, v)
+}
+
+// GetOwner returns the Owner field value
+func (o *ListDatabase) GetOwner() (ret ListDatabaseGetOwnerRetType) {
+ ret, _ = o.GetOwnerOk()
+ return ret
+}
+
+// GetOwnerOk returns a tuple with the Owner field value
+// and a boolean to check if the value has been set.
+func (o *ListDatabase) GetOwnerOk() (ret ListDatabaseGetOwnerRetType, ok bool) {
+ return getListDatabaseGetOwnerAttributeTypeOk(o.Owner)
+}
+
+// SetOwner sets field value
+func (o *ListDatabase) SetOwner(v ListDatabaseGetOwnerRetType) {
+ setListDatabaseGetOwnerAttributeType(&o.Owner, v)
+}
+
+func (o ListDatabase) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListDatabaseGetCreatedAttributeTypeOk(o.Created); ok {
+ toSerialize["Created"] = val
+ }
+ if val, ok := getListDatabaseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getListDatabaseGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getListDatabaseGetOwnerAttributeTypeOk(o.Owner); ok {
+ toSerialize["Owner"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListDatabase struct {
+ value *ListDatabase
+ isSet bool
+}
+
+func (v NullableListDatabase) Get() *ListDatabase {
+ return v.value
+}
+
+func (v *NullableListDatabase) Set(val *ListDatabase) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListDatabase) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListDatabase) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListDatabase(val *ListDatabase) *NullableListDatabase {
+ return &NullableListDatabase{value: val, isSet: true}
+}
+
+func (v NullableListDatabase) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListDatabase) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_list_database_test.go b/pkg/postgresflexalpha/model_list_database_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_database_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_list_databases_response.go b/pkg/postgresflexalpha/model_list_databases_response.go
new file mode 100644
index 00000000..5bdb5e24
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_databases_response.go
@@ -0,0 +1,169 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListDatabasesResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListDatabasesResponse{}
+
+/*
+ types and functions for databases
+*/
+
+// isArray
+type ListDatabasesResponseGetDatabasesAttributeType = *[]ListDatabase
+type ListDatabasesResponseGetDatabasesArgType = []ListDatabase
+type ListDatabasesResponseGetDatabasesRetType = []ListDatabase
+
+func getListDatabasesResponseGetDatabasesAttributeTypeOk(arg ListDatabasesResponseGetDatabasesAttributeType) (ret ListDatabasesResponseGetDatabasesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListDatabasesResponseGetDatabasesAttributeType(arg *ListDatabasesResponseGetDatabasesAttributeType, val ListDatabasesResponseGetDatabasesRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for pagination
+*/
+
+// isModel
+type ListDatabasesResponseGetPaginationAttributeType = *Pagination
+type ListDatabasesResponseGetPaginationArgType = Pagination
+type ListDatabasesResponseGetPaginationRetType = Pagination
+
+func getListDatabasesResponseGetPaginationAttributeTypeOk(arg ListDatabasesResponseGetPaginationAttributeType) (ret ListDatabasesResponseGetPaginationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListDatabasesResponseGetPaginationAttributeType(arg *ListDatabasesResponseGetPaginationAttributeType, val ListDatabasesResponseGetPaginationRetType) {
+ *arg = &val
+}
+
+// ListDatabasesResponse struct for ListDatabasesResponse
+type ListDatabasesResponse struct {
+ // A list containing all databases for the instance.
+ // REQUIRED
+ Databases ListDatabasesResponseGetDatabasesAttributeType `json:"databases" required:"true"`
+ // REQUIRED
+ Pagination ListDatabasesResponseGetPaginationAttributeType `json:"pagination" required:"true"`
+}
+
+type _ListDatabasesResponse ListDatabasesResponse
+
+// NewListDatabasesResponse instantiates a new ListDatabasesResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListDatabasesResponse(databases ListDatabasesResponseGetDatabasesArgType, pagination ListDatabasesResponseGetPaginationArgType) *ListDatabasesResponse {
+ this := ListDatabasesResponse{}
+ setListDatabasesResponseGetDatabasesAttributeType(&this.Databases, databases)
+ setListDatabasesResponseGetPaginationAttributeType(&this.Pagination, pagination)
+ return &this
+}
+
+// NewListDatabasesResponseWithDefaults instantiates a new ListDatabasesResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListDatabasesResponseWithDefaults() *ListDatabasesResponse {
+ this := ListDatabasesResponse{}
+ return &this
+}
+
+// GetDatabases returns the Databases field value
+func (o *ListDatabasesResponse) GetDatabases() (ret ListDatabasesResponseGetDatabasesRetType) {
+ ret, _ = o.GetDatabasesOk()
+ return ret
+}
+
+// GetDatabasesOk returns a tuple with the Databases field value
+// and a boolean to check if the value has been set.
+func (o *ListDatabasesResponse) GetDatabasesOk() (ret ListDatabasesResponseGetDatabasesRetType, ok bool) {
+ return getListDatabasesResponseGetDatabasesAttributeTypeOk(o.Databases)
+}
+
+// SetDatabases sets field value
+func (o *ListDatabasesResponse) SetDatabases(v ListDatabasesResponseGetDatabasesRetType) {
+ setListDatabasesResponseGetDatabasesAttributeType(&o.Databases, v)
+}
+
+// GetPagination returns the Pagination field value
+func (o *ListDatabasesResponse) GetPagination() (ret ListDatabasesResponseGetPaginationRetType) {
+ ret, _ = o.GetPaginationOk()
+ return ret
+}
+
+// GetPaginationOk returns a tuple with the Pagination field value
+// and a boolean to check if the value has been set.
+func (o *ListDatabasesResponse) GetPaginationOk() (ret ListDatabasesResponseGetPaginationRetType, ok bool) {
+ return getListDatabasesResponseGetPaginationAttributeTypeOk(o.Pagination)
+}
+
+// SetPagination sets field value
+func (o *ListDatabasesResponse) SetPagination(v ListDatabasesResponseGetPaginationRetType) {
+ setListDatabasesResponseGetPaginationAttributeType(&o.Pagination, v)
+}
+
+func (o ListDatabasesResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListDatabasesResponseGetDatabasesAttributeTypeOk(o.Databases); ok {
+ toSerialize["Databases"] = val
+ }
+ if val, ok := getListDatabasesResponseGetPaginationAttributeTypeOk(o.Pagination); ok {
+ toSerialize["Pagination"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListDatabasesResponse struct {
+ value *ListDatabasesResponse
+ isSet bool
+}
+
+func (v NullableListDatabasesResponse) Get() *ListDatabasesResponse {
+ return v.value
+}
+
+func (v *NullableListDatabasesResponse) Set(val *ListDatabasesResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListDatabasesResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListDatabasesResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListDatabasesResponse(val *ListDatabasesResponse) *NullableListDatabasesResponse {
+ return &NullableListDatabasesResponse{value: val, isSet: true}
+}
+
+func (v NullableListDatabasesResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListDatabasesResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_list_databases_response_test.go b/pkg/postgresflexalpha/model_list_databases_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_databases_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_list_flavors.go b/pkg/postgresflexalpha/model_list_flavors.go
new file mode 100644
index 00000000..ad4e8722
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_flavors.go
@@ -0,0 +1,439 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListFlavors type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListFlavors{}
+
+/*
+ types and functions for cpu
+*/
+
+// isLong
+type ListFlavorsGetCpuAttributeType = *int64
+type ListFlavorsGetCpuArgType = int64
+type ListFlavorsGetCpuRetType = int64
+
+func getListFlavorsGetCpuAttributeTypeOk(arg ListFlavorsGetCpuAttributeType) (ret ListFlavorsGetCpuRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetCpuAttributeType(arg *ListFlavorsGetCpuAttributeType, val ListFlavorsGetCpuRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for description
+*/
+
+// isNotNullableString
+type ListFlavorsGetDescriptionAttributeType = *string
+
+func getListFlavorsGetDescriptionAttributeTypeOk(arg ListFlavorsGetDescriptionAttributeType) (ret ListFlavorsGetDescriptionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetDescriptionAttributeType(arg *ListFlavorsGetDescriptionAttributeType, val ListFlavorsGetDescriptionRetType) {
+ *arg = &val
+}
+
+type ListFlavorsGetDescriptionArgType = string
+type ListFlavorsGetDescriptionRetType = string
+
+/*
+ types and functions for id
+*/
+
+// isNotNullableString
+type ListFlavorsGetIdAttributeType = *string
+
+func getListFlavorsGetIdAttributeTypeOk(arg ListFlavorsGetIdAttributeType) (ret ListFlavorsGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetIdAttributeType(arg *ListFlavorsGetIdAttributeType, val ListFlavorsGetIdRetType) {
+ *arg = &val
+}
+
+type ListFlavorsGetIdArgType = string
+type ListFlavorsGetIdRetType = string
+
+/*
+ types and functions for maxGB
+*/
+
+// isInteger
+type ListFlavorsGetMaxGBAttributeType = *int64
+type ListFlavorsGetMaxGBArgType = int64
+type ListFlavorsGetMaxGBRetType = int64
+
+func getListFlavorsGetMaxGBAttributeTypeOk(arg ListFlavorsGetMaxGBAttributeType) (ret ListFlavorsGetMaxGBRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetMaxGBAttributeType(arg *ListFlavorsGetMaxGBAttributeType, val ListFlavorsGetMaxGBRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for memory
+*/
+
+// isLong
+type ListFlavorsGetMemoryAttributeType = *int64
+type ListFlavorsGetMemoryArgType = int64
+type ListFlavorsGetMemoryRetType = int64
+
+func getListFlavorsGetMemoryAttributeTypeOk(arg ListFlavorsGetMemoryAttributeType) (ret ListFlavorsGetMemoryRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetMemoryAttributeType(arg *ListFlavorsGetMemoryAttributeType, val ListFlavorsGetMemoryRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for minGB
+*/
+
+// isInteger
+type ListFlavorsGetMinGBAttributeType = *int64
+type ListFlavorsGetMinGBArgType = int64
+type ListFlavorsGetMinGBRetType = int64
+
+func getListFlavorsGetMinGBAttributeTypeOk(arg ListFlavorsGetMinGBAttributeType) (ret ListFlavorsGetMinGBRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetMinGBAttributeType(arg *ListFlavorsGetMinGBAttributeType, val ListFlavorsGetMinGBRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for nodeType
+*/
+
+// isNotNullableString
+type ListFlavorsGetNodeTypeAttributeType = *string
+
+func getListFlavorsGetNodeTypeAttributeTypeOk(arg ListFlavorsGetNodeTypeAttributeType) (ret ListFlavorsGetNodeTypeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetNodeTypeAttributeType(arg *ListFlavorsGetNodeTypeAttributeType, val ListFlavorsGetNodeTypeRetType) {
+ *arg = &val
+}
+
+type ListFlavorsGetNodeTypeArgType = string
+type ListFlavorsGetNodeTypeRetType = string
+
+/*
+ types and functions for storageClasses
+*/
+
+// isArray
+type ListFlavorsGetStorageClassesAttributeType = *[]FlavorStorageClassesStorageClass
+type ListFlavorsGetStorageClassesArgType = []FlavorStorageClassesStorageClass
+type ListFlavorsGetStorageClassesRetType = []FlavorStorageClassesStorageClass
+
+func getListFlavorsGetStorageClassesAttributeTypeOk(arg ListFlavorsGetStorageClassesAttributeType) (ret ListFlavorsGetStorageClassesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetStorageClassesAttributeType(arg *ListFlavorsGetStorageClassesAttributeType, val ListFlavorsGetStorageClassesRetType) {
+ *arg = &val
+}
+
+// ListFlavors The flavor of the instance containing the technical features.
+type ListFlavors struct {
+ // The cpu count of the instance.
+ // REQUIRED
+ Cpu ListFlavorsGetCpuAttributeType `json:"cpu" required:"true"`
+ // The flavor description.
+ // REQUIRED
+ Description ListFlavorsGetDescriptionAttributeType `json:"description" required:"true"`
+ // The id of the instance flavor.
+ // REQUIRED
+ Id ListFlavorsGetIdAttributeType `json:"id" required:"true"`
+ // maximum storage which can be ordered for the flavor in Gigabyte.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ MaxGB ListFlavorsGetMaxGBAttributeType `json:"maxGB" required:"true"`
+ // The memory of the instance in Gibibyte.
+ // REQUIRED
+ Memory ListFlavorsGetMemoryAttributeType `json:"memory" required:"true"`
+ // minimum storage which is required to order in Gigabyte.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ MinGB ListFlavorsGetMinGBAttributeType `json:"minGB" required:"true"`
+ // defines the nodeType it can be either single or replica
+ // REQUIRED
+ NodeType ListFlavorsGetNodeTypeAttributeType `json:"nodeType" required:"true"`
+ // maximum storage which can be ordered for the flavor in Gigabyte.
+ // REQUIRED
+ StorageClasses ListFlavorsGetStorageClassesAttributeType `json:"storageClasses" required:"true"`
+}
+
+type _ListFlavors ListFlavors
+
+// NewListFlavors instantiates a new ListFlavors object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListFlavors(cpu ListFlavorsGetCpuArgType, description ListFlavorsGetDescriptionArgType, id ListFlavorsGetIdArgType, maxGB ListFlavorsGetMaxGBArgType, memory ListFlavorsGetMemoryArgType, minGB ListFlavorsGetMinGBArgType, nodeType ListFlavorsGetNodeTypeArgType, storageClasses ListFlavorsGetStorageClassesArgType) *ListFlavors {
+ this := ListFlavors{}
+ setListFlavorsGetCpuAttributeType(&this.Cpu, cpu)
+ setListFlavorsGetDescriptionAttributeType(&this.Description, description)
+ setListFlavorsGetIdAttributeType(&this.Id, id)
+ setListFlavorsGetMaxGBAttributeType(&this.MaxGB, maxGB)
+ setListFlavorsGetMemoryAttributeType(&this.Memory, memory)
+ setListFlavorsGetMinGBAttributeType(&this.MinGB, minGB)
+ setListFlavorsGetNodeTypeAttributeType(&this.NodeType, nodeType)
+ setListFlavorsGetStorageClassesAttributeType(&this.StorageClasses, storageClasses)
+ return &this
+}
+
+// NewListFlavorsWithDefaults instantiates a new ListFlavors object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListFlavorsWithDefaults() *ListFlavors {
+ this := ListFlavors{}
+ return &this
+}
+
+// GetCpu returns the Cpu field value
+func (o *ListFlavors) GetCpu() (ret ListFlavorsGetCpuRetType) {
+ ret, _ = o.GetCpuOk()
+ return ret
+}
+
+// GetCpuOk returns a tuple with the Cpu field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetCpuOk() (ret ListFlavorsGetCpuRetType, ok bool) {
+ return getListFlavorsGetCpuAttributeTypeOk(o.Cpu)
+}
+
+// SetCpu sets field value
+func (o *ListFlavors) SetCpu(v ListFlavorsGetCpuRetType) {
+ setListFlavorsGetCpuAttributeType(&o.Cpu, v)
+}
+
+// GetDescription returns the Description field value
+func (o *ListFlavors) GetDescription() (ret ListFlavorsGetDescriptionRetType) {
+ ret, _ = o.GetDescriptionOk()
+ return ret
+}
+
+// GetDescriptionOk returns a tuple with the Description field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetDescriptionOk() (ret ListFlavorsGetDescriptionRetType, ok bool) {
+ return getListFlavorsGetDescriptionAttributeTypeOk(o.Description)
+}
+
+// SetDescription sets field value
+func (o *ListFlavors) SetDescription(v ListFlavorsGetDescriptionRetType) {
+ setListFlavorsGetDescriptionAttributeType(&o.Description, v)
+}
+
+// GetId returns the Id field value
+func (o *ListFlavors) GetId() (ret ListFlavorsGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetIdOk() (ret ListFlavorsGetIdRetType, ok bool) {
+ return getListFlavorsGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *ListFlavors) SetId(v ListFlavorsGetIdRetType) {
+ setListFlavorsGetIdAttributeType(&o.Id, v)
+}
+
+// GetMaxGB returns the MaxGB field value
+func (o *ListFlavors) GetMaxGB() (ret ListFlavorsGetMaxGBRetType) {
+ ret, _ = o.GetMaxGBOk()
+ return ret
+}
+
+// GetMaxGBOk returns a tuple with the MaxGB field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetMaxGBOk() (ret ListFlavorsGetMaxGBRetType, ok bool) {
+ return getListFlavorsGetMaxGBAttributeTypeOk(o.MaxGB)
+}
+
+// SetMaxGB sets field value
+func (o *ListFlavors) SetMaxGB(v ListFlavorsGetMaxGBRetType) {
+ setListFlavorsGetMaxGBAttributeType(&o.MaxGB, v)
+}
+
+// GetMemory returns the Memory field value
+func (o *ListFlavors) GetMemory() (ret ListFlavorsGetMemoryRetType) {
+ ret, _ = o.GetMemoryOk()
+ return ret
+}
+
+// GetMemoryOk returns a tuple with the Memory field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetMemoryOk() (ret ListFlavorsGetMemoryRetType, ok bool) {
+ return getListFlavorsGetMemoryAttributeTypeOk(o.Memory)
+}
+
+// SetMemory sets field value
+func (o *ListFlavors) SetMemory(v ListFlavorsGetMemoryRetType) {
+ setListFlavorsGetMemoryAttributeType(&o.Memory, v)
+}
+
+// GetMinGB returns the MinGB field value
+func (o *ListFlavors) GetMinGB() (ret ListFlavorsGetMinGBRetType) {
+ ret, _ = o.GetMinGBOk()
+ return ret
+}
+
+// GetMinGBOk returns a tuple with the MinGB field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetMinGBOk() (ret ListFlavorsGetMinGBRetType, ok bool) {
+ return getListFlavorsGetMinGBAttributeTypeOk(o.MinGB)
+}
+
+// SetMinGB sets field value
+func (o *ListFlavors) SetMinGB(v ListFlavorsGetMinGBRetType) {
+ setListFlavorsGetMinGBAttributeType(&o.MinGB, v)
+}
+
+// GetNodeType returns the NodeType field value
+func (o *ListFlavors) GetNodeType() (ret ListFlavorsGetNodeTypeRetType) {
+ ret, _ = o.GetNodeTypeOk()
+ return ret
+}
+
+// GetNodeTypeOk returns a tuple with the NodeType field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetNodeTypeOk() (ret ListFlavorsGetNodeTypeRetType, ok bool) {
+ return getListFlavorsGetNodeTypeAttributeTypeOk(o.NodeType)
+}
+
+// SetNodeType sets field value
+func (o *ListFlavors) SetNodeType(v ListFlavorsGetNodeTypeRetType) {
+ setListFlavorsGetNodeTypeAttributeType(&o.NodeType, v)
+}
+
+// GetStorageClasses returns the StorageClasses field value
+func (o *ListFlavors) GetStorageClasses() (ret ListFlavorsGetStorageClassesRetType) {
+ ret, _ = o.GetStorageClassesOk()
+ return ret
+}
+
+// GetStorageClassesOk returns a tuple with the StorageClasses field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetStorageClassesOk() (ret ListFlavorsGetStorageClassesRetType, ok bool) {
+ return getListFlavorsGetStorageClassesAttributeTypeOk(o.StorageClasses)
+}
+
+// SetStorageClasses sets field value
+func (o *ListFlavors) SetStorageClasses(v ListFlavorsGetStorageClassesRetType) {
+ setListFlavorsGetStorageClassesAttributeType(&o.StorageClasses, v)
+}
+
+func (o ListFlavors) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListFlavorsGetCpuAttributeTypeOk(o.Cpu); ok {
+ toSerialize["Cpu"] = val
+ }
+ if val, ok := getListFlavorsGetDescriptionAttributeTypeOk(o.Description); ok {
+ toSerialize["Description"] = val
+ }
+ if val, ok := getListFlavorsGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getListFlavorsGetMaxGBAttributeTypeOk(o.MaxGB); ok {
+ toSerialize["MaxGB"] = val
+ }
+ if val, ok := getListFlavorsGetMemoryAttributeTypeOk(o.Memory); ok {
+ toSerialize["Memory"] = val
+ }
+ if val, ok := getListFlavorsGetMinGBAttributeTypeOk(o.MinGB); ok {
+ toSerialize["MinGB"] = val
+ }
+ if val, ok := getListFlavorsGetNodeTypeAttributeTypeOk(o.NodeType); ok {
+ toSerialize["NodeType"] = val
+ }
+ if val, ok := getListFlavorsGetStorageClassesAttributeTypeOk(o.StorageClasses); ok {
+ toSerialize["StorageClasses"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListFlavors struct {
+ value *ListFlavors
+ isSet bool
+}
+
+func (v NullableListFlavors) Get() *ListFlavors {
+ return v.value
+}
+
+func (v *NullableListFlavors) Set(val *ListFlavors) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListFlavors) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListFlavors) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListFlavors(val *ListFlavors) *NullableListFlavors {
+ return &NullableListFlavors{value: val, isSet: true}
+}
+
+func (v NullableListFlavors) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListFlavors) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_list_flavors_test.go b/pkg/postgresflexalpha/model_list_flavors_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_flavors_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_list_instance.go b/pkg/postgresflexalpha/model_list_instance.go
new file mode 100644
index 00000000..467a71f2
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_instance.go
@@ -0,0 +1,259 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListInstance type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListInstance{}
+
+/*
+ types and functions for id
+*/
+
+// isNotNullableString
+type ListInstanceGetIdAttributeType = *string
+
+func getListInstanceGetIdAttributeTypeOk(arg ListInstanceGetIdAttributeType) (ret ListInstanceGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListInstanceGetIdAttributeType(arg *ListInstanceGetIdAttributeType, val ListInstanceGetIdRetType) {
+ *arg = &val
+}
+
+type ListInstanceGetIdArgType = string
+type ListInstanceGetIdRetType = string
+
+/*
+ types and functions for isDeletable
+*/
+
+// isBoolean
+type ListInstancegetIsDeletableAttributeType = *bool
+type ListInstancegetIsDeletableArgType = bool
+type ListInstancegetIsDeletableRetType = bool
+
+func getListInstancegetIsDeletableAttributeTypeOk(arg ListInstancegetIsDeletableAttributeType) (ret ListInstancegetIsDeletableRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListInstancegetIsDeletableAttributeType(arg *ListInstancegetIsDeletableAttributeType, val ListInstancegetIsDeletableRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type ListInstanceGetNameAttributeType = *string
+
+func getListInstanceGetNameAttributeTypeOk(arg ListInstanceGetNameAttributeType) (ret ListInstanceGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListInstanceGetNameAttributeType(arg *ListInstanceGetNameAttributeType, val ListInstanceGetNameRetType) {
+ *arg = &val
+}
+
+type ListInstanceGetNameArgType = string
+type ListInstanceGetNameRetType = string
+
+/*
+ types and functions for status
+*/
+
+// isEnumRef
+type ListInstanceGetStatusAttributeType = *Status
+type ListInstanceGetStatusArgType = Status
+type ListInstanceGetStatusRetType = Status
+
+func getListInstanceGetStatusAttributeTypeOk(arg ListInstanceGetStatusAttributeType) (ret ListInstanceGetStatusRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListInstanceGetStatusAttributeType(arg *ListInstanceGetStatusAttributeType, val ListInstanceGetStatusRetType) {
+ *arg = &val
+}
+
+// ListInstance struct for ListInstance
+type ListInstance struct {
+ // The ID of the instance.
+ // REQUIRED
+ Id ListInstanceGetIdAttributeType `json:"id" required:"true"`
+ // Whether the instance can be deleted or not.
+ // REQUIRED
+ IsDeletable ListInstancegetIsDeletableAttributeType `json:"isDeletable" required:"true"`
+ // The name of the instance.
+ // REQUIRED
+ Name ListInstanceGetNameAttributeType `json:"name" required:"true"`
+ // REQUIRED
+ Status ListInstanceGetStatusAttributeType `json:"status" required:"true"`
+}
+
+type _ListInstance ListInstance
+
+// NewListInstance instantiates a new ListInstance object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListInstance(id ListInstanceGetIdArgType, isDeletable ListInstancegetIsDeletableArgType, name ListInstanceGetNameArgType, status ListInstanceGetStatusArgType) *ListInstance {
+ this := ListInstance{}
+ setListInstanceGetIdAttributeType(&this.Id, id)
+ setListInstancegetIsDeletableAttributeType(&this.IsDeletable, isDeletable)
+ setListInstanceGetNameAttributeType(&this.Name, name)
+ setListInstanceGetStatusAttributeType(&this.Status, status)
+ return &this
+}
+
+// NewListInstanceWithDefaults instantiates a new ListInstance object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListInstanceWithDefaults() *ListInstance {
+ this := ListInstance{}
+ return &this
+}
+
+// GetId returns the Id field value
+func (o *ListInstance) GetId() (ret ListInstanceGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *ListInstance) GetIdOk() (ret ListInstanceGetIdRetType, ok bool) {
+ return getListInstanceGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *ListInstance) SetId(v ListInstanceGetIdRetType) {
+ setListInstanceGetIdAttributeType(&o.Id, v)
+}
+
+// GetIsDeletable returns the IsDeletable field value
+func (o *ListInstance) GetIsDeletable() (ret ListInstancegetIsDeletableRetType) {
+ ret, _ = o.GetIsDeletableOk()
+ return ret
+}
+
+// GetIsDeletableOk returns a tuple with the IsDeletable field value
+// and a boolean to check if the value has been set.
+func (o *ListInstance) GetIsDeletableOk() (ret ListInstancegetIsDeletableRetType, ok bool) {
+ return getListInstancegetIsDeletableAttributeTypeOk(o.IsDeletable)
+}
+
+// SetIsDeletable sets field value
+func (o *ListInstance) SetIsDeletable(v ListInstancegetIsDeletableRetType) {
+ setListInstancegetIsDeletableAttributeType(&o.IsDeletable, v)
+}
+
+// GetName returns the Name field value
+func (o *ListInstance) GetName() (ret ListInstanceGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *ListInstance) GetNameOk() (ret ListInstanceGetNameRetType, ok bool) {
+ return getListInstanceGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *ListInstance) SetName(v ListInstanceGetNameRetType) {
+ setListInstanceGetNameAttributeType(&o.Name, v)
+}
+
+// GetStatus returns the Status field value
+func (o *ListInstance) GetStatus() (ret ListInstanceGetStatusRetType) {
+ ret, _ = o.GetStatusOk()
+ return ret
+}
+
+// GetStatusOk returns a tuple with the Status field value
+// and a boolean to check if the value has been set.
+func (o *ListInstance) GetStatusOk() (ret ListInstanceGetStatusRetType, ok bool) {
+ return getListInstanceGetStatusAttributeTypeOk(o.Status)
+}
+
+// SetStatus sets field value
+func (o *ListInstance) SetStatus(v ListInstanceGetStatusRetType) {
+ setListInstanceGetStatusAttributeType(&o.Status, v)
+}
+
+func (o ListInstance) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListInstanceGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getListInstancegetIsDeletableAttributeTypeOk(o.IsDeletable); ok {
+ toSerialize["IsDeletable"] = val
+ }
+ if val, ok := getListInstanceGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getListInstanceGetStatusAttributeTypeOk(o.Status); ok {
+ toSerialize["Status"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListInstance struct {
+ value *ListInstance
+ isSet bool
+}
+
+func (v NullableListInstance) Get() *ListInstance {
+ return v.value
+}
+
+func (v *NullableListInstance) Set(val *ListInstance) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListInstance) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListInstance) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListInstance(val *ListInstance) *NullableListInstance {
+ return &NullableListInstance{value: val, isSet: true}
+}
+
+func (v NullableListInstance) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListInstance) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_list_instance_test.go b/pkg/postgresflexalpha/model_list_instance_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_instance_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_list_instances_response.go b/pkg/postgresflexalpha/model_list_instances_response.go
new file mode 100644
index 00000000..61487dba
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_instances_response.go
@@ -0,0 +1,169 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListInstancesResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListInstancesResponse{}
+
+/*
+ types and functions for instances
+*/
+
+// isArray
+type ListInstancesResponseGetInstancesAttributeType = *[]ListInstance
+type ListInstancesResponseGetInstancesArgType = []ListInstance
+type ListInstancesResponseGetInstancesRetType = []ListInstance
+
+func getListInstancesResponseGetInstancesAttributeTypeOk(arg ListInstancesResponseGetInstancesAttributeType) (ret ListInstancesResponseGetInstancesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListInstancesResponseGetInstancesAttributeType(arg *ListInstancesResponseGetInstancesAttributeType, val ListInstancesResponseGetInstancesRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for pagination
+*/
+
+// isModel
+type ListInstancesResponseGetPaginationAttributeType = *Pagination
+type ListInstancesResponseGetPaginationArgType = Pagination
+type ListInstancesResponseGetPaginationRetType = Pagination
+
+func getListInstancesResponseGetPaginationAttributeTypeOk(arg ListInstancesResponseGetPaginationAttributeType) (ret ListInstancesResponseGetPaginationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListInstancesResponseGetPaginationAttributeType(arg *ListInstancesResponseGetPaginationAttributeType, val ListInstancesResponseGetPaginationRetType) {
+ *arg = &val
+}
+
+// ListInstancesResponse struct for ListInstancesResponse
+type ListInstancesResponse struct {
+ // List of owned instances and their current status.
+ // REQUIRED
+ Instances ListInstancesResponseGetInstancesAttributeType `json:"instances" required:"true"`
+ // REQUIRED
+ Pagination ListInstancesResponseGetPaginationAttributeType `json:"pagination" required:"true"`
+}
+
+type _ListInstancesResponse ListInstancesResponse
+
+// NewListInstancesResponse instantiates a new ListInstancesResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListInstancesResponse(instances ListInstancesResponseGetInstancesArgType, pagination ListInstancesResponseGetPaginationArgType) *ListInstancesResponse {
+ this := ListInstancesResponse{}
+ setListInstancesResponseGetInstancesAttributeType(&this.Instances, instances)
+ setListInstancesResponseGetPaginationAttributeType(&this.Pagination, pagination)
+ return &this
+}
+
+// NewListInstancesResponseWithDefaults instantiates a new ListInstancesResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListInstancesResponseWithDefaults() *ListInstancesResponse {
+ this := ListInstancesResponse{}
+ return &this
+}
+
+// GetInstances returns the Instances field value
+func (o *ListInstancesResponse) GetInstances() (ret ListInstancesResponseGetInstancesRetType) {
+ ret, _ = o.GetInstancesOk()
+ return ret
+}
+
+// GetInstancesOk returns a tuple with the Instances field value
+// and a boolean to check if the value has been set.
+func (o *ListInstancesResponse) GetInstancesOk() (ret ListInstancesResponseGetInstancesRetType, ok bool) {
+ return getListInstancesResponseGetInstancesAttributeTypeOk(o.Instances)
+}
+
+// SetInstances sets field value
+func (o *ListInstancesResponse) SetInstances(v ListInstancesResponseGetInstancesRetType) {
+ setListInstancesResponseGetInstancesAttributeType(&o.Instances, v)
+}
+
+// GetPagination returns the Pagination field value
+func (o *ListInstancesResponse) GetPagination() (ret ListInstancesResponseGetPaginationRetType) {
+ ret, _ = o.GetPaginationOk()
+ return ret
+}
+
+// GetPaginationOk returns a tuple with the Pagination field value
+// and a boolean to check if the value has been set.
+func (o *ListInstancesResponse) GetPaginationOk() (ret ListInstancesResponseGetPaginationRetType, ok bool) {
+ return getListInstancesResponseGetPaginationAttributeTypeOk(o.Pagination)
+}
+
+// SetPagination sets field value
+func (o *ListInstancesResponse) SetPagination(v ListInstancesResponseGetPaginationRetType) {
+ setListInstancesResponseGetPaginationAttributeType(&o.Pagination, v)
+}
+
+func (o ListInstancesResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListInstancesResponseGetInstancesAttributeTypeOk(o.Instances); ok {
+ toSerialize["Instances"] = val
+ }
+ if val, ok := getListInstancesResponseGetPaginationAttributeTypeOk(o.Pagination); ok {
+ toSerialize["Pagination"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListInstancesResponse struct {
+ value *ListInstancesResponse
+ isSet bool
+}
+
+func (v NullableListInstancesResponse) Get() *ListInstancesResponse {
+ return v.value
+}
+
+func (v *NullableListInstancesResponse) Set(val *ListInstancesResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListInstancesResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListInstancesResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListInstancesResponse(val *ListInstancesResponse) *NullableListInstancesResponse {
+ return &NullableListInstancesResponse{value: val, isSet: true}
+}
+
+func (v NullableListInstancesResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListInstancesResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_list_instances_response_test.go b/pkg/postgresflexalpha/model_list_instances_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_instances_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_list_roles_response.go b/pkg/postgresflexalpha/model_list_roles_response.go
new file mode 100644
index 00000000..ecf37b74
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_roles_response.go
@@ -0,0 +1,126 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListRolesResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListRolesResponse{}
+
+/*
+ types and functions for roles
+*/
+
+// isArray
+type ListRolesResponseGetRolesAttributeType = *[]string
+type ListRolesResponseGetRolesArgType = []string
+type ListRolesResponseGetRolesRetType = []string
+
+func getListRolesResponseGetRolesAttributeTypeOk(arg ListRolesResponseGetRolesAttributeType) (ret ListRolesResponseGetRolesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListRolesResponseGetRolesAttributeType(arg *ListRolesResponseGetRolesAttributeType, val ListRolesResponseGetRolesRetType) {
+ *arg = &val
+}
+
+// ListRolesResponse struct for ListRolesResponse
+type ListRolesResponse struct {
+ // List of all role names available in the instance
+ // REQUIRED
+ Roles ListRolesResponseGetRolesAttributeType `json:"roles" required:"true"`
+}
+
+type _ListRolesResponse ListRolesResponse
+
+// NewListRolesResponse instantiates a new ListRolesResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListRolesResponse(roles ListRolesResponseGetRolesArgType) *ListRolesResponse {
+ this := ListRolesResponse{}
+ setListRolesResponseGetRolesAttributeType(&this.Roles, roles)
+ return &this
+}
+
+// NewListRolesResponseWithDefaults instantiates a new ListRolesResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListRolesResponseWithDefaults() *ListRolesResponse {
+ this := ListRolesResponse{}
+ return &this
+}
+
+// GetRoles returns the Roles field value
+func (o *ListRolesResponse) GetRoles() (ret ListRolesResponseGetRolesRetType) {
+ ret, _ = o.GetRolesOk()
+ return ret
+}
+
+// GetRolesOk returns a tuple with the Roles field value
+// and a boolean to check if the value has been set.
+func (o *ListRolesResponse) GetRolesOk() (ret ListRolesResponseGetRolesRetType, ok bool) {
+ return getListRolesResponseGetRolesAttributeTypeOk(o.Roles)
+}
+
+// SetRoles sets field value
+func (o *ListRolesResponse) SetRoles(v ListRolesResponseGetRolesRetType) {
+ setListRolesResponseGetRolesAttributeType(&o.Roles, v)
+}
+
+func (o ListRolesResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListRolesResponseGetRolesAttributeTypeOk(o.Roles); ok {
+ toSerialize["Roles"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListRolesResponse struct {
+ value *ListRolesResponse
+ isSet bool
+}
+
+func (v NullableListRolesResponse) Get() *ListRolesResponse {
+ return v.value
+}
+
+func (v *NullableListRolesResponse) Set(val *ListRolesResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListRolesResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListRolesResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListRolesResponse(val *ListRolesResponse) *NullableListRolesResponse {
+ return &NullableListRolesResponse{value: val, isSet: true}
+}
+
+func (v NullableListRolesResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListRolesResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_list_roles_response_test.go b/pkg/postgresflexalpha/model_list_roles_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_roles_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_list_user.go b/pkg/postgresflexalpha/model_list_user.go
new file mode 100644
index 00000000..ecd3f590
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_user.go
@@ -0,0 +1,216 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListUser type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListUser{}
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type ListUserGetIdAttributeType = *int64
+type ListUserGetIdArgType = int64
+type ListUserGetIdRetType = int64
+
+func getListUserGetIdAttributeTypeOk(arg ListUserGetIdAttributeType) (ret ListUserGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListUserGetIdAttributeType(arg *ListUserGetIdAttributeType, val ListUserGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type ListUserGetNameAttributeType = *string
+
+func getListUserGetNameAttributeTypeOk(arg ListUserGetNameAttributeType) (ret ListUserGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListUserGetNameAttributeType(arg *ListUserGetNameAttributeType, val ListUserGetNameRetType) {
+ *arg = &val
+}
+
+type ListUserGetNameArgType = string
+type ListUserGetNameRetType = string
+
+/*
+ types and functions for status
+*/
+
+// isNotNullableString
+type ListUserGetStatusAttributeType = *string
+
+func getListUserGetStatusAttributeTypeOk(arg ListUserGetStatusAttributeType) (ret ListUserGetStatusRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListUserGetStatusAttributeType(arg *ListUserGetStatusAttributeType, val ListUserGetStatusRetType) {
+ *arg = &val
+}
+
+type ListUserGetStatusArgType = string
+type ListUserGetStatusRetType = string
+
+// ListUser struct for ListUser
+type ListUser struct {
+ // The ID of the user.
+ // REQUIRED
+ Id ListUserGetIdAttributeType `json:"id" required:"true"`
+ // The name of the user.
+ // REQUIRED
+ Name ListUserGetNameAttributeType `json:"name" required:"true"`
+ // The current status of the user.
+ // REQUIRED
+ Status ListUserGetStatusAttributeType `json:"status" required:"true"`
+}
+
+type _ListUser ListUser
+
+// NewListUser instantiates a new ListUser object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListUser(id ListUserGetIdArgType, name ListUserGetNameArgType, status ListUserGetStatusArgType) *ListUser {
+ this := ListUser{}
+ setListUserGetIdAttributeType(&this.Id, id)
+ setListUserGetNameAttributeType(&this.Name, name)
+ setListUserGetStatusAttributeType(&this.Status, status)
+ return &this
+}
+
+// NewListUserWithDefaults instantiates a new ListUser object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListUserWithDefaults() *ListUser {
+ this := ListUser{}
+ return &this
+}
+
+// GetId returns the Id field value
+func (o *ListUser) GetId() (ret ListUserGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *ListUser) GetIdOk() (ret ListUserGetIdRetType, ok bool) {
+ return getListUserGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *ListUser) SetId(v ListUserGetIdRetType) {
+ setListUserGetIdAttributeType(&o.Id, v)
+}
+
+// GetName returns the Name field value
+func (o *ListUser) GetName() (ret ListUserGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *ListUser) GetNameOk() (ret ListUserGetNameRetType, ok bool) {
+ return getListUserGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *ListUser) SetName(v ListUserGetNameRetType) {
+ setListUserGetNameAttributeType(&o.Name, v)
+}
+
+// GetStatus returns the Status field value
+func (o *ListUser) GetStatus() (ret ListUserGetStatusRetType) {
+ ret, _ = o.GetStatusOk()
+ return ret
+}
+
+// GetStatusOk returns a tuple with the Status field value
+// and a boolean to check if the value has been set.
+func (o *ListUser) GetStatusOk() (ret ListUserGetStatusRetType, ok bool) {
+ return getListUserGetStatusAttributeTypeOk(o.Status)
+}
+
+// SetStatus sets field value
+func (o *ListUser) SetStatus(v ListUserGetStatusRetType) {
+ setListUserGetStatusAttributeType(&o.Status, v)
+}
+
+func (o ListUser) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListUserGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getListUserGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getListUserGetStatusAttributeTypeOk(o.Status); ok {
+ toSerialize["Status"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListUser struct {
+ value *ListUser
+ isSet bool
+}
+
+func (v NullableListUser) Get() *ListUser {
+ return v.value
+}
+
+func (v *NullableListUser) Set(val *ListUser) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListUser) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListUser) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListUser(val *ListUser) *NullableListUser {
+ return &NullableListUser{value: val, isSet: true}
+}
+
+func (v NullableListUser) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListUser) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_list_user_response.go b/pkg/postgresflexalpha/model_list_user_response.go
new file mode 100644
index 00000000..0f9376af
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_user_response.go
@@ -0,0 +1,169 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListUserResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListUserResponse{}
+
+/*
+ types and functions for pagination
+*/
+
+// isModel
+type ListUserResponseGetPaginationAttributeType = *Pagination
+type ListUserResponseGetPaginationArgType = Pagination
+type ListUserResponseGetPaginationRetType = Pagination
+
+func getListUserResponseGetPaginationAttributeTypeOk(arg ListUserResponseGetPaginationAttributeType) (ret ListUserResponseGetPaginationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListUserResponseGetPaginationAttributeType(arg *ListUserResponseGetPaginationAttributeType, val ListUserResponseGetPaginationRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for users
+*/
+
+// isArray
+type ListUserResponseGetUsersAttributeType = *[]ListUser
+type ListUserResponseGetUsersArgType = []ListUser
+type ListUserResponseGetUsersRetType = []ListUser
+
+func getListUserResponseGetUsersAttributeTypeOk(arg ListUserResponseGetUsersAttributeType) (ret ListUserResponseGetUsersRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListUserResponseGetUsersAttributeType(arg *ListUserResponseGetUsersAttributeType, val ListUserResponseGetUsersRetType) {
+ *arg = &val
+}
+
+// ListUserResponse struct for ListUserResponse
+type ListUserResponse struct {
+ // REQUIRED
+ Pagination ListUserResponseGetPaginationAttributeType `json:"pagination" required:"true"`
+ // List of all users inside an instance
+ // REQUIRED
+ Users ListUserResponseGetUsersAttributeType `json:"users" required:"true"`
+}
+
+type _ListUserResponse ListUserResponse
+
+// NewListUserResponse instantiates a new ListUserResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListUserResponse(pagination ListUserResponseGetPaginationArgType, users ListUserResponseGetUsersArgType) *ListUserResponse {
+ this := ListUserResponse{}
+ setListUserResponseGetPaginationAttributeType(&this.Pagination, pagination)
+ setListUserResponseGetUsersAttributeType(&this.Users, users)
+ return &this
+}
+
+// NewListUserResponseWithDefaults instantiates a new ListUserResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListUserResponseWithDefaults() *ListUserResponse {
+ this := ListUserResponse{}
+ return &this
+}
+
+// GetPagination returns the Pagination field value
+func (o *ListUserResponse) GetPagination() (ret ListUserResponseGetPaginationRetType) {
+ ret, _ = o.GetPaginationOk()
+ return ret
+}
+
+// GetPaginationOk returns a tuple with the Pagination field value
+// and a boolean to check if the value has been set.
+func (o *ListUserResponse) GetPaginationOk() (ret ListUserResponseGetPaginationRetType, ok bool) {
+ return getListUserResponseGetPaginationAttributeTypeOk(o.Pagination)
+}
+
+// SetPagination sets field value
+func (o *ListUserResponse) SetPagination(v ListUserResponseGetPaginationRetType) {
+ setListUserResponseGetPaginationAttributeType(&o.Pagination, v)
+}
+
+// GetUsers returns the Users field value
+func (o *ListUserResponse) GetUsers() (ret ListUserResponseGetUsersRetType) {
+ ret, _ = o.GetUsersOk()
+ return ret
+}
+
+// GetUsersOk returns a tuple with the Users field value
+// and a boolean to check if the value has been set.
+func (o *ListUserResponse) GetUsersOk() (ret ListUserResponseGetUsersRetType, ok bool) {
+ return getListUserResponseGetUsersAttributeTypeOk(o.Users)
+}
+
+// SetUsers sets field value
+func (o *ListUserResponse) SetUsers(v ListUserResponseGetUsersRetType) {
+ setListUserResponseGetUsersAttributeType(&o.Users, v)
+}
+
+func (o ListUserResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListUserResponseGetPaginationAttributeTypeOk(o.Pagination); ok {
+ toSerialize["Pagination"] = val
+ }
+ if val, ok := getListUserResponseGetUsersAttributeTypeOk(o.Users); ok {
+ toSerialize["Users"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListUserResponse struct {
+ value *ListUserResponse
+ isSet bool
+}
+
+func (v NullableListUserResponse) Get() *ListUserResponse {
+ return v.value
+}
+
+func (v *NullableListUserResponse) Set(val *ListUserResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListUserResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListUserResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListUserResponse(val *ListUserResponse) *NullableListUserResponse {
+ return &NullableListUserResponse{value: val, isSet: true}
+}
+
+func (v NullableListUserResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListUserResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_list_user_response_test.go b/pkg/postgresflexalpha/model_list_user_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_user_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_list_user_test.go b/pkg/postgresflexalpha/model_list_user_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_list_user_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_pagination.go b/pkg/postgresflexalpha/model_pagination.go
new file mode 100644
index 00000000..e35a1957
--- /dev/null
+++ b/pkg/postgresflexalpha/model_pagination.go
@@ -0,0 +1,298 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the Pagination type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &Pagination{}
+
+/*
+ types and functions for page
+*/
+
+// isLong
+type PaginationGetPageAttributeType = *int64
+type PaginationGetPageArgType = int64
+type PaginationGetPageRetType = int64
+
+func getPaginationGetPageAttributeTypeOk(arg PaginationGetPageAttributeType) (ret PaginationGetPageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPaginationGetPageAttributeType(arg *PaginationGetPageAttributeType, val PaginationGetPageRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for size
+*/
+
+// isLong
+type PaginationGetSizeAttributeType = *int64
+type PaginationGetSizeArgType = int64
+type PaginationGetSizeRetType = int64
+
+func getPaginationGetSizeAttributeTypeOk(arg PaginationGetSizeAttributeType) (ret PaginationGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPaginationGetSizeAttributeType(arg *PaginationGetSizeAttributeType, val PaginationGetSizeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for sort
+*/
+
+// isNotNullableString
+type PaginationGetSortAttributeType = *string
+
+func getPaginationGetSortAttributeTypeOk(arg PaginationGetSortAttributeType) (ret PaginationGetSortRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPaginationGetSortAttributeType(arg *PaginationGetSortAttributeType, val PaginationGetSortRetType) {
+ *arg = &val
+}
+
+type PaginationGetSortArgType = string
+type PaginationGetSortRetType = string
+
+/*
+ types and functions for totalPages
+*/
+
+// isLong
+type PaginationGetTotalPagesAttributeType = *int64
+type PaginationGetTotalPagesArgType = int64
+type PaginationGetTotalPagesRetType = int64
+
+func getPaginationGetTotalPagesAttributeTypeOk(arg PaginationGetTotalPagesAttributeType) (ret PaginationGetTotalPagesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPaginationGetTotalPagesAttributeType(arg *PaginationGetTotalPagesAttributeType, val PaginationGetTotalPagesRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for totalRows
+*/
+
+// isLong
+type PaginationGetTotalRowsAttributeType = *int64
+type PaginationGetTotalRowsArgType = int64
+type PaginationGetTotalRowsRetType = int64
+
+func getPaginationGetTotalRowsAttributeTypeOk(arg PaginationGetTotalRowsAttributeType) (ret PaginationGetTotalRowsRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPaginationGetTotalRowsAttributeType(arg *PaginationGetTotalRowsAttributeType, val PaginationGetTotalRowsRetType) {
+ *arg = &val
+}
+
+// Pagination struct for Pagination
+type Pagination struct {
+ // REQUIRED
+ Page PaginationGetPageAttributeType `json:"page" required:"true"`
+ // REQUIRED
+ Size PaginationGetSizeAttributeType `json:"size" required:"true"`
+ // REQUIRED
+ Sort PaginationGetSortAttributeType `json:"sort" required:"true"`
+ // REQUIRED
+ TotalPages PaginationGetTotalPagesAttributeType `json:"totalPages" required:"true"`
+ // REQUIRED
+ TotalRows PaginationGetTotalRowsAttributeType `json:"totalRows" required:"true"`
+}
+
+type _Pagination Pagination
+
+// NewPagination instantiates a new Pagination object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewPagination(page PaginationGetPageArgType, size PaginationGetSizeArgType, sort PaginationGetSortArgType, totalPages PaginationGetTotalPagesArgType, totalRows PaginationGetTotalRowsArgType) *Pagination {
+ this := Pagination{}
+ setPaginationGetPageAttributeType(&this.Page, page)
+ setPaginationGetSizeAttributeType(&this.Size, size)
+ setPaginationGetSortAttributeType(&this.Sort, sort)
+ setPaginationGetTotalPagesAttributeType(&this.TotalPages, totalPages)
+ setPaginationGetTotalRowsAttributeType(&this.TotalRows, totalRows)
+ return &this
+}
+
+// NewPaginationWithDefaults instantiates a new Pagination object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewPaginationWithDefaults() *Pagination {
+ this := Pagination{}
+ return &this
+}
+
+// GetPage returns the Page field value
+func (o *Pagination) GetPage() (ret PaginationGetPageRetType) {
+ ret, _ = o.GetPageOk()
+ return ret
+}
+
+// GetPageOk returns a tuple with the Page field value
+// and a boolean to check if the value has been set.
+func (o *Pagination) GetPageOk() (ret PaginationGetPageRetType, ok bool) {
+ return getPaginationGetPageAttributeTypeOk(o.Page)
+}
+
+// SetPage sets field value
+func (o *Pagination) SetPage(v PaginationGetPageRetType) {
+ setPaginationGetPageAttributeType(&o.Page, v)
+}
+
+// GetSize returns the Size field value
+func (o *Pagination) GetSize() (ret PaginationGetSizeRetType) {
+ ret, _ = o.GetSizeOk()
+ return ret
+}
+
+// GetSizeOk returns a tuple with the Size field value
+// and a boolean to check if the value has been set.
+func (o *Pagination) GetSizeOk() (ret PaginationGetSizeRetType, ok bool) {
+ return getPaginationGetSizeAttributeTypeOk(o.Size)
+}
+
+// SetSize sets field value
+func (o *Pagination) SetSize(v PaginationGetSizeRetType) {
+ setPaginationGetSizeAttributeType(&o.Size, v)
+}
+
+// GetSort returns the Sort field value
+func (o *Pagination) GetSort() (ret PaginationGetSortRetType) {
+ ret, _ = o.GetSortOk()
+ return ret
+}
+
+// GetSortOk returns a tuple with the Sort field value
+// and a boolean to check if the value has been set.
+func (o *Pagination) GetSortOk() (ret PaginationGetSortRetType, ok bool) {
+ return getPaginationGetSortAttributeTypeOk(o.Sort)
+}
+
+// SetSort sets field value
+func (o *Pagination) SetSort(v PaginationGetSortRetType) {
+ setPaginationGetSortAttributeType(&o.Sort, v)
+}
+
+// GetTotalPages returns the TotalPages field value
+func (o *Pagination) GetTotalPages() (ret PaginationGetTotalPagesRetType) {
+ ret, _ = o.GetTotalPagesOk()
+ return ret
+}
+
+// GetTotalPagesOk returns a tuple with the TotalPages field value
+// and a boolean to check if the value has been set.
+func (o *Pagination) GetTotalPagesOk() (ret PaginationGetTotalPagesRetType, ok bool) {
+ return getPaginationGetTotalPagesAttributeTypeOk(o.TotalPages)
+}
+
+// SetTotalPages sets field value
+func (o *Pagination) SetTotalPages(v PaginationGetTotalPagesRetType) {
+ setPaginationGetTotalPagesAttributeType(&o.TotalPages, v)
+}
+
+// GetTotalRows returns the TotalRows field value
+func (o *Pagination) GetTotalRows() (ret PaginationGetTotalRowsRetType) {
+ ret, _ = o.GetTotalRowsOk()
+ return ret
+}
+
+// GetTotalRowsOk returns a tuple with the TotalRows field value
+// and a boolean to check if the value has been set.
+func (o *Pagination) GetTotalRowsOk() (ret PaginationGetTotalRowsRetType, ok bool) {
+ return getPaginationGetTotalRowsAttributeTypeOk(o.TotalRows)
+}
+
+// SetTotalRows sets field value
+func (o *Pagination) SetTotalRows(v PaginationGetTotalRowsRetType) {
+ setPaginationGetTotalRowsAttributeType(&o.TotalRows, v)
+}
+
+func (o Pagination) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getPaginationGetPageAttributeTypeOk(o.Page); ok {
+ toSerialize["Page"] = val
+ }
+ if val, ok := getPaginationGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ if val, ok := getPaginationGetSortAttributeTypeOk(o.Sort); ok {
+ toSerialize["Sort"] = val
+ }
+ if val, ok := getPaginationGetTotalPagesAttributeTypeOk(o.TotalPages); ok {
+ toSerialize["TotalPages"] = val
+ }
+ if val, ok := getPaginationGetTotalRowsAttributeTypeOk(o.TotalRows); ok {
+ toSerialize["TotalRows"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullablePagination struct {
+ value *Pagination
+ isSet bool
+}
+
+func (v NullablePagination) Get() *Pagination {
+ return v.value
+}
+
+func (v *NullablePagination) Set(val *Pagination) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullablePagination) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullablePagination) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullablePagination(val *Pagination) *NullablePagination {
+ return &NullablePagination{value: val, isSet: true}
+}
+
+func (v NullablePagination) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullablePagination) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_pagination_test.go b/pkg/postgresflexalpha/model_pagination_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_pagination_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_point_in_time_recovery_request_payload.go b/pkg/postgresflexalpha/model_point_in_time_recovery_request_payload.go
new file mode 100644
index 00000000..e64a82c6
--- /dev/null
+++ b/pkg/postgresflexalpha/model_point_in_time_recovery_request_payload.go
@@ -0,0 +1,216 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+ "time"
+)
+
+// checks if the PointInTimeRecoveryRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &PointInTimeRecoveryRequestPayload{}
+
+/*
+ types and functions for performanceClass
+*/
+
+// isNotNullableString
+type PointInTimeRecoveryRequestPayloadGetPerformanceClassAttributeType = *string
+
+func getPointInTimeRecoveryRequestPayloadGetPerformanceClassAttributeTypeOk(arg PointInTimeRecoveryRequestPayloadGetPerformanceClassAttributeType) (ret PointInTimeRecoveryRequestPayloadGetPerformanceClassRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPointInTimeRecoveryRequestPayloadGetPerformanceClassAttributeType(arg *PointInTimeRecoveryRequestPayloadGetPerformanceClassAttributeType, val PointInTimeRecoveryRequestPayloadGetPerformanceClassRetType) {
+ *arg = &val
+}
+
+type PointInTimeRecoveryRequestPayloadGetPerformanceClassArgType = string
+type PointInTimeRecoveryRequestPayloadGetPerformanceClassRetType = string
+
+/*
+ types and functions for recoveryTime
+*/
+
+// isDateTime
+type PointInTimeRecoveryRequestPayloadGetRecoveryTimeAttributeType = *time.Time
+type PointInTimeRecoveryRequestPayloadGetRecoveryTimeArgType = time.Time
+type PointInTimeRecoveryRequestPayloadGetRecoveryTimeRetType = time.Time
+
+func getPointInTimeRecoveryRequestPayloadGetRecoveryTimeAttributeTypeOk(arg PointInTimeRecoveryRequestPayloadGetRecoveryTimeAttributeType) (ret PointInTimeRecoveryRequestPayloadGetRecoveryTimeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPointInTimeRecoveryRequestPayloadGetRecoveryTimeAttributeType(arg *PointInTimeRecoveryRequestPayloadGetRecoveryTimeAttributeType, val PointInTimeRecoveryRequestPayloadGetRecoveryTimeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for size
+*/
+
+// isLong
+type PointInTimeRecoveryRequestPayloadGetSizeAttributeType = *int64
+type PointInTimeRecoveryRequestPayloadGetSizeArgType = int64
+type PointInTimeRecoveryRequestPayloadGetSizeRetType = int64
+
+func getPointInTimeRecoveryRequestPayloadGetSizeAttributeTypeOk(arg PointInTimeRecoveryRequestPayloadGetSizeAttributeType) (ret PointInTimeRecoveryRequestPayloadGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPointInTimeRecoveryRequestPayloadGetSizeAttributeType(arg *PointInTimeRecoveryRequestPayloadGetSizeAttributeType, val PointInTimeRecoveryRequestPayloadGetSizeRetType) {
+ *arg = &val
+}
+
+// PointInTimeRecoveryRequestPayload struct for PointInTimeRecoveryRequestPayload
+type PointInTimeRecoveryRequestPayload struct {
+ // The storage class for the storage.
+ // REQUIRED
+ PerformanceClass PointInTimeRecoveryRequestPayloadGetPerformanceClassAttributeType `json:"performanceClass" required:"true"`
+ // the time for the point in time recovery it will be calculated between first backup and last backup
+ // REQUIRED
+ RecoveryTime PointInTimeRecoveryRequestPayloadGetRecoveryTimeAttributeType `json:"recoveryTime" required:"true"`
+ // The storage size in Gigabytes.
+ // REQUIRED
+ Size PointInTimeRecoveryRequestPayloadGetSizeAttributeType `json:"size" required:"true"`
+}
+
+type _PointInTimeRecoveryRequestPayload PointInTimeRecoveryRequestPayload
+
+// NewPointInTimeRecoveryRequestPayload instantiates a new PointInTimeRecoveryRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewPointInTimeRecoveryRequestPayload(performanceClass PointInTimeRecoveryRequestPayloadGetPerformanceClassArgType, recoveryTime PointInTimeRecoveryRequestPayloadGetRecoveryTimeArgType, size PointInTimeRecoveryRequestPayloadGetSizeArgType) *PointInTimeRecoveryRequestPayload {
+ this := PointInTimeRecoveryRequestPayload{}
+ setPointInTimeRecoveryRequestPayloadGetPerformanceClassAttributeType(&this.PerformanceClass, performanceClass)
+ setPointInTimeRecoveryRequestPayloadGetRecoveryTimeAttributeType(&this.RecoveryTime, recoveryTime)
+ setPointInTimeRecoveryRequestPayloadGetSizeAttributeType(&this.Size, size)
+ return &this
+}
+
+// NewPointInTimeRecoveryRequestPayloadWithDefaults instantiates a new PointInTimeRecoveryRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewPointInTimeRecoveryRequestPayloadWithDefaults() *PointInTimeRecoveryRequestPayload {
+ this := PointInTimeRecoveryRequestPayload{}
+ return &this
+}
+
+// GetPerformanceClass returns the PerformanceClass field value
+func (o *PointInTimeRecoveryRequestPayload) GetPerformanceClass() (ret PointInTimeRecoveryRequestPayloadGetPerformanceClassRetType) {
+ ret, _ = o.GetPerformanceClassOk()
+ return ret
+}
+
+// GetPerformanceClassOk returns a tuple with the PerformanceClass field value
+// and a boolean to check if the value has been set.
+func (o *PointInTimeRecoveryRequestPayload) GetPerformanceClassOk() (ret PointInTimeRecoveryRequestPayloadGetPerformanceClassRetType, ok bool) {
+ return getPointInTimeRecoveryRequestPayloadGetPerformanceClassAttributeTypeOk(o.PerformanceClass)
+}
+
+// SetPerformanceClass sets field value
+func (o *PointInTimeRecoveryRequestPayload) SetPerformanceClass(v PointInTimeRecoveryRequestPayloadGetPerformanceClassRetType) {
+ setPointInTimeRecoveryRequestPayloadGetPerformanceClassAttributeType(&o.PerformanceClass, v)
+}
+
+// GetRecoveryTime returns the RecoveryTime field value
+func (o *PointInTimeRecoveryRequestPayload) GetRecoveryTime() (ret PointInTimeRecoveryRequestPayloadGetRecoveryTimeRetType) {
+ ret, _ = o.GetRecoveryTimeOk()
+ return ret
+}
+
+// GetRecoveryTimeOk returns a tuple with the RecoveryTime field value
+// and a boolean to check if the value has been set.
+func (o *PointInTimeRecoveryRequestPayload) GetRecoveryTimeOk() (ret PointInTimeRecoveryRequestPayloadGetRecoveryTimeRetType, ok bool) {
+ return getPointInTimeRecoveryRequestPayloadGetRecoveryTimeAttributeTypeOk(o.RecoveryTime)
+}
+
+// SetRecoveryTime sets field value
+func (o *PointInTimeRecoveryRequestPayload) SetRecoveryTime(v PointInTimeRecoveryRequestPayloadGetRecoveryTimeRetType) {
+ setPointInTimeRecoveryRequestPayloadGetRecoveryTimeAttributeType(&o.RecoveryTime, v)
+}
+
+// GetSize returns the Size field value
+func (o *PointInTimeRecoveryRequestPayload) GetSize() (ret PointInTimeRecoveryRequestPayloadGetSizeRetType) {
+ ret, _ = o.GetSizeOk()
+ return ret
+}
+
+// GetSizeOk returns a tuple with the Size field value
+// and a boolean to check if the value has been set.
+func (o *PointInTimeRecoveryRequestPayload) GetSizeOk() (ret PointInTimeRecoveryRequestPayloadGetSizeRetType, ok bool) {
+ return getPointInTimeRecoveryRequestPayloadGetSizeAttributeTypeOk(o.Size)
+}
+
+// SetSize sets field value
+func (o *PointInTimeRecoveryRequestPayload) SetSize(v PointInTimeRecoveryRequestPayloadGetSizeRetType) {
+ setPointInTimeRecoveryRequestPayloadGetSizeAttributeType(&o.Size, v)
+}
+
+func (o PointInTimeRecoveryRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getPointInTimeRecoveryRequestPayloadGetPerformanceClassAttributeTypeOk(o.PerformanceClass); ok {
+ toSerialize["PerformanceClass"] = val
+ }
+ if val, ok := getPointInTimeRecoveryRequestPayloadGetRecoveryTimeAttributeTypeOk(o.RecoveryTime); ok {
+ toSerialize["RecoveryTime"] = val
+ }
+ if val, ok := getPointInTimeRecoveryRequestPayloadGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullablePointInTimeRecoveryRequestPayload struct {
+ value *PointInTimeRecoveryRequestPayload
+ isSet bool
+}
+
+func (v NullablePointInTimeRecoveryRequestPayload) Get() *PointInTimeRecoveryRequestPayload {
+ return v.value
+}
+
+func (v *NullablePointInTimeRecoveryRequestPayload) Set(val *PointInTimeRecoveryRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullablePointInTimeRecoveryRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullablePointInTimeRecoveryRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullablePointInTimeRecoveryRequestPayload(val *PointInTimeRecoveryRequestPayload) *NullablePointInTimeRecoveryRequestPayload {
+ return &NullablePointInTimeRecoveryRequestPayload{value: val, isSet: true}
+}
+
+func (v NullablePointInTimeRecoveryRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullablePointInTimeRecoveryRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_point_in_time_recovery_request_payload_test.go b/pkg/postgresflexalpha/model_point_in_time_recovery_request_payload_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_point_in_time_recovery_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_protect_instance_request_payload.go b/pkg/postgresflexalpha/model_protect_instance_request_payload.go
new file mode 100644
index 00000000..d80513dd
--- /dev/null
+++ b/pkg/postgresflexalpha/model_protect_instance_request_payload.go
@@ -0,0 +1,126 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ProtectInstanceRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ProtectInstanceRequestPayload{}
+
+/*
+ types and functions for isDeletable
+*/
+
+// isBoolean
+type ProtectInstanceRequestPayloadgetIsDeletableAttributeType = *bool
+type ProtectInstanceRequestPayloadgetIsDeletableArgType = bool
+type ProtectInstanceRequestPayloadgetIsDeletableRetType = bool
+
+func getProtectInstanceRequestPayloadgetIsDeletableAttributeTypeOk(arg ProtectInstanceRequestPayloadgetIsDeletableAttributeType) (ret ProtectInstanceRequestPayloadgetIsDeletableRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setProtectInstanceRequestPayloadgetIsDeletableAttributeType(arg *ProtectInstanceRequestPayloadgetIsDeletableAttributeType, val ProtectInstanceRequestPayloadgetIsDeletableRetType) {
+ *arg = &val
+}
+
+// ProtectInstanceRequestPayload struct for ProtectInstanceRequestPayload
+type ProtectInstanceRequestPayload struct {
+ // Protect instance from deletion.
+ // REQUIRED
+ IsDeletable ProtectInstanceRequestPayloadgetIsDeletableAttributeType `json:"isDeletable" required:"true"`
+}
+
+type _ProtectInstanceRequestPayload ProtectInstanceRequestPayload
+
+// NewProtectInstanceRequestPayload instantiates a new ProtectInstanceRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewProtectInstanceRequestPayload(isDeletable ProtectInstanceRequestPayloadgetIsDeletableArgType) *ProtectInstanceRequestPayload {
+ this := ProtectInstanceRequestPayload{}
+ setProtectInstanceRequestPayloadgetIsDeletableAttributeType(&this.IsDeletable, isDeletable)
+ return &this
+}
+
+// NewProtectInstanceRequestPayloadWithDefaults instantiates a new ProtectInstanceRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewProtectInstanceRequestPayloadWithDefaults() *ProtectInstanceRequestPayload {
+ this := ProtectInstanceRequestPayload{}
+ return &this
+}
+
+// GetIsDeletable returns the IsDeletable field value
+func (o *ProtectInstanceRequestPayload) GetIsDeletable() (ret ProtectInstanceRequestPayloadgetIsDeletableRetType) {
+ ret, _ = o.GetIsDeletableOk()
+ return ret
+}
+
+// GetIsDeletableOk returns a tuple with the IsDeletable field value
+// and a boolean to check if the value has been set.
+func (o *ProtectInstanceRequestPayload) GetIsDeletableOk() (ret ProtectInstanceRequestPayloadgetIsDeletableRetType, ok bool) {
+ return getProtectInstanceRequestPayloadgetIsDeletableAttributeTypeOk(o.IsDeletable)
+}
+
+// SetIsDeletable sets field value
+func (o *ProtectInstanceRequestPayload) SetIsDeletable(v ProtectInstanceRequestPayloadgetIsDeletableRetType) {
+ setProtectInstanceRequestPayloadgetIsDeletableAttributeType(&o.IsDeletable, v)
+}
+
+func (o ProtectInstanceRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getProtectInstanceRequestPayloadgetIsDeletableAttributeTypeOk(o.IsDeletable); ok {
+ toSerialize["IsDeletable"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableProtectInstanceRequestPayload struct {
+ value *ProtectInstanceRequestPayload
+ isSet bool
+}
+
+func (v NullableProtectInstanceRequestPayload) Get() *ProtectInstanceRequestPayload {
+ return v.value
+}
+
+func (v *NullableProtectInstanceRequestPayload) Set(val *ProtectInstanceRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableProtectInstanceRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableProtectInstanceRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableProtectInstanceRequestPayload(val *ProtectInstanceRequestPayload) *NullableProtectInstanceRequestPayload {
+ return &NullableProtectInstanceRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableProtectInstanceRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableProtectInstanceRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_protect_instance_request_payload_test.go b/pkg/postgresflexalpha/model_protect_instance_request_payload_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_protect_instance_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_protect_instance_response.go b/pkg/postgresflexalpha/model_protect_instance_response.go
new file mode 100644
index 00000000..b0c8c8d5
--- /dev/null
+++ b/pkg/postgresflexalpha/model_protect_instance_response.go
@@ -0,0 +1,126 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ProtectInstanceResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ProtectInstanceResponse{}
+
+/*
+ types and functions for isDeletable
+*/
+
+// isBoolean
+type ProtectInstanceResponsegetIsDeletableAttributeType = *bool
+type ProtectInstanceResponsegetIsDeletableArgType = bool
+type ProtectInstanceResponsegetIsDeletableRetType = bool
+
+func getProtectInstanceResponsegetIsDeletableAttributeTypeOk(arg ProtectInstanceResponsegetIsDeletableAttributeType) (ret ProtectInstanceResponsegetIsDeletableRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setProtectInstanceResponsegetIsDeletableAttributeType(arg *ProtectInstanceResponsegetIsDeletableAttributeType, val ProtectInstanceResponsegetIsDeletableRetType) {
+ *arg = &val
+}
+
+// ProtectInstanceResponse struct for ProtectInstanceResponse
+type ProtectInstanceResponse struct {
+ // Protect instance from deletion.
+ // REQUIRED
+ IsDeletable ProtectInstanceResponsegetIsDeletableAttributeType `json:"isDeletable" required:"true"`
+}
+
+type _ProtectInstanceResponse ProtectInstanceResponse
+
+// NewProtectInstanceResponse instantiates a new ProtectInstanceResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewProtectInstanceResponse(isDeletable ProtectInstanceResponsegetIsDeletableArgType) *ProtectInstanceResponse {
+ this := ProtectInstanceResponse{}
+ setProtectInstanceResponsegetIsDeletableAttributeType(&this.IsDeletable, isDeletable)
+ return &this
+}
+
+// NewProtectInstanceResponseWithDefaults instantiates a new ProtectInstanceResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewProtectInstanceResponseWithDefaults() *ProtectInstanceResponse {
+ this := ProtectInstanceResponse{}
+ return &this
+}
+
+// GetIsDeletable returns the IsDeletable field value
+func (o *ProtectInstanceResponse) GetIsDeletable() (ret ProtectInstanceResponsegetIsDeletableRetType) {
+ ret, _ = o.GetIsDeletableOk()
+ return ret
+}
+
+// GetIsDeletableOk returns a tuple with the IsDeletable field value
+// and a boolean to check if the value has been set.
+func (o *ProtectInstanceResponse) GetIsDeletableOk() (ret ProtectInstanceResponsegetIsDeletableRetType, ok bool) {
+ return getProtectInstanceResponsegetIsDeletableAttributeTypeOk(o.IsDeletable)
+}
+
+// SetIsDeletable sets field value
+func (o *ProtectInstanceResponse) SetIsDeletable(v ProtectInstanceResponsegetIsDeletableRetType) {
+ setProtectInstanceResponsegetIsDeletableAttributeType(&o.IsDeletable, v)
+}
+
+func (o ProtectInstanceResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getProtectInstanceResponsegetIsDeletableAttributeTypeOk(o.IsDeletable); ok {
+ toSerialize["IsDeletable"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableProtectInstanceResponse struct {
+ value *ProtectInstanceResponse
+ isSet bool
+}
+
+func (v NullableProtectInstanceResponse) Get() *ProtectInstanceResponse {
+ return v.value
+}
+
+func (v *NullableProtectInstanceResponse) Set(val *ProtectInstanceResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableProtectInstanceResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableProtectInstanceResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableProtectInstanceResponse(val *ProtectInstanceResponse) *NullableProtectInstanceResponse {
+ return &NullableProtectInstanceResponse{value: val, isSet: true}
+}
+
+func (v NullableProtectInstanceResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableProtectInstanceResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_protect_instance_response_test.go b/pkg/postgresflexalpha/model_protect_instance_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_protect_instance_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_recovery_response.go b/pkg/postgresflexalpha/model_recovery_response.go
new file mode 100644
index 00000000..cb591040
--- /dev/null
+++ b/pkg/postgresflexalpha/model_recovery_response.go
@@ -0,0 +1,127 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the RecoveryResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &RecoveryResponse{}
+
+/*
+ types and functions for id
+*/
+
+// isNotNullableString
+type RecoveryResponseGetIdAttributeType = *string
+
+func getRecoveryResponseGetIdAttributeTypeOk(arg RecoveryResponseGetIdAttributeType) (ret RecoveryResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setRecoveryResponseGetIdAttributeType(arg *RecoveryResponseGetIdAttributeType, val RecoveryResponseGetIdRetType) {
+ *arg = &val
+}
+
+type RecoveryResponseGetIdArgType = string
+type RecoveryResponseGetIdRetType = string
+
+// RecoveryResponse struct for RecoveryResponse
+type RecoveryResponse struct {
+ // The ID of the instance.
+ // REQUIRED
+ Id RecoveryResponseGetIdAttributeType `json:"id" required:"true"`
+}
+
+type _RecoveryResponse RecoveryResponse
+
+// NewRecoveryResponse instantiates a new RecoveryResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewRecoveryResponse(id RecoveryResponseGetIdArgType) *RecoveryResponse {
+ this := RecoveryResponse{}
+ setRecoveryResponseGetIdAttributeType(&this.Id, id)
+ return &this
+}
+
+// NewRecoveryResponseWithDefaults instantiates a new RecoveryResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewRecoveryResponseWithDefaults() *RecoveryResponse {
+ this := RecoveryResponse{}
+ return &this
+}
+
+// GetId returns the Id field value
+func (o *RecoveryResponse) GetId() (ret RecoveryResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *RecoveryResponse) GetIdOk() (ret RecoveryResponseGetIdRetType, ok bool) {
+ return getRecoveryResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *RecoveryResponse) SetId(v RecoveryResponseGetIdRetType) {
+ setRecoveryResponseGetIdAttributeType(&o.Id, v)
+}
+
+func (o RecoveryResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getRecoveryResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableRecoveryResponse struct {
+ value *RecoveryResponse
+ isSet bool
+}
+
+func (v NullableRecoveryResponse) Get() *RecoveryResponse {
+ return v.value
+}
+
+func (v *NullableRecoveryResponse) Set(val *RecoveryResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableRecoveryResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableRecoveryResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableRecoveryResponse(val *RecoveryResponse) *NullableRecoveryResponse {
+ return &NullableRecoveryResponse{value: val, isSet: true}
+}
+
+func (v NullableRecoveryResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableRecoveryResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_recovery_response_test.go b/pkg/postgresflexalpha/model_recovery_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_recovery_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_replicas.go b/pkg/postgresflexalpha/model_replicas.go
new file mode 100644
index 00000000..ec7e9ebe
--- /dev/null
+++ b/pkg/postgresflexalpha/model_replicas.go
@@ -0,0 +1,115 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// Replicas How many replicas the instance should have.
+type Replicas int32
+
+// List of replicas
+const (
+ REPLICAS__1 Replicas = 1
+ REPLICAS__3 Replicas = 3
+)
+
+// All allowed values of Replicas enum
+var AllowedReplicasEnumValues = []Replicas{
+ 1,
+ 3,
+}
+
+func (v *Replicas) UnmarshalJSON(src []byte) error {
+ var value int32
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue int32
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := Replicas(value)
+ for _, existing := range AllowedReplicasEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid Replicas", value)
+}
+
+// NewReplicasFromValue returns a pointer to a valid Replicas
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewReplicasFromValue(v int32) (*Replicas, error) {
+ ev := Replicas(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for Replicas: valid values are %v", v, AllowedReplicasEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v Replicas) IsValid() bool {
+ for _, existing := range AllowedReplicasEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to replicas value
+func (v Replicas) Ptr() *Replicas {
+ return &v
+}
+
+type NullableReplicas struct {
+ value *Replicas
+ isSet bool
+}
+
+func (v NullableReplicas) Get() *Replicas {
+ return v.value
+}
+
+func (v *NullableReplicas) Set(val *Replicas) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableReplicas) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableReplicas) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableReplicas(val *Replicas) *NullableReplicas {
+ return &NullableReplicas{value: val, isSet: true}
+}
+
+func (v NullableReplicas) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableReplicas) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_replicas_opt.go b/pkg/postgresflexalpha/model_replicas_opt.go
new file mode 100644
index 00000000..4761c334
--- /dev/null
+++ b/pkg/postgresflexalpha/model_replicas_opt.go
@@ -0,0 +1,115 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// ReplicasOpt How many replicas the instance should have.
+type ReplicasOpt int32
+
+// List of replicas.opt
+const (
+ REPLICASOPT__1 ReplicasOpt = 1
+ REPLICASOPT__3 ReplicasOpt = 3
+)
+
+// All allowed values of ReplicasOpt enum
+var AllowedReplicasOptEnumValues = []ReplicasOpt{
+ 1,
+ 3,
+}
+
+func (v *ReplicasOpt) UnmarshalJSON(src []byte) error {
+ var value int32
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue int32
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := ReplicasOpt(value)
+ for _, existing := range AllowedReplicasOptEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid ReplicasOpt", value)
+}
+
+// NewReplicasOptFromValue returns a pointer to a valid ReplicasOpt
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewReplicasOptFromValue(v int32) (*ReplicasOpt, error) {
+ ev := ReplicasOpt(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for ReplicasOpt: valid values are %v", v, AllowedReplicasOptEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v ReplicasOpt) IsValid() bool {
+ for _, existing := range AllowedReplicasOptEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to replicas.opt value
+func (v ReplicasOpt) Ptr() *ReplicasOpt {
+ return &v
+}
+
+type NullableReplicasOpt struct {
+ value *ReplicasOpt
+ isSet bool
+}
+
+func (v NullableReplicasOpt) Get() *ReplicasOpt {
+ return v.value
+}
+
+func (v *NullableReplicasOpt) Set(val *ReplicasOpt) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableReplicasOpt) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableReplicasOpt) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableReplicasOpt(val *ReplicasOpt) *NullableReplicasOpt {
+ return &NullableReplicasOpt{value: val, isSet: true}
+}
+
+func (v NullableReplicasOpt) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableReplicasOpt) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_replicas_opt_test.go b/pkg/postgresflexalpha/model_replicas_opt_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_replicas_opt_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_replicas_test.go b/pkg/postgresflexalpha/model_replicas_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_replicas_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_reset_user_response.go b/pkg/postgresflexalpha/model_reset_user_response.go
new file mode 100644
index 00000000..bcff75e4
--- /dev/null
+++ b/pkg/postgresflexalpha/model_reset_user_response.go
@@ -0,0 +1,262 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ResetUserResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ResetUserResponse{}
+
+/*
+ types and functions for connectionString
+*/
+
+// isNotNullableString
+type ResetUserResponseGetConnectionStringAttributeType = *string
+
+func getResetUserResponseGetConnectionStringAttributeTypeOk(arg ResetUserResponseGetConnectionStringAttributeType) (ret ResetUserResponseGetConnectionStringRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setResetUserResponseGetConnectionStringAttributeType(arg *ResetUserResponseGetConnectionStringAttributeType, val ResetUserResponseGetConnectionStringRetType) {
+ *arg = &val
+}
+
+type ResetUserResponseGetConnectionStringArgType = string
+type ResetUserResponseGetConnectionStringRetType = string
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type ResetUserResponseGetNameAttributeType = *string
+
+func getResetUserResponseGetNameAttributeTypeOk(arg ResetUserResponseGetNameAttributeType) (ret ResetUserResponseGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setResetUserResponseGetNameAttributeType(arg *ResetUserResponseGetNameAttributeType, val ResetUserResponseGetNameRetType) {
+ *arg = &val
+}
+
+type ResetUserResponseGetNameArgType = string
+type ResetUserResponseGetNameRetType = string
+
+/*
+ types and functions for password
+*/
+
+// isNotNullableString
+type ResetUserResponseGetPasswordAttributeType = *string
+
+func getResetUserResponseGetPasswordAttributeTypeOk(arg ResetUserResponseGetPasswordAttributeType) (ret ResetUserResponseGetPasswordRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setResetUserResponseGetPasswordAttributeType(arg *ResetUserResponseGetPasswordAttributeType, val ResetUserResponseGetPasswordRetType) {
+ *arg = &val
+}
+
+type ResetUserResponseGetPasswordArgType = string
+type ResetUserResponseGetPasswordRetType = string
+
+/*
+ types and functions for status
+*/
+
+// isNotNullableString
+type ResetUserResponseGetStatusAttributeType = *string
+
+func getResetUserResponseGetStatusAttributeTypeOk(arg ResetUserResponseGetStatusAttributeType) (ret ResetUserResponseGetStatusRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setResetUserResponseGetStatusAttributeType(arg *ResetUserResponseGetStatusAttributeType, val ResetUserResponseGetStatusRetType) {
+ *arg = &val
+}
+
+type ResetUserResponseGetStatusArgType = string
+type ResetUserResponseGetStatusRetType = string
+
+// ResetUserResponse struct for ResetUserResponse
+type ResetUserResponse struct {
+ // The connection string for the user to the instance.
+ // REQUIRED
+ ConnectionString ResetUserResponseGetConnectionStringAttributeType `json:"connectionString" required:"true"`
+ // The name of the user.
+ // REQUIRED
+ Name ResetUserResponseGetNameAttributeType `json:"name" required:"true"`
+ // The password for the user.
+ // REQUIRED
+ Password ResetUserResponseGetPasswordAttributeType `json:"password" required:"true"`
+ // The current status of the user.
+ // REQUIRED
+ Status ResetUserResponseGetStatusAttributeType `json:"status" required:"true"`
+}
+
+type _ResetUserResponse ResetUserResponse
+
+// NewResetUserResponse instantiates a new ResetUserResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewResetUserResponse(connectionString ResetUserResponseGetConnectionStringArgType, name ResetUserResponseGetNameArgType, password ResetUserResponseGetPasswordArgType, status ResetUserResponseGetStatusArgType) *ResetUserResponse {
+ this := ResetUserResponse{}
+ setResetUserResponseGetConnectionStringAttributeType(&this.ConnectionString, connectionString)
+ setResetUserResponseGetNameAttributeType(&this.Name, name)
+ setResetUserResponseGetPasswordAttributeType(&this.Password, password)
+ setResetUserResponseGetStatusAttributeType(&this.Status, status)
+ return &this
+}
+
+// NewResetUserResponseWithDefaults instantiates a new ResetUserResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewResetUserResponseWithDefaults() *ResetUserResponse {
+ this := ResetUserResponse{}
+ return &this
+}
+
+// GetConnectionString returns the ConnectionString field value
+func (o *ResetUserResponse) GetConnectionString() (ret ResetUserResponseGetConnectionStringRetType) {
+ ret, _ = o.GetConnectionStringOk()
+ return ret
+}
+
+// GetConnectionStringOk returns a tuple with the ConnectionString field value
+// and a boolean to check if the value has been set.
+func (o *ResetUserResponse) GetConnectionStringOk() (ret ResetUserResponseGetConnectionStringRetType, ok bool) {
+ return getResetUserResponseGetConnectionStringAttributeTypeOk(o.ConnectionString)
+}
+
+// SetConnectionString sets field value
+func (o *ResetUserResponse) SetConnectionString(v ResetUserResponseGetConnectionStringRetType) {
+ setResetUserResponseGetConnectionStringAttributeType(&o.ConnectionString, v)
+}
+
+// GetName returns the Name field value
+func (o *ResetUserResponse) GetName() (ret ResetUserResponseGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *ResetUserResponse) GetNameOk() (ret ResetUserResponseGetNameRetType, ok bool) {
+ return getResetUserResponseGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *ResetUserResponse) SetName(v ResetUserResponseGetNameRetType) {
+ setResetUserResponseGetNameAttributeType(&o.Name, v)
+}
+
+// GetPassword returns the Password field value
+func (o *ResetUserResponse) GetPassword() (ret ResetUserResponseGetPasswordRetType) {
+ ret, _ = o.GetPasswordOk()
+ return ret
+}
+
+// GetPasswordOk returns a tuple with the Password field value
+// and a boolean to check if the value has been set.
+func (o *ResetUserResponse) GetPasswordOk() (ret ResetUserResponseGetPasswordRetType, ok bool) {
+ return getResetUserResponseGetPasswordAttributeTypeOk(o.Password)
+}
+
+// SetPassword sets field value
+func (o *ResetUserResponse) SetPassword(v ResetUserResponseGetPasswordRetType) {
+ setResetUserResponseGetPasswordAttributeType(&o.Password, v)
+}
+
+// GetStatus returns the Status field value
+func (o *ResetUserResponse) GetStatus() (ret ResetUserResponseGetStatusRetType) {
+ ret, _ = o.GetStatusOk()
+ return ret
+}
+
+// GetStatusOk returns a tuple with the Status field value
+// and a boolean to check if the value has been set.
+func (o *ResetUserResponse) GetStatusOk() (ret ResetUserResponseGetStatusRetType, ok bool) {
+ return getResetUserResponseGetStatusAttributeTypeOk(o.Status)
+}
+
+// SetStatus sets field value
+func (o *ResetUserResponse) SetStatus(v ResetUserResponseGetStatusRetType) {
+ setResetUserResponseGetStatusAttributeType(&o.Status, v)
+}
+
+func (o ResetUserResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getResetUserResponseGetConnectionStringAttributeTypeOk(o.ConnectionString); ok {
+ toSerialize["ConnectionString"] = val
+ }
+ if val, ok := getResetUserResponseGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getResetUserResponseGetPasswordAttributeTypeOk(o.Password); ok {
+ toSerialize["Password"] = val
+ }
+ if val, ok := getResetUserResponseGetStatusAttributeTypeOk(o.Status); ok {
+ toSerialize["Status"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableResetUserResponse struct {
+ value *ResetUserResponse
+ isSet bool
+}
+
+func (v NullableResetUserResponse) Get() *ResetUserResponse {
+ return v.value
+}
+
+func (v *NullableResetUserResponse) Set(val *ResetUserResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableResetUserResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableResetUserResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableResetUserResponse(val *ResetUserResponse) *NullableResetUserResponse {
+ return &NullableResetUserResponse{value: val, isSet: true}
+}
+
+func (v NullableResetUserResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableResetUserResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_reset_user_response_test.go b/pkg/postgresflexalpha/model_reset_user_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_reset_user_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_status.go b/pkg/postgresflexalpha/model_status.go
new file mode 100644
index 00000000..0bd594ce
--- /dev/null
+++ b/pkg/postgresflexalpha/model_status.go
@@ -0,0 +1,123 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// Status The current status of the instance.
+type Status string
+
+// List of status
+const (
+ STATUS_READY Status = "READY"
+ STATUS_PENDING Status = "PENDING"
+ STATUS_PROGRESSING Status = "PROGRESSING"
+ STATUS_FAILURE Status = "FAILURE"
+ STATUS_UNKNOWN Status = "UNKNOWN"
+ STATUS_TERMINATING Status = "TERMINATING"
+)
+
+// All allowed values of Status enum
+var AllowedStatusEnumValues = []Status{
+ "READY",
+ "PENDING",
+ "PROGRESSING",
+ "FAILURE",
+ "UNKNOWN",
+ "TERMINATING",
+}
+
+func (v *Status) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := Status(value)
+ for _, existing := range AllowedStatusEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid Status", value)
+}
+
+// NewStatusFromValue returns a pointer to a valid Status
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewStatusFromValue(v string) (*Status, error) {
+ ev := Status(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for Status: valid values are %v", v, AllowedStatusEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v Status) IsValid() bool {
+ for _, existing := range AllowedStatusEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to status value
+func (v Status) Ptr() *Status {
+ return &v
+}
+
+type NullableStatus struct {
+ value *Status
+ isSet bool
+}
+
+func (v NullableStatus) Get() *Status {
+ return v.value
+}
+
+func (v *NullableStatus) Set(val *Status) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableStatus) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableStatus) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableStatus(val *Status) *NullableStatus {
+ return &NullableStatus{value: val, isSet: true}
+}
+
+func (v NullableStatus) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableStatus) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_status_test.go b/pkg/postgresflexalpha/model_status_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_status_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_storage.go b/pkg/postgresflexalpha/model_storage.go
new file mode 100644
index 00000000..d3bddc55
--- /dev/null
+++ b/pkg/postgresflexalpha/model_storage.go
@@ -0,0 +1,177 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the Storage type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &Storage{}
+
+/*
+ types and functions for performanceClass
+*/
+
+// isNotNullableString
+type StorageGetPerformanceClassAttributeType = *string
+
+func getStorageGetPerformanceClassAttributeTypeOk(arg StorageGetPerformanceClassAttributeType) (ret StorageGetPerformanceClassRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setStorageGetPerformanceClassAttributeType(arg *StorageGetPerformanceClassAttributeType, val StorageGetPerformanceClassRetType) {
+ *arg = &val
+}
+
+type StorageGetPerformanceClassArgType = string
+type StorageGetPerformanceClassRetType = string
+
+/*
+ types and functions for size
+*/
+
+// isLong
+type StorageGetSizeAttributeType = *int64
+type StorageGetSizeArgType = int64
+type StorageGetSizeRetType = int64
+
+func getStorageGetSizeAttributeTypeOk(arg StorageGetSizeAttributeType) (ret StorageGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setStorageGetSizeAttributeType(arg *StorageGetSizeAttributeType, val StorageGetSizeRetType) {
+ *arg = &val
+}
+
+// Storage The object containing information about the storage size and class.
+type Storage struct {
+ // The storage class for the storage.
+ PerformanceClass StorageGetPerformanceClassAttributeType `json:"performanceClass,omitempty"`
+ // The storage size in Gigabytes.
+ Size StorageGetSizeAttributeType `json:"size,omitempty"`
+}
+
+// NewStorage instantiates a new Storage object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewStorage() *Storage {
+ this := Storage{}
+ return &this
+}
+
+// NewStorageWithDefaults instantiates a new Storage object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewStorageWithDefaults() *Storage {
+ this := Storage{}
+ return &this
+}
+
+// GetPerformanceClass returns the PerformanceClass field value if set, zero value otherwise.
+func (o *Storage) GetPerformanceClass() (res StorageGetPerformanceClassRetType) {
+ res, _ = o.GetPerformanceClassOk()
+ return
+}
+
+// GetPerformanceClassOk returns a tuple with the PerformanceClass field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *Storage) GetPerformanceClassOk() (ret StorageGetPerformanceClassRetType, ok bool) {
+ return getStorageGetPerformanceClassAttributeTypeOk(o.PerformanceClass)
+}
+
+// HasPerformanceClass returns a boolean if a field has been set.
+func (o *Storage) HasPerformanceClass() bool {
+ _, ok := o.GetPerformanceClassOk()
+ return ok
+}
+
+// SetPerformanceClass gets a reference to the given string and assigns it to the PerformanceClass field.
+func (o *Storage) SetPerformanceClass(v StorageGetPerformanceClassRetType) {
+ setStorageGetPerformanceClassAttributeType(&o.PerformanceClass, v)
+}
+
+// GetSize returns the Size field value if set, zero value otherwise.
+func (o *Storage) GetSize() (res StorageGetSizeRetType) {
+ res, _ = o.GetSizeOk()
+ return
+}
+
+// GetSizeOk returns a tuple with the Size field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *Storage) GetSizeOk() (ret StorageGetSizeRetType, ok bool) {
+ return getStorageGetSizeAttributeTypeOk(o.Size)
+}
+
+// HasSize returns a boolean if a field has been set.
+func (o *Storage) HasSize() bool {
+ _, ok := o.GetSizeOk()
+ return ok
+}
+
+// SetSize gets a reference to the given int64 and assigns it to the Size field.
+func (o *Storage) SetSize(v StorageGetSizeRetType) {
+ setStorageGetSizeAttributeType(&o.Size, v)
+}
+
+func (o Storage) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getStorageGetPerformanceClassAttributeTypeOk(o.PerformanceClass); ok {
+ toSerialize["PerformanceClass"] = val
+ }
+ if val, ok := getStorageGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableStorage struct {
+ value *Storage
+ isSet bool
+}
+
+func (v NullableStorage) Get() *Storage {
+ return v.value
+}
+
+func (v *NullableStorage) Set(val *Storage) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableStorage) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableStorage) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableStorage(val *Storage) *NullableStorage {
+ return &NullableStorage{value: val, isSet: true}
+}
+
+func (v NullableStorage) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableStorage) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_storage_create.go b/pkg/postgresflexalpha/model_storage_create.go
new file mode 100644
index 00000000..9654433c
--- /dev/null
+++ b/pkg/postgresflexalpha/model_storage_create.go
@@ -0,0 +1,171 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the StorageCreate type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &StorageCreate{}
+
+/*
+ types and functions for performanceClass
+*/
+
+// isNotNullableString
+type StorageCreateGetPerformanceClassAttributeType = *string
+
+func getStorageCreateGetPerformanceClassAttributeTypeOk(arg StorageCreateGetPerformanceClassAttributeType) (ret StorageCreateGetPerformanceClassRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setStorageCreateGetPerformanceClassAttributeType(arg *StorageCreateGetPerformanceClassAttributeType, val StorageCreateGetPerformanceClassRetType) {
+ *arg = &val
+}
+
+type StorageCreateGetPerformanceClassArgType = string
+type StorageCreateGetPerformanceClassRetType = string
+
+/*
+ types and functions for size
+*/
+
+// isLong
+type StorageCreateGetSizeAttributeType = *int64
+type StorageCreateGetSizeArgType = int64
+type StorageCreateGetSizeRetType = int64
+
+func getStorageCreateGetSizeAttributeTypeOk(arg StorageCreateGetSizeAttributeType) (ret StorageCreateGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setStorageCreateGetSizeAttributeType(arg *StorageCreateGetSizeAttributeType, val StorageCreateGetSizeRetType) {
+ *arg = &val
+}
+
+// StorageCreate The object containing information about the storage size and class.
+type StorageCreate struct {
+ // The storage class for the storage.
+ // REQUIRED
+ PerformanceClass StorageCreateGetPerformanceClassAttributeType `json:"performanceClass" required:"true"`
+ // The storage size in Gigabytes.
+ // REQUIRED
+ Size StorageCreateGetSizeAttributeType `json:"size" required:"true"`
+}
+
+type _StorageCreate StorageCreate
+
+// NewStorageCreate instantiates a new StorageCreate object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewStorageCreate(performanceClass StorageCreateGetPerformanceClassArgType, size StorageCreateGetSizeArgType) *StorageCreate {
+ this := StorageCreate{}
+ setStorageCreateGetPerformanceClassAttributeType(&this.PerformanceClass, performanceClass)
+ setStorageCreateGetSizeAttributeType(&this.Size, size)
+ return &this
+}
+
+// NewStorageCreateWithDefaults instantiates a new StorageCreate object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewStorageCreateWithDefaults() *StorageCreate {
+ this := StorageCreate{}
+ return &this
+}
+
+// GetPerformanceClass returns the PerformanceClass field value
+func (o *StorageCreate) GetPerformanceClass() (ret StorageCreateGetPerformanceClassRetType) {
+ ret, _ = o.GetPerformanceClassOk()
+ return ret
+}
+
+// GetPerformanceClassOk returns a tuple with the PerformanceClass field value
+// and a boolean to check if the value has been set.
+func (o *StorageCreate) GetPerformanceClassOk() (ret StorageCreateGetPerformanceClassRetType, ok bool) {
+ return getStorageCreateGetPerformanceClassAttributeTypeOk(o.PerformanceClass)
+}
+
+// SetPerformanceClass sets field value
+func (o *StorageCreate) SetPerformanceClass(v StorageCreateGetPerformanceClassRetType) {
+ setStorageCreateGetPerformanceClassAttributeType(&o.PerformanceClass, v)
+}
+
+// GetSize returns the Size field value
+func (o *StorageCreate) GetSize() (ret StorageCreateGetSizeRetType) {
+ ret, _ = o.GetSizeOk()
+ return ret
+}
+
+// GetSizeOk returns a tuple with the Size field value
+// and a boolean to check if the value has been set.
+func (o *StorageCreate) GetSizeOk() (ret StorageCreateGetSizeRetType, ok bool) {
+ return getStorageCreateGetSizeAttributeTypeOk(o.Size)
+}
+
+// SetSize sets field value
+func (o *StorageCreate) SetSize(v StorageCreateGetSizeRetType) {
+ setStorageCreateGetSizeAttributeType(&o.Size, v)
+}
+
+func (o StorageCreate) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getStorageCreateGetPerformanceClassAttributeTypeOk(o.PerformanceClass); ok {
+ toSerialize["PerformanceClass"] = val
+ }
+ if val, ok := getStorageCreateGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableStorageCreate struct {
+ value *StorageCreate
+ isSet bool
+}
+
+func (v NullableStorageCreate) Get() *StorageCreate {
+ return v.value
+}
+
+func (v *NullableStorageCreate) Set(val *StorageCreate) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableStorageCreate) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableStorageCreate) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableStorageCreate(val *StorageCreate) *NullableStorageCreate {
+ return &NullableStorageCreate{value: val, isSet: true}
+}
+
+func (v NullableStorageCreate) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableStorageCreate) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_storage_create_test.go b/pkg/postgresflexalpha/model_storage_create_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_storage_create_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_storage_test.go b/pkg/postgresflexalpha/model_storage_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_storage_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_storage_update.go b/pkg/postgresflexalpha/model_storage_update.go
new file mode 100644
index 00000000..17496289
--- /dev/null
+++ b/pkg/postgresflexalpha/model_storage_update.go
@@ -0,0 +1,128 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the StorageUpdate type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &StorageUpdate{}
+
+/*
+ types and functions for size
+*/
+
+// isLong
+type StorageUpdateGetSizeAttributeType = *int64
+type StorageUpdateGetSizeArgType = int64
+type StorageUpdateGetSizeRetType = int64
+
+func getStorageUpdateGetSizeAttributeTypeOk(arg StorageUpdateGetSizeAttributeType) (ret StorageUpdateGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setStorageUpdateGetSizeAttributeType(arg *StorageUpdateGetSizeAttributeType, val StorageUpdateGetSizeRetType) {
+ *arg = &val
+}
+
+// StorageUpdate The object containing information about the storage size and class.
+type StorageUpdate struct {
+ // The storage size in Gigabytes.
+ Size StorageUpdateGetSizeAttributeType `json:"size,omitempty"`
+}
+
+// NewStorageUpdate instantiates a new StorageUpdate object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewStorageUpdate() *StorageUpdate {
+ this := StorageUpdate{}
+ return &this
+}
+
+// NewStorageUpdateWithDefaults instantiates a new StorageUpdate object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewStorageUpdateWithDefaults() *StorageUpdate {
+ this := StorageUpdate{}
+ return &this
+}
+
+// GetSize returns the Size field value if set, zero value otherwise.
+func (o *StorageUpdate) GetSize() (res StorageUpdateGetSizeRetType) {
+ res, _ = o.GetSizeOk()
+ return
+}
+
+// GetSizeOk returns a tuple with the Size field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *StorageUpdate) GetSizeOk() (ret StorageUpdateGetSizeRetType, ok bool) {
+ return getStorageUpdateGetSizeAttributeTypeOk(o.Size)
+}
+
+// HasSize returns a boolean if a field has been set.
+func (o *StorageUpdate) HasSize() bool {
+ _, ok := o.GetSizeOk()
+ return ok
+}
+
+// SetSize gets a reference to the given int64 and assigns it to the Size field.
+func (o *StorageUpdate) SetSize(v StorageUpdateGetSizeRetType) {
+ setStorageUpdateGetSizeAttributeType(&o.Size, v)
+}
+
+func (o StorageUpdate) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getStorageUpdateGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableStorageUpdate struct {
+ value *StorageUpdate
+ isSet bool
+}
+
+func (v NullableStorageUpdate) Get() *StorageUpdate {
+ return v.value
+}
+
+func (v *NullableStorageUpdate) Set(val *StorageUpdate) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableStorageUpdate) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableStorageUpdate) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableStorageUpdate(val *StorageUpdate) *NullableStorageUpdate {
+ return &NullableStorageUpdate{value: val, isSet: true}
+}
+
+func (v NullableStorageUpdate) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableStorageUpdate) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_storage_update_test.go b/pkg/postgresflexalpha/model_storage_update_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_storage_update_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_update_database_partially_request_payload.go b/pkg/postgresflexalpha/model_update_database_partially_request_payload.go
new file mode 100644
index 00000000..883e4f6b
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_database_partially_request_payload.go
@@ -0,0 +1,178 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the UpdateDatabasePartiallyRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &UpdateDatabasePartiallyRequestPayload{}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type UpdateDatabasePartiallyRequestPayloadGetNameAttributeType = *string
+
+func getUpdateDatabasePartiallyRequestPayloadGetNameAttributeTypeOk(arg UpdateDatabasePartiallyRequestPayloadGetNameAttributeType) (ret UpdateDatabasePartiallyRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateDatabasePartiallyRequestPayloadGetNameAttributeType(arg *UpdateDatabasePartiallyRequestPayloadGetNameAttributeType, val UpdateDatabasePartiallyRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type UpdateDatabasePartiallyRequestPayloadGetNameArgType = string
+type UpdateDatabasePartiallyRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for owner
+*/
+
+// isNotNullableString
+type UpdateDatabasePartiallyRequestPayloadGetOwnerAttributeType = *string
+
+func getUpdateDatabasePartiallyRequestPayloadGetOwnerAttributeTypeOk(arg UpdateDatabasePartiallyRequestPayloadGetOwnerAttributeType) (ret UpdateDatabasePartiallyRequestPayloadGetOwnerRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateDatabasePartiallyRequestPayloadGetOwnerAttributeType(arg *UpdateDatabasePartiallyRequestPayloadGetOwnerAttributeType, val UpdateDatabasePartiallyRequestPayloadGetOwnerRetType) {
+ *arg = &val
+}
+
+type UpdateDatabasePartiallyRequestPayloadGetOwnerArgType = string
+type UpdateDatabasePartiallyRequestPayloadGetOwnerRetType = string
+
+// UpdateDatabasePartiallyRequestPayload struct for UpdateDatabasePartiallyRequestPayload
+type UpdateDatabasePartiallyRequestPayload struct {
+ // The name of the database.
+ Name UpdateDatabasePartiallyRequestPayloadGetNameAttributeType `json:"name,omitempty"`
+ // The owner of the database.
+ Owner UpdateDatabasePartiallyRequestPayloadGetOwnerAttributeType `json:"owner,omitempty"`
+}
+
+// NewUpdateDatabasePartiallyRequestPayload instantiates a new UpdateDatabasePartiallyRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewUpdateDatabasePartiallyRequestPayload() *UpdateDatabasePartiallyRequestPayload {
+ this := UpdateDatabasePartiallyRequestPayload{}
+ return &this
+}
+
+// NewUpdateDatabasePartiallyRequestPayloadWithDefaults instantiates a new UpdateDatabasePartiallyRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewUpdateDatabasePartiallyRequestPayloadWithDefaults() *UpdateDatabasePartiallyRequestPayload {
+ this := UpdateDatabasePartiallyRequestPayload{}
+ return &this
+}
+
+// GetName returns the Name field value if set, zero value otherwise.
+func (o *UpdateDatabasePartiallyRequestPayload) GetName() (res UpdateDatabasePartiallyRequestPayloadGetNameRetType) {
+ res, _ = o.GetNameOk()
+ return
+}
+
+// GetNameOk returns a tuple with the Name field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateDatabasePartiallyRequestPayload) GetNameOk() (ret UpdateDatabasePartiallyRequestPayloadGetNameRetType, ok bool) {
+ return getUpdateDatabasePartiallyRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// HasName returns a boolean if a field has been set.
+func (o *UpdateDatabasePartiallyRequestPayload) HasName() bool {
+ _, ok := o.GetNameOk()
+ return ok
+}
+
+// SetName gets a reference to the given string and assigns it to the Name field.
+func (o *UpdateDatabasePartiallyRequestPayload) SetName(v UpdateDatabasePartiallyRequestPayloadGetNameRetType) {
+ setUpdateDatabasePartiallyRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetOwner returns the Owner field value if set, zero value otherwise.
+func (o *UpdateDatabasePartiallyRequestPayload) GetOwner() (res UpdateDatabasePartiallyRequestPayloadGetOwnerRetType) {
+ res, _ = o.GetOwnerOk()
+ return
+}
+
+// GetOwnerOk returns a tuple with the Owner field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateDatabasePartiallyRequestPayload) GetOwnerOk() (ret UpdateDatabasePartiallyRequestPayloadGetOwnerRetType, ok bool) {
+ return getUpdateDatabasePartiallyRequestPayloadGetOwnerAttributeTypeOk(o.Owner)
+}
+
+// HasOwner returns a boolean if a field has been set.
+func (o *UpdateDatabasePartiallyRequestPayload) HasOwner() bool {
+ _, ok := o.GetOwnerOk()
+ return ok
+}
+
+// SetOwner gets a reference to the given string and assigns it to the Owner field.
+func (o *UpdateDatabasePartiallyRequestPayload) SetOwner(v UpdateDatabasePartiallyRequestPayloadGetOwnerRetType) {
+ setUpdateDatabasePartiallyRequestPayloadGetOwnerAttributeType(&o.Owner, v)
+}
+
+func (o UpdateDatabasePartiallyRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getUpdateDatabasePartiallyRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getUpdateDatabasePartiallyRequestPayloadGetOwnerAttributeTypeOk(o.Owner); ok {
+ toSerialize["Owner"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableUpdateDatabasePartiallyRequestPayload struct {
+ value *UpdateDatabasePartiallyRequestPayload
+ isSet bool
+}
+
+func (v NullableUpdateDatabasePartiallyRequestPayload) Get() *UpdateDatabasePartiallyRequestPayload {
+ return v.value
+}
+
+func (v *NullableUpdateDatabasePartiallyRequestPayload) Set(val *UpdateDatabasePartiallyRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUpdateDatabasePartiallyRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUpdateDatabasePartiallyRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUpdateDatabasePartiallyRequestPayload(val *UpdateDatabasePartiallyRequestPayload) *NullableUpdateDatabasePartiallyRequestPayload {
+ return &NullableUpdateDatabasePartiallyRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableUpdateDatabasePartiallyRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUpdateDatabasePartiallyRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_update_database_partially_request_payload_test.go b/pkg/postgresflexalpha/model_update_database_partially_request_payload_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_database_partially_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_update_database_partially_response.go b/pkg/postgresflexalpha/model_update_database_partially_response.go
new file mode 100644
index 00000000..f689dec8
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_database_partially_response.go
@@ -0,0 +1,125 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the UpdateDatabasePartiallyResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &UpdateDatabasePartiallyResponse{}
+
+/*
+ types and functions for database
+*/
+
+// isModel
+type UpdateDatabasePartiallyResponseGetDatabaseAttributeType = *ListDatabase
+type UpdateDatabasePartiallyResponseGetDatabaseArgType = ListDatabase
+type UpdateDatabasePartiallyResponseGetDatabaseRetType = ListDatabase
+
+func getUpdateDatabasePartiallyResponseGetDatabaseAttributeTypeOk(arg UpdateDatabasePartiallyResponseGetDatabaseAttributeType) (ret UpdateDatabasePartiallyResponseGetDatabaseRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateDatabasePartiallyResponseGetDatabaseAttributeType(arg *UpdateDatabasePartiallyResponseGetDatabaseAttributeType, val UpdateDatabasePartiallyResponseGetDatabaseRetType) {
+ *arg = &val
+}
+
+// UpdateDatabasePartiallyResponse struct for UpdateDatabasePartiallyResponse
+type UpdateDatabasePartiallyResponse struct {
+ // REQUIRED
+ Database UpdateDatabasePartiallyResponseGetDatabaseAttributeType `json:"database" required:"true"`
+}
+
+type _UpdateDatabasePartiallyResponse UpdateDatabasePartiallyResponse
+
+// NewUpdateDatabasePartiallyResponse instantiates a new UpdateDatabasePartiallyResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewUpdateDatabasePartiallyResponse(database UpdateDatabasePartiallyResponseGetDatabaseArgType) *UpdateDatabasePartiallyResponse {
+ this := UpdateDatabasePartiallyResponse{}
+ setUpdateDatabasePartiallyResponseGetDatabaseAttributeType(&this.Database, database)
+ return &this
+}
+
+// NewUpdateDatabasePartiallyResponseWithDefaults instantiates a new UpdateDatabasePartiallyResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewUpdateDatabasePartiallyResponseWithDefaults() *UpdateDatabasePartiallyResponse {
+ this := UpdateDatabasePartiallyResponse{}
+ return &this
+}
+
+// GetDatabase returns the Database field value
+func (o *UpdateDatabasePartiallyResponse) GetDatabase() (ret UpdateDatabasePartiallyResponseGetDatabaseRetType) {
+ ret, _ = o.GetDatabaseOk()
+ return ret
+}
+
+// GetDatabaseOk returns a tuple with the Database field value
+// and a boolean to check if the value has been set.
+func (o *UpdateDatabasePartiallyResponse) GetDatabaseOk() (ret UpdateDatabasePartiallyResponseGetDatabaseRetType, ok bool) {
+ return getUpdateDatabasePartiallyResponseGetDatabaseAttributeTypeOk(o.Database)
+}
+
+// SetDatabase sets field value
+func (o *UpdateDatabasePartiallyResponse) SetDatabase(v UpdateDatabasePartiallyResponseGetDatabaseRetType) {
+ setUpdateDatabasePartiallyResponseGetDatabaseAttributeType(&o.Database, v)
+}
+
+func (o UpdateDatabasePartiallyResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getUpdateDatabasePartiallyResponseGetDatabaseAttributeTypeOk(o.Database); ok {
+ toSerialize["Database"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableUpdateDatabasePartiallyResponse struct {
+ value *UpdateDatabasePartiallyResponse
+ isSet bool
+}
+
+func (v NullableUpdateDatabasePartiallyResponse) Get() *UpdateDatabasePartiallyResponse {
+ return v.value
+}
+
+func (v *NullableUpdateDatabasePartiallyResponse) Set(val *UpdateDatabasePartiallyResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUpdateDatabasePartiallyResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUpdateDatabasePartiallyResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUpdateDatabasePartiallyResponse(val *UpdateDatabasePartiallyResponse) *NullableUpdateDatabasePartiallyResponse {
+ return &NullableUpdateDatabasePartiallyResponse{value: val, isSet: true}
+}
+
+func (v NullableUpdateDatabasePartiallyResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUpdateDatabasePartiallyResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_update_database_partially_response_test.go b/pkg/postgresflexalpha/model_update_database_partially_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_database_partially_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_update_database_request_payload.go b/pkg/postgresflexalpha/model_update_database_request_payload.go
new file mode 100644
index 00000000..ef00ac4e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_database_request_payload.go
@@ -0,0 +1,172 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the UpdateDatabaseRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &UpdateDatabaseRequestPayload{}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type UpdateDatabaseRequestPayloadGetNameAttributeType = *string
+
+func getUpdateDatabaseRequestPayloadGetNameAttributeTypeOk(arg UpdateDatabaseRequestPayloadGetNameAttributeType) (ret UpdateDatabaseRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateDatabaseRequestPayloadGetNameAttributeType(arg *UpdateDatabaseRequestPayloadGetNameAttributeType, val UpdateDatabaseRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type UpdateDatabaseRequestPayloadGetNameArgType = string
+type UpdateDatabaseRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for owner
+*/
+
+// isNotNullableString
+type UpdateDatabaseRequestPayloadGetOwnerAttributeType = *string
+
+func getUpdateDatabaseRequestPayloadGetOwnerAttributeTypeOk(arg UpdateDatabaseRequestPayloadGetOwnerAttributeType) (ret UpdateDatabaseRequestPayloadGetOwnerRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateDatabaseRequestPayloadGetOwnerAttributeType(arg *UpdateDatabaseRequestPayloadGetOwnerAttributeType, val UpdateDatabaseRequestPayloadGetOwnerRetType) {
+ *arg = &val
+}
+
+type UpdateDatabaseRequestPayloadGetOwnerArgType = string
+type UpdateDatabaseRequestPayloadGetOwnerRetType = string
+
+// UpdateDatabaseRequestPayload struct for UpdateDatabaseRequestPayload
+type UpdateDatabaseRequestPayload struct {
+ // The name of the database.
+ // REQUIRED
+ Name UpdateDatabaseRequestPayloadGetNameAttributeType `json:"name" required:"true"`
+ // The owner of the database.
+ // REQUIRED
+ Owner UpdateDatabaseRequestPayloadGetOwnerAttributeType `json:"owner" required:"true"`
+}
+
+type _UpdateDatabaseRequestPayload UpdateDatabaseRequestPayload
+
+// NewUpdateDatabaseRequestPayload instantiates a new UpdateDatabaseRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewUpdateDatabaseRequestPayload(name UpdateDatabaseRequestPayloadGetNameArgType, owner UpdateDatabaseRequestPayloadGetOwnerArgType) *UpdateDatabaseRequestPayload {
+ this := UpdateDatabaseRequestPayload{}
+ setUpdateDatabaseRequestPayloadGetNameAttributeType(&this.Name, name)
+ setUpdateDatabaseRequestPayloadGetOwnerAttributeType(&this.Owner, owner)
+ return &this
+}
+
+// NewUpdateDatabaseRequestPayloadWithDefaults instantiates a new UpdateDatabaseRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewUpdateDatabaseRequestPayloadWithDefaults() *UpdateDatabaseRequestPayload {
+ this := UpdateDatabaseRequestPayload{}
+ return &this
+}
+
+// GetName returns the Name field value
+func (o *UpdateDatabaseRequestPayload) GetName() (ret UpdateDatabaseRequestPayloadGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *UpdateDatabaseRequestPayload) GetNameOk() (ret UpdateDatabaseRequestPayloadGetNameRetType, ok bool) {
+ return getUpdateDatabaseRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *UpdateDatabaseRequestPayload) SetName(v UpdateDatabaseRequestPayloadGetNameRetType) {
+ setUpdateDatabaseRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetOwner returns the Owner field value
+func (o *UpdateDatabaseRequestPayload) GetOwner() (ret UpdateDatabaseRequestPayloadGetOwnerRetType) {
+ ret, _ = o.GetOwnerOk()
+ return ret
+}
+
+// GetOwnerOk returns a tuple with the Owner field value
+// and a boolean to check if the value has been set.
+func (o *UpdateDatabaseRequestPayload) GetOwnerOk() (ret UpdateDatabaseRequestPayloadGetOwnerRetType, ok bool) {
+ return getUpdateDatabaseRequestPayloadGetOwnerAttributeTypeOk(o.Owner)
+}
+
+// SetOwner sets field value
+func (o *UpdateDatabaseRequestPayload) SetOwner(v UpdateDatabaseRequestPayloadGetOwnerRetType) {
+ setUpdateDatabaseRequestPayloadGetOwnerAttributeType(&o.Owner, v)
+}
+
+func (o UpdateDatabaseRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getUpdateDatabaseRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getUpdateDatabaseRequestPayloadGetOwnerAttributeTypeOk(o.Owner); ok {
+ toSerialize["Owner"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableUpdateDatabaseRequestPayload struct {
+ value *UpdateDatabaseRequestPayload
+ isSet bool
+}
+
+func (v NullableUpdateDatabaseRequestPayload) Get() *UpdateDatabaseRequestPayload {
+ return v.value
+}
+
+func (v *NullableUpdateDatabaseRequestPayload) Set(val *UpdateDatabaseRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUpdateDatabaseRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUpdateDatabaseRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUpdateDatabaseRequestPayload(val *UpdateDatabaseRequestPayload) *NullableUpdateDatabaseRequestPayload {
+ return &NullableUpdateDatabaseRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableUpdateDatabaseRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUpdateDatabaseRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_update_database_request_payload_test.go b/pkg/postgresflexalpha/model_update_database_request_payload_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_database_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_update_database_response.go b/pkg/postgresflexalpha/model_update_database_response.go
new file mode 100644
index 00000000..b875b677
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_database_response.go
@@ -0,0 +1,125 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the UpdateDatabaseResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &UpdateDatabaseResponse{}
+
+/*
+ types and functions for database
+*/
+
+// isModel
+type UpdateDatabaseResponseGetDatabaseAttributeType = *ListDatabase
+type UpdateDatabaseResponseGetDatabaseArgType = ListDatabase
+type UpdateDatabaseResponseGetDatabaseRetType = ListDatabase
+
+func getUpdateDatabaseResponseGetDatabaseAttributeTypeOk(arg UpdateDatabaseResponseGetDatabaseAttributeType) (ret UpdateDatabaseResponseGetDatabaseRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateDatabaseResponseGetDatabaseAttributeType(arg *UpdateDatabaseResponseGetDatabaseAttributeType, val UpdateDatabaseResponseGetDatabaseRetType) {
+ *arg = &val
+}
+
+// UpdateDatabaseResponse struct for UpdateDatabaseResponse
+type UpdateDatabaseResponse struct {
+ // REQUIRED
+ Database UpdateDatabaseResponseGetDatabaseAttributeType `json:"database" required:"true"`
+}
+
+type _UpdateDatabaseResponse UpdateDatabaseResponse
+
+// NewUpdateDatabaseResponse instantiates a new UpdateDatabaseResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewUpdateDatabaseResponse(database UpdateDatabaseResponseGetDatabaseArgType) *UpdateDatabaseResponse {
+ this := UpdateDatabaseResponse{}
+ setUpdateDatabaseResponseGetDatabaseAttributeType(&this.Database, database)
+ return &this
+}
+
+// NewUpdateDatabaseResponseWithDefaults instantiates a new UpdateDatabaseResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewUpdateDatabaseResponseWithDefaults() *UpdateDatabaseResponse {
+ this := UpdateDatabaseResponse{}
+ return &this
+}
+
+// GetDatabase returns the Database field value
+func (o *UpdateDatabaseResponse) GetDatabase() (ret UpdateDatabaseResponseGetDatabaseRetType) {
+ ret, _ = o.GetDatabaseOk()
+ return ret
+}
+
+// GetDatabaseOk returns a tuple with the Database field value
+// and a boolean to check if the value has been set.
+func (o *UpdateDatabaseResponse) GetDatabaseOk() (ret UpdateDatabaseResponseGetDatabaseRetType, ok bool) {
+ return getUpdateDatabaseResponseGetDatabaseAttributeTypeOk(o.Database)
+}
+
+// SetDatabase sets field value
+func (o *UpdateDatabaseResponse) SetDatabase(v UpdateDatabaseResponseGetDatabaseRetType) {
+ setUpdateDatabaseResponseGetDatabaseAttributeType(&o.Database, v)
+}
+
+func (o UpdateDatabaseResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getUpdateDatabaseResponseGetDatabaseAttributeTypeOk(o.Database); ok {
+ toSerialize["Database"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableUpdateDatabaseResponse struct {
+ value *UpdateDatabaseResponse
+ isSet bool
+}
+
+func (v NullableUpdateDatabaseResponse) Get() *UpdateDatabaseResponse {
+ return v.value
+}
+
+func (v *NullableUpdateDatabaseResponse) Set(val *UpdateDatabaseResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUpdateDatabaseResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUpdateDatabaseResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUpdateDatabaseResponse(val *UpdateDatabaseResponse) *NullableUpdateDatabaseResponse {
+ return &NullableUpdateDatabaseResponse{value: val, isSet: true}
+}
+
+func (v NullableUpdateDatabaseResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUpdateDatabaseResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_update_database_response_test.go b/pkg/postgresflexalpha/model_update_database_response_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_database_response_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_update_instance_partially_request_payload.go b/pkg/postgresflexalpha/model_update_instance_partially_request_payload.go
new file mode 100644
index 00000000..e1f2924a
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_instance_partially_request_payload.go
@@ -0,0 +1,467 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the UpdateInstancePartiallyRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &UpdateInstancePartiallyRequestPayload{}
+
+/*
+ types and functions for acl
+*/
+
+// isArray
+type UpdateInstancePartiallyRequestPayloadGetAclAttributeType = *[]string
+type UpdateInstancePartiallyRequestPayloadGetAclArgType = []string
+type UpdateInstancePartiallyRequestPayloadGetAclRetType = []string
+
+func getUpdateInstancePartiallyRequestPayloadGetAclAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetAclAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetAclRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetAclAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetAclAttributeType, val UpdateInstancePartiallyRequestPayloadGetAclRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for backupSchedule
+*/
+
+// isNotNullableString
+type UpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeType = *string
+
+func getUpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetBackupScheduleRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeType, val UpdateInstancePartiallyRequestPayloadGetBackupScheduleRetType) {
+ *arg = &val
+}
+
+type UpdateInstancePartiallyRequestPayloadGetBackupScheduleArgType = string
+type UpdateInstancePartiallyRequestPayloadGetBackupScheduleRetType = string
+
+/*
+ types and functions for flavorId
+*/
+
+// isNotNullableString
+type UpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeType = *string
+
+func getUpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetFlavorIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeType, val UpdateInstancePartiallyRequestPayloadGetFlavorIdRetType) {
+ *arg = &val
+}
+
+type UpdateInstancePartiallyRequestPayloadGetFlavorIdArgType = string
+type UpdateInstancePartiallyRequestPayloadGetFlavorIdRetType = string
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type UpdateInstancePartiallyRequestPayloadGetNameAttributeType = *string
+
+func getUpdateInstancePartiallyRequestPayloadGetNameAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetNameAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetNameAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetNameAttributeType, val UpdateInstancePartiallyRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type UpdateInstancePartiallyRequestPayloadGetNameArgType = string
+type UpdateInstancePartiallyRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for replicas
+*/
+
+// isEnumRef
+type UpdateInstancePartiallyRequestPayloadGetReplicasAttributeType = *ReplicasOpt
+type UpdateInstancePartiallyRequestPayloadGetReplicasArgType = ReplicasOpt
+type UpdateInstancePartiallyRequestPayloadGetReplicasRetType = ReplicasOpt
+
+func getUpdateInstancePartiallyRequestPayloadGetReplicasAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetReplicasAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetReplicasRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetReplicasAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetReplicasAttributeType, val UpdateInstancePartiallyRequestPayloadGetReplicasRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for retentionDays
+*/
+
+// isInteger
+type UpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeType = *int64
+type UpdateInstancePartiallyRequestPayloadGetRetentionDaysArgType = int64
+type UpdateInstancePartiallyRequestPayloadGetRetentionDaysRetType = int64
+
+func getUpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetRetentionDaysRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeType, val UpdateInstancePartiallyRequestPayloadGetRetentionDaysRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for storage
+*/
+
+// isModel
+type UpdateInstancePartiallyRequestPayloadGetStorageAttributeType = *StorageUpdate
+type UpdateInstancePartiallyRequestPayloadGetStorageArgType = StorageUpdate
+type UpdateInstancePartiallyRequestPayloadGetStorageRetType = StorageUpdate
+
+func getUpdateInstancePartiallyRequestPayloadGetStorageAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetStorageAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetStorageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetStorageAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetStorageAttributeType, val UpdateInstancePartiallyRequestPayloadGetStorageRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for version
+*/
+
+// isNotNullableString
+type UpdateInstancePartiallyRequestPayloadGetVersionAttributeType = *string
+
+func getUpdateInstancePartiallyRequestPayloadGetVersionAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetVersionAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetVersionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetVersionAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetVersionAttributeType, val UpdateInstancePartiallyRequestPayloadGetVersionRetType) {
+ *arg = &val
+}
+
+type UpdateInstancePartiallyRequestPayloadGetVersionArgType = string
+type UpdateInstancePartiallyRequestPayloadGetVersionRetType = string
+
+// UpdateInstancePartiallyRequestPayload struct for UpdateInstancePartiallyRequestPayload
+type UpdateInstancePartiallyRequestPayload struct {
+ // List of IPV4 cidr.
+ Acl UpdateInstancePartiallyRequestPayloadGetAclAttributeType `json:"acl,omitempty"`
+ // The schedule for on what time and how often the database backup will be created. The schedule is written as a cron schedule.
+ BackupSchedule UpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeType `json:"backupSchedule,omitempty"`
+ // The id of the instance flavor.
+ FlavorId UpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeType `json:"flavorId,omitempty"`
+ // The name of the instance.
+ Name UpdateInstancePartiallyRequestPayloadGetNameAttributeType `json:"name,omitempty"`
+ Replicas UpdateInstancePartiallyRequestPayloadGetReplicasAttributeType `json:"replicas,omitempty"`
+ // How long backups are retained. The value can only be between 32 and 365 days.
+ // Can be cast to int32 without loss of precision.
+ RetentionDays UpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeType `json:"retentionDays,omitempty"`
+ Storage UpdateInstancePartiallyRequestPayloadGetStorageAttributeType `json:"storage,omitempty"`
+ // The Postgres version used for the instance. See [Versions Endpoint](/documentation/postgres-flex-service/version/v3alpha1#tag/Version) for supported version parameters.
+ Version UpdateInstancePartiallyRequestPayloadGetVersionAttributeType `json:"version,omitempty"`
+}
+
+// NewUpdateInstancePartiallyRequestPayload instantiates a new UpdateInstancePartiallyRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewUpdateInstancePartiallyRequestPayload() *UpdateInstancePartiallyRequestPayload {
+ this := UpdateInstancePartiallyRequestPayload{}
+ return &this
+}
+
+// NewUpdateInstancePartiallyRequestPayloadWithDefaults instantiates a new UpdateInstancePartiallyRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewUpdateInstancePartiallyRequestPayloadWithDefaults() *UpdateInstancePartiallyRequestPayload {
+ this := UpdateInstancePartiallyRequestPayload{}
+ return &this
+}
+
+// GetAcl returns the Acl field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetAcl() (res UpdateInstancePartiallyRequestPayloadGetAclRetType) {
+ res, _ = o.GetAclOk()
+ return
+}
+
+// GetAclOk returns a tuple with the Acl field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetAclOk() (ret UpdateInstancePartiallyRequestPayloadGetAclRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetAclAttributeTypeOk(o.Acl)
+}
+
+// HasAcl returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasAcl() bool {
+ _, ok := o.GetAclOk()
+ return ok
+}
+
+// SetAcl gets a reference to the given []string and assigns it to the Acl field.
+func (o *UpdateInstancePartiallyRequestPayload) SetAcl(v UpdateInstancePartiallyRequestPayloadGetAclRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetAclAttributeType(&o.Acl, v)
+}
+
+// GetBackupSchedule returns the BackupSchedule field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetBackupSchedule() (res UpdateInstancePartiallyRequestPayloadGetBackupScheduleRetType) {
+ res, _ = o.GetBackupScheduleOk()
+ return
+}
+
+// GetBackupScheduleOk returns a tuple with the BackupSchedule field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetBackupScheduleOk() (ret UpdateInstancePartiallyRequestPayloadGetBackupScheduleRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeTypeOk(o.BackupSchedule)
+}
+
+// HasBackupSchedule returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasBackupSchedule() bool {
+ _, ok := o.GetBackupScheduleOk()
+ return ok
+}
+
+// SetBackupSchedule gets a reference to the given string and assigns it to the BackupSchedule field.
+func (o *UpdateInstancePartiallyRequestPayload) SetBackupSchedule(v UpdateInstancePartiallyRequestPayloadGetBackupScheduleRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeType(&o.BackupSchedule, v)
+}
+
+// GetFlavorId returns the FlavorId field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetFlavorId() (res UpdateInstancePartiallyRequestPayloadGetFlavorIdRetType) {
+ res, _ = o.GetFlavorIdOk()
+ return
+}
+
+// GetFlavorIdOk returns a tuple with the FlavorId field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetFlavorIdOk() (ret UpdateInstancePartiallyRequestPayloadGetFlavorIdRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeTypeOk(o.FlavorId)
+}
+
+// HasFlavorId returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasFlavorId() bool {
+ _, ok := o.GetFlavorIdOk()
+ return ok
+}
+
+// SetFlavorId gets a reference to the given string and assigns it to the FlavorId field.
+func (o *UpdateInstancePartiallyRequestPayload) SetFlavorId(v UpdateInstancePartiallyRequestPayloadGetFlavorIdRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeType(&o.FlavorId, v)
+}
+
+// GetName returns the Name field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetName() (res UpdateInstancePartiallyRequestPayloadGetNameRetType) {
+ res, _ = o.GetNameOk()
+ return
+}
+
+// GetNameOk returns a tuple with the Name field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetNameOk() (ret UpdateInstancePartiallyRequestPayloadGetNameRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// HasName returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasName() bool {
+ _, ok := o.GetNameOk()
+ return ok
+}
+
+// SetName gets a reference to the given string and assigns it to the Name field.
+func (o *UpdateInstancePartiallyRequestPayload) SetName(v UpdateInstancePartiallyRequestPayloadGetNameRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetReplicas returns the Replicas field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetReplicas() (res UpdateInstancePartiallyRequestPayloadGetReplicasRetType) {
+ res, _ = o.GetReplicasOk()
+ return
+}
+
+// GetReplicasOk returns a tuple with the Replicas field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetReplicasOk() (ret UpdateInstancePartiallyRequestPayloadGetReplicasRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetReplicasAttributeTypeOk(o.Replicas)
+}
+
+// HasReplicas returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasReplicas() bool {
+ _, ok := o.GetReplicasOk()
+ return ok
+}
+
+// SetReplicas gets a reference to the given ReplicasOpt and assigns it to the Replicas field.
+func (o *UpdateInstancePartiallyRequestPayload) SetReplicas(v UpdateInstancePartiallyRequestPayloadGetReplicasRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetReplicasAttributeType(&o.Replicas, v)
+}
+
+// GetRetentionDays returns the RetentionDays field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetRetentionDays() (res UpdateInstancePartiallyRequestPayloadGetRetentionDaysRetType) {
+ res, _ = o.GetRetentionDaysOk()
+ return
+}
+
+// GetRetentionDaysOk returns a tuple with the RetentionDays field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetRetentionDaysOk() (ret UpdateInstancePartiallyRequestPayloadGetRetentionDaysRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeTypeOk(o.RetentionDays)
+}
+
+// HasRetentionDays returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasRetentionDays() bool {
+ _, ok := o.GetRetentionDaysOk()
+ return ok
+}
+
+// SetRetentionDays gets a reference to the given int64 and assigns it to the RetentionDays field.
+func (o *UpdateInstancePartiallyRequestPayload) SetRetentionDays(v UpdateInstancePartiallyRequestPayloadGetRetentionDaysRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeType(&o.RetentionDays, v)
+}
+
+// GetStorage returns the Storage field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetStorage() (res UpdateInstancePartiallyRequestPayloadGetStorageRetType) {
+ res, _ = o.GetStorageOk()
+ return
+}
+
+// GetStorageOk returns a tuple with the Storage field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetStorageOk() (ret UpdateInstancePartiallyRequestPayloadGetStorageRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetStorageAttributeTypeOk(o.Storage)
+}
+
+// HasStorage returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasStorage() bool {
+ _, ok := o.GetStorageOk()
+ return ok
+}
+
+// SetStorage gets a reference to the given StorageUpdate and assigns it to the Storage field.
+func (o *UpdateInstancePartiallyRequestPayload) SetStorage(v UpdateInstancePartiallyRequestPayloadGetStorageRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetStorageAttributeType(&o.Storage, v)
+}
+
+// GetVersion returns the Version field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetVersion() (res UpdateInstancePartiallyRequestPayloadGetVersionRetType) {
+ res, _ = o.GetVersionOk()
+ return
+}
+
+// GetVersionOk returns a tuple with the Version field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetVersionOk() (ret UpdateInstancePartiallyRequestPayloadGetVersionRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetVersionAttributeTypeOk(o.Version)
+}
+
+// HasVersion returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasVersion() bool {
+ _, ok := o.GetVersionOk()
+ return ok
+}
+
+// SetVersion gets a reference to the given string and assigns it to the Version field.
+func (o *UpdateInstancePartiallyRequestPayload) SetVersion(v UpdateInstancePartiallyRequestPayloadGetVersionRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetVersionAttributeType(&o.Version, v)
+}
+
+func (o UpdateInstancePartiallyRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetAclAttributeTypeOk(o.Acl); ok {
+ toSerialize["Acl"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeTypeOk(o.BackupSchedule); ok {
+ toSerialize["BackupSchedule"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeTypeOk(o.FlavorId); ok {
+ toSerialize["FlavorId"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetReplicasAttributeTypeOk(o.Replicas); ok {
+ toSerialize["Replicas"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeTypeOk(o.RetentionDays); ok {
+ toSerialize["RetentionDays"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetStorageAttributeTypeOk(o.Storage); ok {
+ toSerialize["Storage"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetVersionAttributeTypeOk(o.Version); ok {
+ toSerialize["Version"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableUpdateInstancePartiallyRequestPayload struct {
+ value *UpdateInstancePartiallyRequestPayload
+ isSet bool
+}
+
+func (v NullableUpdateInstancePartiallyRequestPayload) Get() *UpdateInstancePartiallyRequestPayload {
+ return v.value
+}
+
+func (v *NullableUpdateInstancePartiallyRequestPayload) Set(val *UpdateInstancePartiallyRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUpdateInstancePartiallyRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUpdateInstancePartiallyRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUpdateInstancePartiallyRequestPayload(val *UpdateInstancePartiallyRequestPayload) *NullableUpdateInstancePartiallyRequestPayload {
+ return &NullableUpdateInstancePartiallyRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableUpdateInstancePartiallyRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUpdateInstancePartiallyRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_update_instance_partially_request_payload_test.go b/pkg/postgresflexalpha/model_update_instance_partially_request_payload_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_instance_partially_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_update_instance_request_payload.go b/pkg/postgresflexalpha/model_update_instance_request_payload.go
new file mode 100644
index 00000000..613a8bb3
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_instance_request_payload.go
@@ -0,0 +1,437 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the UpdateInstanceRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &UpdateInstanceRequestPayload{}
+
+/*
+ types and functions for acl
+*/
+
+// isArray
+type UpdateInstanceRequestPayloadGetAclAttributeType = *[]string
+type UpdateInstanceRequestPayloadGetAclArgType = []string
+type UpdateInstanceRequestPayloadGetAclRetType = []string
+
+func getUpdateInstanceRequestPayloadGetAclAttributeTypeOk(arg UpdateInstanceRequestPayloadGetAclAttributeType) (ret UpdateInstanceRequestPayloadGetAclRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetAclAttributeType(arg *UpdateInstanceRequestPayloadGetAclAttributeType, val UpdateInstanceRequestPayloadGetAclRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for backupSchedule
+*/
+
+// isNotNullableString
+type UpdateInstanceRequestPayloadGetBackupScheduleAttributeType = *string
+
+func getUpdateInstanceRequestPayloadGetBackupScheduleAttributeTypeOk(arg UpdateInstanceRequestPayloadGetBackupScheduleAttributeType) (ret UpdateInstanceRequestPayloadGetBackupScheduleRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetBackupScheduleAttributeType(arg *UpdateInstanceRequestPayloadGetBackupScheduleAttributeType, val UpdateInstanceRequestPayloadGetBackupScheduleRetType) {
+ *arg = &val
+}
+
+type UpdateInstanceRequestPayloadGetBackupScheduleArgType = string
+type UpdateInstanceRequestPayloadGetBackupScheduleRetType = string
+
+/*
+ types and functions for flavorId
+*/
+
+// isNotNullableString
+type UpdateInstanceRequestPayloadGetFlavorIdAttributeType = *string
+
+func getUpdateInstanceRequestPayloadGetFlavorIdAttributeTypeOk(arg UpdateInstanceRequestPayloadGetFlavorIdAttributeType) (ret UpdateInstanceRequestPayloadGetFlavorIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetFlavorIdAttributeType(arg *UpdateInstanceRequestPayloadGetFlavorIdAttributeType, val UpdateInstanceRequestPayloadGetFlavorIdRetType) {
+ *arg = &val
+}
+
+type UpdateInstanceRequestPayloadGetFlavorIdArgType = string
+type UpdateInstanceRequestPayloadGetFlavorIdRetType = string
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type UpdateInstanceRequestPayloadGetNameAttributeType = *string
+
+func getUpdateInstanceRequestPayloadGetNameAttributeTypeOk(arg UpdateInstanceRequestPayloadGetNameAttributeType) (ret UpdateInstanceRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetNameAttributeType(arg *UpdateInstanceRequestPayloadGetNameAttributeType, val UpdateInstanceRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type UpdateInstanceRequestPayloadGetNameArgType = string
+type UpdateInstanceRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for replicas
+*/
+
+// isEnumRef
+type UpdateInstanceRequestPayloadGetReplicasAttributeType = *Replicas
+type UpdateInstanceRequestPayloadGetReplicasArgType = Replicas
+type UpdateInstanceRequestPayloadGetReplicasRetType = Replicas
+
+func getUpdateInstanceRequestPayloadGetReplicasAttributeTypeOk(arg UpdateInstanceRequestPayloadGetReplicasAttributeType) (ret UpdateInstanceRequestPayloadGetReplicasRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetReplicasAttributeType(arg *UpdateInstanceRequestPayloadGetReplicasAttributeType, val UpdateInstanceRequestPayloadGetReplicasRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for retentionDays
+*/
+
+// isInteger
+type UpdateInstanceRequestPayloadGetRetentionDaysAttributeType = *int64
+type UpdateInstanceRequestPayloadGetRetentionDaysArgType = int64
+type UpdateInstanceRequestPayloadGetRetentionDaysRetType = int64
+
+func getUpdateInstanceRequestPayloadGetRetentionDaysAttributeTypeOk(arg UpdateInstanceRequestPayloadGetRetentionDaysAttributeType) (ret UpdateInstanceRequestPayloadGetRetentionDaysRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetRetentionDaysAttributeType(arg *UpdateInstanceRequestPayloadGetRetentionDaysAttributeType, val UpdateInstanceRequestPayloadGetRetentionDaysRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for storage
+*/
+
+// isModel
+type UpdateInstanceRequestPayloadGetStorageAttributeType = *StorageUpdate
+type UpdateInstanceRequestPayloadGetStorageArgType = StorageUpdate
+type UpdateInstanceRequestPayloadGetStorageRetType = StorageUpdate
+
+func getUpdateInstanceRequestPayloadGetStorageAttributeTypeOk(arg UpdateInstanceRequestPayloadGetStorageAttributeType) (ret UpdateInstanceRequestPayloadGetStorageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetStorageAttributeType(arg *UpdateInstanceRequestPayloadGetStorageAttributeType, val UpdateInstanceRequestPayloadGetStorageRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for version
+*/
+
+// isNotNullableString
+type UpdateInstanceRequestPayloadGetVersionAttributeType = *string
+
+func getUpdateInstanceRequestPayloadGetVersionAttributeTypeOk(arg UpdateInstanceRequestPayloadGetVersionAttributeType) (ret UpdateInstanceRequestPayloadGetVersionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetVersionAttributeType(arg *UpdateInstanceRequestPayloadGetVersionAttributeType, val UpdateInstanceRequestPayloadGetVersionRetType) {
+ *arg = &val
+}
+
+type UpdateInstanceRequestPayloadGetVersionArgType = string
+type UpdateInstanceRequestPayloadGetVersionRetType = string
+
+// UpdateInstanceRequestPayload struct for UpdateInstanceRequestPayload
+type UpdateInstanceRequestPayload struct {
+ // List of IPV4 cidr.
+ // REQUIRED
+ Acl UpdateInstanceRequestPayloadGetAclAttributeType `json:"acl" required:"true"`
+ // The schedule for on what time and how often the database backup will be created. The schedule is written as a cron schedule.
+ // REQUIRED
+ BackupSchedule UpdateInstanceRequestPayloadGetBackupScheduleAttributeType `json:"backupSchedule" required:"true"`
+ // The id of the instance flavor.
+ // REQUIRED
+ FlavorId UpdateInstanceRequestPayloadGetFlavorIdAttributeType `json:"flavorId" required:"true"`
+ // The name of the instance.
+ // REQUIRED
+ Name UpdateInstanceRequestPayloadGetNameAttributeType `json:"name" required:"true"`
+ // REQUIRED
+ Replicas UpdateInstanceRequestPayloadGetReplicasAttributeType `json:"replicas" required:"true"`
+ // How long backups are retained. The value can only be between 32 and 365 days.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ RetentionDays UpdateInstanceRequestPayloadGetRetentionDaysAttributeType `json:"retentionDays" required:"true"`
+ // REQUIRED
+ Storage UpdateInstanceRequestPayloadGetStorageAttributeType `json:"storage" required:"true"`
+ // The Postgres version used for the instance. See [Versions Endpoint](/documentation/postgres-flex-service/version/v3alpha1#tag/Version) for supported version parameters.
+ // REQUIRED
+ Version UpdateInstanceRequestPayloadGetVersionAttributeType `json:"version" required:"true"`
+}
+
+type _UpdateInstanceRequestPayload UpdateInstanceRequestPayload
+
+// NewUpdateInstanceRequestPayload instantiates a new UpdateInstanceRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewUpdateInstanceRequestPayload(acl UpdateInstanceRequestPayloadGetAclArgType, backupSchedule UpdateInstanceRequestPayloadGetBackupScheduleArgType, flavorId UpdateInstanceRequestPayloadGetFlavorIdArgType, name UpdateInstanceRequestPayloadGetNameArgType, replicas UpdateInstanceRequestPayloadGetReplicasArgType, retentionDays UpdateInstanceRequestPayloadGetRetentionDaysArgType, storage UpdateInstanceRequestPayloadGetStorageArgType, version UpdateInstanceRequestPayloadGetVersionArgType) *UpdateInstanceRequestPayload {
+ this := UpdateInstanceRequestPayload{}
+ setUpdateInstanceRequestPayloadGetAclAttributeType(&this.Acl, acl)
+ setUpdateInstanceRequestPayloadGetBackupScheduleAttributeType(&this.BackupSchedule, backupSchedule)
+ setUpdateInstanceRequestPayloadGetFlavorIdAttributeType(&this.FlavorId, flavorId)
+ setUpdateInstanceRequestPayloadGetNameAttributeType(&this.Name, name)
+ setUpdateInstanceRequestPayloadGetReplicasAttributeType(&this.Replicas, replicas)
+ setUpdateInstanceRequestPayloadGetRetentionDaysAttributeType(&this.RetentionDays, retentionDays)
+ setUpdateInstanceRequestPayloadGetStorageAttributeType(&this.Storage, storage)
+ setUpdateInstanceRequestPayloadGetVersionAttributeType(&this.Version, version)
+ return &this
+}
+
+// NewUpdateInstanceRequestPayloadWithDefaults instantiates a new UpdateInstanceRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewUpdateInstanceRequestPayloadWithDefaults() *UpdateInstanceRequestPayload {
+ this := UpdateInstanceRequestPayload{}
+ return &this
+}
+
+// GetAcl returns the Acl field value
+func (o *UpdateInstanceRequestPayload) GetAcl() (ret UpdateInstanceRequestPayloadGetAclRetType) {
+ ret, _ = o.GetAclOk()
+ return ret
+}
+
+// GetAclOk returns a tuple with the Acl field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetAclOk() (ret UpdateInstanceRequestPayloadGetAclRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetAclAttributeTypeOk(o.Acl)
+}
+
+// SetAcl sets field value
+func (o *UpdateInstanceRequestPayload) SetAcl(v UpdateInstanceRequestPayloadGetAclRetType) {
+ setUpdateInstanceRequestPayloadGetAclAttributeType(&o.Acl, v)
+}
+
+// GetBackupSchedule returns the BackupSchedule field value
+func (o *UpdateInstanceRequestPayload) GetBackupSchedule() (ret UpdateInstanceRequestPayloadGetBackupScheduleRetType) {
+ ret, _ = o.GetBackupScheduleOk()
+ return ret
+}
+
+// GetBackupScheduleOk returns a tuple with the BackupSchedule field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetBackupScheduleOk() (ret UpdateInstanceRequestPayloadGetBackupScheduleRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetBackupScheduleAttributeTypeOk(o.BackupSchedule)
+}
+
+// SetBackupSchedule sets field value
+func (o *UpdateInstanceRequestPayload) SetBackupSchedule(v UpdateInstanceRequestPayloadGetBackupScheduleRetType) {
+ setUpdateInstanceRequestPayloadGetBackupScheduleAttributeType(&o.BackupSchedule, v)
+}
+
+// GetFlavorId returns the FlavorId field value
+func (o *UpdateInstanceRequestPayload) GetFlavorId() (ret UpdateInstanceRequestPayloadGetFlavorIdRetType) {
+ ret, _ = o.GetFlavorIdOk()
+ return ret
+}
+
+// GetFlavorIdOk returns a tuple with the FlavorId field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetFlavorIdOk() (ret UpdateInstanceRequestPayloadGetFlavorIdRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetFlavorIdAttributeTypeOk(o.FlavorId)
+}
+
+// SetFlavorId sets field value
+func (o *UpdateInstanceRequestPayload) SetFlavorId(v UpdateInstanceRequestPayloadGetFlavorIdRetType) {
+ setUpdateInstanceRequestPayloadGetFlavorIdAttributeType(&o.FlavorId, v)
+}
+
+// GetName returns the Name field value
+func (o *UpdateInstanceRequestPayload) GetName() (ret UpdateInstanceRequestPayloadGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetNameOk() (ret UpdateInstanceRequestPayloadGetNameRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *UpdateInstanceRequestPayload) SetName(v UpdateInstanceRequestPayloadGetNameRetType) {
+ setUpdateInstanceRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetReplicas returns the Replicas field value
+func (o *UpdateInstanceRequestPayload) GetReplicas() (ret UpdateInstanceRequestPayloadGetReplicasRetType) {
+ ret, _ = o.GetReplicasOk()
+ return ret
+}
+
+// GetReplicasOk returns a tuple with the Replicas field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetReplicasOk() (ret UpdateInstanceRequestPayloadGetReplicasRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetReplicasAttributeTypeOk(o.Replicas)
+}
+
+// SetReplicas sets field value
+func (o *UpdateInstanceRequestPayload) SetReplicas(v UpdateInstanceRequestPayloadGetReplicasRetType) {
+ setUpdateInstanceRequestPayloadGetReplicasAttributeType(&o.Replicas, v)
+}
+
+// GetRetentionDays returns the RetentionDays field value
+func (o *UpdateInstanceRequestPayload) GetRetentionDays() (ret UpdateInstanceRequestPayloadGetRetentionDaysRetType) {
+ ret, _ = o.GetRetentionDaysOk()
+ return ret
+}
+
+// GetRetentionDaysOk returns a tuple with the RetentionDays field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetRetentionDaysOk() (ret UpdateInstanceRequestPayloadGetRetentionDaysRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetRetentionDaysAttributeTypeOk(o.RetentionDays)
+}
+
+// SetRetentionDays sets field value
+func (o *UpdateInstanceRequestPayload) SetRetentionDays(v UpdateInstanceRequestPayloadGetRetentionDaysRetType) {
+ setUpdateInstanceRequestPayloadGetRetentionDaysAttributeType(&o.RetentionDays, v)
+}
+
+// GetStorage returns the Storage field value
+func (o *UpdateInstanceRequestPayload) GetStorage() (ret UpdateInstanceRequestPayloadGetStorageRetType) {
+ ret, _ = o.GetStorageOk()
+ return ret
+}
+
+// GetStorageOk returns a tuple with the Storage field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetStorageOk() (ret UpdateInstanceRequestPayloadGetStorageRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetStorageAttributeTypeOk(o.Storage)
+}
+
+// SetStorage sets field value
+func (o *UpdateInstanceRequestPayload) SetStorage(v UpdateInstanceRequestPayloadGetStorageRetType) {
+ setUpdateInstanceRequestPayloadGetStorageAttributeType(&o.Storage, v)
+}
+
+// GetVersion returns the Version field value
+func (o *UpdateInstanceRequestPayload) GetVersion() (ret UpdateInstanceRequestPayloadGetVersionRetType) {
+ ret, _ = o.GetVersionOk()
+ return ret
+}
+
+// GetVersionOk returns a tuple with the Version field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetVersionOk() (ret UpdateInstanceRequestPayloadGetVersionRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetVersionAttributeTypeOk(o.Version)
+}
+
+// SetVersion sets field value
+func (o *UpdateInstanceRequestPayload) SetVersion(v UpdateInstanceRequestPayloadGetVersionRetType) {
+ setUpdateInstanceRequestPayloadGetVersionAttributeType(&o.Version, v)
+}
+
+func (o UpdateInstanceRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getUpdateInstanceRequestPayloadGetAclAttributeTypeOk(o.Acl); ok {
+ toSerialize["Acl"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetBackupScheduleAttributeTypeOk(o.BackupSchedule); ok {
+ toSerialize["BackupSchedule"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetFlavorIdAttributeTypeOk(o.FlavorId); ok {
+ toSerialize["FlavorId"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetReplicasAttributeTypeOk(o.Replicas); ok {
+ toSerialize["Replicas"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetRetentionDaysAttributeTypeOk(o.RetentionDays); ok {
+ toSerialize["RetentionDays"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetStorageAttributeTypeOk(o.Storage); ok {
+ toSerialize["Storage"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetVersionAttributeTypeOk(o.Version); ok {
+ toSerialize["Version"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableUpdateInstanceRequestPayload struct {
+ value *UpdateInstanceRequestPayload
+ isSet bool
+}
+
+func (v NullableUpdateInstanceRequestPayload) Get() *UpdateInstanceRequestPayload {
+ return v.value
+}
+
+func (v *NullableUpdateInstanceRequestPayload) Set(val *UpdateInstanceRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUpdateInstanceRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUpdateInstanceRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUpdateInstanceRequestPayload(val *UpdateInstanceRequestPayload) *NullableUpdateInstanceRequestPayload {
+ return &NullableUpdateInstanceRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableUpdateInstanceRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUpdateInstanceRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_update_instance_request_payload_test.go b/pkg/postgresflexalpha/model_update_instance_request_payload_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_instance_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_update_user_partially_request_payload.go b/pkg/postgresflexalpha/model_update_user_partially_request_payload.go
new file mode 100644
index 00000000..9edb2ee3
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_user_partially_request_payload.go
@@ -0,0 +1,177 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the UpdateUserPartiallyRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &UpdateUserPartiallyRequestPayload{}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type UpdateUserPartiallyRequestPayloadGetNameAttributeType = *string
+
+func getUpdateUserPartiallyRequestPayloadGetNameAttributeTypeOk(arg UpdateUserPartiallyRequestPayloadGetNameAttributeType) (ret UpdateUserPartiallyRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateUserPartiallyRequestPayloadGetNameAttributeType(arg *UpdateUserPartiallyRequestPayloadGetNameAttributeType, val UpdateUserPartiallyRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type UpdateUserPartiallyRequestPayloadGetNameArgType = string
+type UpdateUserPartiallyRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for roles
+*/
+
+// isArray
+type UpdateUserPartiallyRequestPayloadGetRolesAttributeType = *[]UserRole
+type UpdateUserPartiallyRequestPayloadGetRolesArgType = []UserRole
+type UpdateUserPartiallyRequestPayloadGetRolesRetType = []UserRole
+
+func getUpdateUserPartiallyRequestPayloadGetRolesAttributeTypeOk(arg UpdateUserPartiallyRequestPayloadGetRolesAttributeType) (ret UpdateUserPartiallyRequestPayloadGetRolesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateUserPartiallyRequestPayloadGetRolesAttributeType(arg *UpdateUserPartiallyRequestPayloadGetRolesAttributeType, val UpdateUserPartiallyRequestPayloadGetRolesRetType) {
+ *arg = &val
+}
+
+// UpdateUserPartiallyRequestPayload struct for UpdateUserPartiallyRequestPayload
+type UpdateUserPartiallyRequestPayload struct {
+ // The name of the user.
+ Name UpdateUserPartiallyRequestPayloadGetNameAttributeType `json:"name,omitempty"`
+ // A list containing the user roles for the instance.
+ Roles UpdateUserPartiallyRequestPayloadGetRolesAttributeType `json:"roles,omitempty"`
+}
+
+// NewUpdateUserPartiallyRequestPayload instantiates a new UpdateUserPartiallyRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewUpdateUserPartiallyRequestPayload() *UpdateUserPartiallyRequestPayload {
+ this := UpdateUserPartiallyRequestPayload{}
+ return &this
+}
+
+// NewUpdateUserPartiallyRequestPayloadWithDefaults instantiates a new UpdateUserPartiallyRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewUpdateUserPartiallyRequestPayloadWithDefaults() *UpdateUserPartiallyRequestPayload {
+ this := UpdateUserPartiallyRequestPayload{}
+ return &this
+}
+
+// GetName returns the Name field value if set, zero value otherwise.
+func (o *UpdateUserPartiallyRequestPayload) GetName() (res UpdateUserPartiallyRequestPayloadGetNameRetType) {
+ res, _ = o.GetNameOk()
+ return
+}
+
+// GetNameOk returns a tuple with the Name field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateUserPartiallyRequestPayload) GetNameOk() (ret UpdateUserPartiallyRequestPayloadGetNameRetType, ok bool) {
+ return getUpdateUserPartiallyRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// HasName returns a boolean if a field has been set.
+func (o *UpdateUserPartiallyRequestPayload) HasName() bool {
+ _, ok := o.GetNameOk()
+ return ok
+}
+
+// SetName gets a reference to the given string and assigns it to the Name field.
+func (o *UpdateUserPartiallyRequestPayload) SetName(v UpdateUserPartiallyRequestPayloadGetNameRetType) {
+ setUpdateUserPartiallyRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetRoles returns the Roles field value if set, zero value otherwise.
+func (o *UpdateUserPartiallyRequestPayload) GetRoles() (res UpdateUserPartiallyRequestPayloadGetRolesRetType) {
+ res, _ = o.GetRolesOk()
+ return
+}
+
+// GetRolesOk returns a tuple with the Roles field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateUserPartiallyRequestPayload) GetRolesOk() (ret UpdateUserPartiallyRequestPayloadGetRolesRetType, ok bool) {
+ return getUpdateUserPartiallyRequestPayloadGetRolesAttributeTypeOk(o.Roles)
+}
+
+// HasRoles returns a boolean if a field has been set.
+func (o *UpdateUserPartiallyRequestPayload) HasRoles() bool {
+ _, ok := o.GetRolesOk()
+ return ok
+}
+
+// SetRoles gets a reference to the given []UserRole and assigns it to the Roles field.
+func (o *UpdateUserPartiallyRequestPayload) SetRoles(v UpdateUserPartiallyRequestPayloadGetRolesRetType) {
+ setUpdateUserPartiallyRequestPayloadGetRolesAttributeType(&o.Roles, v)
+}
+
+func (o UpdateUserPartiallyRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getUpdateUserPartiallyRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getUpdateUserPartiallyRequestPayloadGetRolesAttributeTypeOk(o.Roles); ok {
+ toSerialize["Roles"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableUpdateUserPartiallyRequestPayload struct {
+ value *UpdateUserPartiallyRequestPayload
+ isSet bool
+}
+
+func (v NullableUpdateUserPartiallyRequestPayload) Get() *UpdateUserPartiallyRequestPayload {
+ return v.value
+}
+
+func (v *NullableUpdateUserPartiallyRequestPayload) Set(val *UpdateUserPartiallyRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUpdateUserPartiallyRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUpdateUserPartiallyRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUpdateUserPartiallyRequestPayload(val *UpdateUserPartiallyRequestPayload) *NullableUpdateUserPartiallyRequestPayload {
+ return &NullableUpdateUserPartiallyRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableUpdateUserPartiallyRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUpdateUserPartiallyRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_update_user_partially_request_payload_test.go b/pkg/postgresflexalpha/model_update_user_partially_request_payload_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_user_partially_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_update_user_request_payload.go b/pkg/postgresflexalpha/model_update_user_request_payload.go
new file mode 100644
index 00000000..5eeeb059
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_user_request_payload.go
@@ -0,0 +1,175 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the UpdateUserRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &UpdateUserRequestPayload{}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type UpdateUserRequestPayloadGetNameAttributeType = *string
+
+func getUpdateUserRequestPayloadGetNameAttributeTypeOk(arg UpdateUserRequestPayloadGetNameAttributeType) (ret UpdateUserRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateUserRequestPayloadGetNameAttributeType(arg *UpdateUserRequestPayloadGetNameAttributeType, val UpdateUserRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type UpdateUserRequestPayloadGetNameArgType = string
+type UpdateUserRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for roles
+*/
+
+// isArray
+type UpdateUserRequestPayloadGetRolesAttributeType = *[]UserRole
+type UpdateUserRequestPayloadGetRolesArgType = []UserRole
+type UpdateUserRequestPayloadGetRolesRetType = []UserRole
+
+func getUpdateUserRequestPayloadGetRolesAttributeTypeOk(arg UpdateUserRequestPayloadGetRolesAttributeType) (ret UpdateUserRequestPayloadGetRolesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateUserRequestPayloadGetRolesAttributeType(arg *UpdateUserRequestPayloadGetRolesAttributeType, val UpdateUserRequestPayloadGetRolesRetType) {
+ *arg = &val
+}
+
+// UpdateUserRequestPayload struct for UpdateUserRequestPayload
+type UpdateUserRequestPayload struct {
+ // The name of the user.
+ Name UpdateUserRequestPayloadGetNameAttributeType `json:"name,omitempty"`
+ // A list containing the user roles for the instance.
+ // REQUIRED
+ Roles UpdateUserRequestPayloadGetRolesAttributeType `json:"roles" required:"true"`
+}
+
+type _UpdateUserRequestPayload UpdateUserRequestPayload
+
+// NewUpdateUserRequestPayload instantiates a new UpdateUserRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewUpdateUserRequestPayload(roles UpdateUserRequestPayloadGetRolesArgType) *UpdateUserRequestPayload {
+ this := UpdateUserRequestPayload{}
+ setUpdateUserRequestPayloadGetRolesAttributeType(&this.Roles, roles)
+ return &this
+}
+
+// NewUpdateUserRequestPayloadWithDefaults instantiates a new UpdateUserRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewUpdateUserRequestPayloadWithDefaults() *UpdateUserRequestPayload {
+ this := UpdateUserRequestPayload{}
+ return &this
+}
+
+// GetName returns the Name field value if set, zero value otherwise.
+func (o *UpdateUserRequestPayload) GetName() (res UpdateUserRequestPayloadGetNameRetType) {
+ res, _ = o.GetNameOk()
+ return
+}
+
+// GetNameOk returns a tuple with the Name field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateUserRequestPayload) GetNameOk() (ret UpdateUserRequestPayloadGetNameRetType, ok bool) {
+ return getUpdateUserRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// HasName returns a boolean if a field has been set.
+func (o *UpdateUserRequestPayload) HasName() bool {
+ _, ok := o.GetNameOk()
+ return ok
+}
+
+// SetName gets a reference to the given string and assigns it to the Name field.
+func (o *UpdateUserRequestPayload) SetName(v UpdateUserRequestPayloadGetNameRetType) {
+ setUpdateUserRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetRoles returns the Roles field value
+func (o *UpdateUserRequestPayload) GetRoles() (ret UpdateUserRequestPayloadGetRolesRetType) {
+ ret, _ = o.GetRolesOk()
+ return ret
+}
+
+// GetRolesOk returns a tuple with the Roles field value
+// and a boolean to check if the value has been set.
+func (o *UpdateUserRequestPayload) GetRolesOk() (ret UpdateUserRequestPayloadGetRolesRetType, ok bool) {
+ return getUpdateUserRequestPayloadGetRolesAttributeTypeOk(o.Roles)
+}
+
+// SetRoles sets field value
+func (o *UpdateUserRequestPayload) SetRoles(v UpdateUserRequestPayloadGetRolesRetType) {
+ setUpdateUserRequestPayloadGetRolesAttributeType(&o.Roles, v)
+}
+
+func (o UpdateUserRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getUpdateUserRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getUpdateUserRequestPayloadGetRolesAttributeTypeOk(o.Roles); ok {
+ toSerialize["Roles"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableUpdateUserRequestPayload struct {
+ value *UpdateUserRequestPayload
+ isSet bool
+}
+
+func (v NullableUpdateUserRequestPayload) Get() *UpdateUserRequestPayload {
+ return v.value
+}
+
+func (v *NullableUpdateUserRequestPayload) Set(val *UpdateUserRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUpdateUserRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUpdateUserRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUpdateUserRequestPayload(val *UpdateUserRequestPayload) *NullableUpdateUserRequestPayload {
+ return &NullableUpdateUserRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableUpdateUserRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUpdateUserRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_update_user_request_payload_test.go b/pkg/postgresflexalpha/model_update_user_request_payload_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_update_user_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_user_role.go b/pkg/postgresflexalpha/model_user_role.go
new file mode 100644
index 00000000..4c5b2ba3
--- /dev/null
+++ b/pkg/postgresflexalpha/model_user_role.go
@@ -0,0 +1,117 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// UserRole The user role for the instance.
+type UserRole string
+
+// List of user.role
+const (
+ USERROLE_CREATEDB UserRole = "createdb"
+ USERROLE_LOGIN UserRole = "login"
+ USERROLE_CREATEROLE UserRole = "createrole"
+)
+
+// All allowed values of UserRole enum
+var AllowedUserRoleEnumValues = []UserRole{
+ "createdb",
+ "login",
+ "createrole",
+}
+
+func (v *UserRole) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := UserRole(value)
+ for _, existing := range AllowedUserRoleEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid UserRole", value)
+}
+
+// NewUserRoleFromValue returns a pointer to a valid UserRole
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewUserRoleFromValue(v string) (*UserRole, error) {
+ ev := UserRole(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for UserRole: valid values are %v", v, AllowedUserRoleEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v UserRole) IsValid() bool {
+ for _, existing := range AllowedUserRoleEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to user.role value
+func (v UserRole) Ptr() *UserRole {
+ return &v
+}
+
+type NullableUserRole struct {
+ value *UserRole
+ isSet bool
+}
+
+func (v NullableUserRole) Get() *UserRole {
+ return v.value
+}
+
+func (v *NullableUserRole) Set(val *UserRole) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUserRole) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUserRole) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUserRole(val *UserRole) *NullableUserRole {
+ return &NullableUserRole{value: val, isSet: true}
+}
+
+func (v NullableUserRole) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUserRole) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_user_role_test.go b/pkg/postgresflexalpha/model_user_role_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_user_role_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_user_sort.go b/pkg/postgresflexalpha/model_user_sort.go
new file mode 100644
index 00000000..a47ae0d9
--- /dev/null
+++ b/pkg/postgresflexalpha/model_user_sort.go
@@ -0,0 +1,127 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// UserSort the model 'UserSort'
+type UserSort string
+
+// List of user.sort
+const (
+ USERSORT_ID_ASC UserSort = "id.asc"
+ USERSORT_ID_DESC UserSort = "id.desc"
+ USERSORT_INDEX_DESC UserSort = "index.desc"
+ USERSORT_INDEX_ASC UserSort = "index.asc"
+ USERSORT_NAME_DESC UserSort = "name.desc"
+ USERSORT_NAME_ASC UserSort = "name.asc"
+ USERSORT_STATUS_DESC UserSort = "status.desc"
+ USERSORT_STATUS_ASC UserSort = "status.asc"
+)
+
+// All allowed values of UserSort enum
+var AllowedUserSortEnumValues = []UserSort{
+ "id.asc",
+ "id.desc",
+ "index.desc",
+ "index.asc",
+ "name.desc",
+ "name.asc",
+ "status.desc",
+ "status.asc",
+}
+
+func (v *UserSort) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := UserSort(value)
+ for _, existing := range AllowedUserSortEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid UserSort", value)
+}
+
+// NewUserSortFromValue returns a pointer to a valid UserSort
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewUserSortFromValue(v string) (*UserSort, error) {
+ ev := UserSort(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for UserSort: valid values are %v", v, AllowedUserSortEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v UserSort) IsValid() bool {
+ for _, existing := range AllowedUserSortEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to user.sort value
+func (v UserSort) Ptr() *UserSort {
+ return &v
+}
+
+type NullableUserSort struct {
+ value *UserSort
+ isSet bool
+}
+
+func (v NullableUserSort) Get() *UserSort {
+ return v.value
+}
+
+func (v *NullableUserSort) Set(val *UserSort) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUserSort) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUserSort) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUserSort(val *UserSort) *NullableUserSort {
+ return &NullableUserSort{value: val, isSet: true}
+}
+
+func (v NullableUserSort) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUserSort) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_user_sort_test.go b/pkg/postgresflexalpha/model_user_sort_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_user_sort_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_validation_error.go b/pkg/postgresflexalpha/model_validation_error.go
new file mode 100644
index 00000000..0d708746
--- /dev/null
+++ b/pkg/postgresflexalpha/model_validation_error.go
@@ -0,0 +1,171 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ValidationError type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ValidationError{}
+
+/*
+ types and functions for code
+*/
+
+// isInteger
+type ValidationErrorGetCodeAttributeType = *int64
+type ValidationErrorGetCodeArgType = int64
+type ValidationErrorGetCodeRetType = int64
+
+func getValidationErrorGetCodeAttributeTypeOk(arg ValidationErrorGetCodeAttributeType) (ret ValidationErrorGetCodeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setValidationErrorGetCodeAttributeType(arg *ValidationErrorGetCodeAttributeType, val ValidationErrorGetCodeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for validation
+*/
+
+// isArray
+type ValidationErrorGetValidationAttributeType = *[]ValidationErrorValidationInner
+type ValidationErrorGetValidationArgType = []ValidationErrorValidationInner
+type ValidationErrorGetValidationRetType = []ValidationErrorValidationInner
+
+func getValidationErrorGetValidationAttributeTypeOk(arg ValidationErrorGetValidationAttributeType) (ret ValidationErrorGetValidationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setValidationErrorGetValidationAttributeType(arg *ValidationErrorGetValidationAttributeType, val ValidationErrorGetValidationRetType) {
+ *arg = &val
+}
+
+// ValidationError struct for ValidationError
+type ValidationError struct {
+ // the http error should be always 422 for validationError
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ Code ValidationErrorGetCodeAttributeType `json:"code" required:"true"`
+ // errors for all fields where the error happened
+ // REQUIRED
+ Validation ValidationErrorGetValidationAttributeType `json:"validation" required:"true"`
+}
+
+type _ValidationError ValidationError
+
+// NewValidationError instantiates a new ValidationError object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewValidationError(code ValidationErrorGetCodeArgType, validation ValidationErrorGetValidationArgType) *ValidationError {
+ this := ValidationError{}
+ setValidationErrorGetCodeAttributeType(&this.Code, code)
+ setValidationErrorGetValidationAttributeType(&this.Validation, validation)
+ return &this
+}
+
+// NewValidationErrorWithDefaults instantiates a new ValidationError object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewValidationErrorWithDefaults() *ValidationError {
+ this := ValidationError{}
+ return &this
+}
+
+// GetCode returns the Code field value
+func (o *ValidationError) GetCode() (ret ValidationErrorGetCodeRetType) {
+ ret, _ = o.GetCodeOk()
+ return ret
+}
+
+// GetCodeOk returns a tuple with the Code field value
+// and a boolean to check if the value has been set.
+func (o *ValidationError) GetCodeOk() (ret ValidationErrorGetCodeRetType, ok bool) {
+ return getValidationErrorGetCodeAttributeTypeOk(o.Code)
+}
+
+// SetCode sets field value
+func (o *ValidationError) SetCode(v ValidationErrorGetCodeRetType) {
+ setValidationErrorGetCodeAttributeType(&o.Code, v)
+}
+
+// GetValidation returns the Validation field value
+func (o *ValidationError) GetValidation() (ret ValidationErrorGetValidationRetType) {
+ ret, _ = o.GetValidationOk()
+ return ret
+}
+
+// GetValidationOk returns a tuple with the Validation field value
+// and a boolean to check if the value has been set.
+func (o *ValidationError) GetValidationOk() (ret ValidationErrorGetValidationRetType, ok bool) {
+ return getValidationErrorGetValidationAttributeTypeOk(o.Validation)
+}
+
+// SetValidation sets field value
+func (o *ValidationError) SetValidation(v ValidationErrorGetValidationRetType) {
+ setValidationErrorGetValidationAttributeType(&o.Validation, v)
+}
+
+func (o ValidationError) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getValidationErrorGetCodeAttributeTypeOk(o.Code); ok {
+ toSerialize["Code"] = val
+ }
+ if val, ok := getValidationErrorGetValidationAttributeTypeOk(o.Validation); ok {
+ toSerialize["Validation"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableValidationError struct {
+ value *ValidationError
+ isSet bool
+}
+
+func (v NullableValidationError) Get() *ValidationError {
+ return v.value
+}
+
+func (v *NullableValidationError) Set(val *ValidationError) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableValidationError) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableValidationError) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableValidationError(val *ValidationError) *NullableValidationError {
+ return &NullableValidationError{value: val, isSet: true}
+}
+
+func (v NullableValidationError) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableValidationError) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_validation_error_test.go b/pkg/postgresflexalpha/model_validation_error_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_validation_error_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_validation_error_validation_inner.go b/pkg/postgresflexalpha/model_validation_error_validation_inner.go
new file mode 100644
index 00000000..cfb92ffc
--- /dev/null
+++ b/pkg/postgresflexalpha/model_validation_error_validation_inner.go
@@ -0,0 +1,170 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ValidationErrorValidationInner type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ValidationErrorValidationInner{}
+
+/*
+ types and functions for field
+*/
+
+// isNotNullableString
+type ValidationErrorValidationInnerGetFieldAttributeType = *string
+
+func getValidationErrorValidationInnerGetFieldAttributeTypeOk(arg ValidationErrorValidationInnerGetFieldAttributeType) (ret ValidationErrorValidationInnerGetFieldRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setValidationErrorValidationInnerGetFieldAttributeType(arg *ValidationErrorValidationInnerGetFieldAttributeType, val ValidationErrorValidationInnerGetFieldRetType) {
+ *arg = &val
+}
+
+type ValidationErrorValidationInnerGetFieldArgType = string
+type ValidationErrorValidationInnerGetFieldRetType = string
+
+/*
+ types and functions for message
+*/
+
+// isNotNullableString
+type ValidationErrorValidationInnerGetMessageAttributeType = *string
+
+func getValidationErrorValidationInnerGetMessageAttributeTypeOk(arg ValidationErrorValidationInnerGetMessageAttributeType) (ret ValidationErrorValidationInnerGetMessageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setValidationErrorValidationInnerGetMessageAttributeType(arg *ValidationErrorValidationInnerGetMessageAttributeType, val ValidationErrorValidationInnerGetMessageRetType) {
+ *arg = &val
+}
+
+type ValidationErrorValidationInnerGetMessageArgType = string
+type ValidationErrorValidationInnerGetMessageRetType = string
+
+// ValidationErrorValidationInner struct for ValidationErrorValidationInner
+type ValidationErrorValidationInner struct {
+ // REQUIRED
+ Field ValidationErrorValidationInnerGetFieldAttributeType `json:"field" required:"true"`
+ // REQUIRED
+ Message ValidationErrorValidationInnerGetMessageAttributeType `json:"message" required:"true"`
+}
+
+type _ValidationErrorValidationInner ValidationErrorValidationInner
+
+// NewValidationErrorValidationInner instantiates a new ValidationErrorValidationInner object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewValidationErrorValidationInner(field ValidationErrorValidationInnerGetFieldArgType, message ValidationErrorValidationInnerGetMessageArgType) *ValidationErrorValidationInner {
+ this := ValidationErrorValidationInner{}
+ setValidationErrorValidationInnerGetFieldAttributeType(&this.Field, field)
+ setValidationErrorValidationInnerGetMessageAttributeType(&this.Message, message)
+ return &this
+}
+
+// NewValidationErrorValidationInnerWithDefaults instantiates a new ValidationErrorValidationInner object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewValidationErrorValidationInnerWithDefaults() *ValidationErrorValidationInner {
+ this := ValidationErrorValidationInner{}
+ return &this
+}
+
+// GetField returns the Field field value
+func (o *ValidationErrorValidationInner) GetField() (ret ValidationErrorValidationInnerGetFieldRetType) {
+ ret, _ = o.GetFieldOk()
+ return ret
+}
+
+// GetFieldOk returns a tuple with the Field field value
+// and a boolean to check if the value has been set.
+func (o *ValidationErrorValidationInner) GetFieldOk() (ret ValidationErrorValidationInnerGetFieldRetType, ok bool) {
+ return getValidationErrorValidationInnerGetFieldAttributeTypeOk(o.Field)
+}
+
+// SetField sets field value
+func (o *ValidationErrorValidationInner) SetField(v ValidationErrorValidationInnerGetFieldRetType) {
+ setValidationErrorValidationInnerGetFieldAttributeType(&o.Field, v)
+}
+
+// GetMessage returns the Message field value
+func (o *ValidationErrorValidationInner) GetMessage() (ret ValidationErrorValidationInnerGetMessageRetType) {
+ ret, _ = o.GetMessageOk()
+ return ret
+}
+
+// GetMessageOk returns a tuple with the Message field value
+// and a boolean to check if the value has been set.
+func (o *ValidationErrorValidationInner) GetMessageOk() (ret ValidationErrorValidationInnerGetMessageRetType, ok bool) {
+ return getValidationErrorValidationInnerGetMessageAttributeTypeOk(o.Message)
+}
+
+// SetMessage sets field value
+func (o *ValidationErrorValidationInner) SetMessage(v ValidationErrorValidationInnerGetMessageRetType) {
+ setValidationErrorValidationInnerGetMessageAttributeType(&o.Message, v)
+}
+
+func (o ValidationErrorValidationInner) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getValidationErrorValidationInnerGetFieldAttributeTypeOk(o.Field); ok {
+ toSerialize["Field"] = val
+ }
+ if val, ok := getValidationErrorValidationInnerGetMessageAttributeTypeOk(o.Message); ok {
+ toSerialize["Message"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableValidationErrorValidationInner struct {
+ value *ValidationErrorValidationInner
+ isSet bool
+}
+
+func (v NullableValidationErrorValidationInner) Get() *ValidationErrorValidationInner {
+ return v.value
+}
+
+func (v *NullableValidationErrorValidationInner) Set(val *ValidationErrorValidationInner) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableValidationErrorValidationInner) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableValidationErrorValidationInner) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableValidationErrorValidationInner(val *ValidationErrorValidationInner) *NullableValidationErrorValidationInner {
+ return &NullableValidationErrorValidationInner{value: val, isSet: true}
+}
+
+func (v NullableValidationErrorValidationInner) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableValidationErrorValidationInner) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_validation_error_validation_inner_test.go b/pkg/postgresflexalpha/model_validation_error_validation_inner_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_validation_error_validation_inner_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/model_version.go b/pkg/postgresflexalpha/model_version.go
new file mode 100644
index 00000000..d9c6f402
--- /dev/null
+++ b/pkg/postgresflexalpha/model_version.go
@@ -0,0 +1,260 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the Version type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &Version{}
+
+/*
+ types and functions for beta
+*/
+
+// isBoolean
+type VersiongetBetaAttributeType = *bool
+type VersiongetBetaArgType = bool
+type VersiongetBetaRetType = bool
+
+func getVersiongetBetaAttributeTypeOk(arg VersiongetBetaAttributeType) (ret VersiongetBetaRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setVersiongetBetaAttributeType(arg *VersiongetBetaAttributeType, val VersiongetBetaRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for deprecated
+*/
+
+// isNotNullableString
+type VersionGetDeprecatedAttributeType = *string
+
+func getVersionGetDeprecatedAttributeTypeOk(arg VersionGetDeprecatedAttributeType) (ret VersionGetDeprecatedRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setVersionGetDeprecatedAttributeType(arg *VersionGetDeprecatedAttributeType, val VersionGetDeprecatedRetType) {
+ *arg = &val
+}
+
+type VersionGetDeprecatedArgType = string
+type VersionGetDeprecatedRetType = string
+
+/*
+ types and functions for recommend
+*/
+
+// isBoolean
+type VersiongetRecommendAttributeType = *bool
+type VersiongetRecommendArgType = bool
+type VersiongetRecommendRetType = bool
+
+func getVersiongetRecommendAttributeTypeOk(arg VersiongetRecommendAttributeType) (ret VersiongetRecommendRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setVersiongetRecommendAttributeType(arg *VersiongetRecommendAttributeType, val VersiongetRecommendRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for version
+*/
+
+// isNotNullableString
+type VersionGetVersionAttributeType = *string
+
+func getVersionGetVersionAttributeTypeOk(arg VersionGetVersionAttributeType) (ret VersionGetVersionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setVersionGetVersionAttributeType(arg *VersionGetVersionAttributeType, val VersionGetVersionRetType) {
+ *arg = &val
+}
+
+type VersionGetVersionArgType = string
+type VersionGetVersionRetType = string
+
+// Version The version of the postgres instance and more details.
+type Version struct {
+ // Flag if the version is a beta version. If set the version may contain bugs and is not fully tested.
+ // REQUIRED
+ Beta VersiongetBetaAttributeType `json:"beta" required:"true"`
+ // Timestamp in RFC3339 format which says when the version will no longer be supported by STACKIT.
+ // REQUIRED
+ Deprecated VersionGetDeprecatedAttributeType `json:"deprecated" required:"true"`
+ // Flag if the version is recommend by the STACKIT Team.
+ // REQUIRED
+ Recommend VersiongetRecommendAttributeType `json:"recommend" required:"true"`
+ // The postgres version used for the instance.
+ // REQUIRED
+ Version VersionGetVersionAttributeType `json:"version" required:"true"`
+}
+
+type _Version Version
+
+// NewVersion instantiates a new Version object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewVersion(beta VersiongetBetaArgType, deprecated VersionGetDeprecatedArgType, recommend VersiongetRecommendArgType, version VersionGetVersionArgType) *Version {
+ this := Version{}
+ setVersiongetBetaAttributeType(&this.Beta, beta)
+ setVersionGetDeprecatedAttributeType(&this.Deprecated, deprecated)
+ setVersiongetRecommendAttributeType(&this.Recommend, recommend)
+ setVersionGetVersionAttributeType(&this.Version, version)
+ return &this
+}
+
+// NewVersionWithDefaults instantiates a new Version object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewVersionWithDefaults() *Version {
+ this := Version{}
+ return &this
+}
+
+// GetBeta returns the Beta field value
+func (o *Version) GetBeta() (ret VersiongetBetaRetType) {
+ ret, _ = o.GetBetaOk()
+ return ret
+}
+
+// GetBetaOk returns a tuple with the Beta field value
+// and a boolean to check if the value has been set.
+func (o *Version) GetBetaOk() (ret VersiongetBetaRetType, ok bool) {
+ return getVersiongetBetaAttributeTypeOk(o.Beta)
+}
+
+// SetBeta sets field value
+func (o *Version) SetBeta(v VersiongetBetaRetType) {
+ setVersiongetBetaAttributeType(&o.Beta, v)
+}
+
+// GetDeprecated returns the Deprecated field value
+func (o *Version) GetDeprecated() (ret VersionGetDeprecatedRetType) {
+ ret, _ = o.GetDeprecatedOk()
+ return ret
+}
+
+// GetDeprecatedOk returns a tuple with the Deprecated field value
+// and a boolean to check if the value has been set.
+func (o *Version) GetDeprecatedOk() (ret VersionGetDeprecatedRetType, ok bool) {
+ return getVersionGetDeprecatedAttributeTypeOk(o.Deprecated)
+}
+
+// SetDeprecated sets field value
+func (o *Version) SetDeprecated(v VersionGetDeprecatedRetType) {
+ setVersionGetDeprecatedAttributeType(&o.Deprecated, v)
+}
+
+// GetRecommend returns the Recommend field value
+func (o *Version) GetRecommend() (ret VersiongetRecommendRetType) {
+ ret, _ = o.GetRecommendOk()
+ return ret
+}
+
+// GetRecommendOk returns a tuple with the Recommend field value
+// and a boolean to check if the value has been set.
+func (o *Version) GetRecommendOk() (ret VersiongetRecommendRetType, ok bool) {
+ return getVersiongetRecommendAttributeTypeOk(o.Recommend)
+}
+
+// SetRecommend sets field value
+func (o *Version) SetRecommend(v VersiongetRecommendRetType) {
+ setVersiongetRecommendAttributeType(&o.Recommend, v)
+}
+
+// GetVersion returns the Version field value
+func (o *Version) GetVersion() (ret VersionGetVersionRetType) {
+ ret, _ = o.GetVersionOk()
+ return ret
+}
+
+// GetVersionOk returns a tuple with the Version field value
+// and a boolean to check if the value has been set.
+func (o *Version) GetVersionOk() (ret VersionGetVersionRetType, ok bool) {
+ return getVersionGetVersionAttributeTypeOk(o.Version)
+}
+
+// SetVersion sets field value
+func (o *Version) SetVersion(v VersionGetVersionRetType) {
+ setVersionGetVersionAttributeType(&o.Version, v)
+}
+
+func (o Version) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getVersiongetBetaAttributeTypeOk(o.Beta); ok {
+ toSerialize["Beta"] = val
+ }
+ if val, ok := getVersionGetDeprecatedAttributeTypeOk(o.Deprecated); ok {
+ toSerialize["Deprecated"] = val
+ }
+ if val, ok := getVersiongetRecommendAttributeTypeOk(o.Recommend); ok {
+ toSerialize["Recommend"] = val
+ }
+ if val, ok := getVersionGetVersionAttributeTypeOk(o.Version); ok {
+ toSerialize["Version"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableVersion struct {
+ value *Version
+ isSet bool
+}
+
+func (v NullableVersion) Get() *Version {
+ return v.value
+}
+
+func (v *NullableVersion) Set(val *Version) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableVersion) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableVersion) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableVersion(val *Version) *NullableVersion {
+ return &NullableVersion{value: val, isSet: true}
+}
+
+func (v NullableVersion) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableVersion) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/postgresflexalpha/model_version_test.go b/pkg/postgresflexalpha/model_version_test.go
new file mode 100644
index 00000000..e1ff850e
--- /dev/null
+++ b/pkg/postgresflexalpha/model_version_test.go
@@ -0,0 +1,11 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
diff --git a/pkg/postgresflexalpha/utils.go b/pkg/postgresflexalpha/utils.go
new file mode 100644
index 00000000..0517a2ed
--- /dev/null
+++ b/pkg/postgresflexalpha/utils.go
@@ -0,0 +1,385 @@
+/*
+PostgreSQL Flex API
+
+This is the documentation for the STACKIT Postgres Flex service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package postgresflexalpha
+
+import (
+ "encoding/json"
+ "math/rand"
+ "reflect"
+ "time"
+)
+
+// PtrBool is a helper routine that returns a pointer to given boolean value.
+func PtrBool(v bool) *bool { return &v }
+
+// PtrInt is a helper routine that returns a pointer to given integer value.
+func PtrInt(v int) *int { return &v }
+
+// PtrInt32 is a helper routine that returns a pointer to given integer value.
+func PtrInt32(v int32) *int32 { return &v }
+
+// PtrInt64 is a helper routine that returns a pointer to given integer value.
+func PtrInt64(v int64) *int64 { return &v }
+
+// PtrFloat32 is a helper routine that returns a pointer to given float value.
+func PtrFloat32(v float32) *float32 { return &v }
+
+// PtrFloat64 is a helper routine that returns a pointer to given float value.
+func PtrFloat64(v float64) *float64 { return &v }
+
+// PtrString is a helper routine that returns a pointer to given string value.
+func PtrString(v string) *string { return &v }
+
+// PtrTime is helper routine that returns a pointer to given Time value.
+func PtrTime(v time.Time) *time.Time { return &v }
+
+type NullableValue[T any] struct {
+ value *T
+ isSet bool
+}
+
+func (v NullableValue[T]) Get() *T {
+ return v.value
+}
+
+func (v *NullableValue[T]) Set(val *T) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableValue[T]) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableValue[T]) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+type NullableBool struct {
+ value *bool
+ isSet bool
+}
+
+func (v NullableBool) Get() *bool {
+ return v.value
+}
+
+func (v *NullableBool) Set(val *bool) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableBool) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableBool) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableBool(val *bool) *NullableBool {
+ return &NullableBool{value: val, isSet: true}
+}
+
+func (v NullableBool) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableBool) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableInt struct {
+ value *int
+ isSet bool
+}
+
+func (v NullableInt) Get() *int {
+ return v.value
+}
+
+func (v *NullableInt) Set(val *int) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInt) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInt) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInt(val *int) *NullableInt {
+ return &NullableInt{value: val, isSet: true}
+}
+
+func (v NullableInt) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInt) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableInt32 struct {
+ value *int32
+ isSet bool
+}
+
+func (v NullableInt32) Get() *int32 {
+ return v.value
+}
+
+func (v *NullableInt32) Set(val *int32) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInt32) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInt32) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInt32(val *int32) *NullableInt32 {
+ return &NullableInt32{value: val, isSet: true}
+}
+
+func (v NullableInt32) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInt32) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableInt64 struct {
+ value *int64
+ isSet bool
+}
+
+func (v NullableInt64) Get() *int64 {
+ return v.value
+}
+
+func (v *NullableInt64) Set(val *int64) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInt64) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInt64) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInt64(val *int64) *NullableInt64 {
+ return &NullableInt64{value: val, isSet: true}
+}
+
+func (v NullableInt64) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInt64) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableFloat32 struct {
+ value *float32
+ isSet bool
+}
+
+func (v NullableFloat32) Get() *float32 {
+ return v.value
+}
+
+func (v *NullableFloat32) Set(val *float32) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableFloat32) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableFloat32) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableFloat32(val *float32) *NullableFloat32 {
+ return &NullableFloat32{value: val, isSet: true}
+}
+
+func (v NullableFloat32) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableFloat32) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableFloat64 struct {
+ value *float64
+ isSet bool
+}
+
+func (v NullableFloat64) Get() *float64 {
+ return v.value
+}
+
+func (v *NullableFloat64) Set(val *float64) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableFloat64) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableFloat64) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableFloat64(val *float64) *NullableFloat64 {
+ return &NullableFloat64{value: val, isSet: true}
+}
+
+func (v NullableFloat64) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableFloat64) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableString struct {
+ value *string
+ isSet bool
+}
+
+func (v NullableString) Get() *string {
+ return v.value
+}
+
+func (v *NullableString) Set(val *string) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableString) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableString) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableString(val *string) *NullableString {
+ return &NullableString{value: val, isSet: true}
+}
+
+func (v NullableString) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableString) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableTime struct {
+ value *time.Time
+ isSet bool
+}
+
+func (v NullableTime) Get() *time.Time {
+ return v.value
+}
+
+func (v *NullableTime) Set(val *time.Time) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableTime) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableTime) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableTime(val *time.Time) *NullableTime {
+ return &NullableTime{value: val, isSet: true}
+}
+
+func (v NullableTime) MarshalJSON() ([]byte, error) {
+ return v.value.MarshalJSON()
+}
+
+func (v *NullableTime) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+// IsNil checks if an input is nil
+func IsNil(i interface{}) bool {
+ if i == nil {
+ return true
+ }
+ if t, ok := i.(interface{ IsSet() bool }); ok {
+ return !t.IsSet()
+ }
+ switch reflect.TypeOf(i).Kind() {
+ case reflect.Chan, reflect.Func, reflect.Map, reflect.Ptr, reflect.UnsafePointer, reflect.Interface, reflect.Slice:
+ return reflect.ValueOf(i).IsNil()
+ case reflect.Array:
+ return reflect.ValueOf(i).IsZero()
+ }
+ return false
+}
+
+type MappedNullable interface {
+ ToMap() (map[string]interface{}, error)
+}
+
+const letterRunes = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
+
+// randString returns a random string with a specified length. It panics if n <= 0.
+func randString(n int) string {
+ b := make([]byte, n)
+ for i := range b {
+ b[i] = letterRunes[rand.Intn(len(letterRunes))]
+ }
+ return string(b)
+}
diff --git a/pkg/postgresflexalpha/wait/wait.go b/pkg/postgresflexalpha/wait/wait.go
new file mode 100644
index 00000000..283cb315
--- /dev/null
+++ b/pkg/postgresflexalpha/wait/wait.go
@@ -0,0 +1,170 @@
+package wait
+
+import (
+ "context"
+ "fmt"
+ "time"
+
+ postgresflex "github.com/stackitcloud/terraform-provider-stackit/pkg/postgresflexalpha"
+
+ "github.com/stackitcloud/stackit-sdk-go/core/oapierror"
+ "github.com/stackitcloud/stackit-sdk-go/core/wait"
+)
+
+const (
+ InstanceStateEmpty = ""
+ InstanceStateProgressing = "Progressing"
+ InstanceStateSuccess = "Ready"
+ InstanceStateFailed = "Failure"
+ InstanceStateDeleted = "Deleted"
+)
+
+// Interface needed for tests
+type APIClientInstanceInterface interface {
+ GetInstanceRequestExecute(ctx context.Context, projectId, region, instanceId string) (*postgresflex.GetInstanceResponse, error)
+ ListUsersRequestExecute(ctx context.Context, projectId, region, instanceId string) (*postgresflex.ListUserResponse, error)
+}
+
+// Interface needed for tests
+type APIClientUserInterface interface {
+ GetUserRequestExecute(ctx context.Context, projectId, region, instanceId string, userId int64) (*postgresflex.GetUserResponse, error)
+}
+
+// CreateInstanceWaitHandler will wait for instance creation
+func CreateInstanceWaitHandler(ctx context.Context, a APIClientInstanceInterface, projectId, region, instanceId string) *wait.AsyncActionHandler[postgresflex.GetInstanceResponse] {
+ instanceCreated := false
+ var instanceGetResponse *postgresflex.GetInstanceResponse
+
+ handler := wait.New(func() (waitFinished bool, response *postgresflex.GetInstanceResponse, err error) {
+ if !instanceCreated {
+ s, err := a.GetInstanceRequestExecute(ctx, projectId, region, instanceId)
+ if err != nil {
+ return false, nil, err
+ }
+ if s == nil || s.Id == nil || *s.Id != instanceId || s.Status == nil {
+ return false, nil, nil
+ }
+ switch *s.Status {
+ default:
+ return true, s, fmt.Errorf("instance with id %s has unexpected status %s", instanceId, *s.Status)
+ case InstanceStateEmpty:
+ return false, nil, nil
+ case InstanceStateProgressing:
+ return false, nil, nil
+ case InstanceStateSuccess:
+ instanceCreated = true
+ instanceGetResponse = s
+ case InstanceStateFailed:
+ return true, s, fmt.Errorf("create failed for instance with id %s", instanceId)
+ }
+ }
+
+ // User operations aren't available right after an instance is deemed successful
+ // To check if they are, perform a users request
+ _, err = a.ListUsersRequestExecute(ctx, projectId, region, instanceId)
+ if err == nil {
+ return true, instanceGetResponse, nil
+ }
+ oapiErr, ok := err.(*oapierror.GenericOpenAPIError) //nolint:errorlint //complaining that error.As should be used to catch wrapped errors, but this error should not be wrapped
+ if !ok {
+ return false, nil, err
+ }
+ if oapiErr.StatusCode < 500 {
+ return true, instanceGetResponse, fmt.Errorf("users request after instance creation returned %d status code", oapiErr.StatusCode)
+ }
+ return false, nil, nil
+ })
+ // Sleep before wait is set because sometimes API returns 404 right after creation request
+ handler.SetTimeout(45 * time.Minute).SetSleepBeforeWait(15 * time.Second)
+ return handler
+}
+
+// PartialUpdateInstanceWaitHandler will wait for instance update
+func PartialUpdateInstanceWaitHandler(ctx context.Context, a APIClientInstanceInterface, projectId, region, instanceId string) *wait.AsyncActionHandler[postgresflex.GetInstanceResponse] {
+ handler := wait.New(func() (waitFinished bool, response *postgresflex.GetInstanceResponse, err error) {
+ s, err := a.GetInstanceRequestExecute(ctx, projectId, region, instanceId)
+ if err != nil {
+ return false, nil, err
+ }
+ if s == nil || s.Id == nil || *s.Id != instanceId || s.Status == nil {
+ return false, nil, nil
+ }
+ switch *s.Status {
+ default:
+ return true, s, fmt.Errorf("instance with id %s has unexpected status %s", instanceId, *s.Status)
+ case InstanceStateEmpty:
+ return false, nil, nil
+ case InstanceStateProgressing:
+ return false, nil, nil
+ case InstanceStateSuccess:
+ return true, s, nil
+ case InstanceStateFailed:
+ return true, s, fmt.Errorf("update failed for instance with id %s", instanceId)
+ }
+ })
+ handler.SetTimeout(45 * time.Minute)
+ return handler
+}
+
+// DeleteInstanceWaitHandler will wait for instance deletion
+func DeleteInstanceWaitHandler(ctx context.Context, a APIClientInstanceInterface, projectId, region, instanceId string) *wait.AsyncActionHandler[struct{}] {
+ handler := wait.New(func() (waitFinished bool, response *struct{}, err error) {
+ s, err := a.GetInstanceRequestExecute(ctx, projectId, region, instanceId)
+ if err != nil {
+ return false, nil, err
+ }
+ if s == nil || s.Id == nil || *s.Id != instanceId || s.Status == nil {
+ return false, nil, nil
+ }
+ switch *s.Status {
+ default:
+ return true, nil, fmt.Errorf("instance with id %s has unexpected status %s", instanceId, *s.Status)
+ case InstanceStateSuccess:
+ return false, nil, nil
+ case InstanceStateDeleted:
+ return true, nil, nil
+ }
+ })
+ handler.SetTimeout(5 * time.Minute)
+ return handler
+}
+
+// ForceDeleteInstanceWaitHandler will wait for instance deletion
+func ForceDeleteInstanceWaitHandler(ctx context.Context, a APIClientInstanceInterface, projectId, region, instanceId string) *wait.AsyncActionHandler[struct{}] {
+ handler := wait.New(func() (waitFinished bool, response *struct{}, err error) {
+ _, err = a.GetInstanceRequestExecute(ctx, projectId, region, instanceId)
+ if err == nil {
+ return false, nil, nil
+ }
+ oapiErr, ok := err.(*oapierror.GenericOpenAPIError) //nolint:errorlint //complaining that error.As should be used to catch wrapped errors, but this error should not be wrapped
+ if !ok {
+ return false, nil, err
+ }
+ if oapiErr.StatusCode != 404 {
+ return false, nil, err
+ }
+ return true, nil, nil
+ })
+ handler.SetTimeout(15 * time.Minute)
+ return handler
+}
+
+// DeleteUserWaitHandler will wait for delete
+func DeleteUserWaitHandler(ctx context.Context, a APIClientUserInterface, projectId, region, instanceId string, userId int64) *wait.AsyncActionHandler[struct{}] {
+ handler := wait.New(func() (waitFinished bool, response *struct{}, err error) {
+ _, err = a.GetUserRequestExecute(ctx, projectId, region, instanceId, userId)
+ if err == nil {
+ return false, nil, nil
+ }
+ oapiErr, ok := err.(*oapierror.GenericOpenAPIError) //nolint:errorlint //complaining that error.As should be used to catch wrapped errors, but this error should not be wrapped
+ if !ok {
+ return false, nil, err
+ }
+ if oapiErr.StatusCode != 404 {
+ return false, nil, err
+ }
+ return true, nil, nil
+ })
+ handler.SetTimeout(1 * time.Minute)
+ return handler
+}
diff --git a/pkg/postgresflexalpha/wait/wait_test.go b/pkg/postgresflexalpha/wait/wait_test.go
new file mode 100644
index 00000000..a0270001
--- /dev/null
+++ b/pkg/postgresflexalpha/wait/wait_test.go
@@ -0,0 +1,389 @@
+package wait
+
+import (
+ "context"
+ "testing"
+ "time"
+
+ "github.com/google/go-cmp/cmp"
+ "github.com/stackitcloud/stackit-sdk-go/core/oapierror"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+ postgresflex "github.com/stackitcloud/terraform-provider-stackit/pkg/postgresflexalpha"
+)
+
+// Used for testing instance operations
+type apiClientInstanceMocked struct {
+ instanceId string
+ instanceState string
+ instanceIsForceDeleted bool
+ instanceGetFails bool
+ usersGetErrorStatus int
+}
+
+func (a *apiClientInstanceMocked) GetInstanceRequestExecute(_ context.Context, _, _, _ string) (*postgresflex.GetInstanceResponse, error) {
+ if a.instanceGetFails {
+ return nil, &oapierror.GenericOpenAPIError{
+ StatusCode: 500,
+ }
+ }
+
+ if a.instanceIsForceDeleted {
+ return nil, &oapierror.GenericOpenAPIError{
+ StatusCode: 404,
+ }
+ }
+
+ return &postgresflex.GetInstanceResponse{
+ Id: &a.instanceId,
+ Status: postgresflex.GetInstanceResponseGetStatusAttributeType(&a.instanceState),
+ }, nil
+}
+
+func (a *apiClientInstanceMocked) ListUsersRequestExecute(_ context.Context, _, _, _ string) (*postgresflex.ListUserResponse, error) {
+ if a.usersGetErrorStatus != 0 {
+ return nil, &oapierror.GenericOpenAPIError{
+ StatusCode: a.usersGetErrorStatus,
+ }
+ }
+
+ aux := int64(0)
+ return &postgresflex.ListUserResponse{
+ Pagination: &postgresflex.Pagination{
+ TotalRows: &aux,
+ },
+ Users: &[]postgresflex.ListUser{},
+ }, nil
+}
+
+// Used for testing user operations
+type apiClientUserMocked struct {
+ getFails bool
+ userId int64
+ isUserDeleted bool
+}
+
+func (a *apiClientUserMocked) GetUserRequestExecute(_ context.Context, _, _, _ string, _ int64) (*postgresflex.GetUserResponse, error) {
+ if a.getFails {
+ return nil, &oapierror.GenericOpenAPIError{
+ StatusCode: 500,
+ }
+ }
+
+ if a.isUserDeleted {
+ return nil, &oapierror.GenericOpenAPIError{
+ StatusCode: 404,
+ }
+ }
+
+ return &postgresflex.GetUserResponse{
+ Id: &a.userId,
+ }, nil
+}
+
+func TestCreateInstanceWaitHandler(t *testing.T) {
+ tests := []struct {
+ desc string
+ instanceGetFails bool
+ instanceState string
+ usersGetErrorStatus int
+ wantErr bool
+ wantResp bool
+ }{
+ {
+ desc: "create_succeeded",
+ instanceGetFails: false,
+ instanceState: InstanceStateSuccess,
+ wantErr: false,
+ wantResp: true,
+ },
+ {
+ desc: "create_failed",
+ instanceGetFails: false,
+ instanceState: InstanceStateFailed,
+ wantErr: true,
+ wantResp: true,
+ },
+ {
+ desc: "create_failed_2",
+ instanceGetFails: false,
+ instanceState: InstanceStateEmpty,
+ wantErr: true,
+ wantResp: false,
+ },
+ {
+ desc: "instance_get_fails",
+ instanceGetFails: true,
+ wantErr: true,
+ wantResp: false,
+ },
+ {
+ desc: "users_get_fails",
+ instanceGetFails: false,
+ instanceState: InstanceStateSuccess,
+ usersGetErrorStatus: 500,
+ wantErr: true,
+ wantResp: false,
+ },
+ {
+ desc: "users_get_fails_2",
+ instanceGetFails: false,
+ instanceState: InstanceStateSuccess,
+ usersGetErrorStatus: 400,
+ wantErr: true,
+ wantResp: true,
+ },
+ {
+ desc: "timeout",
+ instanceGetFails: false,
+ instanceState: InstanceStateProgressing,
+ wantErr: true,
+ wantResp: false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.desc, func(t *testing.T) {
+ instanceId := "foo-bar"
+
+ apiClient := &apiClientInstanceMocked{
+ instanceId: instanceId,
+ instanceState: tt.instanceState,
+ instanceGetFails: tt.instanceGetFails,
+ usersGetErrorStatus: tt.usersGetErrorStatus,
+ }
+
+ var wantRes *postgresflex.GetInstanceResponse
+ if tt.wantResp {
+ wantRes = &postgresflex.GetInstanceResponse{
+ Id: &instanceId,
+ Status: postgresflex.GetInstanceResponseGetStatusAttributeType(utils.Ptr(tt.instanceState)),
+ }
+ }
+
+ handler := CreateInstanceWaitHandler(context.Background(), apiClient, "", "", instanceId)
+
+ gotRes, err := handler.SetTimeout(10 * time.Millisecond).SetSleepBeforeWait(1 * time.Millisecond).WaitWithContext(context.Background())
+
+ if (err != nil) != tt.wantErr {
+ t.Fatalf("handler error = %v, wantErr %v", err, tt.wantErr)
+ }
+ if !cmp.Equal(gotRes, wantRes) {
+ t.Fatalf("handler gotRes = %v, want %v", gotRes, wantRes)
+ }
+ })
+ }
+}
+
+func TestUpdateInstanceWaitHandler(t *testing.T) {
+ tests := []struct {
+ desc string
+ instanceGetFails bool
+ instanceState string
+ wantErr bool
+ wantResp bool
+ }{
+ {
+ desc: "update_succeeded",
+ instanceGetFails: false,
+ instanceState: InstanceStateSuccess,
+ wantErr: false,
+ wantResp: true,
+ },
+ {
+ desc: "update_failed",
+ instanceGetFails: false,
+ instanceState: InstanceStateFailed,
+ wantErr: true,
+ wantResp: true,
+ },
+ {
+ desc: "update_failed_2",
+ instanceGetFails: false,
+ instanceState: InstanceStateEmpty,
+ wantErr: true,
+ wantResp: false,
+ },
+ {
+ desc: "get_fails",
+ instanceGetFails: true,
+ wantErr: true,
+ wantResp: false,
+ },
+ {
+ desc: "timeout",
+ instanceGetFails: false,
+ instanceState: InstanceStateProgressing,
+ wantErr: true,
+ wantResp: false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.desc, func(t *testing.T) {
+ instanceId := "foo-bar"
+
+ apiClient := &apiClientInstanceMocked{
+ instanceId: instanceId,
+ instanceState: tt.instanceState,
+ instanceGetFails: tt.instanceGetFails,
+ }
+
+ var wantRes *postgresflex.GetInstanceResponse
+ if tt.wantResp {
+ wantRes = &postgresflex.GetInstanceResponse{
+ Id: &instanceId,
+ Status: postgresflex.GetInstanceResponseGetStatusAttributeType(utils.Ptr(tt.instanceState)),
+ }
+ }
+
+ handler := PartialUpdateInstanceWaitHandler(context.Background(), apiClient, "", "", instanceId)
+
+ gotRes, err := handler.SetTimeout(10 * time.Millisecond).WaitWithContext(context.Background())
+
+ if (err != nil) != tt.wantErr {
+ t.Fatalf("handler error = %v, wantErr %v", err, tt.wantErr)
+ }
+ if !cmp.Equal(gotRes, wantRes) {
+ t.Fatalf("handler gotRes = %v, want %v", gotRes, wantRes)
+ }
+ })
+ }
+}
+
+func TestDeleteInstanceWaitHandler(t *testing.T) {
+ tests := []struct {
+ desc string
+ instanceGetFails bool
+ instanceState string
+ wantErr bool
+ }{
+ {
+ desc: "delete_succeeded",
+ instanceGetFails: false,
+ instanceState: InstanceStateDeleted,
+ wantErr: false,
+ },
+ {
+ desc: "delete_failed",
+ instanceGetFails: false,
+ instanceState: InstanceStateFailed,
+ wantErr: true,
+ },
+ {
+ desc: "get_fails",
+ instanceGetFails: true,
+ wantErr: true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.desc, func(t *testing.T) {
+ instanceId := "foo-bar"
+
+ apiClient := &apiClientInstanceMocked{
+ instanceGetFails: tt.instanceGetFails,
+ instanceId: instanceId,
+ instanceState: tt.instanceState,
+ }
+
+ handler := DeleteInstanceWaitHandler(context.Background(), apiClient, "", "", instanceId)
+
+ _, err := handler.SetTimeout(10 * time.Millisecond).WaitWithContext(context.Background())
+
+ if (err != nil) != tt.wantErr {
+ t.Fatalf("handler error = %v, wantErr %v", err, tt.wantErr)
+ }
+ })
+ }
+}
+
+func TestForceDeleteInstanceWaitHandler(t *testing.T) {
+ tests := []struct {
+ desc string
+ instanceGetFails bool
+ instanceState string
+ wantErr bool
+ }{
+ {
+ desc: "delete_succeeded",
+ instanceGetFails: false,
+ instanceState: InstanceStateDeleted,
+ wantErr: false,
+ },
+ {
+ desc: "delete_failed",
+ instanceGetFails: false,
+ instanceState: InstanceStateFailed,
+ wantErr: true,
+ },
+ {
+ desc: "get_fails",
+ instanceGetFails: true,
+ wantErr: true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.desc, func(t *testing.T) {
+ instanceId := "foo-bar"
+
+ apiClient := &apiClientInstanceMocked{
+ instanceGetFails: tt.instanceGetFails,
+ instanceIsForceDeleted: tt.instanceState == InstanceStateDeleted,
+ instanceId: instanceId,
+ instanceState: tt.instanceState,
+ }
+
+ handler := ForceDeleteInstanceWaitHandler(context.Background(), apiClient, "", "", instanceId)
+
+ _, err := handler.SetTimeout(10 * time.Millisecond).WaitWithContext(context.Background())
+
+ if (err != nil) != tt.wantErr {
+ t.Fatalf("handler error = %v, wantErr %v", err, tt.wantErr)
+ }
+ })
+ }
+}
+
+func TestDeleteUserWaitHandler(t *testing.T) {
+ tests := []struct {
+ desc string
+ deleteFails bool
+ getFails bool
+ wantErr bool
+ }{
+ {
+ desc: "delete_succeeded",
+ deleteFails: false,
+ getFails: false,
+ wantErr: false,
+ },
+ {
+ desc: "delete_failed",
+ deleteFails: true,
+ getFails: false,
+ wantErr: true,
+ },
+ {
+ desc: "get_fails",
+ deleteFails: false,
+ getFails: true,
+ wantErr: true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.desc, func(t *testing.T) {
+ userId := int64(1001)
+
+ apiClient := &apiClientUserMocked{
+ getFails: tt.getFails,
+ userId: userId,
+ isUserDeleted: !tt.deleteFails,
+ }
+
+ handler := DeleteUserWaitHandler(context.Background(), apiClient, "", "", "", userId)
+
+ _, err := handler.SetTimeout(10 * time.Millisecond).WaitWithContext(context.Background())
+
+ if (err != nil) != tt.wantErr {
+ t.Fatalf("handler error = %v, wantErr %v", err, tt.wantErr)
+ }
+ })
+ }
+}
diff --git a/pkg/sqlserverflexalpha/.openapi-generator/VERSION b/pkg/sqlserverflexalpha/.openapi-generator/VERSION
new file mode 100644
index 00000000..cd802a1e
--- /dev/null
+++ b/pkg/sqlserverflexalpha/.openapi-generator/VERSION
@@ -0,0 +1 @@
+6.6.0
\ No newline at end of file
diff --git a/pkg/sqlserverflexalpha/api_default.go b/pkg/sqlserverflexalpha/api_default.go
new file mode 100644
index 00000000..08774fd3
--- /dev/null
+++ b/pkg/sqlserverflexalpha/api_default.go
@@ -0,0 +1,6176 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "bytes"
+ "context"
+ "fmt"
+ "io"
+ "net/http"
+ "net/url"
+ "strings"
+
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+ "github.com/stackitcloud/stackit-sdk-go/core/oapierror"
+)
+
+type DefaultApi interface {
+ /*
+ CreateDatabaseRequest Create Database
+ Create database for a user. Note: The name of a valid user must be provided in the 'options' map field using the key 'owner'
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiCreateDatabaseRequestRequest
+ */
+ CreateDatabaseRequest(ctx context.Context, projectId string, region string, instanceId string) ApiCreateDatabaseRequestRequest
+ /*
+ CreateDatabaseRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return CreateDatabaseResponse
+
+ */
+ CreateDatabaseRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*CreateDatabaseResponse, error)
+ /*
+ CreateInstanceRequest Create Instance
+ Create a new instance of a sqlserver database instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiCreateInstanceRequestRequest
+ */
+ CreateInstanceRequest(ctx context.Context, projectId string, region string) ApiCreateInstanceRequestRequest
+ /*
+ CreateInstanceRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return CreateInstanceResponse
+
+ */
+ CreateInstanceRequestExecute(ctx context.Context, projectId string, region string) (*CreateInstanceResponse, error)
+ /*
+ CreateUserRequest Create User
+ Create user for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiCreateUserRequestRequest
+ */
+ CreateUserRequest(ctx context.Context, projectId string, region string, instanceId string) ApiCreateUserRequestRequest
+ /*
+ CreateUserRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return CreateUserResponse
+
+ */
+ CreateUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*CreateUserResponse, error)
+ /*
+ DeleteDatabaseRequest Delete Database
+ Delete database for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseName The name of the database.
+ @return ApiDeleteDatabaseRequestRequest
+ */
+ DeleteDatabaseRequest(ctx context.Context, projectId string, region string, instanceId string, databaseName string) ApiDeleteDatabaseRequestRequest
+ /*
+ DeleteDatabaseRequestExecute executes the request
+
+ */
+ DeleteDatabaseRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseName string) error
+ /*
+ DeleteInstanceRequest Delete Instance
+ Delete an available sqlserver instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiDeleteInstanceRequestRequest
+ */
+ DeleteInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiDeleteInstanceRequestRequest
+ /*
+ DeleteInstanceRequestExecute executes the request
+
+ */
+ DeleteInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) error
+ /*
+ DeleteUserRequest Delete User
+ Delete an user from a specific instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiDeleteUserRequestRequest
+ */
+ DeleteUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiDeleteUserRequestRequest
+ /*
+ DeleteUserRequestExecute executes the request
+
+ */
+ DeleteUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) error
+ /*
+ GetBackupRequest Get specific backup
+ Get information about a specific backup for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param backupId The ID of the backup.
+ @return ApiGetBackupRequestRequest
+ */
+ GetBackupRequest(ctx context.Context, projectId string, region string, instanceId string, backupId int64) ApiGetBackupRequestRequest
+ /*
+ GetBackupRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param backupId The ID of the backup.
+ @return GetBackupResponse
+
+ */
+ GetBackupRequestExecute(ctx context.Context, projectId string, region string, instanceId string, backupId int64) (*GetBackupResponse, error)
+ /*
+ GetCollationsRequest Get database collation list
+ Returns a list of collations for an instance
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiGetCollationsRequestRequest
+ */
+ GetCollationsRequest(ctx context.Context, projectId string, region string, instanceId string) ApiGetCollationsRequestRequest
+ /*
+ GetCollationsRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return GetCollationsResponse
+
+ */
+ GetCollationsRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*GetCollationsResponse, error)
+ /*
+ GetDatabaseRequest Get Database
+ Get specific available database
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseName The name of the database.
+ @return ApiGetDatabaseRequestRequest
+ */
+ GetDatabaseRequest(ctx context.Context, projectId string, region string, instanceId string, databaseName string) ApiGetDatabaseRequestRequest
+ /*
+ GetDatabaseRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseName The name of the database.
+ @return GetDatabaseResponse
+
+ */
+ GetDatabaseRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseName string) (*GetDatabaseResponse, error)
+ /*
+ GetFlavorsRequest Get Flavors
+ Get all available flavors for a project.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiGetFlavorsRequestRequest
+ */
+ GetFlavorsRequest(ctx context.Context, projectId, region string, page, size *int64, sort FlavorSort) ApiGetFlavorsRequestRequest
+ /*
+ GetFlavorsRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return GetFlavorsResponse
+
+ */
+ GetFlavorsRequestExecute(ctx context.Context, projectId, region string, page, size *int64, sort FlavorSort) (*GetFlavorsResponse, error)
+ /*
+ GetInstanceRequest Get Specific Instance
+ Get information about a specific available instance
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiGetInstanceRequestRequest
+ */
+ GetInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiGetInstanceRequestRequest
+ /*
+ GetInstanceRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return GetInstanceResponse
+
+ */
+ GetInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*GetInstanceResponse, error)
+ /*
+ GetStoragesRequest Get Storages
+ Get available storages for a specific flavor
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param flavorId The id of an instance flavor.
+ @return ApiGetStoragesRequestRequest
+ */
+ GetStoragesRequest(ctx context.Context, projectId string, region string, flavorId string) ApiGetStoragesRequestRequest
+ /*
+ GetStoragesRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param flavorId The id of an instance flavor.
+ @return GetStoragesResponse
+
+ */
+ GetStoragesRequestExecute(ctx context.Context, projectId string, region string, flavorId string) (*GetStoragesResponse, error)
+ /*
+ GetUserRequest Get User
+ Get a specific available user for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiGetUserRequestRequest
+ */
+ GetUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiGetUserRequestRequest
+ /*
+ GetUserRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return GetUserResponse
+
+ */
+ GetUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) (*GetUserResponse, error)
+ /*
+ GetVersionsRequest Get Versions
+ Get the sqlserver available versions for the project.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiGetVersionsRequestRequest
+ */
+ GetVersionsRequest(ctx context.Context, projectId string, region string) ApiGetVersionsRequestRequest
+ /*
+ GetVersionsRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return GetVersionsResponse
+
+ */
+ GetVersionsRequestExecute(ctx context.Context, projectId string, region string) (*GetVersionsResponse, error)
+ /*
+ ListBackupsRequest List backups
+ List all backups which are available for a specific instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListBackupsRequestRequest
+ */
+ ListBackupsRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListBackupsRequestRequest
+ /*
+ ListBackupsRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ListBackupResponse
+
+ */
+ ListBackupsRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListBackupResponse, error)
+ /*
+ ListCompatibilitiesRequest Get database compatibility list
+ Returns a list of compatibility levels for creating a new database
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListCompatibilitiesRequestRequest
+ */
+ ListCompatibilitiesRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListCompatibilitiesRequestRequest
+ /*
+ ListCompatibilitiesRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ListCompatibilityResponse
+
+ */
+ ListCompatibilitiesRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListCompatibilityResponse, error)
+ /*
+ ListCurrentRunningRestoreJobs List current running restore jobs
+ List all currently running restore jobs which are available for a specific instance
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListCurrentRunningRestoreJobsRequest
+ */
+ ListCurrentRunningRestoreJobs(ctx context.Context, projectId string, region string, instanceId string) ApiListCurrentRunningRestoreJobsRequest
+ /*
+ ListCurrentRunningRestoreJobsExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ListCurrentRunningRestoreJobs
+
+ */
+ ListCurrentRunningRestoreJobsExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListCurrentRunningRestoreJobs, error)
+ /*
+ ListDatabasesRequest List Databases
+ List available databases for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListDatabasesRequestRequest
+ */
+ ListDatabasesRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListDatabasesRequestRequest
+ /*
+ ListDatabasesRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ListDatabasesResponse
+
+ */
+ ListDatabasesRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListDatabasesResponse, error)
+ /*
+ ListInstancesRequest List Instances
+ List all available instances for your project.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiListInstancesRequestRequest
+ */
+ ListInstancesRequest(ctx context.Context, projectId string, region string) ApiListInstancesRequestRequest
+ /*
+ ListInstancesRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ListInstancesResponse
+
+ */
+ ListInstancesRequestExecute(ctx context.Context, projectId string, region string) (*ListInstancesResponse, error)
+ /*
+ ListRolesRequest List Roles
+ List available roles for an instance that can be assigned to a user
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListRolesRequestRequest
+ */
+ ListRolesRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListRolesRequestRequest
+ /*
+ ListRolesRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ListRolesResponse
+
+ */
+ ListRolesRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListRolesResponse, error)
+ /*
+ ListUsersRequest List Users
+ List available users for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListUsersRequestRequest
+ */
+ ListUsersRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListUsersRequestRequest
+ /*
+ ListUsersRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ListUserResponse
+
+ */
+ ListUsersRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListUserResponse, error)
+ /*
+ ProtectInstanceRequest Protect Instance
+ Toggle the deletion protection for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiProtectInstanceRequestRequest
+ */
+ ProtectInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiProtectInstanceRequestRequest
+ /*
+ ProtectInstanceRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ProtectInstanceResponse
+
+ */
+ ProtectInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ProtectInstanceResponse, error)
+ /*
+ ResetUserRequest Reset User
+ Reset an user from an specific instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiResetUserRequestRequest
+ */
+ ResetUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiResetUserRequestRequest
+ /*
+ ResetUserRequestExecute executes the request
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ResetUserResponse
+
+ */
+ ResetUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) (*ResetUserResponse, error)
+ /*
+ TriggerBackupRequest Trigger backup for a specific Database
+ Trigger backup for a specific database
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseName The name of the database.
+ @return ApiTriggerBackupRequestRequest
+ */
+ TriggerBackupRequest(ctx context.Context, projectId string, region string, instanceId string, databaseName string) ApiTriggerBackupRequestRequest
+ /*
+ TriggerBackupRequestExecute executes the request
+
+ */
+ TriggerBackupRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseName string) error
+ /*
+ TriggerRestoreRequest Trigger restore for a specific Database
+ Trigger restore for a specific Database
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseName The name of the database.
+ @return ApiTriggerRestoreRequestRequest
+ */
+ TriggerRestoreRequest(ctx context.Context, projectId string, region string, instanceId string, databaseName string) ApiTriggerRestoreRequestRequest
+ /*
+ TriggerRestoreRequestExecute executes the request
+
+ */
+ TriggerRestoreRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseName string) error
+ /*
+ UpdateInstancePartiallyRequest Update Instance Partially
+ Update an available instance of a mssql database. No fields are required.
+
+ **Please note that any changes applied via PUT or PATCH requests will initiate a reboot of the SQL Server Flex Instance.**
+
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiUpdateInstancePartiallyRequestRequest
+ */
+ UpdateInstancePartiallyRequest(ctx context.Context, projectId string, region string, instanceId string) ApiUpdateInstancePartiallyRequestRequest
+ /*
+ UpdateInstancePartiallyRequestExecute executes the request
+
+ */
+ UpdateInstancePartiallyRequestExecute(ctx context.Context, projectId string, region string, instanceId string) error
+ /*
+ UpdateInstanceRequest Update Instance
+ Updates an available instance of a sqlserver database
+
+ **Please note that any changes applied via PUT or PATCH requests will initiate a reboot of the SQL Server Flex Instance.**
+
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiUpdateInstanceRequestRequest
+ */
+ UpdateInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiUpdateInstanceRequestRequest
+ /*
+ UpdateInstanceRequestExecute executes the request
+
+ */
+ UpdateInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) error
+}
+
+type ApiCreateDatabaseRequestRequest interface {
+ // The request body containing the information for the new database.
+ CreateDatabaseRequestPayload(createDatabaseRequestPayload CreateDatabaseRequestPayload) ApiCreateDatabaseRequestRequest
+ Execute() (*CreateDatabaseResponse, error)
+}
+
+type ApiCreateInstanceRequestRequest interface {
+ // The request body with the parameters for the instance creation. Every parameter is required.
+ CreateInstanceRequestPayload(createInstanceRequestPayload CreateInstanceRequestPayload) ApiCreateInstanceRequestRequest
+ Execute() (*CreateInstanceResponse, error)
+}
+
+type ApiCreateUserRequestRequest interface {
+ // The request body containing the user details.
+ CreateUserRequestPayload(createUserRequestPayload CreateUserRequestPayload) ApiCreateUserRequestRequest
+ Execute() (*CreateUserResponse, error)
+}
+
+type ApiDeleteDatabaseRequestRequest interface {
+ Execute() error
+}
+
+type ApiDeleteInstanceRequestRequest interface {
+ Execute() error
+}
+
+type ApiDeleteUserRequestRequest interface {
+ Execute() error
+}
+
+type ApiGetBackupRequestRequest interface {
+ Execute() (*GetBackupResponse, error)
+}
+
+type ApiGetCollationsRequestRequest interface {
+ Execute() (*GetCollationsResponse, error)
+}
+
+type ApiGetDatabaseRequestRequest interface {
+ Execute() (*GetDatabaseResponse, error)
+}
+
+type ApiGetFlavorsRequestRequest interface {
+ // Number of the page of items list to be returned.
+ Page(page int64) ApiGetFlavorsRequestRequest
+ // Number of items to be returned on each page.
+ Size(size int64) ApiGetFlavorsRequestRequest
+ // Sorting of the flavors to be returned on each page.
+ Sort(sort FlavorSort) ApiGetFlavorsRequestRequest
+ Execute() (*GetFlavorsResponse, error)
+}
+
+type ApiGetInstanceRequestRequest interface {
+ Execute() (*GetInstanceResponse, error)
+}
+
+type ApiGetStoragesRequestRequest interface {
+ Execute() (*GetStoragesResponse, error)
+}
+
+type ApiGetUserRequestRequest interface {
+ Execute() (*GetUserResponse, error)
+}
+
+type ApiGetVersionsRequestRequest interface {
+ Execute() (*GetVersionsResponse, error)
+}
+
+type ApiListBackupsRequestRequest interface {
+ // Number of the page of items list to be returned.
+ Page(page int64) ApiListBackupsRequestRequest
+ // Number of items to be returned on each page.
+ Size(size int64) ApiListBackupsRequestRequest
+ // Sorting of the backups to be returned on each page.
+ Sort(sort BackupSort) ApiListBackupsRequestRequest
+ Execute() (*ListBackupResponse, error)
+}
+
+type ApiListCompatibilitiesRequestRequest interface {
+ Execute() (*ListCompatibilityResponse, error)
+}
+
+type ApiListCurrentRunningRestoreJobsRequest interface {
+ Execute() (*ListCurrentRunningRestoreJobs, error)
+}
+
+type ApiListDatabasesRequestRequest interface {
+ // Number of the page of items list to be returned.
+ Page(page int64) ApiListDatabasesRequestRequest
+ // Number of items to be returned on each page.
+ Size(size int64) ApiListDatabasesRequestRequest
+ // Sorting of the databases to be returned on each page.
+ Sort(sort DatabaseSort) ApiListDatabasesRequestRequest
+ Execute() (*ListDatabasesResponse, error)
+}
+
+type ApiListInstancesRequestRequest interface {
+ // Number of the page of items list to be returned.
+ Page(page int64) ApiListInstancesRequestRequest
+ // Number of items to be returned on each page.
+ Size(size int64) ApiListInstancesRequestRequest
+ // Sorting of the items to be returned on each page.
+ Sort(sort InstanceSort) ApiListInstancesRequestRequest
+ Execute() (*ListInstancesResponse, error)
+}
+
+type ApiListRolesRequestRequest interface {
+ Execute() (*ListRolesResponse, error)
+}
+
+type ApiListUsersRequestRequest interface {
+ // Number of the page of items list to be returned.
+ Page(page int64) ApiListUsersRequestRequest
+ // Number of items to be returned on each page.
+ Size(size int64) ApiListUsersRequestRequest
+ // Sorting of the users to be returned on each page.
+ Sort(sort UserSort) ApiListUsersRequestRequest
+ Execute() (*ListUserResponse, error)
+}
+
+type ApiProtectInstanceRequestRequest interface {
+ // The request body with flag isDeletable. Parameter is required.
+ ProtectInstanceRequestPayload(protectInstanceRequestPayload ProtectInstanceRequestPayload) ApiProtectInstanceRequestRequest
+ Execute() (*ProtectInstanceResponse, error)
+}
+
+type ApiResetUserRequestRequest interface {
+ Execute() (*ResetUserResponse, error)
+}
+
+type ApiTriggerBackupRequestRequest interface {
+ Execute() error
+}
+
+type ApiTriggerRestoreRequestRequest interface {
+ // The request body with the parameters for the database restore.
+ TriggerRestoreRequestPayload(triggerRestoreRequestPayload TriggerRestoreRequestPayload) ApiTriggerRestoreRequestRequest
+ Execute() error
+}
+
+type ApiUpdateInstancePartiallyRequestRequest interface {
+ // The request body with the parameters for updating the instance.
+ UpdateInstancePartiallyRequestPayload(updateInstancePartiallyRequestPayload UpdateInstancePartiallyRequestPayload) ApiUpdateInstancePartiallyRequestRequest
+ Execute() error
+}
+
+type ApiUpdateInstanceRequestRequest interface {
+ // The request body with the parameters for updating the instance
+ UpdateInstanceRequestPayload(updateInstanceRequestPayload UpdateInstanceRequestPayload) ApiUpdateInstanceRequestRequest
+ Execute() error
+}
+
+// DefaultApiService DefaultApi service
+type DefaultApiService service
+
+type CreateDatabaseRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ createDatabaseRequestPayload *CreateDatabaseRequestPayload
+}
+
+// The request body containing the information for the new database.
+
+func (r CreateDatabaseRequestRequest) CreateDatabaseRequestPayload(createDatabaseRequestPayload CreateDatabaseRequestPayload) ApiCreateDatabaseRequestRequest {
+ r.createDatabaseRequestPayload = &createDatabaseRequestPayload
+ return r
+}
+
+func (r CreateDatabaseRequestRequest) Execute() (*CreateDatabaseResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *CreateDatabaseResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.CreateDatabaseRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.createDatabaseRequestPayload == nil {
+ return localVarReturnValue, fmt.Errorf("createDatabaseRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.createDatabaseRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+CreateDatabaseRequest: Create Database
+
+Create database for a user. Note: The name of a valid user must be provided in the 'options' map field using the key 'owner'
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiCreateDatabaseRequestRequest
+*/
+func (a *APIClient) CreateDatabaseRequest(ctx context.Context, projectId string, region string, instanceId string) ApiCreateDatabaseRequestRequest {
+ return CreateDatabaseRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) CreateDatabaseRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*CreateDatabaseResponse, error) {
+ r := CreateDatabaseRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type CreateInstanceRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ createInstanceRequestPayload *CreateInstanceRequestPayload
+}
+
+// The request body with the parameters for the instance creation. Every parameter is required.
+
+func (r CreateInstanceRequestRequest) CreateInstanceRequestPayload(createInstanceRequestPayload CreateInstanceRequestPayload) ApiCreateInstanceRequestRequest {
+ r.createInstanceRequestPayload = &createInstanceRequestPayload
+ return r
+}
+
+func (r CreateInstanceRequestRequest) Execute() (*CreateInstanceResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *CreateInstanceResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.CreateInstanceRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.createInstanceRequestPayload == nil {
+ return localVarReturnValue, fmt.Errorf("createInstanceRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.createInstanceRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+CreateInstanceRequest: Create Instance
+
+Create a new instance of a sqlserver database instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiCreateInstanceRequestRequest
+*/
+func (a *APIClient) CreateInstanceRequest(ctx context.Context, projectId string, region string) ApiCreateInstanceRequestRequest {
+ return CreateInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+}
+
+func (a *APIClient) CreateInstanceRequestExecute(ctx context.Context, projectId string, region string) (*CreateInstanceResponse, error) {
+ r := CreateInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+ return r.Execute()
+}
+
+type CreateUserRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ createUserRequestPayload *CreateUserRequestPayload
+}
+
+// The request body containing the user details.
+
+func (r CreateUserRequestRequest) CreateUserRequestPayload(createUserRequestPayload CreateUserRequestPayload) ApiCreateUserRequestRequest {
+ r.createUserRequestPayload = &createUserRequestPayload
+ return r
+}
+
+func (r CreateUserRequestRequest) Execute() (*CreateUserResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *CreateUserResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.CreateUserRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.createUserRequestPayload == nil {
+ return localVarReturnValue, fmt.Errorf("createUserRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.createUserRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+CreateUserRequest: Create User
+
+Create user for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiCreateUserRequestRequest
+*/
+func (a *APIClient) CreateUserRequest(ctx context.Context, projectId string, region string, instanceId string) ApiCreateUserRequestRequest {
+ return CreateUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) CreateUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*CreateUserResponse, error) {
+ r := CreateUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type DeleteDatabaseRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ databaseName string
+}
+
+func (r DeleteDatabaseRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodDelete
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.DeleteDatabaseRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases/{databaseName}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"databaseName"+"}", url.PathEscape(ParameterValueToString(r.databaseName, "databaseName")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+DeleteDatabaseRequest: Delete Database
+
+Delete database for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseName The name of the database.
+ @return ApiDeleteDatabaseRequestRequest
+*/
+func (a *APIClient) DeleteDatabaseRequest(ctx context.Context, projectId string, region string, instanceId string, databaseName string) ApiDeleteDatabaseRequestRequest {
+ return DeleteDatabaseRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseName: databaseName,
+ }
+}
+
+func (a *APIClient) DeleteDatabaseRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseName string) error {
+ r := DeleteDatabaseRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseName: databaseName,
+ }
+ return r.Execute()
+}
+
+type DeleteInstanceRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+}
+
+func (r DeleteInstanceRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodDelete
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.DeleteInstanceRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+DeleteInstanceRequest: Delete Instance
+
+Delete an available sqlserver instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiDeleteInstanceRequestRequest
+*/
+func (a *APIClient) DeleteInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiDeleteInstanceRequestRequest {
+ return DeleteInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) DeleteInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) error {
+ r := DeleteInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type DeleteUserRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ userId int64
+}
+
+func (r DeleteUserRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodDelete
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.DeleteUserRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(r.userId, "userId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+DeleteUserRequest: Delete User
+
+Delete an user from a specific instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiDeleteUserRequestRequest
+*/
+func (a *APIClient) DeleteUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiDeleteUserRequestRequest {
+ return DeleteUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+}
+
+func (a *APIClient) DeleteUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) error {
+ r := DeleteUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+ return r.Execute()
+}
+
+type GetBackupRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ backupId int64
+}
+
+func (r GetBackupRequestRequest) Execute() (*GetBackupResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetBackupResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetBackupRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups/{backupId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"backupId"+"}", url.PathEscape(ParameterValueToString(r.backupId, "backupId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetBackupRequest: Get specific backup
+
+Get information about a specific backup for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param backupId The ID of the backup.
+ @return ApiGetBackupRequestRequest
+*/
+func (a *APIClient) GetBackupRequest(ctx context.Context, projectId string, region string, instanceId string, backupId int64) ApiGetBackupRequestRequest {
+ return GetBackupRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ backupId: backupId,
+ }
+}
+
+func (a *APIClient) GetBackupRequestExecute(ctx context.Context, projectId string, region string, instanceId string, backupId int64) (*GetBackupResponse, error) {
+ r := GetBackupRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ backupId: backupId,
+ }
+ return r.Execute()
+}
+
+type GetCollationsRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+}
+
+func (r GetCollationsRequestRequest) Execute() (*GetCollationsResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetCollationsResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetCollationsRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/collations"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetCollationsRequest: Get database collation list
+
+Returns a list of collations for an instance
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiGetCollationsRequestRequest
+*/
+func (a *APIClient) GetCollationsRequest(ctx context.Context, projectId string, region string, instanceId string) ApiGetCollationsRequestRequest {
+ return GetCollationsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) GetCollationsRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*GetCollationsResponse, error) {
+ r := GetCollationsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type GetDatabaseRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ databaseName string
+}
+
+func (r GetDatabaseRequestRequest) Execute() (*GetDatabaseResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetDatabaseResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetDatabaseRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases/{databaseName}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"databaseName"+"}", url.PathEscape(ParameterValueToString(r.databaseName, "databaseName")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetDatabaseRequest: Get Database
+
+Get specific available database
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseName The name of the database.
+ @return ApiGetDatabaseRequestRequest
+*/
+func (a *APIClient) GetDatabaseRequest(ctx context.Context, projectId string, region string, instanceId string, databaseName string) ApiGetDatabaseRequestRequest {
+ return GetDatabaseRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseName: databaseName,
+ }
+}
+
+func (a *APIClient) GetDatabaseRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseName string) (*GetDatabaseResponse, error) {
+ r := GetDatabaseRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseName: databaseName,
+ }
+ return r.Execute()
+}
+
+type GetFlavorsRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ page *int64
+ size *int64
+ sort *FlavorSort
+}
+
+// Number of the page of items list to be returned.
+
+func (r GetFlavorsRequestRequest) Page(page int64) ApiGetFlavorsRequestRequest {
+ r.page = &page
+ return r
+}
+
+// Number of items to be returned on each page.
+
+func (r GetFlavorsRequestRequest) Size(size int64) ApiGetFlavorsRequestRequest {
+ r.size = &size
+ return r
+}
+
+// Sorting of the flavors to be returned on each page.
+
+func (r GetFlavorsRequestRequest) Sort(sort FlavorSort) ApiGetFlavorsRequestRequest {
+ r.sort = &sort
+ return r
+}
+
+func (r GetFlavorsRequestRequest) Execute() (*GetFlavorsResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetFlavorsResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetFlavorsRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/flavors"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ if r.page != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "page", r.page, "")
+ }
+ if r.size != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "size", r.size, "")
+ }
+ if r.sort != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "sort", r.sort, "")
+ }
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetFlavorsRequest: Get Flavors
+
+Get all available flavors for a project.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiGetFlavorsRequestRequest
+*/
+func (a *APIClient) GetFlavorsRequest(ctx context.Context, projectId, region string, page, size *int64, sort FlavorSort) ApiGetFlavorsRequestRequest {
+ return GetFlavorsRequestRequest{
+ ctx: ctx,
+ apiService: a.defaultApi,
+ projectId: projectId,
+ region: region,
+ page: page,
+ size: size,
+ sort: &sort,
+ }
+}
+
+func (a *APIClient) GetFlavorsRequestExecute(ctx context.Context, projectId, region string, page, size *int64, sort FlavorSort) (*GetFlavorsResponse, error) {
+ r := GetFlavorsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ page: page,
+ size: size,
+ sort: &sort,
+ }
+ return r.Execute()
+}
+
+type GetInstanceRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+}
+
+func (r GetInstanceRequestRequest) Execute() (*GetInstanceResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetInstanceResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetInstanceRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetInstanceRequest: Get Specific Instance
+
+Get information about a specific available instance
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiGetInstanceRequestRequest
+*/
+func (a *APIClient) GetInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiGetInstanceRequestRequest {
+ return GetInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) GetInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*GetInstanceResponse, error) {
+ r := GetInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type GetStoragesRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ flavorId string
+}
+
+func (r GetStoragesRequestRequest) Execute() (*GetStoragesResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetStoragesResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetStoragesRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/storages/{flavorId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"flavorId"+"}", url.PathEscape(ParameterValueToString(r.flavorId, "flavorId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetStoragesRequest: Get Storages
+
+Get available storages for a specific flavor
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param flavorId The id of an instance flavor.
+ @return ApiGetStoragesRequestRequest
+*/
+func (a *APIClient) GetStoragesRequest(ctx context.Context, projectId string, region string, flavorId string) ApiGetStoragesRequestRequest {
+ return GetStoragesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ flavorId: flavorId,
+ }
+}
+
+func (a *APIClient) GetStoragesRequestExecute(ctx context.Context, projectId string, region string, flavorId string) (*GetStoragesResponse, error) {
+ r := GetStoragesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ flavorId: flavorId,
+ }
+ return r.Execute()
+}
+
+type GetUserRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ userId int64
+}
+
+func (r GetUserRequestRequest) Execute() (*GetUserResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetUserResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetUserRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(r.userId, "userId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetUserRequest: Get User
+
+Get a specific available user for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiGetUserRequestRequest
+*/
+func (a *APIClient) GetUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiGetUserRequestRequest {
+ return GetUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+}
+
+func (a *APIClient) GetUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) (*GetUserResponse, error) {
+ r := GetUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+ return r.Execute()
+}
+
+type GetVersionsRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+}
+
+func (r GetVersionsRequestRequest) Execute() (*GetVersionsResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *GetVersionsResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.GetVersionsRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/versions"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+GetVersionsRequest: Get Versions
+
+Get the sqlserver available versions for the project.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiGetVersionsRequestRequest
+*/
+func (a *APIClient) GetVersionsRequest(ctx context.Context, projectId string, region string) ApiGetVersionsRequestRequest {
+ return GetVersionsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+}
+
+func (a *APIClient) GetVersionsRequestExecute(ctx context.Context, projectId string, region string) (*GetVersionsResponse, error) {
+ r := GetVersionsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+ return r.Execute()
+}
+
+type ListBackupsRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ page *int64
+ size *int64
+ sort *BackupSort
+}
+
+// Number of the page of items list to be returned.
+
+func (r ListBackupsRequestRequest) Page(page int64) ApiListBackupsRequestRequest {
+ r.page = &page
+ return r
+}
+
+// Number of items to be returned on each page.
+
+func (r ListBackupsRequestRequest) Size(size int64) ApiListBackupsRequestRequest {
+ r.size = &size
+ return r
+}
+
+// Sorting of the backups to be returned on each page.
+
+func (r ListBackupsRequestRequest) Sort(sort BackupSort) ApiListBackupsRequestRequest {
+ r.sort = &sort
+ return r
+}
+
+func (r ListBackupsRequestRequest) Execute() (*ListBackupResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ListBackupResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ListBackupsRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ if r.page != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "page", r.page, "")
+ }
+ if r.size != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "size", r.size, "")
+ }
+ if r.sort != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "sort", r.sort, "")
+ }
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ListBackupsRequest: List backups
+
+List all backups which are available for a specific instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListBackupsRequestRequest
+*/
+func (a *APIClient) ListBackupsRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListBackupsRequestRequest {
+ return ListBackupsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) ListBackupsRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListBackupResponse, error) {
+ r := ListBackupsRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type ListCompatibilitiesRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+}
+
+func (r ListCompatibilitiesRequestRequest) Execute() (*ListCompatibilityResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ListCompatibilityResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ListCompatibilitiesRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/compatibility"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ListCompatibilitiesRequest: Get database compatibility list
+
+Returns a list of compatibility levels for creating a new database
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListCompatibilitiesRequestRequest
+*/
+func (a *APIClient) ListCompatibilitiesRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListCompatibilitiesRequestRequest {
+ return ListCompatibilitiesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) ListCompatibilitiesRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListCompatibilityResponse, error) {
+ r := ListCompatibilitiesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type ListCurrentRunningRestoreJobsRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+}
+
+func (r ListCurrentRunningRestoreJobsRequest) Execute() (*ListCurrentRunningRestoreJobs, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ListCurrentRunningRestoreJobs
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ListCurrentRunningRestoreJobs")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/restore-jobs"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ListCurrentRunningRestoreJobs: List current running restore jobs
+
+List all currently running restore jobs which are available for a specific instance
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListCurrentRunningRestoreJobsRequest
+*/
+func (a *APIClient) ListCurrentRunningRestoreJobs(ctx context.Context, projectId string, region string, instanceId string) ApiListCurrentRunningRestoreJobsRequest {
+ return ListCurrentRunningRestoreJobsRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) ListCurrentRunningRestoreJobsExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListCurrentRunningRestoreJobs, error) {
+ r := ListCurrentRunningRestoreJobsRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type ListDatabasesRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ page *int64
+ size *int64
+ sort *DatabaseSort
+}
+
+// Number of the page of items list to be returned.
+
+func (r ListDatabasesRequestRequest) Page(page int64) ApiListDatabasesRequestRequest {
+ r.page = &page
+ return r
+}
+
+// Number of items to be returned on each page.
+
+func (r ListDatabasesRequestRequest) Size(size int64) ApiListDatabasesRequestRequest {
+ r.size = &size
+ return r
+}
+
+// Sorting of the databases to be returned on each page.
+
+func (r ListDatabasesRequestRequest) Sort(sort DatabaseSort) ApiListDatabasesRequestRequest {
+ r.sort = &sort
+ return r
+}
+
+func (r ListDatabasesRequestRequest) Execute() (*ListDatabasesResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ListDatabasesResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ListDatabasesRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ if r.page != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "page", r.page, "")
+ }
+ if r.size != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "size", r.size, "")
+ }
+ if r.sort != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "sort", r.sort, "")
+ }
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ListDatabasesRequest: List Databases
+
+List available databases for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListDatabasesRequestRequest
+*/
+func (a *APIClient) ListDatabasesRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListDatabasesRequestRequest {
+ return ListDatabasesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) ListDatabasesRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListDatabasesResponse, error) {
+ r := ListDatabasesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type ListInstancesRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ page *int64
+ size *int64
+ sort *InstanceSort
+}
+
+// Number of the page of items list to be returned.
+
+func (r ListInstancesRequestRequest) Page(page int64) ApiListInstancesRequestRequest {
+ r.page = &page
+ return r
+}
+
+// Number of items to be returned on each page.
+
+func (r ListInstancesRequestRequest) Size(size int64) ApiListInstancesRequestRequest {
+ r.size = &size
+ return r
+}
+
+// Sorting of the items to be returned on each page.
+
+func (r ListInstancesRequestRequest) Sort(sort InstanceSort) ApiListInstancesRequestRequest {
+ r.sort = &sort
+ return r
+}
+
+func (r ListInstancesRequestRequest) Execute() (*ListInstancesResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ListInstancesResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ListInstancesRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ if r.page != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "page", r.page, "")
+ }
+ if r.size != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "size", r.size, "")
+ }
+ if r.sort != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "sort", r.sort, "")
+ }
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ListInstancesRequest: List Instances
+
+List all available instances for your project.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @return ApiListInstancesRequestRequest
+*/
+func (a *APIClient) ListInstancesRequest(ctx context.Context, projectId string, region string) ApiListInstancesRequestRequest {
+ return ListInstancesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+}
+
+func (a *APIClient) ListInstancesRequestExecute(ctx context.Context, projectId string, region string) (*ListInstancesResponse, error) {
+ r := ListInstancesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ }
+ return r.Execute()
+}
+
+type ListRolesRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+}
+
+func (r ListRolesRequestRequest) Execute() (*ListRolesResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ListRolesResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ListRolesRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/roles"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ListRolesRequest: List Roles
+
+List available roles for an instance that can be assigned to a user
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListRolesRequestRequest
+*/
+func (a *APIClient) ListRolesRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListRolesRequestRequest {
+ return ListRolesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) ListRolesRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListRolesResponse, error) {
+ r := ListRolesRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type ListUsersRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ page *int64
+ size *int64
+ sort *UserSort
+}
+
+// Number of the page of items list to be returned.
+
+func (r ListUsersRequestRequest) Page(page int64) ApiListUsersRequestRequest {
+ r.page = &page
+ return r
+}
+
+// Number of items to be returned on each page.
+
+func (r ListUsersRequestRequest) Size(size int64) ApiListUsersRequestRequest {
+ r.size = &size
+ return r
+}
+
+// Sorting of the users to be returned on each page.
+
+func (r ListUsersRequestRequest) Sort(sort UserSort) ApiListUsersRequestRequest {
+ r.sort = &sort
+ return r
+}
+
+func (r ListUsersRequestRequest) Execute() (*ListUserResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodGet
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ListUserResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ListUsersRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ if r.page != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "page", r.page, "")
+ }
+ if r.size != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "size", r.size, "")
+ }
+ if r.sort != nil {
+ parameterAddToHeaderOrQuery(localVarQueryParams, "sort", r.sort, "")
+ }
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ListUsersRequest: List Users
+
+List available users for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiListUsersRequestRequest
+*/
+func (a *APIClient) ListUsersRequest(ctx context.Context, projectId string, region string, instanceId string) ApiListUsersRequestRequest {
+ return ListUsersRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) ListUsersRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ListUserResponse, error) {
+ r := ListUsersRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type ProtectInstanceRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ protectInstanceRequestPayload *ProtectInstanceRequestPayload
+}
+
+// The request body with flag isDeletable. Parameter is required.
+
+func (r ProtectInstanceRequestRequest) ProtectInstanceRequestPayload(protectInstanceRequestPayload ProtectInstanceRequestPayload) ApiProtectInstanceRequestRequest {
+ r.protectInstanceRequestPayload = &protectInstanceRequestPayload
+ return r
+}
+
+func (r ProtectInstanceRequestRequest) Execute() (*ProtectInstanceResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ProtectInstanceResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ProtectInstanceRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/protections"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.protectInstanceRequestPayload == nil {
+ return localVarReturnValue, fmt.Errorf("protectInstanceRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.protectInstanceRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ProtectInstanceRequest: Protect Instance
+
+Toggle the deletion protection for an instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiProtectInstanceRequestRequest
+*/
+func (a *APIClient) ProtectInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiProtectInstanceRequestRequest {
+ return ProtectInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) ProtectInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) (*ProtectInstanceResponse, error) {
+ r := ProtectInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type ResetUserRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ userId int64
+}
+
+func (r ResetUserRequestRequest) Execute() (*ResetUserResponse, error) {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ localVarReturnValue *ResetUserResponse
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return localVarReturnValue, fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.ResetUserRequest")
+ if err != nil {
+ return localVarReturnValue, &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}/reset"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(r.userId, "userId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return localVarReturnValue, err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return localVarReturnValue, err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return localVarReturnValue, newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return localVarReturnValue, newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return localVarReturnValue, newErr
+ }
+
+ err = client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: err.Error(),
+ }
+ return localVarReturnValue, newErr
+ }
+
+ return localVarReturnValue, nil
+}
+
+/*
+ResetUserRequest: Reset User
+
+Reset an user from an specific instance.
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param userId The ID of the user.
+ @return ApiResetUserRequestRequest
+*/
+func (a *APIClient) ResetUserRequest(ctx context.Context, projectId string, region string, instanceId string, userId int64) ApiResetUserRequestRequest {
+ return ResetUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+}
+
+func (a *APIClient) ResetUserRequestExecute(ctx context.Context, projectId string, region string, instanceId string, userId int64) (*ResetUserResponse, error) {
+ r := ResetUserRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ userId: userId,
+ }
+ return r.Execute()
+}
+
+type TriggerBackupRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ databaseName string
+}
+
+func (r TriggerBackupRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.TriggerBackupRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups/databases/{databaseName}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"databaseName"+"}", url.PathEscape(ParameterValueToString(r.databaseName, "databaseName")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+TriggerBackupRequest: Trigger backup for a specific Database
+
+Trigger backup for a specific database
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseName The name of the database.
+ @return ApiTriggerBackupRequestRequest
+*/
+func (a *APIClient) TriggerBackupRequest(ctx context.Context, projectId string, region string, instanceId string, databaseName string) ApiTriggerBackupRequestRequest {
+ return TriggerBackupRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseName: databaseName,
+ }
+}
+
+func (a *APIClient) TriggerBackupRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseName string) error {
+ r := TriggerBackupRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseName: databaseName,
+ }
+ return r.Execute()
+}
+
+type TriggerRestoreRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ databaseName string
+ triggerRestoreRequestPayload *TriggerRestoreRequestPayload
+}
+
+// The request body with the parameters for the database restore.
+
+func (r TriggerRestoreRequestRequest) TriggerRestoreRequestPayload(triggerRestoreRequestPayload TriggerRestoreRequestPayload) ApiTriggerRestoreRequestRequest {
+ r.triggerRestoreRequestPayload = &triggerRestoreRequestPayload
+ return r
+}
+
+func (r TriggerRestoreRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodPost
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.TriggerRestoreRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups/databases/{databaseName}/restores"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"databaseName"+"}", url.PathEscape(ParameterValueToString(r.databaseName, "databaseName")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.triggerRestoreRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 501 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+TriggerRestoreRequest: Trigger restore for a specific Database
+
+Trigger restore for a specific Database
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @param databaseName The name of the database.
+ @return ApiTriggerRestoreRequestRequest
+*/
+func (a *APIClient) TriggerRestoreRequest(ctx context.Context, projectId string, region string, instanceId string, databaseName string) ApiTriggerRestoreRequestRequest {
+ return TriggerRestoreRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseName: databaseName,
+ }
+}
+
+func (a *APIClient) TriggerRestoreRequestExecute(ctx context.Context, projectId string, region string, instanceId string, databaseName string) error {
+ r := TriggerRestoreRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ databaseName: databaseName,
+ }
+ return r.Execute()
+}
+
+type UpdateInstancePartiallyRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ updateInstancePartiallyRequestPayload *UpdateInstancePartiallyRequestPayload
+}
+
+// The request body with the parameters for updating the instance.
+
+func (r UpdateInstancePartiallyRequestRequest) UpdateInstancePartiallyRequestPayload(updateInstancePartiallyRequestPayload UpdateInstancePartiallyRequestPayload) ApiUpdateInstancePartiallyRequestRequest {
+ r.updateInstancePartiallyRequestPayload = &updateInstancePartiallyRequestPayload
+ return r
+}
+
+func (r UpdateInstancePartiallyRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodPatch
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.UpdateInstancePartiallyRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.updateInstancePartiallyRequestPayload == nil {
+ return fmt.Errorf("updateInstancePartiallyRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.updateInstancePartiallyRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+UpdateInstancePartiallyRequest: Update Instance Partially
+
+Update an available instance of a mssql database. No fields are required.
+
+**Please note that any changes applied via PUT or PATCH requests will initiate a reboot of the SQL Server Flex Instance.**
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiUpdateInstancePartiallyRequestRequest
+*/
+func (a *APIClient) UpdateInstancePartiallyRequest(ctx context.Context, projectId string, region string, instanceId string) ApiUpdateInstancePartiallyRequestRequest {
+ return UpdateInstancePartiallyRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) UpdateInstancePartiallyRequestExecute(ctx context.Context, projectId string, region string, instanceId string) error {
+ r := UpdateInstancePartiallyRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
+
+type UpdateInstanceRequestRequest struct {
+ ctx context.Context
+ apiService *DefaultApiService
+ projectId string
+ region string
+ instanceId string
+ updateInstanceRequestPayload *UpdateInstanceRequestPayload
+}
+
+// The request body with the parameters for updating the instance
+
+func (r UpdateInstanceRequestRequest) UpdateInstanceRequestPayload(updateInstanceRequestPayload UpdateInstanceRequestPayload) ApiUpdateInstanceRequestRequest {
+ r.updateInstanceRequestPayload = &updateInstanceRequestPayload
+ return r
+}
+
+func (r UpdateInstanceRequestRequest) Execute() error {
+ var (
+ localVarHTTPMethod = http.MethodPut
+ localVarPostBody interface{}
+ formFiles []formFile
+ )
+ a := r.apiService
+ client, ok := a.client.(*APIClient)
+ if !ok {
+ return fmt.Errorf("could not parse client to type APIClient")
+ }
+ localBasePath, err := client.cfg.ServerURLWithContext(r.ctx, "DefaultApiService.UpdateInstanceRequest")
+ if err != nil {
+ return &oapierror.GenericOpenAPIError{ErrorMessage: err.Error()}
+ }
+
+ localVarPath := localBasePath + "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ localVarPath = strings.Replace(localVarPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(r.projectId, "projectId")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(r.region, "region")), -1)
+ localVarPath = strings.Replace(localVarPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(r.instanceId, "instanceId")), -1)
+
+ localVarHeaderParams := make(map[string]string)
+ localVarQueryParams := url.Values{}
+ localVarFormParams := url.Values{}
+ if r.updateInstanceRequestPayload == nil {
+ return fmt.Errorf("updateInstanceRequestPayload is required and must be specified")
+ }
+
+ // to determine the Content-Type header
+ localVarHTTPContentTypes := []string{"application/json"}
+
+ // set Content-Type header
+ localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
+ if localVarHTTPContentType != "" {
+ localVarHeaderParams["Content-Type"] = localVarHTTPContentType
+ }
+
+ // to determine the Accept header
+ localVarHTTPHeaderAccepts := []string{"application/json"}
+
+ // set Accept header
+ localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
+ if localVarHTTPHeaderAccept != "" {
+ localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
+ }
+ // body params
+ localVarPostBody = r.updateInstanceRequestPayload
+ req, err := client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
+ if err != nil {
+ return err
+ }
+
+ contextHTTPRequest, ok := r.ctx.Value(config.ContextHTTPRequest).(**http.Request)
+ if ok {
+ *contextHTTPRequest = req
+ }
+
+ localVarHTTPResponse, err := client.callAPI(req)
+ contextHTTPResponse, ok := r.ctx.Value(config.ContextHTTPResponse).(**http.Response)
+ if ok {
+ *contextHTTPResponse = localVarHTTPResponse
+ }
+ if err != nil || localVarHTTPResponse == nil {
+ return err
+ }
+
+ localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
+ localVarHTTPResponse.Body.Close()
+ localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
+ if err != nil {
+ return err
+ }
+
+ if localVarHTTPResponse.StatusCode >= 300 {
+ newErr := &oapierror.GenericOpenAPIError{
+ StatusCode: localVarHTTPResponse.StatusCode,
+ Body: localVarBody,
+ ErrorMessage: localVarHTTPResponse.Status,
+ }
+ if localVarHTTPResponse.StatusCode == 400 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 401 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 403 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 404 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 422 {
+ var v ValidationError
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ return newErr
+ }
+ if localVarHTTPResponse.StatusCode == 500 {
+ var v Error
+ err = client.decode(&v, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
+ if err != nil {
+ newErr.ErrorMessage = err.Error()
+ return newErr
+ }
+ newErr.ErrorMessage = oapierror.FormatErrorMessage(localVarHTTPResponse.Status, &v)
+ newErr.Model = v
+ }
+ return newErr
+ }
+
+ return nil
+}
+
+/*
+UpdateInstanceRequest: Update Instance
+
+# Updates an available instance of a sqlserver database
+
+**Please note that any changes applied via PUT or PATCH requests will initiate a reboot of the SQL Server Flex Instance.**
+
+ @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
+ @param projectId The STACKIT project ID.
+ @param region The region which should be addressed
+ @param instanceId The ID of the instance.
+ @return ApiUpdateInstanceRequestRequest
+*/
+func (a *APIClient) UpdateInstanceRequest(ctx context.Context, projectId string, region string, instanceId string) ApiUpdateInstanceRequestRequest {
+ return UpdateInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+}
+
+func (a *APIClient) UpdateInstanceRequestExecute(ctx context.Context, projectId string, region string, instanceId string) error {
+ r := UpdateInstanceRequestRequest{
+ apiService: a.defaultApi,
+ ctx: ctx,
+ projectId: projectId,
+ region: region,
+ instanceId: instanceId,
+ }
+ return r.Execute()
+}
diff --git a/pkg/sqlserverflexalpha/api_default_test.go b/pkg/sqlserverflexalpha/api_default_test.go
new file mode 100644
index 00000000..217f3399
--- /dev/null
+++ b/pkg/sqlserverflexalpha/api_default_test.go
@@ -0,0 +1,1570 @@
+/*
+STACKIT MSSQL Service API
+
+Testing DefaultApiService
+
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech);
+
+package sqlserverflexalpha
+
+import (
+ "context"
+ "encoding/json"
+ "net/http"
+ "net/http/httptest"
+ "net/url"
+ "strings"
+ "testing"
+
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+)
+
+func Test_sqlserverflexalpha_DefaultApiService(t *testing.T) {
+
+ t.Run("Test DefaultApiService CreateDatabaseRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := CreateDatabaseResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ createDatabaseRequestPayload := CreateDatabaseRequestPayload{}
+
+ resp, reqErr := apiClient.CreateDatabaseRequest(context.Background(), projectId, region, instanceId).CreateDatabaseRequestPayload(createDatabaseRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService CreateInstanceRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := CreateInstanceResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ createInstanceRequestPayload := CreateInstanceRequestPayload{}
+
+ resp, reqErr := apiClient.CreateInstanceRequest(context.Background(), projectId, region).CreateInstanceRequestPayload(createInstanceRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService CreateUserRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := CreateUserResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ createUserRequestPayload := CreateUserRequestPayload{}
+
+ resp, reqErr := apiClient.CreateUserRequest(context.Background(), projectId, region, instanceId).CreateUserRequestPayload(createUserRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService DeleteDatabaseRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases/{databaseName}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ databaseNameValue := "databaseName-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"databaseName"+"}", url.PathEscape(ParameterValueToString(databaseNameValue, "databaseName")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ databaseName := databaseNameValue
+
+ reqErr := apiClient.DeleteDatabaseRequest(context.Background(), projectId, region, instanceId, databaseName).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService DeleteInstanceRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ reqErr := apiClient.DeleteInstanceRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService DeleteUserRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ userIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(userIdValue, "userId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ userId := userIdValue
+
+ reqErr := apiClient.DeleteUserRequest(context.Background(), projectId, region, instanceId, userId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService GetBackupRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups/{backupId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ backupIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"backupId"+"}", url.PathEscape(ParameterValueToString(backupIdValue, "backupId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetBackupResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ backupId := backupIdValue
+
+ resp, reqErr := apiClient.GetBackupRequest(context.Background(), projectId, region, instanceId, backupId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService GetCollationsRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/collations"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetCollationsResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.GetCollationsRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService GetDatabaseRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases/{databaseName}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ databaseNameValue := "databaseName-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"databaseName"+"}", url.PathEscape(ParameterValueToString(databaseNameValue, "databaseName")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetDatabaseResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ databaseName := databaseNameValue
+
+ resp, reqErr := apiClient.GetDatabaseRequest(context.Background(), projectId, region, instanceId, databaseName).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService GetFlavorsRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/flavors"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetFlavorsResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+
+ page := int64(1)
+ size := int64(10)
+ resp, reqErr := apiClient.GetFlavorsRequest(context.Background(), projectId, region, &page, &size, FLAVORSORT_ID_DESC).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService GetInstanceRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetInstanceResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.GetInstanceRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService GetStoragesRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/storages/{flavorId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ flavorIdValue := "flavorId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"flavorId"+"}", url.PathEscape(ParameterValueToString(flavorIdValue, "flavorId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetStoragesResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ flavorId := flavorIdValue
+
+ resp, reqErr := apiClient.GetStoragesRequest(context.Background(), projectId, region, flavorId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService GetUserRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ userIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(userIdValue, "userId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetUserResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ userId := userIdValue
+
+ resp, reqErr := apiClient.GetUserRequest(context.Background(), projectId, region, instanceId, userId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService GetVersionsRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/versions"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := GetVersionsResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+
+ resp, reqErr := apiClient.GetVersionsRequest(context.Background(), projectId, region).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ListBackupsRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ListBackupResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.ListBackupsRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ListCompatibilitiesRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/compatibility"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ListCompatibilityResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.ListCompatibilitiesRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ListCurrentRunningRestoreJobs", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/restore-jobs"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ListCurrentRunningRestoreJobs{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.ListCurrentRunningRestoreJobs(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ListDatabasesRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/databases"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ListDatabasesResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.ListDatabasesRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ListInstancesRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ListInstancesResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+
+ resp, reqErr := apiClient.ListInstancesRequest(context.Background(), projectId, region).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ListRolesRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/roles"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ListRolesResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.ListRolesRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ListUsersRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ListUserResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+
+ resp, reqErr := apiClient.ListUsersRequest(context.Background(), projectId, region, instanceId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ProtectInstanceRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/protections"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ProtectInstanceResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ protectInstanceRequestPayload := ProtectInstanceRequestPayload{}
+
+ resp, reqErr := apiClient.ProtectInstanceRequest(context.Background(), projectId, region, instanceId).ProtectInstanceRequestPayload(protectInstanceRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService ResetUserRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/users/{userId}/reset"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ userIdValue := int64(123)
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"userId"+"}", url.PathEscape(ParameterValueToString(userIdValue, "userId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ data := ResetUserResponse{}
+ w.Header().Add("Content-Type", "application/json")
+ json.NewEncoder(w).Encode(data)
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ userId := userIdValue
+
+ resp, reqErr := apiClient.ResetUserRequest(context.Background(), projectId, region, instanceId, userId).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ if IsNil(resp) {
+ t.Fatalf("response not present")
+ }
+ })
+
+ t.Run("Test DefaultApiService TriggerBackupRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups/databases/{databaseName}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ databaseNameValue := "databaseName-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"databaseName"+"}", url.PathEscape(ParameterValueToString(databaseNameValue, "databaseName")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ databaseName := databaseNameValue
+
+ reqErr := apiClient.TriggerBackupRequest(context.Background(), projectId, region, instanceId, databaseName).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService TriggerRestoreRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}/backups/databases/{databaseName}/restores"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+ databaseNameValue := "databaseName-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"databaseName"+"}", url.PathEscape(ParameterValueToString(databaseNameValue, "databaseName")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ databaseName := databaseNameValue
+
+ reqErr := apiClient.TriggerRestoreRequest(context.Background(), projectId, region, instanceId, databaseName).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService UpdateInstancePartiallyRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ updateInstancePartiallyRequestPayload := UpdateInstancePartiallyRequestPayload{}
+
+ reqErr := apiClient.UpdateInstancePartiallyRequest(context.Background(), projectId, region, instanceId).UpdateInstancePartiallyRequestPayload(updateInstancePartiallyRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+ t.Run("Test DefaultApiService UpdateInstanceRequest", func(t *testing.T) {
+ _apiUrlPath := "/v3alpha1/projects/{projectId}/regions/{region}/instances/{instanceId}"
+ projectIdValue := "projectId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"projectId"+"}", url.PathEscape(ParameterValueToString(projectIdValue, "projectId")), -1)
+ regionValue := "region-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"region"+"}", url.PathEscape(ParameterValueToString(regionValue, "region")), -1)
+ instanceIdValue := "instanceId-value"
+ _apiUrlPath = strings.Replace(_apiUrlPath, "{"+"instanceId"+"}", url.PathEscape(ParameterValueToString(instanceIdValue, "instanceId")), -1)
+
+ testDefaultApiServeMux := http.NewServeMux()
+ testDefaultApiServeMux.HandleFunc(_apiUrlPath, func(w http.ResponseWriter, req *http.Request) {
+ })
+ testServer := httptest.NewServer(testDefaultApiServeMux)
+ defer testServer.Close()
+
+ configuration := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "OpenAPI-Generator/1.0.0/go",
+ Debug: false,
+ Region: "test_region",
+ Servers: config.ServerConfigurations{
+ {
+ URL: testServer.URL,
+ Description: "Localhost for sqlserverflexalpha_DefaultApi",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ DefaultValue: "test_region.",
+ EnumValues: []string{
+ "test_region.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ apiClient, err := NewAPIClient(config.WithCustomConfiguration(configuration), config.WithoutAuthentication())
+ if err != nil {
+ t.Fatalf("creating API client: %v", err)
+ }
+
+ projectId := projectIdValue
+ region := regionValue
+ instanceId := instanceIdValue
+ updateInstanceRequestPayload := UpdateInstanceRequestPayload{}
+
+ reqErr := apiClient.UpdateInstanceRequest(context.Background(), projectId, region, instanceId).UpdateInstanceRequestPayload(updateInstanceRequestPayload).Execute()
+
+ if reqErr != nil {
+ t.Fatalf("error in call: %v", reqErr)
+ }
+ })
+
+}
diff --git a/pkg/sqlserverflexalpha/client.go b/pkg/sqlserverflexalpha/client.go
new file mode 100644
index 00000000..f8a9ddbe
--- /dev/null
+++ b/pkg/sqlserverflexalpha/client.go
@@ -0,0 +1,631 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "bytes"
+ "context"
+ "encoding/json"
+ "encoding/xml"
+ "fmt"
+ "io"
+ "log"
+ "mime/multipart"
+ "net/http"
+ "net/http/httputil"
+ "net/url"
+ "os"
+ "path/filepath"
+ "reflect"
+ "regexp"
+ "strconv"
+ "strings"
+ "time"
+ "unicode/utf8"
+
+ "github.com/stackitcloud/stackit-sdk-go/core/auth"
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+)
+
+var (
+ jsonCheck = regexp.MustCompile(`(?i:(?:application|text)/(?:vnd\.[^;]+\+)?json)`)
+ xmlCheck = regexp.MustCompile(`(?i:(?:application|text)/xml)`)
+ queryParamSplit = regexp.MustCompile(`(^|&)([^&]+)`)
+ queryDescape = strings.NewReplacer("%5B", "[", "%5D", "]")
+)
+
+// APIClient manages communication with the STACKIT MSSQL Service API API v3alpha1
+// In most cases there should be only one, shared, APIClient.
+type APIClient struct {
+ cfg *config.Configuration
+ common service // Reuse a single struct instead of allocating one for each service on the heap.
+ defaultApi *DefaultApiService
+}
+
+type service struct {
+ client DefaultApi
+}
+
+// NewAPIClient creates a new API client.
+// Optionally receives configuration options
+func NewAPIClient(opts ...config.ConfigurationOption) (*APIClient, error) {
+ cfg := NewConfiguration()
+
+ for _, option := range opts {
+ err := option(cfg)
+ if err != nil {
+ return nil, fmt.Errorf("configuring the client: %w", err)
+ }
+ }
+
+ err := config.ConfigureRegion(cfg)
+ if err != nil {
+ return nil, fmt.Errorf("configuring region: %w", err)
+ }
+
+ if cfg.HTTPClient == nil {
+ cfg.HTTPClient = &http.Client{}
+ }
+
+ authRoundTripper, err := auth.SetupAuth(cfg)
+ if err != nil {
+ return nil, fmt.Errorf("setting up authentication: %w", err)
+ }
+
+ roundTripper := authRoundTripper
+ if cfg.Middleware != nil {
+ roundTripper = config.ChainMiddleware(roundTripper, cfg.Middleware...)
+ }
+
+ cfg.HTTPClient.Transport = roundTripper
+
+ c := &APIClient{}
+ c.cfg = cfg
+ c.common.client = c
+ c.defaultApi = (*DefaultApiService)(&c.common)
+
+ return c, nil
+}
+
+func atoi(in string) (int, error) {
+ return strconv.Atoi(in)
+}
+
+// selectHeaderContentType select a content type from the available list.
+func selectHeaderContentType(contentTypes []string) string {
+ if len(contentTypes) == 0 {
+ return ""
+ }
+ if contains(contentTypes, "application/json") {
+ return "application/json"
+ }
+ return contentTypes[0] // use the first content type specified in 'consumes'
+}
+
+// selectHeaderAccept join all accept types and return
+func selectHeaderAccept(accepts []string) string {
+ if len(accepts) == 0 {
+ return ""
+ }
+
+ if contains(accepts, "application/json") {
+ return "application/json"
+ }
+
+ return strings.Join(accepts, ",")
+}
+
+// contains is a case insensitive match, finding needle in a haystack
+func contains(haystack []string, needle string) bool {
+ for _, a := range haystack {
+ if strings.EqualFold(a, needle) {
+ return true
+ }
+ }
+ return false
+}
+
+// Verify optional parameters are of the correct type.
+func typeCheckParameter(obj interface{}, expected string, name string) error {
+ // Make sure there is an object.
+ if obj == nil {
+ return nil
+ }
+
+ // Check the type is as expected.
+ if reflect.TypeOf(obj).String() != expected {
+ return fmt.Errorf("expected %s to be of type %s but received %s", name, expected, reflect.TypeOf(obj).String())
+ }
+ return nil
+}
+
+func ParameterValueToString(obj interface{}, key string) string {
+ if reflect.TypeOf(obj).Kind() != reflect.Ptr {
+ return fmt.Sprintf("%v", obj)
+ }
+ var param, ok = obj.(MappedNullable)
+ if !ok {
+ return ""
+ }
+ dataMap, err := param.ToMap()
+ if err != nil {
+ return ""
+ }
+ return fmt.Sprintf("%v", dataMap[key])
+}
+
+// parameterAddToHeaderOrQuery adds the provided object to the request header or url query
+// supporting deep object syntax
+func parameterAddToHeaderOrQuery(headerOrQueryParams interface{}, keyPrefix string, obj interface{}, collectionType string) {
+ var v = reflect.ValueOf(obj)
+ var value = ""
+ if v == reflect.ValueOf(nil) {
+ value = "null"
+ } else {
+ switch v.Kind() {
+ case reflect.Invalid:
+ value = "invalid"
+
+ case reflect.Struct:
+ if t, ok := obj.(MappedNullable); ok {
+ dataMap, err := t.ToMap()
+ if err != nil {
+ return
+ }
+ parameterAddToHeaderOrQuery(headerOrQueryParams, keyPrefix, dataMap, collectionType)
+ return
+ }
+ if t, ok := obj.(time.Time); ok {
+ parameterAddToHeaderOrQuery(headerOrQueryParams, keyPrefix, t.Format(time.RFC3339), collectionType)
+ return
+ }
+ value = v.Type().String() + " value"
+ case reflect.Slice:
+ var indValue = reflect.ValueOf(obj)
+ if indValue == reflect.ValueOf(nil) {
+ return
+ }
+ var lenIndValue = indValue.Len()
+ for i := 0; i < lenIndValue; i++ {
+ var arrayValue = indValue.Index(i)
+ parameterAddToHeaderOrQuery(headerOrQueryParams, keyPrefix, arrayValue.Interface(), collectionType)
+ }
+ return
+
+ case reflect.Map:
+ var indValue = reflect.ValueOf(obj)
+ if indValue == reflect.ValueOf(nil) {
+ return
+ }
+ iter := indValue.MapRange()
+ for iter.Next() {
+ k, v := iter.Key(), iter.Value()
+ parameterAddToHeaderOrQuery(headerOrQueryParams, fmt.Sprintf("%s[%s]", keyPrefix, k.String()), v.Interface(), collectionType)
+ }
+ return
+
+ case reflect.Interface:
+ fallthrough
+ case reflect.Ptr:
+ parameterAddToHeaderOrQuery(headerOrQueryParams, keyPrefix, v.Elem().Interface(), collectionType)
+ return
+
+ case reflect.Int, reflect.Int8, reflect.Int16,
+ reflect.Int32, reflect.Int64:
+ value = strconv.FormatInt(v.Int(), 10)
+ case reflect.Uint, reflect.Uint8, reflect.Uint16,
+ reflect.Uint32, reflect.Uint64, reflect.Uintptr:
+ value = strconv.FormatUint(v.Uint(), 10)
+ case reflect.Float32, reflect.Float64:
+ value = strconv.FormatFloat(v.Float(), 'g', -1, 32)
+ case reflect.Bool:
+ value = strconv.FormatBool(v.Bool())
+ case reflect.String:
+ value = v.String()
+ default:
+ value = v.Type().String() + " value"
+ }
+ }
+
+ switch valuesMap := headerOrQueryParams.(type) {
+ case url.Values:
+ if collectionType == "csv" && valuesMap.Get(keyPrefix) != "" {
+ valuesMap.Set(keyPrefix, valuesMap.Get(keyPrefix)+","+value)
+ } else {
+ valuesMap.Add(keyPrefix, value)
+ }
+ break
+ case map[string]string:
+ valuesMap[keyPrefix] = value
+ break
+ }
+}
+
+// helper for converting interface{} parameters to json strings
+func parameterToJson(obj interface{}) (string, error) {
+ jsonBuf, err := json.Marshal(obj)
+ if err != nil {
+ return "", err
+ }
+ return string(jsonBuf), err
+}
+
+// callAPI do the request.
+func (c *APIClient) callAPI(request *http.Request) (*http.Response, error) {
+ if c.cfg.Debug {
+ dump, err := httputil.DumpRequestOut(request, true)
+ if err != nil {
+ return nil, err
+ }
+ log.Printf("\n%s\n", string(dump))
+ }
+
+ resp, err := c.cfg.HTTPClient.Do(request)
+ if err != nil {
+ return resp, err
+ }
+
+ if c.cfg.Debug {
+ dump, err := httputil.DumpResponse(resp, true)
+ if err != nil {
+ return resp, err
+ }
+ log.Printf("\n%s\n", string(dump))
+ }
+ return resp, err
+}
+
+// Allow modification of underlying config for alternate implementations and testing
+// Caution: modifying the configuration while live can cause data races and potentially unwanted behavior
+func (c *APIClient) GetConfig() *config.Configuration {
+ return c.cfg
+}
+
+type formFile struct {
+ fileBytes []byte
+ fileName string
+ formFileName string
+}
+
+// prepareRequest build the request
+func (c *APIClient) prepareRequest(
+ ctx context.Context,
+ path string, method string,
+ postBody interface{},
+ headerParams map[string]string,
+ queryParams url.Values,
+ formParams url.Values,
+ formFiles []formFile) (localVarRequest *http.Request, err error) {
+
+ var body *bytes.Buffer
+
+ // Detect postBody type and post.
+ if !IsNil(postBody) {
+ contentType := headerParams["Content-Type"]
+ if contentType == "" {
+ contentType = detectContentType(postBody)
+ headerParams["Content-Type"] = contentType
+ }
+
+ body, err = setBody(postBody, contentType)
+ if err != nil {
+ return nil, err
+ }
+ }
+
+ // add form parameters and file if available.
+ if strings.HasPrefix(headerParams["Content-Type"], "multipart/form-data") && len(formParams) > 0 || (len(formFiles) > 0) {
+ if body != nil {
+ return nil, fmt.Errorf("cannot specify postBody and multipart form at the same time.")
+ }
+ body = &bytes.Buffer{}
+ w := multipart.NewWriter(body)
+
+ for k, v := range formParams {
+ for _, iv := range v {
+ if strings.HasPrefix(k, "@") { // file
+ err = addFile(w, k[1:], iv)
+ if err != nil {
+ return nil, err
+ }
+ } else { // form value
+ w.WriteField(k, iv)
+ }
+ }
+ }
+ for _, formFile := range formFiles {
+ if len(formFile.fileBytes) > 0 && formFile.fileName != "" {
+ w.Boundary()
+ part, err := w.CreateFormFile(formFile.formFileName, filepath.Base(formFile.fileName))
+ if err != nil {
+ return nil, err
+ }
+ _, err = part.Write(formFile.fileBytes)
+ if err != nil {
+ return nil, err
+ }
+ }
+ }
+
+ // Set the Boundary in the Content-Type
+ headerParams["Content-Type"] = w.FormDataContentType()
+
+ // Set Content-Length
+ headerParams["Content-Length"] = fmt.Sprintf("%d", body.Len())
+ w.Close()
+ }
+
+ if strings.HasPrefix(headerParams["Content-Type"], "application/x-www-form-urlencoded") && len(formParams) > 0 {
+ if body != nil {
+ return nil, fmt.Errorf("cannot specify postBody and x-www-form-urlencoded form at the same time.")
+ }
+ body = &bytes.Buffer{}
+ body.WriteString(formParams.Encode())
+ // Set Content-Length
+ headerParams["Content-Length"] = fmt.Sprintf("%d", body.Len())
+ }
+
+ // Setup path and query parameters
+ url, err := url.Parse(path)
+ if err != nil {
+ return nil, err
+ }
+
+ // Override request host, if applicable
+ if c.cfg.Host != "" {
+ url.Host = c.cfg.Host
+ }
+
+ // Override request scheme, if applicable
+ if c.cfg.Scheme != "" {
+ url.Scheme = c.cfg.Scheme
+ }
+
+ // Adding Query Param
+ query := url.Query()
+ for k, v := range queryParams {
+ for _, iv := range v {
+ query.Add(k, iv)
+ }
+ }
+
+ // Encode the parameters.
+ url.RawQuery = queryParamSplit.ReplaceAllStringFunc(query.Encode(), func(s string) string {
+ pieces := strings.Split(s, "=")
+ pieces[0] = queryDescape.Replace(pieces[0])
+ return strings.Join(pieces, "=")
+ })
+
+ // Generate a new request
+ if body != nil {
+ localVarRequest, err = http.NewRequest(method, url.String(), body)
+ } else {
+ localVarRequest, err = http.NewRequest(method, url.String(), nil)
+ }
+ if err != nil {
+ return nil, err
+ }
+
+ // add header parameters, if any
+ if len(headerParams) > 0 {
+ headers := http.Header{}
+ for h, v := range headerParams {
+ headers[h] = []string{v}
+ }
+ localVarRequest.Header = headers
+ }
+
+ // Add the user agent to the request.
+ localVarRequest.Header.Add("User-Agent", c.cfg.UserAgent)
+
+ if ctx != nil {
+ // add context to the request
+ localVarRequest = localVarRequest.WithContext(ctx)
+
+ // Walk through any authentication.
+
+ }
+
+ for header, value := range c.cfg.DefaultHeader {
+ localVarRequest.Header.Add(header, value)
+ }
+ return localVarRequest, nil
+}
+
+func (c *APIClient) decode(v interface{}, b []byte, contentType string) (err error) {
+ if len(b) == 0 {
+ return nil
+ }
+ if s, ok := v.(*string); ok {
+ *s = string(b)
+ return nil
+ }
+ if f, ok := v.(*os.File); ok {
+ f, err = os.CreateTemp("", "HttpClientFile")
+ if err != nil {
+ return
+ }
+ _, err = f.Write(b)
+ if err != nil {
+ return
+ }
+ _, err = f.Seek(0, io.SeekStart)
+ return
+ }
+ if f, ok := v.(**os.File); ok {
+ *f, err = os.CreateTemp("", "HttpClientFile")
+ if err != nil {
+ return
+ }
+ _, err = (*f).Write(b)
+ if err != nil {
+ return
+ }
+ _, err = (*f).Seek(0, io.SeekStart)
+ return
+ }
+ if xmlCheck.MatchString(contentType) {
+ if err = xml.Unmarshal(b, v); err != nil {
+ return err
+ }
+ return nil
+ }
+ if jsonCheck.MatchString(contentType) {
+ if actualObj, ok := v.(interface{ GetActualInstance() interface{} }); ok { // oneOf, anyOf schemas
+ if unmarshalObj, ok := actualObj.(interface{ UnmarshalJSON([]byte) error }); ok { // make sure it has UnmarshalJSON defined
+ if err = unmarshalObj.UnmarshalJSON(b); err != nil {
+ return err
+ }
+ } else {
+ return fmt.Errorf("unknown type with GetActualInstance but no unmarshalObj.UnmarshalJSON defined")
+ }
+ } else if err = json.Unmarshal(b, v); err != nil { // simple model
+ return err
+ }
+ return nil
+ }
+ return fmt.Errorf("undefined response type")
+}
+
+// Add a file to the multipart request
+func addFile(w *multipart.Writer, fieldName, path string) error {
+ file, err := os.Open(filepath.Clean(path))
+ if err != nil {
+ return err
+ }
+ err = file.Close()
+ if err != nil {
+ return err
+ }
+
+ part, err := w.CreateFormFile(fieldName, filepath.Base(path))
+ if err != nil {
+ return err
+ }
+ _, err = io.Copy(part, file)
+
+ return err
+}
+
+// A wrapper for strict JSON decoding
+func newStrictDecoder(data []byte) *json.Decoder {
+ dec := json.NewDecoder(bytes.NewBuffer(data))
+ dec.DisallowUnknownFields()
+ return dec
+}
+
+// Set request body from an interface{}
+func setBody(body interface{}, contentType string) (bodyBuf *bytes.Buffer, err error) {
+ if bodyBuf == nil {
+ bodyBuf = &bytes.Buffer{}
+ }
+
+ if reader, ok := body.(io.Reader); ok {
+ _, err = bodyBuf.ReadFrom(reader)
+ } else if fp, ok := body.(*os.File); ok {
+ _, err = bodyBuf.ReadFrom(fp)
+ } else if b, ok := body.([]byte); ok {
+ _, err = bodyBuf.Write(b)
+ } else if s, ok := body.(string); ok {
+ _, err = bodyBuf.WriteString(s)
+ } else if s, ok := body.(*string); ok {
+ _, err = bodyBuf.WriteString(*s)
+ } else if jsonCheck.MatchString(contentType) {
+ err = json.NewEncoder(bodyBuf).Encode(body)
+ } else if xmlCheck.MatchString(contentType) {
+ err = xml.NewEncoder(bodyBuf).Encode(body)
+ }
+
+ if err != nil {
+ return nil, err
+ }
+
+ if bodyBuf.Len() == 0 {
+ err = fmt.Errorf("invalid body type %s", contentType)
+ return nil, err
+ }
+ return bodyBuf, nil
+}
+
+// detectContentType method is used to figure out `Request.Body` content type for request header
+func detectContentType(body interface{}) string {
+ contentType := "text/plain; charset=utf-8"
+ kind := reflect.TypeOf(body).Kind()
+
+ switch kind {
+ case reflect.Struct, reflect.Map, reflect.Ptr:
+ contentType = "application/json; charset=utf-8"
+ case reflect.String:
+ contentType = "text/plain; charset=utf-8"
+ default:
+ if b, ok := body.([]byte); ok {
+ contentType = http.DetectContentType(b)
+ } else if kind == reflect.Slice {
+ contentType = "application/json; charset=utf-8"
+ }
+ }
+
+ return contentType
+}
+
+// Ripped from https://github.com/gregjones/httpcache/blob/master/httpcache.go
+type cacheControl map[string]string
+
+func parseCacheControl(headers http.Header) cacheControl {
+ cc := cacheControl{}
+ ccHeader := headers.Get("Cache-Control")
+ for _, part := range strings.Split(ccHeader, ",") {
+ part = strings.Trim(part, " ")
+ if part == "" {
+ continue
+ }
+ if strings.ContainsRune(part, '=') {
+ keyval := strings.Split(part, "=")
+ cc[strings.Trim(keyval[0], " ")] = strings.Trim(keyval[1], ",")
+ } else {
+ cc[part] = ""
+ }
+ }
+ return cc
+}
+
+// CacheExpires helper function to determine remaining time before repeating a request.
+func CacheExpires(r *http.Response) time.Time {
+ // Figure out when the cache expires.
+ var expires time.Time
+ now, err := time.Parse(time.RFC1123, r.Header.Get("date"))
+ if err != nil {
+ return time.Now()
+ }
+ respCacheControl := parseCacheControl(r.Header)
+
+ if maxAge, ok := respCacheControl["max-age"]; ok {
+ lifetime, err := time.ParseDuration(maxAge + "s")
+ if err != nil {
+ expires = now
+ } else {
+ expires = now.Add(lifetime)
+ }
+ } else {
+ expiresHeader := r.Header.Get("Expires")
+ if expiresHeader != "" {
+ expires, err = time.Parse(time.RFC1123, expiresHeader)
+ if err != nil {
+ expires = now
+ }
+ }
+ }
+ return expires
+}
+
+func strlen(s string) int {
+ return utf8.RuneCountInString(s)
+}
diff --git a/pkg/sqlserverflexalpha/configuration.go b/pkg/sqlserverflexalpha/configuration.go
new file mode 100644
index 00000000..e6150bdf
--- /dev/null
+++ b/pkg/sqlserverflexalpha/configuration.go
@@ -0,0 +1,41 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+)
+
+// NewConfiguration returns a new Configuration object
+func NewConfiguration() *config.Configuration {
+ cfg := &config.Configuration{
+ DefaultHeader: make(map[string]string),
+ UserAgent: "stackit-sdk-go/sqlserverflexalpha",
+ Debug: false,
+ Servers: config.ServerConfigurations{
+ {
+ URL: "https://mssql-flex-service.api.{region}stackit.cloud",
+ Description: "No description provided",
+ Variables: map[string]config.ServerVariable{
+ "region": {
+ Description: "No description provided",
+ DefaultValue: "eu01.",
+ EnumValues: []string{
+ "eu01.",
+ },
+ },
+ },
+ },
+ },
+ OperationServers: map[string]config.ServerConfigurations{},
+ }
+ return cfg
+}
diff --git a/pkg/sqlserverflexalpha/model_backup_running_restore.go b/pkg/sqlserverflexalpha/model_backup_running_restore.go
new file mode 100644
index 00000000..e226d582
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_backup_running_restore.go
@@ -0,0 +1,307 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the BackupRunningRestore type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &BackupRunningRestore{}
+
+/*
+ types and functions for command
+*/
+
+// isNotNullableString
+type BackupRunningRestoreGetCommandAttributeType = *string
+
+func getBackupRunningRestoreGetCommandAttributeTypeOk(arg BackupRunningRestoreGetCommandAttributeType) (ret BackupRunningRestoreGetCommandRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setBackupRunningRestoreGetCommandAttributeType(arg *BackupRunningRestoreGetCommandAttributeType, val BackupRunningRestoreGetCommandRetType) {
+ *arg = &val
+}
+
+type BackupRunningRestoreGetCommandArgType = string
+type BackupRunningRestoreGetCommandRetType = string
+
+/*
+ types and functions for database_name
+*/
+
+// isNotNullableString
+type BackupRunningRestoreGetDatabaseNameAttributeType = *string
+
+func getBackupRunningRestoreGetDatabaseNameAttributeTypeOk(arg BackupRunningRestoreGetDatabaseNameAttributeType) (ret BackupRunningRestoreGetDatabaseNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setBackupRunningRestoreGetDatabaseNameAttributeType(arg *BackupRunningRestoreGetDatabaseNameAttributeType, val BackupRunningRestoreGetDatabaseNameRetType) {
+ *arg = &val
+}
+
+type BackupRunningRestoreGetDatabaseNameArgType = string
+type BackupRunningRestoreGetDatabaseNameRetType = string
+
+/*
+ types and functions for estimated_completion_time
+*/
+
+// isNotNullableString
+type BackupRunningRestoreGetEstimatedCompletionTimeAttributeType = *string
+
+func getBackupRunningRestoreGetEstimatedCompletionTimeAttributeTypeOk(arg BackupRunningRestoreGetEstimatedCompletionTimeAttributeType) (ret BackupRunningRestoreGetEstimatedCompletionTimeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setBackupRunningRestoreGetEstimatedCompletionTimeAttributeType(arg *BackupRunningRestoreGetEstimatedCompletionTimeAttributeType, val BackupRunningRestoreGetEstimatedCompletionTimeRetType) {
+ *arg = &val
+}
+
+type BackupRunningRestoreGetEstimatedCompletionTimeArgType = string
+type BackupRunningRestoreGetEstimatedCompletionTimeRetType = string
+
+/*
+ types and functions for percent_complete
+*/
+
+// isInteger
+type BackupRunningRestoreGetPercentCompleteAttributeType = *int64
+type BackupRunningRestoreGetPercentCompleteArgType = int64
+type BackupRunningRestoreGetPercentCompleteRetType = int64
+
+func getBackupRunningRestoreGetPercentCompleteAttributeTypeOk(arg BackupRunningRestoreGetPercentCompleteAttributeType) (ret BackupRunningRestoreGetPercentCompleteRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setBackupRunningRestoreGetPercentCompleteAttributeType(arg *BackupRunningRestoreGetPercentCompleteAttributeType, val BackupRunningRestoreGetPercentCompleteRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for start_time
+*/
+
+// isNotNullableString
+type BackupRunningRestoreGetStartTimeAttributeType = *string
+
+func getBackupRunningRestoreGetStartTimeAttributeTypeOk(arg BackupRunningRestoreGetStartTimeAttributeType) (ret BackupRunningRestoreGetStartTimeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setBackupRunningRestoreGetStartTimeAttributeType(arg *BackupRunningRestoreGetStartTimeAttributeType, val BackupRunningRestoreGetStartTimeRetType) {
+ *arg = &val
+}
+
+type BackupRunningRestoreGetStartTimeArgType = string
+type BackupRunningRestoreGetStartTimeRetType = string
+
+// BackupRunningRestore struct for BackupRunningRestore
+type BackupRunningRestore struct {
+ // the command that was executed
+ // REQUIRED
+ Command BackupRunningRestoreGetCommandAttributeType `json:"command" required:"true" validate:"required,restoreCommand"`
+ // the name of the database that is being restored
+ // REQUIRED
+ DatabaseName BackupRunningRestoreGetDatabaseNameAttributeType `json:"database_name" required:"true" validate:"required,databaseName"`
+ // the projected time when the restore should be completed
+ // REQUIRED
+ EstimatedCompletionTime BackupRunningRestoreGetEstimatedCompletionTimeAttributeType `json:"estimated_completion_time" required:"true" validate:"required,time"`
+ // the percentage of the current running restore job
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ PercentComplete BackupRunningRestoreGetPercentCompleteAttributeType `json:"percent_complete" required:"true" validate:"required,min=0,max=100"`
+ // the start time of the current running restore job
+ // REQUIRED
+ StartTime BackupRunningRestoreGetStartTimeAttributeType `json:"start_time" required:"true" validate:"required,time"`
+}
+
+type _BackupRunningRestore BackupRunningRestore
+
+// NewBackupRunningRestore instantiates a new BackupRunningRestore object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewBackupRunningRestore(command BackupRunningRestoreGetCommandArgType, databaseName BackupRunningRestoreGetDatabaseNameArgType, estimatedCompletionTime BackupRunningRestoreGetEstimatedCompletionTimeArgType, percentComplete BackupRunningRestoreGetPercentCompleteArgType, startTime BackupRunningRestoreGetStartTimeArgType) *BackupRunningRestore {
+ this := BackupRunningRestore{}
+ setBackupRunningRestoreGetCommandAttributeType(&this.Command, command)
+ setBackupRunningRestoreGetDatabaseNameAttributeType(&this.DatabaseName, databaseName)
+ setBackupRunningRestoreGetEstimatedCompletionTimeAttributeType(&this.EstimatedCompletionTime, estimatedCompletionTime)
+ setBackupRunningRestoreGetPercentCompleteAttributeType(&this.PercentComplete, percentComplete)
+ setBackupRunningRestoreGetStartTimeAttributeType(&this.StartTime, startTime)
+ return &this
+}
+
+// NewBackupRunningRestoreWithDefaults instantiates a new BackupRunningRestore object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewBackupRunningRestoreWithDefaults() *BackupRunningRestore {
+ this := BackupRunningRestore{}
+ return &this
+}
+
+// GetCommand returns the Command field value
+func (o *BackupRunningRestore) GetCommand() (ret BackupRunningRestoreGetCommandRetType) {
+ ret, _ = o.GetCommandOk()
+ return ret
+}
+
+// GetCommandOk returns a tuple with the Command field value
+// and a boolean to check if the value has been set.
+func (o *BackupRunningRestore) GetCommandOk() (ret BackupRunningRestoreGetCommandRetType, ok bool) {
+ return getBackupRunningRestoreGetCommandAttributeTypeOk(o.Command)
+}
+
+// SetCommand sets field value
+func (o *BackupRunningRestore) SetCommand(v BackupRunningRestoreGetCommandRetType) {
+ setBackupRunningRestoreGetCommandAttributeType(&o.Command, v)
+}
+
+// GetDatabaseName returns the DatabaseName field value
+func (o *BackupRunningRestore) GetDatabaseName() (ret BackupRunningRestoreGetDatabaseNameRetType) {
+ ret, _ = o.GetDatabaseNameOk()
+ return ret
+}
+
+// GetDatabaseNameOk returns a tuple with the DatabaseName field value
+// and a boolean to check if the value has been set.
+func (o *BackupRunningRestore) GetDatabaseNameOk() (ret BackupRunningRestoreGetDatabaseNameRetType, ok bool) {
+ return getBackupRunningRestoreGetDatabaseNameAttributeTypeOk(o.DatabaseName)
+}
+
+// SetDatabaseName sets field value
+func (o *BackupRunningRestore) SetDatabaseName(v BackupRunningRestoreGetDatabaseNameRetType) {
+ setBackupRunningRestoreGetDatabaseNameAttributeType(&o.DatabaseName, v)
+}
+
+// GetEstimatedCompletionTime returns the EstimatedCompletionTime field value
+func (o *BackupRunningRestore) GetEstimatedCompletionTime() (ret BackupRunningRestoreGetEstimatedCompletionTimeRetType) {
+ ret, _ = o.GetEstimatedCompletionTimeOk()
+ return ret
+}
+
+// GetEstimatedCompletionTimeOk returns a tuple with the EstimatedCompletionTime field value
+// and a boolean to check if the value has been set.
+func (o *BackupRunningRestore) GetEstimatedCompletionTimeOk() (ret BackupRunningRestoreGetEstimatedCompletionTimeRetType, ok bool) {
+ return getBackupRunningRestoreGetEstimatedCompletionTimeAttributeTypeOk(o.EstimatedCompletionTime)
+}
+
+// SetEstimatedCompletionTime sets field value
+func (o *BackupRunningRestore) SetEstimatedCompletionTime(v BackupRunningRestoreGetEstimatedCompletionTimeRetType) {
+ setBackupRunningRestoreGetEstimatedCompletionTimeAttributeType(&o.EstimatedCompletionTime, v)
+}
+
+// GetPercentComplete returns the PercentComplete field value
+func (o *BackupRunningRestore) GetPercentComplete() (ret BackupRunningRestoreGetPercentCompleteRetType) {
+ ret, _ = o.GetPercentCompleteOk()
+ return ret
+}
+
+// GetPercentCompleteOk returns a tuple with the PercentComplete field value
+// and a boolean to check if the value has been set.
+func (o *BackupRunningRestore) GetPercentCompleteOk() (ret BackupRunningRestoreGetPercentCompleteRetType, ok bool) {
+ return getBackupRunningRestoreGetPercentCompleteAttributeTypeOk(o.PercentComplete)
+}
+
+// SetPercentComplete sets field value
+func (o *BackupRunningRestore) SetPercentComplete(v BackupRunningRestoreGetPercentCompleteRetType) {
+ setBackupRunningRestoreGetPercentCompleteAttributeType(&o.PercentComplete, v)
+}
+
+// GetStartTime returns the StartTime field value
+func (o *BackupRunningRestore) GetStartTime() (ret BackupRunningRestoreGetStartTimeRetType) {
+ ret, _ = o.GetStartTimeOk()
+ return ret
+}
+
+// GetStartTimeOk returns a tuple with the StartTime field value
+// and a boolean to check if the value has been set.
+func (o *BackupRunningRestore) GetStartTimeOk() (ret BackupRunningRestoreGetStartTimeRetType, ok bool) {
+ return getBackupRunningRestoreGetStartTimeAttributeTypeOk(o.StartTime)
+}
+
+// SetStartTime sets field value
+func (o *BackupRunningRestore) SetStartTime(v BackupRunningRestoreGetStartTimeRetType) {
+ setBackupRunningRestoreGetStartTimeAttributeType(&o.StartTime, v)
+}
+
+func (o BackupRunningRestore) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getBackupRunningRestoreGetCommandAttributeTypeOk(o.Command); ok {
+ toSerialize["Command"] = val
+ }
+ if val, ok := getBackupRunningRestoreGetDatabaseNameAttributeTypeOk(o.DatabaseName); ok {
+ toSerialize["DatabaseName"] = val
+ }
+ if val, ok := getBackupRunningRestoreGetEstimatedCompletionTimeAttributeTypeOk(o.EstimatedCompletionTime); ok {
+ toSerialize["EstimatedCompletionTime"] = val
+ }
+ if val, ok := getBackupRunningRestoreGetPercentCompleteAttributeTypeOk(o.PercentComplete); ok {
+ toSerialize["PercentComplete"] = val
+ }
+ if val, ok := getBackupRunningRestoreGetStartTimeAttributeTypeOk(o.StartTime); ok {
+ toSerialize["StartTime"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableBackupRunningRestore struct {
+ value *BackupRunningRestore
+ isSet bool
+}
+
+func (v NullableBackupRunningRestore) Get() *BackupRunningRestore {
+ return v.value
+}
+
+func (v *NullableBackupRunningRestore) Set(val *BackupRunningRestore) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableBackupRunningRestore) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableBackupRunningRestore) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableBackupRunningRestore(val *BackupRunningRestore) *NullableBackupRunningRestore {
+ return &NullableBackupRunningRestore{value: val, isSet: true}
+}
+
+func (v NullableBackupRunningRestore) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableBackupRunningRestore) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_backup_running_restore_test.go b/pkg/sqlserverflexalpha/model_backup_running_restore_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_backup_running_restore_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_backup_sort.go b/pkg/sqlserverflexalpha/model_backup_sort.go
new file mode 100644
index 00000000..3a7a9669
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_backup_sort.go
@@ -0,0 +1,135 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// BackupSort the model 'BackupSort'
+type BackupSort string
+
+// List of backup.sort
+const (
+ BACKUPSORT_END_TIME_DESC BackupSort = "end_time.desc"
+ BACKUPSORT_END_TIME_ASC BackupSort = "end_time.asc"
+ BACKUPSORT_INDEX_DESC BackupSort = "index.desc"
+ BACKUPSORT_INDEX_ASC BackupSort = "index.asc"
+ BACKUPSORT_NAME_DESC BackupSort = "name.desc"
+ BACKUPSORT_NAME_ASC BackupSort = "name.asc"
+ BACKUPSORT_RETAINED_UNTIL_DESC BackupSort = "retained_until.desc"
+ BACKUPSORT_RETAINED_UNTIL_ASC BackupSort = "retained_until.asc"
+ BACKUPSORT_SIZE_DESC BackupSort = "size.desc"
+ BACKUPSORT_SIZE_ASC BackupSort = "size.asc"
+ BACKUPSORT_TYPE_DESC BackupSort = "type.desc"
+ BACKUPSORT_TYPE_ASC BackupSort = "type.asc"
+)
+
+// All allowed values of BackupSort enum
+var AllowedBackupSortEnumValues = []BackupSort{
+ "end_time.desc",
+ "end_time.asc",
+ "index.desc",
+ "index.asc",
+ "name.desc",
+ "name.asc",
+ "retained_until.desc",
+ "retained_until.asc",
+ "size.desc",
+ "size.asc",
+ "type.desc",
+ "type.asc",
+}
+
+func (v *BackupSort) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := BackupSort(value)
+ for _, existing := range AllowedBackupSortEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid BackupSort", value)
+}
+
+// NewBackupSortFromValue returns a pointer to a valid BackupSort
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewBackupSortFromValue(v string) (*BackupSort, error) {
+ ev := BackupSort(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for BackupSort: valid values are %v", v, AllowedBackupSortEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v BackupSort) IsValid() bool {
+ for _, existing := range AllowedBackupSortEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to backup.sort value
+func (v BackupSort) Ptr() *BackupSort {
+ return &v
+}
+
+type NullableBackupSort struct {
+ value *BackupSort
+ isSet bool
+}
+
+func (v NullableBackupSort) Get() *BackupSort {
+ return v.value
+}
+
+func (v *NullableBackupSort) Set(val *BackupSort) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableBackupSort) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableBackupSort) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableBackupSort(val *BackupSort) *NullableBackupSort {
+ return &NullableBackupSort{value: val, isSet: true}
+}
+
+func (v NullableBackupSort) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableBackupSort) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_backup_sort_test.go b/pkg/sqlserverflexalpha/model_backup_sort_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_backup_sort_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_create_database_request_payload.go b/pkg/sqlserverflexalpha/model_create_database_request_payload.go
new file mode 100644
index 00000000..84fe2798
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_database_request_payload.go
@@ -0,0 +1,270 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateDatabaseRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateDatabaseRequestPayload{}
+
+/*
+ types and functions for collation
+*/
+
+// isNotNullableString
+type CreateDatabaseRequestPayloadGetCollationAttributeType = *string
+
+func getCreateDatabaseRequestPayloadGetCollationAttributeTypeOk(arg CreateDatabaseRequestPayloadGetCollationAttributeType) (ret CreateDatabaseRequestPayloadGetCollationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateDatabaseRequestPayloadGetCollationAttributeType(arg *CreateDatabaseRequestPayloadGetCollationAttributeType, val CreateDatabaseRequestPayloadGetCollationRetType) {
+ *arg = &val
+}
+
+type CreateDatabaseRequestPayloadGetCollationArgType = string
+type CreateDatabaseRequestPayloadGetCollationRetType = string
+
+/*
+ types and functions for compatibility
+*/
+
+// isInteger
+type CreateDatabaseRequestPayloadGetCompatibilityAttributeType = *int64
+type CreateDatabaseRequestPayloadGetCompatibilityArgType = int64
+type CreateDatabaseRequestPayloadGetCompatibilityRetType = int64
+
+func getCreateDatabaseRequestPayloadGetCompatibilityAttributeTypeOk(arg CreateDatabaseRequestPayloadGetCompatibilityAttributeType) (ret CreateDatabaseRequestPayloadGetCompatibilityRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateDatabaseRequestPayloadGetCompatibilityAttributeType(arg *CreateDatabaseRequestPayloadGetCompatibilityAttributeType, val CreateDatabaseRequestPayloadGetCompatibilityRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type CreateDatabaseRequestPayloadGetNameAttributeType = *string
+
+func getCreateDatabaseRequestPayloadGetNameAttributeTypeOk(arg CreateDatabaseRequestPayloadGetNameAttributeType) (ret CreateDatabaseRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateDatabaseRequestPayloadGetNameAttributeType(arg *CreateDatabaseRequestPayloadGetNameAttributeType, val CreateDatabaseRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type CreateDatabaseRequestPayloadGetNameArgType = string
+type CreateDatabaseRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for owner
+*/
+
+// isNotNullableString
+type CreateDatabaseRequestPayloadGetOwnerAttributeType = *string
+
+func getCreateDatabaseRequestPayloadGetOwnerAttributeTypeOk(arg CreateDatabaseRequestPayloadGetOwnerAttributeType) (ret CreateDatabaseRequestPayloadGetOwnerRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateDatabaseRequestPayloadGetOwnerAttributeType(arg *CreateDatabaseRequestPayloadGetOwnerAttributeType, val CreateDatabaseRequestPayloadGetOwnerRetType) {
+ *arg = &val
+}
+
+type CreateDatabaseRequestPayloadGetOwnerArgType = string
+type CreateDatabaseRequestPayloadGetOwnerRetType = string
+
+// CreateDatabaseRequestPayload struct for CreateDatabaseRequestPayload
+type CreateDatabaseRequestPayload struct {
+ // The collation of the database. This database collation should match the *collation_name* of one of the collations given by the **Get database collation list** endpoint.
+ Collation CreateDatabaseRequestPayloadGetCollationAttributeType `json:"collation,omitempty"`
+ // CompatibilityLevel of the Database.
+ // Can be cast to int32 without loss of precision.
+ Compatibility CreateDatabaseRequestPayloadGetCompatibilityAttributeType `json:"compatibility,omitempty"`
+ // The name of the database.
+ // REQUIRED
+ Name CreateDatabaseRequestPayloadGetNameAttributeType `json:"name" required:"true"`
+ // The owner of the database.
+ // REQUIRED
+ Owner CreateDatabaseRequestPayloadGetOwnerAttributeType `json:"owner" required:"true"`
+}
+
+type _CreateDatabaseRequestPayload CreateDatabaseRequestPayload
+
+// NewCreateDatabaseRequestPayload instantiates a new CreateDatabaseRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateDatabaseRequestPayload(name CreateDatabaseRequestPayloadGetNameArgType, owner CreateDatabaseRequestPayloadGetOwnerArgType) *CreateDatabaseRequestPayload {
+ this := CreateDatabaseRequestPayload{}
+ setCreateDatabaseRequestPayloadGetNameAttributeType(&this.Name, name)
+ setCreateDatabaseRequestPayloadGetOwnerAttributeType(&this.Owner, owner)
+ return &this
+}
+
+// NewCreateDatabaseRequestPayloadWithDefaults instantiates a new CreateDatabaseRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateDatabaseRequestPayloadWithDefaults() *CreateDatabaseRequestPayload {
+ this := CreateDatabaseRequestPayload{}
+ return &this
+}
+
+// GetCollation returns the Collation field value if set, zero value otherwise.
+func (o *CreateDatabaseRequestPayload) GetCollation() (res CreateDatabaseRequestPayloadGetCollationRetType) {
+ res, _ = o.GetCollationOk()
+ return
+}
+
+// GetCollationOk returns a tuple with the Collation field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *CreateDatabaseRequestPayload) GetCollationOk() (ret CreateDatabaseRequestPayloadGetCollationRetType, ok bool) {
+ return getCreateDatabaseRequestPayloadGetCollationAttributeTypeOk(o.Collation)
+}
+
+// HasCollation returns a boolean if a field has been set.
+func (o *CreateDatabaseRequestPayload) HasCollation() bool {
+ _, ok := o.GetCollationOk()
+ return ok
+}
+
+// SetCollation gets a reference to the given string and assigns it to the Collation field.
+func (o *CreateDatabaseRequestPayload) SetCollation(v CreateDatabaseRequestPayloadGetCollationRetType) {
+ setCreateDatabaseRequestPayloadGetCollationAttributeType(&o.Collation, v)
+}
+
+// GetCompatibility returns the Compatibility field value if set, zero value otherwise.
+func (o *CreateDatabaseRequestPayload) GetCompatibility() (res CreateDatabaseRequestPayloadGetCompatibilityRetType) {
+ res, _ = o.GetCompatibilityOk()
+ return
+}
+
+// GetCompatibilityOk returns a tuple with the Compatibility field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *CreateDatabaseRequestPayload) GetCompatibilityOk() (ret CreateDatabaseRequestPayloadGetCompatibilityRetType, ok bool) {
+ return getCreateDatabaseRequestPayloadGetCompatibilityAttributeTypeOk(o.Compatibility)
+}
+
+// HasCompatibility returns a boolean if a field has been set.
+func (o *CreateDatabaseRequestPayload) HasCompatibility() bool {
+ _, ok := o.GetCompatibilityOk()
+ return ok
+}
+
+// SetCompatibility gets a reference to the given int64 and assigns it to the Compatibility field.
+func (o *CreateDatabaseRequestPayload) SetCompatibility(v CreateDatabaseRequestPayloadGetCompatibilityRetType) {
+ setCreateDatabaseRequestPayloadGetCompatibilityAttributeType(&o.Compatibility, v)
+}
+
+// GetName returns the Name field value
+func (o *CreateDatabaseRequestPayload) GetName() (ret CreateDatabaseRequestPayloadGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *CreateDatabaseRequestPayload) GetNameOk() (ret CreateDatabaseRequestPayloadGetNameRetType, ok bool) {
+ return getCreateDatabaseRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *CreateDatabaseRequestPayload) SetName(v CreateDatabaseRequestPayloadGetNameRetType) {
+ setCreateDatabaseRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetOwner returns the Owner field value
+func (o *CreateDatabaseRequestPayload) GetOwner() (ret CreateDatabaseRequestPayloadGetOwnerRetType) {
+ ret, _ = o.GetOwnerOk()
+ return ret
+}
+
+// GetOwnerOk returns a tuple with the Owner field value
+// and a boolean to check if the value has been set.
+func (o *CreateDatabaseRequestPayload) GetOwnerOk() (ret CreateDatabaseRequestPayloadGetOwnerRetType, ok bool) {
+ return getCreateDatabaseRequestPayloadGetOwnerAttributeTypeOk(o.Owner)
+}
+
+// SetOwner sets field value
+func (o *CreateDatabaseRequestPayload) SetOwner(v CreateDatabaseRequestPayloadGetOwnerRetType) {
+ setCreateDatabaseRequestPayloadGetOwnerAttributeType(&o.Owner, v)
+}
+
+func (o CreateDatabaseRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateDatabaseRequestPayloadGetCollationAttributeTypeOk(o.Collation); ok {
+ toSerialize["Collation"] = val
+ }
+ if val, ok := getCreateDatabaseRequestPayloadGetCompatibilityAttributeTypeOk(o.Compatibility); ok {
+ toSerialize["Compatibility"] = val
+ }
+ if val, ok := getCreateDatabaseRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getCreateDatabaseRequestPayloadGetOwnerAttributeTypeOk(o.Owner); ok {
+ toSerialize["Owner"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateDatabaseRequestPayload struct {
+ value *CreateDatabaseRequestPayload
+ isSet bool
+}
+
+func (v NullableCreateDatabaseRequestPayload) Get() *CreateDatabaseRequestPayload {
+ return v.value
+}
+
+func (v *NullableCreateDatabaseRequestPayload) Set(val *CreateDatabaseRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateDatabaseRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateDatabaseRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateDatabaseRequestPayload(val *CreateDatabaseRequestPayload) *NullableCreateDatabaseRequestPayload {
+ return &NullableCreateDatabaseRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableCreateDatabaseRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateDatabaseRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_create_database_request_payload_test.go b/pkg/sqlserverflexalpha/model_create_database_request_payload_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_database_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_create_database_response.go b/pkg/sqlserverflexalpha/model_create_database_response.go
new file mode 100644
index 00000000..6473bb5e
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_database_response.go
@@ -0,0 +1,126 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateDatabaseResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateDatabaseResponse{}
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type CreateDatabaseResponseGetIdAttributeType = *int64
+type CreateDatabaseResponseGetIdArgType = int64
+type CreateDatabaseResponseGetIdRetType = int64
+
+func getCreateDatabaseResponseGetIdAttributeTypeOk(arg CreateDatabaseResponseGetIdAttributeType) (ret CreateDatabaseResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateDatabaseResponseGetIdAttributeType(arg *CreateDatabaseResponseGetIdAttributeType, val CreateDatabaseResponseGetIdRetType) {
+ *arg = &val
+}
+
+// CreateDatabaseResponse struct for CreateDatabaseResponse
+type CreateDatabaseResponse struct {
+ // The id of the database.
+ // REQUIRED
+ Id CreateDatabaseResponseGetIdAttributeType `json:"id" required:"true"`
+}
+
+type _CreateDatabaseResponse CreateDatabaseResponse
+
+// NewCreateDatabaseResponse instantiates a new CreateDatabaseResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateDatabaseResponse(id CreateDatabaseResponseGetIdArgType) *CreateDatabaseResponse {
+ this := CreateDatabaseResponse{}
+ setCreateDatabaseResponseGetIdAttributeType(&this.Id, id)
+ return &this
+}
+
+// NewCreateDatabaseResponseWithDefaults instantiates a new CreateDatabaseResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateDatabaseResponseWithDefaults() *CreateDatabaseResponse {
+ this := CreateDatabaseResponse{}
+ return &this
+}
+
+// GetId returns the Id field value
+func (o *CreateDatabaseResponse) GetId() (ret CreateDatabaseResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *CreateDatabaseResponse) GetIdOk() (ret CreateDatabaseResponseGetIdRetType, ok bool) {
+ return getCreateDatabaseResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *CreateDatabaseResponse) SetId(v CreateDatabaseResponseGetIdRetType) {
+ setCreateDatabaseResponseGetIdAttributeType(&o.Id, v)
+}
+
+func (o CreateDatabaseResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateDatabaseResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateDatabaseResponse struct {
+ value *CreateDatabaseResponse
+ isSet bool
+}
+
+func (v NullableCreateDatabaseResponse) Get() *CreateDatabaseResponse {
+ return v.value
+}
+
+func (v *NullableCreateDatabaseResponse) Set(val *CreateDatabaseResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateDatabaseResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateDatabaseResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateDatabaseResponse(val *CreateDatabaseResponse) *NullableCreateDatabaseResponse {
+ return &NullableCreateDatabaseResponse{value: val, isSet: true}
+}
+
+func (v NullableCreateDatabaseResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateDatabaseResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_create_database_response_test.go b/pkg/sqlserverflexalpha/model_create_database_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_database_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_create_instance_request_payload.go b/pkg/sqlserverflexalpha/model_create_instance_request_payload.go
new file mode 100644
index 00000000..ff990d79
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_instance_request_payload.go
@@ -0,0 +1,489 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateInstanceRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateInstanceRequestPayload{}
+
+/*
+ types and functions for acl
+*/
+
+// isArray
+type CreateInstanceRequestPayloadGetAclAttributeType = *[]string
+type CreateInstanceRequestPayloadGetAclArgType = []string
+type CreateInstanceRequestPayloadGetAclRetType = []string
+
+func getCreateInstanceRequestPayloadGetAclAttributeTypeOk(arg CreateInstanceRequestPayloadGetAclAttributeType) (ret CreateInstanceRequestPayloadGetAclRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetAclAttributeType(arg *CreateInstanceRequestPayloadGetAclAttributeType, val CreateInstanceRequestPayloadGetAclRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for backupSchedule
+*/
+
+// isNotNullableString
+type CreateInstanceRequestPayloadGetBackupScheduleAttributeType = *string
+
+func getCreateInstanceRequestPayloadGetBackupScheduleAttributeTypeOk(arg CreateInstanceRequestPayloadGetBackupScheduleAttributeType) (ret CreateInstanceRequestPayloadGetBackupScheduleRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetBackupScheduleAttributeType(arg *CreateInstanceRequestPayloadGetBackupScheduleAttributeType, val CreateInstanceRequestPayloadGetBackupScheduleRetType) {
+ *arg = &val
+}
+
+type CreateInstanceRequestPayloadGetBackupScheduleArgType = string
+type CreateInstanceRequestPayloadGetBackupScheduleRetType = string
+
+/*
+ types and functions for encryption
+*/
+
+// isModel
+type CreateInstanceRequestPayloadGetEncryptionAttributeType = *InstanceEncryption
+type CreateInstanceRequestPayloadGetEncryptionArgType = InstanceEncryption
+type CreateInstanceRequestPayloadGetEncryptionRetType = InstanceEncryption
+
+func getCreateInstanceRequestPayloadGetEncryptionAttributeTypeOk(arg CreateInstanceRequestPayloadGetEncryptionAttributeType) (ret CreateInstanceRequestPayloadGetEncryptionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetEncryptionAttributeType(arg *CreateInstanceRequestPayloadGetEncryptionAttributeType, val CreateInstanceRequestPayloadGetEncryptionRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for flavorId
+*/
+
+// isNotNullableString
+type CreateInstanceRequestPayloadGetFlavorIdAttributeType = *string
+
+func getCreateInstanceRequestPayloadGetFlavorIdAttributeTypeOk(arg CreateInstanceRequestPayloadGetFlavorIdAttributeType) (ret CreateInstanceRequestPayloadGetFlavorIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetFlavorIdAttributeType(arg *CreateInstanceRequestPayloadGetFlavorIdAttributeType, val CreateInstanceRequestPayloadGetFlavorIdRetType) {
+ *arg = &val
+}
+
+type CreateInstanceRequestPayloadGetFlavorIdArgType = string
+type CreateInstanceRequestPayloadGetFlavorIdRetType = string
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type CreateInstanceRequestPayloadGetNameAttributeType = *string
+
+func getCreateInstanceRequestPayloadGetNameAttributeTypeOk(arg CreateInstanceRequestPayloadGetNameAttributeType) (ret CreateInstanceRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetNameAttributeType(arg *CreateInstanceRequestPayloadGetNameAttributeType, val CreateInstanceRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type CreateInstanceRequestPayloadGetNameArgType = string
+type CreateInstanceRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for network
+*/
+
+// isModel
+type CreateInstanceRequestPayloadGetNetworkAttributeType = *CreateInstanceRequestPayloadNetwork
+type CreateInstanceRequestPayloadGetNetworkArgType = CreateInstanceRequestPayloadNetwork
+type CreateInstanceRequestPayloadGetNetworkRetType = CreateInstanceRequestPayloadNetwork
+
+func getCreateInstanceRequestPayloadGetNetworkAttributeTypeOk(arg CreateInstanceRequestPayloadGetNetworkAttributeType) (ret CreateInstanceRequestPayloadGetNetworkRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetNetworkAttributeType(arg *CreateInstanceRequestPayloadGetNetworkAttributeType, val CreateInstanceRequestPayloadGetNetworkRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for retentionDays
+*/
+
+// isInteger
+type CreateInstanceRequestPayloadGetRetentionDaysAttributeType = *int64
+type CreateInstanceRequestPayloadGetRetentionDaysArgType = int64
+type CreateInstanceRequestPayloadGetRetentionDaysRetType = int64
+
+func getCreateInstanceRequestPayloadGetRetentionDaysAttributeTypeOk(arg CreateInstanceRequestPayloadGetRetentionDaysAttributeType) (ret CreateInstanceRequestPayloadGetRetentionDaysRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetRetentionDaysAttributeType(arg *CreateInstanceRequestPayloadGetRetentionDaysAttributeType, val CreateInstanceRequestPayloadGetRetentionDaysRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for storage
+*/
+
+// isModel
+type CreateInstanceRequestPayloadGetStorageAttributeType = *StorageCreate
+type CreateInstanceRequestPayloadGetStorageArgType = StorageCreate
+type CreateInstanceRequestPayloadGetStorageRetType = StorageCreate
+
+func getCreateInstanceRequestPayloadGetStorageAttributeTypeOk(arg CreateInstanceRequestPayloadGetStorageAttributeType) (ret CreateInstanceRequestPayloadGetStorageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetStorageAttributeType(arg *CreateInstanceRequestPayloadGetStorageAttributeType, val CreateInstanceRequestPayloadGetStorageRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for version
+*/
+
+// isEnumRef
+type CreateInstanceRequestPayloadGetVersionAttributeType = *InstanceVersion
+type CreateInstanceRequestPayloadGetVersionArgType = InstanceVersion
+type CreateInstanceRequestPayloadGetVersionRetType = InstanceVersion
+
+func getCreateInstanceRequestPayloadGetVersionAttributeTypeOk(arg CreateInstanceRequestPayloadGetVersionAttributeType) (ret CreateInstanceRequestPayloadGetVersionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadGetVersionAttributeType(arg *CreateInstanceRequestPayloadGetVersionAttributeType, val CreateInstanceRequestPayloadGetVersionRetType) {
+ *arg = &val
+}
+
+// CreateInstanceRequestPayload struct for CreateInstanceRequestPayload
+type CreateInstanceRequestPayload struct {
+ // Deprecated: List of IPV4 cidr.
+ // REQUIRED
+ Acl CreateInstanceRequestPayloadGetAclAttributeType `json:"acl" required:"true"`
+ // The schedule for on what time and how often the database backup will be created. The schedule is written as a cron schedule.
+ // REQUIRED
+ BackupSchedule CreateInstanceRequestPayloadGetBackupScheduleAttributeType `json:"backupSchedule" required:"true"`
+ Encryption CreateInstanceRequestPayloadGetEncryptionAttributeType `json:"encryption,omitempty"`
+ // The id of the instance flavor.
+ // REQUIRED
+ FlavorId CreateInstanceRequestPayloadGetFlavorIdAttributeType `json:"flavorId" required:"true"`
+ // The name of the instance.
+ // REQUIRED
+ Name CreateInstanceRequestPayloadGetNameAttributeType `json:"name" required:"true"`
+ Network CreateInstanceRequestPayloadGetNetworkAttributeType `json:"network,omitempty"`
+ // The days for how long the backup files should be stored before cleaned up. 30 to 365
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ RetentionDays CreateInstanceRequestPayloadGetRetentionDaysAttributeType `json:"retentionDays" required:"true"`
+ // REQUIRED
+ Storage CreateInstanceRequestPayloadGetStorageAttributeType `json:"storage" required:"true"`
+ // REQUIRED
+ Version CreateInstanceRequestPayloadGetVersionAttributeType `json:"version" required:"true"`
+}
+
+type _CreateInstanceRequestPayload CreateInstanceRequestPayload
+
+// NewCreateInstanceRequestPayload instantiates a new CreateInstanceRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateInstanceRequestPayload(acl CreateInstanceRequestPayloadGetAclArgType, backupSchedule CreateInstanceRequestPayloadGetBackupScheduleArgType, flavorId CreateInstanceRequestPayloadGetFlavorIdArgType, name CreateInstanceRequestPayloadGetNameArgType, retentionDays CreateInstanceRequestPayloadGetRetentionDaysArgType, storage CreateInstanceRequestPayloadGetStorageArgType, version CreateInstanceRequestPayloadGetVersionArgType) *CreateInstanceRequestPayload {
+ this := CreateInstanceRequestPayload{}
+ setCreateInstanceRequestPayloadGetAclAttributeType(&this.Acl, acl)
+ setCreateInstanceRequestPayloadGetBackupScheduleAttributeType(&this.BackupSchedule, backupSchedule)
+ setCreateInstanceRequestPayloadGetFlavorIdAttributeType(&this.FlavorId, flavorId)
+ setCreateInstanceRequestPayloadGetNameAttributeType(&this.Name, name)
+ setCreateInstanceRequestPayloadGetRetentionDaysAttributeType(&this.RetentionDays, retentionDays)
+ setCreateInstanceRequestPayloadGetStorageAttributeType(&this.Storage, storage)
+ setCreateInstanceRequestPayloadGetVersionAttributeType(&this.Version, version)
+ return &this
+}
+
+// NewCreateInstanceRequestPayloadWithDefaults instantiates a new CreateInstanceRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateInstanceRequestPayloadWithDefaults() *CreateInstanceRequestPayload {
+ this := CreateInstanceRequestPayload{}
+ return &this
+}
+
+// GetAcl returns the Acl field value
+// Deprecated
+func (o *CreateInstanceRequestPayload) GetAcl() (ret CreateInstanceRequestPayloadGetAclRetType) {
+ ret, _ = o.GetAclOk()
+ return ret
+}
+
+// GetAclOk returns a tuple with the Acl field value
+// and a boolean to check if the value has been set.
+// Deprecated
+func (o *CreateInstanceRequestPayload) GetAclOk() (ret CreateInstanceRequestPayloadGetAclRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetAclAttributeTypeOk(o.Acl)
+}
+
+// SetAcl sets field value
+// Deprecated
+func (o *CreateInstanceRequestPayload) SetAcl(v CreateInstanceRequestPayloadGetAclRetType) {
+ setCreateInstanceRequestPayloadGetAclAttributeType(&o.Acl, v)
+}
+
+// GetBackupSchedule returns the BackupSchedule field value
+func (o *CreateInstanceRequestPayload) GetBackupSchedule() (ret CreateInstanceRequestPayloadGetBackupScheduleRetType) {
+ ret, _ = o.GetBackupScheduleOk()
+ return ret
+}
+
+// GetBackupScheduleOk returns a tuple with the BackupSchedule field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetBackupScheduleOk() (ret CreateInstanceRequestPayloadGetBackupScheduleRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetBackupScheduleAttributeTypeOk(o.BackupSchedule)
+}
+
+// SetBackupSchedule sets field value
+func (o *CreateInstanceRequestPayload) SetBackupSchedule(v CreateInstanceRequestPayloadGetBackupScheduleRetType) {
+ setCreateInstanceRequestPayloadGetBackupScheduleAttributeType(&o.BackupSchedule, v)
+}
+
+// GetEncryption returns the Encryption field value if set, zero value otherwise.
+func (o *CreateInstanceRequestPayload) GetEncryption() (res CreateInstanceRequestPayloadGetEncryptionRetType) {
+ res, _ = o.GetEncryptionOk()
+ return
+}
+
+// GetEncryptionOk returns a tuple with the Encryption field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetEncryptionOk() (ret CreateInstanceRequestPayloadGetEncryptionRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetEncryptionAttributeTypeOk(o.Encryption)
+}
+
+// HasEncryption returns a boolean if a field has been set.
+func (o *CreateInstanceRequestPayload) HasEncryption() bool {
+ _, ok := o.GetEncryptionOk()
+ return ok
+}
+
+// SetEncryption gets a reference to the given InstanceEncryption and assigns it to the Encryption field.
+func (o *CreateInstanceRequestPayload) SetEncryption(v CreateInstanceRequestPayloadGetEncryptionRetType) {
+ setCreateInstanceRequestPayloadGetEncryptionAttributeType(&o.Encryption, v)
+}
+
+// GetFlavorId returns the FlavorId field value
+func (o *CreateInstanceRequestPayload) GetFlavorId() (ret CreateInstanceRequestPayloadGetFlavorIdRetType) {
+ ret, _ = o.GetFlavorIdOk()
+ return ret
+}
+
+// GetFlavorIdOk returns a tuple with the FlavorId field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetFlavorIdOk() (ret CreateInstanceRequestPayloadGetFlavorIdRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetFlavorIdAttributeTypeOk(o.FlavorId)
+}
+
+// SetFlavorId sets field value
+func (o *CreateInstanceRequestPayload) SetFlavorId(v CreateInstanceRequestPayloadGetFlavorIdRetType) {
+ setCreateInstanceRequestPayloadGetFlavorIdAttributeType(&o.FlavorId, v)
+}
+
+// GetName returns the Name field value
+func (o *CreateInstanceRequestPayload) GetName() (ret CreateInstanceRequestPayloadGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetNameOk() (ret CreateInstanceRequestPayloadGetNameRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *CreateInstanceRequestPayload) SetName(v CreateInstanceRequestPayloadGetNameRetType) {
+ setCreateInstanceRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetNetwork returns the Network field value if set, zero value otherwise.
+func (o *CreateInstanceRequestPayload) GetNetwork() (res CreateInstanceRequestPayloadGetNetworkRetType) {
+ res, _ = o.GetNetworkOk()
+ return
+}
+
+// GetNetworkOk returns a tuple with the Network field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetNetworkOk() (ret CreateInstanceRequestPayloadGetNetworkRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetNetworkAttributeTypeOk(o.Network)
+}
+
+// HasNetwork returns a boolean if a field has been set.
+func (o *CreateInstanceRequestPayload) HasNetwork() bool {
+ _, ok := o.GetNetworkOk()
+ return ok
+}
+
+// SetNetwork gets a reference to the given CreateInstanceRequestPayloadNetwork and assigns it to the Network field.
+func (o *CreateInstanceRequestPayload) SetNetwork(v CreateInstanceRequestPayloadGetNetworkRetType) {
+ setCreateInstanceRequestPayloadGetNetworkAttributeType(&o.Network, v)
+}
+
+// GetRetentionDays returns the RetentionDays field value
+func (o *CreateInstanceRequestPayload) GetRetentionDays() (ret CreateInstanceRequestPayloadGetRetentionDaysRetType) {
+ ret, _ = o.GetRetentionDaysOk()
+ return ret
+}
+
+// GetRetentionDaysOk returns a tuple with the RetentionDays field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetRetentionDaysOk() (ret CreateInstanceRequestPayloadGetRetentionDaysRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetRetentionDaysAttributeTypeOk(o.RetentionDays)
+}
+
+// SetRetentionDays sets field value
+func (o *CreateInstanceRequestPayload) SetRetentionDays(v CreateInstanceRequestPayloadGetRetentionDaysRetType) {
+ setCreateInstanceRequestPayloadGetRetentionDaysAttributeType(&o.RetentionDays, v)
+}
+
+// GetStorage returns the Storage field value
+func (o *CreateInstanceRequestPayload) GetStorage() (ret CreateInstanceRequestPayloadGetStorageRetType) {
+ ret, _ = o.GetStorageOk()
+ return ret
+}
+
+// GetStorageOk returns a tuple with the Storage field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetStorageOk() (ret CreateInstanceRequestPayloadGetStorageRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetStorageAttributeTypeOk(o.Storage)
+}
+
+// SetStorage sets field value
+func (o *CreateInstanceRequestPayload) SetStorage(v CreateInstanceRequestPayloadGetStorageRetType) {
+ setCreateInstanceRequestPayloadGetStorageAttributeType(&o.Storage, v)
+}
+
+// GetVersion returns the Version field value
+func (o *CreateInstanceRequestPayload) GetVersion() (ret CreateInstanceRequestPayloadGetVersionRetType) {
+ ret, _ = o.GetVersionOk()
+ return ret
+}
+
+// GetVersionOk returns a tuple with the Version field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayload) GetVersionOk() (ret CreateInstanceRequestPayloadGetVersionRetType, ok bool) {
+ return getCreateInstanceRequestPayloadGetVersionAttributeTypeOk(o.Version)
+}
+
+// SetVersion sets field value
+func (o *CreateInstanceRequestPayload) SetVersion(v CreateInstanceRequestPayloadGetVersionRetType) {
+ setCreateInstanceRequestPayloadGetVersionAttributeType(&o.Version, v)
+}
+
+func (o CreateInstanceRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateInstanceRequestPayloadGetAclAttributeTypeOk(o.Acl); ok {
+ toSerialize["Acl"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetBackupScheduleAttributeTypeOk(o.BackupSchedule); ok {
+ toSerialize["BackupSchedule"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetEncryptionAttributeTypeOk(o.Encryption); ok {
+ toSerialize["Encryption"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetFlavorIdAttributeTypeOk(o.FlavorId); ok {
+ toSerialize["FlavorId"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetNetworkAttributeTypeOk(o.Network); ok {
+ toSerialize["Network"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetRetentionDaysAttributeTypeOk(o.RetentionDays); ok {
+ toSerialize["RetentionDays"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetStorageAttributeTypeOk(o.Storage); ok {
+ toSerialize["Storage"] = val
+ }
+ if val, ok := getCreateInstanceRequestPayloadGetVersionAttributeTypeOk(o.Version); ok {
+ toSerialize["Version"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateInstanceRequestPayload struct {
+ value *CreateInstanceRequestPayload
+ isSet bool
+}
+
+func (v NullableCreateInstanceRequestPayload) Get() *CreateInstanceRequestPayload {
+ return v.value
+}
+
+func (v *NullableCreateInstanceRequestPayload) Set(val *CreateInstanceRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateInstanceRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateInstanceRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateInstanceRequestPayload(val *CreateInstanceRequestPayload) *NullableCreateInstanceRequestPayload {
+ return &NullableCreateInstanceRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableCreateInstanceRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateInstanceRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_create_instance_request_payload_network.go b/pkg/sqlserverflexalpha/model_create_instance_request_payload_network.go
new file mode 100644
index 00000000..816601d3
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_instance_request_payload_network.go
@@ -0,0 +1,129 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateInstanceRequestPayloadNetwork type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateInstanceRequestPayloadNetwork{}
+
+/*
+ types and functions for accessScope
+*/
+
+// isEnumRef
+type CreateInstanceRequestPayloadNetworkGetAccessScopeAttributeType = *InstanceNetworkAccessScope
+type CreateInstanceRequestPayloadNetworkGetAccessScopeArgType = InstanceNetworkAccessScope
+type CreateInstanceRequestPayloadNetworkGetAccessScopeRetType = InstanceNetworkAccessScope
+
+func getCreateInstanceRequestPayloadNetworkGetAccessScopeAttributeTypeOk(arg CreateInstanceRequestPayloadNetworkGetAccessScopeAttributeType) (ret CreateInstanceRequestPayloadNetworkGetAccessScopeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceRequestPayloadNetworkGetAccessScopeAttributeType(arg *CreateInstanceRequestPayloadNetworkGetAccessScopeAttributeType, val CreateInstanceRequestPayloadNetworkGetAccessScopeRetType) {
+ *arg = &val
+}
+
+// CreateInstanceRequestPayloadNetwork the network configuration of the instance.
+type CreateInstanceRequestPayloadNetwork struct {
+ AccessScope CreateInstanceRequestPayloadNetworkGetAccessScopeAttributeType `json:"accessScope,omitempty"`
+}
+
+// NewCreateInstanceRequestPayloadNetwork instantiates a new CreateInstanceRequestPayloadNetwork object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateInstanceRequestPayloadNetwork() *CreateInstanceRequestPayloadNetwork {
+ this := CreateInstanceRequestPayloadNetwork{}
+ return &this
+}
+
+// NewCreateInstanceRequestPayloadNetworkWithDefaults instantiates a new CreateInstanceRequestPayloadNetwork object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateInstanceRequestPayloadNetworkWithDefaults() *CreateInstanceRequestPayloadNetwork {
+ this := CreateInstanceRequestPayloadNetwork{}
+ var accessScope InstanceNetworkAccessScope = INSTANCENETWORKACCESSSCOPE_PUBLIC
+ this.AccessScope = &accessScope
+ return &this
+}
+
+// GetAccessScope returns the AccessScope field value if set, zero value otherwise.
+func (o *CreateInstanceRequestPayloadNetwork) GetAccessScope() (res CreateInstanceRequestPayloadNetworkGetAccessScopeRetType) {
+ res, _ = o.GetAccessScopeOk()
+ return
+}
+
+// GetAccessScopeOk returns a tuple with the AccessScope field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceRequestPayloadNetwork) GetAccessScopeOk() (ret CreateInstanceRequestPayloadNetworkGetAccessScopeRetType, ok bool) {
+ return getCreateInstanceRequestPayloadNetworkGetAccessScopeAttributeTypeOk(o.AccessScope)
+}
+
+// HasAccessScope returns a boolean if a field has been set.
+func (o *CreateInstanceRequestPayloadNetwork) HasAccessScope() bool {
+ _, ok := o.GetAccessScopeOk()
+ return ok
+}
+
+// SetAccessScope gets a reference to the given InstanceNetworkAccessScope and assigns it to the AccessScope field.
+func (o *CreateInstanceRequestPayloadNetwork) SetAccessScope(v CreateInstanceRequestPayloadNetworkGetAccessScopeRetType) {
+ setCreateInstanceRequestPayloadNetworkGetAccessScopeAttributeType(&o.AccessScope, v)
+}
+
+func (o CreateInstanceRequestPayloadNetwork) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateInstanceRequestPayloadNetworkGetAccessScopeAttributeTypeOk(o.AccessScope); ok {
+ toSerialize["AccessScope"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateInstanceRequestPayloadNetwork struct {
+ value *CreateInstanceRequestPayloadNetwork
+ isSet bool
+}
+
+func (v NullableCreateInstanceRequestPayloadNetwork) Get() *CreateInstanceRequestPayloadNetwork {
+ return v.value
+}
+
+func (v *NullableCreateInstanceRequestPayloadNetwork) Set(val *CreateInstanceRequestPayloadNetwork) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateInstanceRequestPayloadNetwork) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateInstanceRequestPayloadNetwork) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateInstanceRequestPayloadNetwork(val *CreateInstanceRequestPayloadNetwork) *NullableCreateInstanceRequestPayloadNetwork {
+ return &NullableCreateInstanceRequestPayloadNetwork{value: val, isSet: true}
+}
+
+func (v NullableCreateInstanceRequestPayloadNetwork) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateInstanceRequestPayloadNetwork) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_create_instance_request_payload_network_test.go b/pkg/sqlserverflexalpha/model_create_instance_request_payload_network_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_instance_request_payload_network_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_create_instance_request_payload_test.go b/pkg/sqlserverflexalpha/model_create_instance_request_payload_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_instance_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_create_instance_response.go b/pkg/sqlserverflexalpha/model_create_instance_response.go
new file mode 100644
index 00000000..cce13f0f
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_instance_response.go
@@ -0,0 +1,127 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateInstanceResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateInstanceResponse{}
+
+/*
+ types and functions for id
+*/
+
+// isNotNullableString
+type CreateInstanceResponseGetIdAttributeType = *string
+
+func getCreateInstanceResponseGetIdAttributeTypeOk(arg CreateInstanceResponseGetIdAttributeType) (ret CreateInstanceResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateInstanceResponseGetIdAttributeType(arg *CreateInstanceResponseGetIdAttributeType, val CreateInstanceResponseGetIdRetType) {
+ *arg = &val
+}
+
+type CreateInstanceResponseGetIdArgType = string
+type CreateInstanceResponseGetIdRetType = string
+
+// CreateInstanceResponse struct for CreateInstanceResponse
+type CreateInstanceResponse struct {
+ // The ID of the instance.
+ // REQUIRED
+ Id CreateInstanceResponseGetIdAttributeType `json:"id" required:"true"`
+}
+
+type _CreateInstanceResponse CreateInstanceResponse
+
+// NewCreateInstanceResponse instantiates a new CreateInstanceResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateInstanceResponse(id CreateInstanceResponseGetIdArgType) *CreateInstanceResponse {
+ this := CreateInstanceResponse{}
+ setCreateInstanceResponseGetIdAttributeType(&this.Id, id)
+ return &this
+}
+
+// NewCreateInstanceResponseWithDefaults instantiates a new CreateInstanceResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateInstanceResponseWithDefaults() *CreateInstanceResponse {
+ this := CreateInstanceResponse{}
+ return &this
+}
+
+// GetId returns the Id field value
+func (o *CreateInstanceResponse) GetId() (ret CreateInstanceResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *CreateInstanceResponse) GetIdOk() (ret CreateInstanceResponseGetIdRetType, ok bool) {
+ return getCreateInstanceResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *CreateInstanceResponse) SetId(v CreateInstanceResponseGetIdRetType) {
+ setCreateInstanceResponseGetIdAttributeType(&o.Id, v)
+}
+
+func (o CreateInstanceResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateInstanceResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateInstanceResponse struct {
+ value *CreateInstanceResponse
+ isSet bool
+}
+
+func (v NullableCreateInstanceResponse) Get() *CreateInstanceResponse {
+ return v.value
+}
+
+func (v *NullableCreateInstanceResponse) Set(val *CreateInstanceResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateInstanceResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateInstanceResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateInstanceResponse(val *CreateInstanceResponse) *NullableCreateInstanceResponse {
+ return &NullableCreateInstanceResponse{value: val, isSet: true}
+}
+
+func (v NullableCreateInstanceResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateInstanceResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_create_instance_response_test.go b/pkg/sqlserverflexalpha/model_create_instance_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_instance_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_create_user_request_payload.go b/pkg/sqlserverflexalpha/model_create_user_request_payload.go
new file mode 100644
index 00000000..9f169e65
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_user_request_payload.go
@@ -0,0 +1,220 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateUserRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateUserRequestPayload{}
+
+/*
+ types and functions for default_database
+*/
+
+// isNotNullableString
+type CreateUserRequestPayloadGetDefaultDatabaseAttributeType = *string
+
+func getCreateUserRequestPayloadGetDefaultDatabaseAttributeTypeOk(arg CreateUserRequestPayloadGetDefaultDatabaseAttributeType) (ret CreateUserRequestPayloadGetDefaultDatabaseRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserRequestPayloadGetDefaultDatabaseAttributeType(arg *CreateUserRequestPayloadGetDefaultDatabaseAttributeType, val CreateUserRequestPayloadGetDefaultDatabaseRetType) {
+ *arg = &val
+}
+
+type CreateUserRequestPayloadGetDefaultDatabaseArgType = string
+type CreateUserRequestPayloadGetDefaultDatabaseRetType = string
+
+/*
+ types and functions for roles
+*/
+
+// isArray
+type CreateUserRequestPayloadGetRolesAttributeType = *[]UserRole
+type CreateUserRequestPayloadGetRolesArgType = []UserRole
+type CreateUserRequestPayloadGetRolesRetType = []UserRole
+
+func getCreateUserRequestPayloadGetRolesAttributeTypeOk(arg CreateUserRequestPayloadGetRolesAttributeType) (ret CreateUserRequestPayloadGetRolesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserRequestPayloadGetRolesAttributeType(arg *CreateUserRequestPayloadGetRolesAttributeType, val CreateUserRequestPayloadGetRolesRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for username
+*/
+
+// isNotNullableString
+type CreateUserRequestPayloadGetUsernameAttributeType = *string
+
+func getCreateUserRequestPayloadGetUsernameAttributeTypeOk(arg CreateUserRequestPayloadGetUsernameAttributeType) (ret CreateUserRequestPayloadGetUsernameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserRequestPayloadGetUsernameAttributeType(arg *CreateUserRequestPayloadGetUsernameAttributeType, val CreateUserRequestPayloadGetUsernameRetType) {
+ *arg = &val
+}
+
+type CreateUserRequestPayloadGetUsernameArgType = string
+type CreateUserRequestPayloadGetUsernameRetType = string
+
+// CreateUserRequestPayload struct for CreateUserRequestPayload
+type CreateUserRequestPayload struct {
+ // The default database for a user of the instance.
+ DefaultDatabase CreateUserRequestPayloadGetDefaultDatabaseAttributeType `json:"default_database,omitempty"`
+ // A list containing the user roles for the instance.
+ // REQUIRED
+ Roles CreateUserRequestPayloadGetRolesAttributeType `json:"roles" required:"true"`
+ // The name of the user.
+ // REQUIRED
+ Username CreateUserRequestPayloadGetUsernameAttributeType `json:"username" required:"true"`
+}
+
+type _CreateUserRequestPayload CreateUserRequestPayload
+
+// NewCreateUserRequestPayload instantiates a new CreateUserRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateUserRequestPayload(roles CreateUserRequestPayloadGetRolesArgType, username CreateUserRequestPayloadGetUsernameArgType) *CreateUserRequestPayload {
+ this := CreateUserRequestPayload{}
+ setCreateUserRequestPayloadGetRolesAttributeType(&this.Roles, roles)
+ setCreateUserRequestPayloadGetUsernameAttributeType(&this.Username, username)
+ return &this
+}
+
+// NewCreateUserRequestPayloadWithDefaults instantiates a new CreateUserRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateUserRequestPayloadWithDefaults() *CreateUserRequestPayload {
+ this := CreateUserRequestPayload{}
+ return &this
+}
+
+// GetDefaultDatabase returns the DefaultDatabase field value if set, zero value otherwise.
+func (o *CreateUserRequestPayload) GetDefaultDatabase() (res CreateUserRequestPayloadGetDefaultDatabaseRetType) {
+ res, _ = o.GetDefaultDatabaseOk()
+ return
+}
+
+// GetDefaultDatabaseOk returns a tuple with the DefaultDatabase field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *CreateUserRequestPayload) GetDefaultDatabaseOk() (ret CreateUserRequestPayloadGetDefaultDatabaseRetType, ok bool) {
+ return getCreateUserRequestPayloadGetDefaultDatabaseAttributeTypeOk(o.DefaultDatabase)
+}
+
+// HasDefaultDatabase returns a boolean if a field has been set.
+func (o *CreateUserRequestPayload) HasDefaultDatabase() bool {
+ _, ok := o.GetDefaultDatabaseOk()
+ return ok
+}
+
+// SetDefaultDatabase gets a reference to the given string and assigns it to the DefaultDatabase field.
+func (o *CreateUserRequestPayload) SetDefaultDatabase(v CreateUserRequestPayloadGetDefaultDatabaseRetType) {
+ setCreateUserRequestPayloadGetDefaultDatabaseAttributeType(&o.DefaultDatabase, v)
+}
+
+// GetRoles returns the Roles field value
+func (o *CreateUserRequestPayload) GetRoles() (ret CreateUserRequestPayloadGetRolesRetType) {
+ ret, _ = o.GetRolesOk()
+ return ret
+}
+
+// GetRolesOk returns a tuple with the Roles field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserRequestPayload) GetRolesOk() (ret CreateUserRequestPayloadGetRolesRetType, ok bool) {
+ return getCreateUserRequestPayloadGetRolesAttributeTypeOk(o.Roles)
+}
+
+// SetRoles sets field value
+func (o *CreateUserRequestPayload) SetRoles(v CreateUserRequestPayloadGetRolesRetType) {
+ setCreateUserRequestPayloadGetRolesAttributeType(&o.Roles, v)
+}
+
+// GetUsername returns the Username field value
+func (o *CreateUserRequestPayload) GetUsername() (ret CreateUserRequestPayloadGetUsernameRetType) {
+ ret, _ = o.GetUsernameOk()
+ return ret
+}
+
+// GetUsernameOk returns a tuple with the Username field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserRequestPayload) GetUsernameOk() (ret CreateUserRequestPayloadGetUsernameRetType, ok bool) {
+ return getCreateUserRequestPayloadGetUsernameAttributeTypeOk(o.Username)
+}
+
+// SetUsername sets field value
+func (o *CreateUserRequestPayload) SetUsername(v CreateUserRequestPayloadGetUsernameRetType) {
+ setCreateUserRequestPayloadGetUsernameAttributeType(&o.Username, v)
+}
+
+func (o CreateUserRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateUserRequestPayloadGetDefaultDatabaseAttributeTypeOk(o.DefaultDatabase); ok {
+ toSerialize["DefaultDatabase"] = val
+ }
+ if val, ok := getCreateUserRequestPayloadGetRolesAttributeTypeOk(o.Roles); ok {
+ toSerialize["Roles"] = val
+ }
+ if val, ok := getCreateUserRequestPayloadGetUsernameAttributeTypeOk(o.Username); ok {
+ toSerialize["Username"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateUserRequestPayload struct {
+ value *CreateUserRequestPayload
+ isSet bool
+}
+
+func (v NullableCreateUserRequestPayload) Get() *CreateUserRequestPayload {
+ return v.value
+}
+
+func (v *NullableCreateUserRequestPayload) Set(val *CreateUserRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateUserRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateUserRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateUserRequestPayload(val *CreateUserRequestPayload) *NullableCreateUserRequestPayload {
+ return &NullableCreateUserRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableCreateUserRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateUserRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_create_user_request_payload_test.go b/pkg/sqlserverflexalpha/model_create_user_request_payload_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_user_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_create_user_response.go b/pkg/sqlserverflexalpha/model_create_user_response.go
new file mode 100644
index 00000000..b25f632b
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_user_response.go
@@ -0,0 +1,484 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the CreateUserResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &CreateUserResponse{}
+
+/*
+ types and functions for default_database
+*/
+
+// isNotNullableString
+type CreateUserResponseGetDefaultDatabaseAttributeType = *string
+
+func getCreateUserResponseGetDefaultDatabaseAttributeTypeOk(arg CreateUserResponseGetDefaultDatabaseAttributeType) (ret CreateUserResponseGetDefaultDatabaseRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetDefaultDatabaseAttributeType(arg *CreateUserResponseGetDefaultDatabaseAttributeType, val CreateUserResponseGetDefaultDatabaseRetType) {
+ *arg = &val
+}
+
+type CreateUserResponseGetDefaultDatabaseArgType = string
+type CreateUserResponseGetDefaultDatabaseRetType = string
+
+/*
+ types and functions for host
+*/
+
+// isNotNullableString
+type CreateUserResponseGetHostAttributeType = *string
+
+func getCreateUserResponseGetHostAttributeTypeOk(arg CreateUserResponseGetHostAttributeType) (ret CreateUserResponseGetHostRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetHostAttributeType(arg *CreateUserResponseGetHostAttributeType, val CreateUserResponseGetHostRetType) {
+ *arg = &val
+}
+
+type CreateUserResponseGetHostArgType = string
+type CreateUserResponseGetHostRetType = string
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type CreateUserResponseGetIdAttributeType = *int64
+type CreateUserResponseGetIdArgType = int64
+type CreateUserResponseGetIdRetType = int64
+
+func getCreateUserResponseGetIdAttributeTypeOk(arg CreateUserResponseGetIdAttributeType) (ret CreateUserResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetIdAttributeType(arg *CreateUserResponseGetIdAttributeType, val CreateUserResponseGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for password
+*/
+
+// isNotNullableString
+type CreateUserResponseGetPasswordAttributeType = *string
+
+func getCreateUserResponseGetPasswordAttributeTypeOk(arg CreateUserResponseGetPasswordAttributeType) (ret CreateUserResponseGetPasswordRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetPasswordAttributeType(arg *CreateUserResponseGetPasswordAttributeType, val CreateUserResponseGetPasswordRetType) {
+ *arg = &val
+}
+
+type CreateUserResponseGetPasswordArgType = string
+type CreateUserResponseGetPasswordRetType = string
+
+/*
+ types and functions for port
+*/
+
+// isInteger
+type CreateUserResponseGetPortAttributeType = *int64
+type CreateUserResponseGetPortArgType = int64
+type CreateUserResponseGetPortRetType = int64
+
+func getCreateUserResponseGetPortAttributeTypeOk(arg CreateUserResponseGetPortAttributeType) (ret CreateUserResponseGetPortRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetPortAttributeType(arg *CreateUserResponseGetPortAttributeType, val CreateUserResponseGetPortRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for roles
+*/
+
+// isArray
+type CreateUserResponseGetRolesAttributeType = *[]UserRole
+type CreateUserResponseGetRolesArgType = []UserRole
+type CreateUserResponseGetRolesRetType = []UserRole
+
+func getCreateUserResponseGetRolesAttributeTypeOk(arg CreateUserResponseGetRolesAttributeType) (ret CreateUserResponseGetRolesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetRolesAttributeType(arg *CreateUserResponseGetRolesAttributeType, val CreateUserResponseGetRolesRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for status
+*/
+
+// isNotNullableString
+type CreateUserResponseGetStatusAttributeType = *string
+
+func getCreateUserResponseGetStatusAttributeTypeOk(arg CreateUserResponseGetStatusAttributeType) (ret CreateUserResponseGetStatusRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetStatusAttributeType(arg *CreateUserResponseGetStatusAttributeType, val CreateUserResponseGetStatusRetType) {
+ *arg = &val
+}
+
+type CreateUserResponseGetStatusArgType = string
+type CreateUserResponseGetStatusRetType = string
+
+/*
+ types and functions for uri
+*/
+
+// isNotNullableString
+type CreateUserResponseGetUriAttributeType = *string
+
+func getCreateUserResponseGetUriAttributeTypeOk(arg CreateUserResponseGetUriAttributeType) (ret CreateUserResponseGetUriRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetUriAttributeType(arg *CreateUserResponseGetUriAttributeType, val CreateUserResponseGetUriRetType) {
+ *arg = &val
+}
+
+type CreateUserResponseGetUriArgType = string
+type CreateUserResponseGetUriRetType = string
+
+/*
+ types and functions for username
+*/
+
+// isNotNullableString
+type CreateUserResponseGetUsernameAttributeType = *string
+
+func getCreateUserResponseGetUsernameAttributeTypeOk(arg CreateUserResponseGetUsernameAttributeType) (ret CreateUserResponseGetUsernameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setCreateUserResponseGetUsernameAttributeType(arg *CreateUserResponseGetUsernameAttributeType, val CreateUserResponseGetUsernameRetType) {
+ *arg = &val
+}
+
+type CreateUserResponseGetUsernameArgType = string
+type CreateUserResponseGetUsernameRetType = string
+
+// CreateUserResponse struct for CreateUserResponse
+type CreateUserResponse struct {
+ // The default database for a user of the instance.
+ // REQUIRED
+ DefaultDatabase CreateUserResponseGetDefaultDatabaseAttributeType `json:"default_database" required:"true"`
+ // The host of the instance in which the user belongs to.
+ // REQUIRED
+ Host CreateUserResponseGetHostAttributeType `json:"host" required:"true"`
+ // The ID of the user.
+ // REQUIRED
+ Id CreateUserResponseGetIdAttributeType `json:"id" required:"true"`
+ // The password for the user.
+ // REQUIRED
+ Password CreateUserResponseGetPasswordAttributeType `json:"password" required:"true"`
+ // The port of the instance in which the user belongs to.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ Port CreateUserResponseGetPortAttributeType `json:"port" required:"true"`
+ // REQUIRED
+ Roles CreateUserResponseGetRolesAttributeType `json:"roles" required:"true"`
+ // The current status of the user.
+ // REQUIRED
+ Status CreateUserResponseGetStatusAttributeType `json:"status" required:"true"`
+ // The connection string for the user to the instance.
+ // REQUIRED
+ Uri CreateUserResponseGetUriAttributeType `json:"uri" required:"true"`
+ // The name of the user.
+ // REQUIRED
+ Username CreateUserResponseGetUsernameAttributeType `json:"username" required:"true"`
+}
+
+type _CreateUserResponse CreateUserResponse
+
+// NewCreateUserResponse instantiates a new CreateUserResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewCreateUserResponse(defaultDatabase CreateUserResponseGetDefaultDatabaseArgType, host CreateUserResponseGetHostArgType, id CreateUserResponseGetIdArgType, password CreateUserResponseGetPasswordArgType, port CreateUserResponseGetPortArgType, roles CreateUserResponseGetRolesArgType, status CreateUserResponseGetStatusArgType, uri CreateUserResponseGetUriArgType, username CreateUserResponseGetUsernameArgType) *CreateUserResponse {
+ this := CreateUserResponse{}
+ setCreateUserResponseGetDefaultDatabaseAttributeType(&this.DefaultDatabase, defaultDatabase)
+ setCreateUserResponseGetHostAttributeType(&this.Host, host)
+ setCreateUserResponseGetIdAttributeType(&this.Id, id)
+ setCreateUserResponseGetPasswordAttributeType(&this.Password, password)
+ setCreateUserResponseGetPortAttributeType(&this.Port, port)
+ setCreateUserResponseGetRolesAttributeType(&this.Roles, roles)
+ setCreateUserResponseGetStatusAttributeType(&this.Status, status)
+ setCreateUserResponseGetUriAttributeType(&this.Uri, uri)
+ setCreateUserResponseGetUsernameAttributeType(&this.Username, username)
+ return &this
+}
+
+// NewCreateUserResponseWithDefaults instantiates a new CreateUserResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewCreateUserResponseWithDefaults() *CreateUserResponse {
+ this := CreateUserResponse{}
+ return &this
+}
+
+// GetDefaultDatabase returns the DefaultDatabase field value
+func (o *CreateUserResponse) GetDefaultDatabase() (ret CreateUserResponseGetDefaultDatabaseRetType) {
+ ret, _ = o.GetDefaultDatabaseOk()
+ return ret
+}
+
+// GetDefaultDatabaseOk returns a tuple with the DefaultDatabase field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetDefaultDatabaseOk() (ret CreateUserResponseGetDefaultDatabaseRetType, ok bool) {
+ return getCreateUserResponseGetDefaultDatabaseAttributeTypeOk(o.DefaultDatabase)
+}
+
+// SetDefaultDatabase sets field value
+func (o *CreateUserResponse) SetDefaultDatabase(v CreateUserResponseGetDefaultDatabaseRetType) {
+ setCreateUserResponseGetDefaultDatabaseAttributeType(&o.DefaultDatabase, v)
+}
+
+// GetHost returns the Host field value
+func (o *CreateUserResponse) GetHost() (ret CreateUserResponseGetHostRetType) {
+ ret, _ = o.GetHostOk()
+ return ret
+}
+
+// GetHostOk returns a tuple with the Host field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetHostOk() (ret CreateUserResponseGetHostRetType, ok bool) {
+ return getCreateUserResponseGetHostAttributeTypeOk(o.Host)
+}
+
+// SetHost sets field value
+func (o *CreateUserResponse) SetHost(v CreateUserResponseGetHostRetType) {
+ setCreateUserResponseGetHostAttributeType(&o.Host, v)
+}
+
+// GetId returns the Id field value
+func (o *CreateUserResponse) GetId() (ret CreateUserResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetIdOk() (ret CreateUserResponseGetIdRetType, ok bool) {
+ return getCreateUserResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *CreateUserResponse) SetId(v CreateUserResponseGetIdRetType) {
+ setCreateUserResponseGetIdAttributeType(&o.Id, v)
+}
+
+// GetPassword returns the Password field value
+func (o *CreateUserResponse) GetPassword() (ret CreateUserResponseGetPasswordRetType) {
+ ret, _ = o.GetPasswordOk()
+ return ret
+}
+
+// GetPasswordOk returns a tuple with the Password field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetPasswordOk() (ret CreateUserResponseGetPasswordRetType, ok bool) {
+ return getCreateUserResponseGetPasswordAttributeTypeOk(o.Password)
+}
+
+// SetPassword sets field value
+func (o *CreateUserResponse) SetPassword(v CreateUserResponseGetPasswordRetType) {
+ setCreateUserResponseGetPasswordAttributeType(&o.Password, v)
+}
+
+// GetPort returns the Port field value
+func (o *CreateUserResponse) GetPort() (ret CreateUserResponseGetPortRetType) {
+ ret, _ = o.GetPortOk()
+ return ret
+}
+
+// GetPortOk returns a tuple with the Port field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetPortOk() (ret CreateUserResponseGetPortRetType, ok bool) {
+ return getCreateUserResponseGetPortAttributeTypeOk(o.Port)
+}
+
+// SetPort sets field value
+func (o *CreateUserResponse) SetPort(v CreateUserResponseGetPortRetType) {
+ setCreateUserResponseGetPortAttributeType(&o.Port, v)
+}
+
+// GetRoles returns the Roles field value
+func (o *CreateUserResponse) GetRoles() (ret CreateUserResponseGetRolesRetType) {
+ ret, _ = o.GetRolesOk()
+ return ret
+}
+
+// GetRolesOk returns a tuple with the Roles field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetRolesOk() (ret CreateUserResponseGetRolesRetType, ok bool) {
+ return getCreateUserResponseGetRolesAttributeTypeOk(o.Roles)
+}
+
+// SetRoles sets field value
+func (o *CreateUserResponse) SetRoles(v CreateUserResponseGetRolesRetType) {
+ setCreateUserResponseGetRolesAttributeType(&o.Roles, v)
+}
+
+// GetStatus returns the Status field value
+func (o *CreateUserResponse) GetStatus() (ret CreateUserResponseGetStatusRetType) {
+ ret, _ = o.GetStatusOk()
+ return ret
+}
+
+// GetStatusOk returns a tuple with the Status field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetStatusOk() (ret CreateUserResponseGetStatusRetType, ok bool) {
+ return getCreateUserResponseGetStatusAttributeTypeOk(o.Status)
+}
+
+// SetStatus sets field value
+func (o *CreateUserResponse) SetStatus(v CreateUserResponseGetStatusRetType) {
+ setCreateUserResponseGetStatusAttributeType(&o.Status, v)
+}
+
+// GetUri returns the Uri field value
+func (o *CreateUserResponse) GetUri() (ret CreateUserResponseGetUriRetType) {
+ ret, _ = o.GetUriOk()
+ return ret
+}
+
+// GetUriOk returns a tuple with the Uri field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetUriOk() (ret CreateUserResponseGetUriRetType, ok bool) {
+ return getCreateUserResponseGetUriAttributeTypeOk(o.Uri)
+}
+
+// SetUri sets field value
+func (o *CreateUserResponse) SetUri(v CreateUserResponseGetUriRetType) {
+ setCreateUserResponseGetUriAttributeType(&o.Uri, v)
+}
+
+// GetUsername returns the Username field value
+func (o *CreateUserResponse) GetUsername() (ret CreateUserResponseGetUsernameRetType) {
+ ret, _ = o.GetUsernameOk()
+ return ret
+}
+
+// GetUsernameOk returns a tuple with the Username field value
+// and a boolean to check if the value has been set.
+func (o *CreateUserResponse) GetUsernameOk() (ret CreateUserResponseGetUsernameRetType, ok bool) {
+ return getCreateUserResponseGetUsernameAttributeTypeOk(o.Username)
+}
+
+// SetUsername sets field value
+func (o *CreateUserResponse) SetUsername(v CreateUserResponseGetUsernameRetType) {
+ setCreateUserResponseGetUsernameAttributeType(&o.Username, v)
+}
+
+func (o CreateUserResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getCreateUserResponseGetDefaultDatabaseAttributeTypeOk(o.DefaultDatabase); ok {
+ toSerialize["DefaultDatabase"] = val
+ }
+ if val, ok := getCreateUserResponseGetHostAttributeTypeOk(o.Host); ok {
+ toSerialize["Host"] = val
+ }
+ if val, ok := getCreateUserResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getCreateUserResponseGetPasswordAttributeTypeOk(o.Password); ok {
+ toSerialize["Password"] = val
+ }
+ if val, ok := getCreateUserResponseGetPortAttributeTypeOk(o.Port); ok {
+ toSerialize["Port"] = val
+ }
+ if val, ok := getCreateUserResponseGetRolesAttributeTypeOk(o.Roles); ok {
+ toSerialize["Roles"] = val
+ }
+ if val, ok := getCreateUserResponseGetStatusAttributeTypeOk(o.Status); ok {
+ toSerialize["Status"] = val
+ }
+ if val, ok := getCreateUserResponseGetUriAttributeTypeOk(o.Uri); ok {
+ toSerialize["Uri"] = val
+ }
+ if val, ok := getCreateUserResponseGetUsernameAttributeTypeOk(o.Username); ok {
+ toSerialize["Username"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableCreateUserResponse struct {
+ value *CreateUserResponse
+ isSet bool
+}
+
+func (v NullableCreateUserResponse) Get() *CreateUserResponse {
+ return v.value
+}
+
+func (v *NullableCreateUserResponse) Set(val *CreateUserResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableCreateUserResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableCreateUserResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableCreateUserResponse(val *CreateUserResponse) *NullableCreateUserResponse {
+ return &NullableCreateUserResponse{value: val, isSet: true}
+}
+
+func (v NullableCreateUserResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableCreateUserResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_create_user_response_test.go b/pkg/sqlserverflexalpha/model_create_user_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_create_user_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_database_getcollation.go b/pkg/sqlserverflexalpha/model_database_getcollation.go
new file mode 100644
index 00000000..892a426f
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_database_getcollation.go
@@ -0,0 +1,176 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the DatabaseGetcollation type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &DatabaseGetcollation{}
+
+/*
+ types and functions for collation_name
+*/
+
+// isNotNullableString
+type DatabaseGetcollationGetCollationNameAttributeType = *string
+
+func getDatabaseGetcollationGetCollationNameAttributeTypeOk(arg DatabaseGetcollationGetCollationNameAttributeType) (ret DatabaseGetcollationGetCollationNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setDatabaseGetcollationGetCollationNameAttributeType(arg *DatabaseGetcollationGetCollationNameAttributeType, val DatabaseGetcollationGetCollationNameRetType) {
+ *arg = &val
+}
+
+type DatabaseGetcollationGetCollationNameArgType = string
+type DatabaseGetcollationGetCollationNameRetType = string
+
+/*
+ types and functions for description
+*/
+
+// isNotNullableString
+type DatabaseGetcollationGetDescriptionAttributeType = *string
+
+func getDatabaseGetcollationGetDescriptionAttributeTypeOk(arg DatabaseGetcollationGetDescriptionAttributeType) (ret DatabaseGetcollationGetDescriptionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setDatabaseGetcollationGetDescriptionAttributeType(arg *DatabaseGetcollationGetDescriptionAttributeType, val DatabaseGetcollationGetDescriptionRetType) {
+ *arg = &val
+}
+
+type DatabaseGetcollationGetDescriptionArgType = string
+type DatabaseGetcollationGetDescriptionRetType = string
+
+// DatabaseGetcollation struct for DatabaseGetcollation
+type DatabaseGetcollation struct {
+ CollationName DatabaseGetcollationGetCollationNameAttributeType `json:"collation_name,omitempty"`
+ Description DatabaseGetcollationGetDescriptionAttributeType `json:"description,omitempty"`
+}
+
+// NewDatabaseGetcollation instantiates a new DatabaseGetcollation object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewDatabaseGetcollation() *DatabaseGetcollation {
+ this := DatabaseGetcollation{}
+ return &this
+}
+
+// NewDatabaseGetcollationWithDefaults instantiates a new DatabaseGetcollation object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewDatabaseGetcollationWithDefaults() *DatabaseGetcollation {
+ this := DatabaseGetcollation{}
+ return &this
+}
+
+// GetCollationName returns the CollationName field value if set, zero value otherwise.
+func (o *DatabaseGetcollation) GetCollationName() (res DatabaseGetcollationGetCollationNameRetType) {
+ res, _ = o.GetCollationNameOk()
+ return
+}
+
+// GetCollationNameOk returns a tuple with the CollationName field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *DatabaseGetcollation) GetCollationNameOk() (ret DatabaseGetcollationGetCollationNameRetType, ok bool) {
+ return getDatabaseGetcollationGetCollationNameAttributeTypeOk(o.CollationName)
+}
+
+// HasCollationName returns a boolean if a field has been set.
+func (o *DatabaseGetcollation) HasCollationName() bool {
+ _, ok := o.GetCollationNameOk()
+ return ok
+}
+
+// SetCollationName gets a reference to the given string and assigns it to the CollationName field.
+func (o *DatabaseGetcollation) SetCollationName(v DatabaseGetcollationGetCollationNameRetType) {
+ setDatabaseGetcollationGetCollationNameAttributeType(&o.CollationName, v)
+}
+
+// GetDescription returns the Description field value if set, zero value otherwise.
+func (o *DatabaseGetcollation) GetDescription() (res DatabaseGetcollationGetDescriptionRetType) {
+ res, _ = o.GetDescriptionOk()
+ return
+}
+
+// GetDescriptionOk returns a tuple with the Description field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *DatabaseGetcollation) GetDescriptionOk() (ret DatabaseGetcollationGetDescriptionRetType, ok bool) {
+ return getDatabaseGetcollationGetDescriptionAttributeTypeOk(o.Description)
+}
+
+// HasDescription returns a boolean if a field has been set.
+func (o *DatabaseGetcollation) HasDescription() bool {
+ _, ok := o.GetDescriptionOk()
+ return ok
+}
+
+// SetDescription gets a reference to the given string and assigns it to the Description field.
+func (o *DatabaseGetcollation) SetDescription(v DatabaseGetcollationGetDescriptionRetType) {
+ setDatabaseGetcollationGetDescriptionAttributeType(&o.Description, v)
+}
+
+func (o DatabaseGetcollation) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getDatabaseGetcollationGetCollationNameAttributeTypeOk(o.CollationName); ok {
+ toSerialize["CollationName"] = val
+ }
+ if val, ok := getDatabaseGetcollationGetDescriptionAttributeTypeOk(o.Description); ok {
+ toSerialize["Description"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableDatabaseGetcollation struct {
+ value *DatabaseGetcollation
+ isSet bool
+}
+
+func (v NullableDatabaseGetcollation) Get() *DatabaseGetcollation {
+ return v.value
+}
+
+func (v *NullableDatabaseGetcollation) Set(val *DatabaseGetcollation) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableDatabaseGetcollation) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableDatabaseGetcollation) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableDatabaseGetcollation(val *DatabaseGetcollation) *NullableDatabaseGetcollation {
+ return &NullableDatabaseGetcollation{value: val, isSet: true}
+}
+
+func (v NullableDatabaseGetcollation) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableDatabaseGetcollation) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_database_getcollation_test.go b/pkg/sqlserverflexalpha/model_database_getcollation_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_database_getcollation_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_database_getcompatibility.go b/pkg/sqlserverflexalpha/model_database_getcompatibility.go
new file mode 100644
index 00000000..65dedca7
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_database_getcompatibility.go
@@ -0,0 +1,176 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the DatabaseGetcompatibility type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &DatabaseGetcompatibility{}
+
+/*
+ types and functions for compatibility_level
+*/
+
+// isInteger
+type DatabaseGetcompatibilityGetCompatibilityLevelAttributeType = *int64
+type DatabaseGetcompatibilityGetCompatibilityLevelArgType = int64
+type DatabaseGetcompatibilityGetCompatibilityLevelRetType = int64
+
+func getDatabaseGetcompatibilityGetCompatibilityLevelAttributeTypeOk(arg DatabaseGetcompatibilityGetCompatibilityLevelAttributeType) (ret DatabaseGetcompatibilityGetCompatibilityLevelRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setDatabaseGetcompatibilityGetCompatibilityLevelAttributeType(arg *DatabaseGetcompatibilityGetCompatibilityLevelAttributeType, val DatabaseGetcompatibilityGetCompatibilityLevelRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for description
+*/
+
+// isNotNullableString
+type DatabaseGetcompatibilityGetDescriptionAttributeType = *string
+
+func getDatabaseGetcompatibilityGetDescriptionAttributeTypeOk(arg DatabaseGetcompatibilityGetDescriptionAttributeType) (ret DatabaseGetcompatibilityGetDescriptionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setDatabaseGetcompatibilityGetDescriptionAttributeType(arg *DatabaseGetcompatibilityGetDescriptionAttributeType, val DatabaseGetcompatibilityGetDescriptionRetType) {
+ *arg = &val
+}
+
+type DatabaseGetcompatibilityGetDescriptionArgType = string
+type DatabaseGetcompatibilityGetDescriptionRetType = string
+
+// DatabaseGetcompatibility struct for DatabaseGetcompatibility
+type DatabaseGetcompatibility struct {
+ // Can be cast to int32 without loss of precision.
+ CompatibilityLevel DatabaseGetcompatibilityGetCompatibilityLevelAttributeType `json:"compatibility_level,omitempty"`
+ Description DatabaseGetcompatibilityGetDescriptionAttributeType `json:"description,omitempty"`
+}
+
+// NewDatabaseGetcompatibility instantiates a new DatabaseGetcompatibility object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewDatabaseGetcompatibility() *DatabaseGetcompatibility {
+ this := DatabaseGetcompatibility{}
+ return &this
+}
+
+// NewDatabaseGetcompatibilityWithDefaults instantiates a new DatabaseGetcompatibility object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewDatabaseGetcompatibilityWithDefaults() *DatabaseGetcompatibility {
+ this := DatabaseGetcompatibility{}
+ return &this
+}
+
+// GetCompatibilityLevel returns the CompatibilityLevel field value if set, zero value otherwise.
+func (o *DatabaseGetcompatibility) GetCompatibilityLevel() (res DatabaseGetcompatibilityGetCompatibilityLevelRetType) {
+ res, _ = o.GetCompatibilityLevelOk()
+ return
+}
+
+// GetCompatibilityLevelOk returns a tuple with the CompatibilityLevel field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *DatabaseGetcompatibility) GetCompatibilityLevelOk() (ret DatabaseGetcompatibilityGetCompatibilityLevelRetType, ok bool) {
+ return getDatabaseGetcompatibilityGetCompatibilityLevelAttributeTypeOk(o.CompatibilityLevel)
+}
+
+// HasCompatibilityLevel returns a boolean if a field has been set.
+func (o *DatabaseGetcompatibility) HasCompatibilityLevel() bool {
+ _, ok := o.GetCompatibilityLevelOk()
+ return ok
+}
+
+// SetCompatibilityLevel gets a reference to the given int64 and assigns it to the CompatibilityLevel field.
+func (o *DatabaseGetcompatibility) SetCompatibilityLevel(v DatabaseGetcompatibilityGetCompatibilityLevelRetType) {
+ setDatabaseGetcompatibilityGetCompatibilityLevelAttributeType(&o.CompatibilityLevel, v)
+}
+
+// GetDescription returns the Description field value if set, zero value otherwise.
+func (o *DatabaseGetcompatibility) GetDescription() (res DatabaseGetcompatibilityGetDescriptionRetType) {
+ res, _ = o.GetDescriptionOk()
+ return
+}
+
+// GetDescriptionOk returns a tuple with the Description field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *DatabaseGetcompatibility) GetDescriptionOk() (ret DatabaseGetcompatibilityGetDescriptionRetType, ok bool) {
+ return getDatabaseGetcompatibilityGetDescriptionAttributeTypeOk(o.Description)
+}
+
+// HasDescription returns a boolean if a field has been set.
+func (o *DatabaseGetcompatibility) HasDescription() bool {
+ _, ok := o.GetDescriptionOk()
+ return ok
+}
+
+// SetDescription gets a reference to the given string and assigns it to the Description field.
+func (o *DatabaseGetcompatibility) SetDescription(v DatabaseGetcompatibilityGetDescriptionRetType) {
+ setDatabaseGetcompatibilityGetDescriptionAttributeType(&o.Description, v)
+}
+
+func (o DatabaseGetcompatibility) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getDatabaseGetcompatibilityGetCompatibilityLevelAttributeTypeOk(o.CompatibilityLevel); ok {
+ toSerialize["CompatibilityLevel"] = val
+ }
+ if val, ok := getDatabaseGetcompatibilityGetDescriptionAttributeTypeOk(o.Description); ok {
+ toSerialize["Description"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableDatabaseGetcompatibility struct {
+ value *DatabaseGetcompatibility
+ isSet bool
+}
+
+func (v NullableDatabaseGetcompatibility) Get() *DatabaseGetcompatibility {
+ return v.value
+}
+
+func (v *NullableDatabaseGetcompatibility) Set(val *DatabaseGetcompatibility) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableDatabaseGetcompatibility) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableDatabaseGetcompatibility) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableDatabaseGetcompatibility(val *DatabaseGetcompatibility) *NullableDatabaseGetcompatibility {
+ return &NullableDatabaseGetcompatibility{value: val, isSet: true}
+}
+
+func (v NullableDatabaseGetcompatibility) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableDatabaseGetcompatibility) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_database_getcompatibility_test.go b/pkg/sqlserverflexalpha/model_database_getcompatibility_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_database_getcompatibility_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_database_roles.go b/pkg/sqlserverflexalpha/model_database_roles.go
new file mode 100644
index 00000000..8d0a1b7f
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_database_roles.go
@@ -0,0 +1,171 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the DatabaseRoles type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &DatabaseRoles{}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type DatabaseRolesGetNameAttributeType = *string
+
+func getDatabaseRolesGetNameAttributeTypeOk(arg DatabaseRolesGetNameAttributeType) (ret DatabaseRolesGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setDatabaseRolesGetNameAttributeType(arg *DatabaseRolesGetNameAttributeType, val DatabaseRolesGetNameRetType) {
+ *arg = &val
+}
+
+type DatabaseRolesGetNameArgType = string
+type DatabaseRolesGetNameRetType = string
+
+/*
+ types and functions for roles
+*/
+
+// isArray
+type DatabaseRolesGetRolesAttributeType = *[]string
+type DatabaseRolesGetRolesArgType = []string
+type DatabaseRolesGetRolesRetType = []string
+
+func getDatabaseRolesGetRolesAttributeTypeOk(arg DatabaseRolesGetRolesAttributeType) (ret DatabaseRolesGetRolesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setDatabaseRolesGetRolesAttributeType(arg *DatabaseRolesGetRolesAttributeType, val DatabaseRolesGetRolesRetType) {
+ *arg = &val
+}
+
+// DatabaseRoles The name and the roles for a database for a user.
+type DatabaseRoles struct {
+ // The name of the database.
+ // REQUIRED
+ Name DatabaseRolesGetNameAttributeType `json:"name" required:"true"`
+ // The name and the roles for a database
+ // REQUIRED
+ Roles DatabaseRolesGetRolesAttributeType `json:"roles" required:"true"`
+}
+
+type _DatabaseRoles DatabaseRoles
+
+// NewDatabaseRoles instantiates a new DatabaseRoles object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewDatabaseRoles(name DatabaseRolesGetNameArgType, roles DatabaseRolesGetRolesArgType) *DatabaseRoles {
+ this := DatabaseRoles{}
+ setDatabaseRolesGetNameAttributeType(&this.Name, name)
+ setDatabaseRolesGetRolesAttributeType(&this.Roles, roles)
+ return &this
+}
+
+// NewDatabaseRolesWithDefaults instantiates a new DatabaseRoles object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewDatabaseRolesWithDefaults() *DatabaseRoles {
+ this := DatabaseRoles{}
+ return &this
+}
+
+// GetName returns the Name field value
+func (o *DatabaseRoles) GetName() (ret DatabaseRolesGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *DatabaseRoles) GetNameOk() (ret DatabaseRolesGetNameRetType, ok bool) {
+ return getDatabaseRolesGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *DatabaseRoles) SetName(v DatabaseRolesGetNameRetType) {
+ setDatabaseRolesGetNameAttributeType(&o.Name, v)
+}
+
+// GetRoles returns the Roles field value
+func (o *DatabaseRoles) GetRoles() (ret DatabaseRolesGetRolesRetType) {
+ ret, _ = o.GetRolesOk()
+ return ret
+}
+
+// GetRolesOk returns a tuple with the Roles field value
+// and a boolean to check if the value has been set.
+func (o *DatabaseRoles) GetRolesOk() (ret DatabaseRolesGetRolesRetType, ok bool) {
+ return getDatabaseRolesGetRolesAttributeTypeOk(o.Roles)
+}
+
+// SetRoles sets field value
+func (o *DatabaseRoles) SetRoles(v DatabaseRolesGetRolesRetType) {
+ setDatabaseRolesGetRolesAttributeType(&o.Roles, v)
+}
+
+func (o DatabaseRoles) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getDatabaseRolesGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getDatabaseRolesGetRolesAttributeTypeOk(o.Roles); ok {
+ toSerialize["Roles"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableDatabaseRoles struct {
+ value *DatabaseRoles
+ isSet bool
+}
+
+func (v NullableDatabaseRoles) Get() *DatabaseRoles {
+ return v.value
+}
+
+func (v *NullableDatabaseRoles) Set(val *DatabaseRoles) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableDatabaseRoles) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableDatabaseRoles) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableDatabaseRoles(val *DatabaseRoles) *NullableDatabaseRoles {
+ return &NullableDatabaseRoles{value: val, isSet: true}
+}
+
+func (v NullableDatabaseRoles) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableDatabaseRoles) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_database_roles_test.go b/pkg/sqlserverflexalpha/model_database_roles_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_database_roles_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_database_sort.go b/pkg/sqlserverflexalpha/model_database_sort.go
new file mode 100644
index 00000000..f4e45087
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_database_sort.go
@@ -0,0 +1,131 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// DatabaseSort the model 'DatabaseSort'
+type DatabaseSort string
+
+// List of database.sort
+const (
+ DATABASESORT_CREATED_AT_DESC DatabaseSort = "created_at.desc"
+ DATABASESORT_CREATED_AT_ASC DatabaseSort = "created_at.asc"
+ DATABASESORT_DATABASE_ID_DESC DatabaseSort = "database_id.desc"
+ DATABASESORT_DATABASE_ID_ASC DatabaseSort = "database_id.asc"
+ DATABASESORT_DATABASE_NAME_DESC DatabaseSort = "database_name.desc"
+ DATABASESORT_DATABASE_NAME_ASC DatabaseSort = "database_name.asc"
+ DATABASESORT_DATABASE_OWNER_DESC DatabaseSort = "database_owner.desc"
+ DATABASESORT_DATABASE_OWNER_ASC DatabaseSort = "database_owner.asc"
+ DATABASESORT_INDEX_ASC DatabaseSort = "index.asc"
+ DATABASESORT_INDEX_DESC DatabaseSort = "index.desc"
+)
+
+// All allowed values of DatabaseSort enum
+var AllowedDatabaseSortEnumValues = []DatabaseSort{
+ "created_at.desc",
+ "created_at.asc",
+ "database_id.desc",
+ "database_id.asc",
+ "database_name.desc",
+ "database_name.asc",
+ "database_owner.desc",
+ "database_owner.asc",
+ "index.asc",
+ "index.desc",
+}
+
+func (v *DatabaseSort) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := DatabaseSort(value)
+ for _, existing := range AllowedDatabaseSortEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid DatabaseSort", value)
+}
+
+// NewDatabaseSortFromValue returns a pointer to a valid DatabaseSort
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewDatabaseSortFromValue(v string) (*DatabaseSort, error) {
+ ev := DatabaseSort(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for DatabaseSort: valid values are %v", v, AllowedDatabaseSortEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v DatabaseSort) IsValid() bool {
+ for _, existing := range AllowedDatabaseSortEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to database.sort value
+func (v DatabaseSort) Ptr() *DatabaseSort {
+ return &v
+}
+
+type NullableDatabaseSort struct {
+ value *DatabaseSort
+ isSet bool
+}
+
+func (v NullableDatabaseSort) Get() *DatabaseSort {
+ return v.value
+}
+
+func (v *NullableDatabaseSort) Set(val *DatabaseSort) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableDatabaseSort) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableDatabaseSort) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableDatabaseSort(val *DatabaseSort) *NullableDatabaseSort {
+ return &NullableDatabaseSort{value: val, isSet: true}
+}
+
+func (v NullableDatabaseSort) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableDatabaseSort) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_database_sort_test.go b/pkg/sqlserverflexalpha/model_database_sort_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_database_sort_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_error.go b/pkg/sqlserverflexalpha/model_error.go
new file mode 100644
index 00000000..31d53693
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_error.go
@@ -0,0 +1,262 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the Error type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &Error{}
+
+/*
+ types and functions for code
+*/
+
+// isInteger
+type ErrorGetCodeAttributeType = *int64
+type ErrorGetCodeArgType = int64
+type ErrorGetCodeRetType = int64
+
+func getErrorGetCodeAttributeTypeOk(arg ErrorGetCodeAttributeType) (ret ErrorGetCodeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setErrorGetCodeAttributeType(arg *ErrorGetCodeAttributeType, val ErrorGetCodeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for message
+*/
+
+// isNotNullableString
+type ErrorGetMessageAttributeType = *string
+
+func getErrorGetMessageAttributeTypeOk(arg ErrorGetMessageAttributeType) (ret ErrorGetMessageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setErrorGetMessageAttributeType(arg *ErrorGetMessageAttributeType, val ErrorGetMessageRetType) {
+ *arg = &val
+}
+
+type ErrorGetMessageArgType = string
+type ErrorGetMessageRetType = string
+
+/*
+ types and functions for traceId
+*/
+
+// isNotNullableString
+type ErrorGetTraceIdAttributeType = *string
+
+func getErrorGetTraceIdAttributeTypeOk(arg ErrorGetTraceIdAttributeType) (ret ErrorGetTraceIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setErrorGetTraceIdAttributeType(arg *ErrorGetTraceIdAttributeType, val ErrorGetTraceIdRetType) {
+ *arg = &val
+}
+
+type ErrorGetTraceIdArgType = string
+type ErrorGetTraceIdRetType = string
+
+/*
+ types and functions for type
+*/
+
+// isNotNullableString
+type ErrorGetTypeAttributeType = *string
+
+func getErrorGetTypeAttributeTypeOk(arg ErrorGetTypeAttributeType) (ret ErrorGetTypeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setErrorGetTypeAttributeType(arg *ErrorGetTypeAttributeType, val ErrorGetTypeRetType) {
+ *arg = &val
+}
+
+type ErrorGetTypeArgType = string
+type ErrorGetTypeRetType = string
+
+// Error struct for Error
+type Error struct {
+ // The http error code of the error.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ Code ErrorGetCodeAttributeType `json:"code" required:"true" validate:"required,errorCode"`
+ // More detailed information about the error.
+ // REQUIRED
+ Message ErrorGetMessageAttributeType `json:"message" required:"true" validate:"required,errorMsg"`
+ // The trace id of the request.
+ // REQUIRED
+ TraceId ErrorGetTraceIdAttributeType `json:"traceId" required:"true" validate:"required,traceID"`
+ // Describes in which state the api was when the error happened.
+ // REQUIRED
+ Type ErrorGetTypeAttributeType `json:"type" required:"true" validate:"required,errorType"`
+}
+
+type _Error Error
+
+// NewError instantiates a new Error object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewError(code ErrorGetCodeArgType, message ErrorGetMessageArgType, traceId ErrorGetTraceIdArgType, types ErrorGetTypeArgType) *Error {
+ this := Error{}
+ setErrorGetCodeAttributeType(&this.Code, code)
+ setErrorGetMessageAttributeType(&this.Message, message)
+ setErrorGetTraceIdAttributeType(&this.TraceId, traceId)
+ setErrorGetTypeAttributeType(&this.Type, types)
+ return &this
+}
+
+// NewErrorWithDefaults instantiates a new Error object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewErrorWithDefaults() *Error {
+ this := Error{}
+ return &this
+}
+
+// GetCode returns the Code field value
+func (o *Error) GetCode() (ret ErrorGetCodeRetType) {
+ ret, _ = o.GetCodeOk()
+ return ret
+}
+
+// GetCodeOk returns a tuple with the Code field value
+// and a boolean to check if the value has been set.
+func (o *Error) GetCodeOk() (ret ErrorGetCodeRetType, ok bool) {
+ return getErrorGetCodeAttributeTypeOk(o.Code)
+}
+
+// SetCode sets field value
+func (o *Error) SetCode(v ErrorGetCodeRetType) {
+ setErrorGetCodeAttributeType(&o.Code, v)
+}
+
+// GetMessage returns the Message field value
+func (o *Error) GetMessage() (ret ErrorGetMessageRetType) {
+ ret, _ = o.GetMessageOk()
+ return ret
+}
+
+// GetMessageOk returns a tuple with the Message field value
+// and a boolean to check if the value has been set.
+func (o *Error) GetMessageOk() (ret ErrorGetMessageRetType, ok bool) {
+ return getErrorGetMessageAttributeTypeOk(o.Message)
+}
+
+// SetMessage sets field value
+func (o *Error) SetMessage(v ErrorGetMessageRetType) {
+ setErrorGetMessageAttributeType(&o.Message, v)
+}
+
+// GetTraceId returns the TraceId field value
+func (o *Error) GetTraceId() (ret ErrorGetTraceIdRetType) {
+ ret, _ = o.GetTraceIdOk()
+ return ret
+}
+
+// GetTraceIdOk returns a tuple with the TraceId field value
+// and a boolean to check if the value has been set.
+func (o *Error) GetTraceIdOk() (ret ErrorGetTraceIdRetType, ok bool) {
+ return getErrorGetTraceIdAttributeTypeOk(o.TraceId)
+}
+
+// SetTraceId sets field value
+func (o *Error) SetTraceId(v ErrorGetTraceIdRetType) {
+ setErrorGetTraceIdAttributeType(&o.TraceId, v)
+}
+
+// GetType returns the Type field value
+func (o *Error) GetType() (ret ErrorGetTypeRetType) {
+ ret, _ = o.GetTypeOk()
+ return ret
+}
+
+// GetTypeOk returns a tuple with the Type field value
+// and a boolean to check if the value has been set.
+func (o *Error) GetTypeOk() (ret ErrorGetTypeRetType, ok bool) {
+ return getErrorGetTypeAttributeTypeOk(o.Type)
+}
+
+// SetType sets field value
+func (o *Error) SetType(v ErrorGetTypeRetType) {
+ setErrorGetTypeAttributeType(&o.Type, v)
+}
+
+func (o Error) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getErrorGetCodeAttributeTypeOk(o.Code); ok {
+ toSerialize["Code"] = val
+ }
+ if val, ok := getErrorGetMessageAttributeTypeOk(o.Message); ok {
+ toSerialize["Message"] = val
+ }
+ if val, ok := getErrorGetTraceIdAttributeTypeOk(o.TraceId); ok {
+ toSerialize["TraceId"] = val
+ }
+ if val, ok := getErrorGetTypeAttributeTypeOk(o.Type); ok {
+ toSerialize["Type"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableError struct {
+ value *Error
+ isSet bool
+}
+
+func (v NullableError) Get() *Error {
+ return v.value
+}
+
+func (v *NullableError) Set(val *Error) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableError) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableError) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableError(val *Error) *NullableError {
+ return &NullableError{value: val, isSet: true}
+}
+
+func (v NullableError) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableError) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_error_test.go b/pkg/sqlserverflexalpha/model_error_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_error_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_flavor_sort.go b/pkg/sqlserverflexalpha/model_flavor_sort.go
new file mode 100644
index 00000000..65e628ec
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_flavor_sort.go
@@ -0,0 +1,147 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// FlavorSort the model 'FlavorSort'
+type FlavorSort string
+
+// List of flavor.sort
+const (
+ FLAVORSORT_INDEX_DESC FlavorSort = "index.desc"
+ FLAVORSORT_INDEX_ASC FlavorSort = "index.asc"
+ FLAVORSORT_CPU_DESC FlavorSort = "cpu.desc"
+ FLAVORSORT_CPU_ASC FlavorSort = "cpu.asc"
+ FLAVORSORT_FLAVOR_DESCRIPTION_ASC FlavorSort = "flavor_description.asc"
+ FLAVORSORT_FLAVOR_DESCRIPTION_DESC FlavorSort = "flavor_description.desc"
+ FLAVORSORT_ID_DESC FlavorSort = "id.desc"
+ FLAVORSORT_ID_ASC FlavorSort = "id.asc"
+ FLAVORSORT_SIZE_MAX_DESC FlavorSort = "size_max.desc"
+ FLAVORSORT_SIZE_MAX_ASC FlavorSort = "size_max.asc"
+ FLAVORSORT_RAM_DESC FlavorSort = "ram.desc"
+ FLAVORSORT_RAM_ASC FlavorSort = "ram.asc"
+ FLAVORSORT_SIZE_MIN_DESC FlavorSort = "size_min.desc"
+ FLAVORSORT_SIZE_MIN_ASC FlavorSort = "size_min.asc"
+ FLAVORSORT_STORAGE_CLASS_ASC FlavorSort = "storage_class.asc"
+ FLAVORSORT_STORAGE_CLASS_DESC FlavorSort = "storage_class.desc"
+ FLAVORSORT_NODE_TYPE_ASC FlavorSort = "node_type.asc"
+ FLAVORSORT_NODE_TYPE_DESC FlavorSort = "node_type.desc"
+)
+
+// All allowed values of FlavorSort enum
+var AllowedFlavorSortEnumValues = []FlavorSort{
+ "index.desc",
+ "index.asc",
+ "cpu.desc",
+ "cpu.asc",
+ "flavor_description.asc",
+ "flavor_description.desc",
+ "id.desc",
+ "id.asc",
+ "size_max.desc",
+ "size_max.asc",
+ "ram.desc",
+ "ram.asc",
+ "size_min.desc",
+ "size_min.asc",
+ "storage_class.asc",
+ "storage_class.desc",
+ "node_type.asc",
+ "node_type.desc",
+}
+
+func (v *FlavorSort) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := FlavorSort(value)
+ for _, existing := range AllowedFlavorSortEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid FlavorSort", value)
+}
+
+// NewFlavorSortFromValue returns a pointer to a valid FlavorSort
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewFlavorSortFromValue(v string) (*FlavorSort, error) {
+ ev := FlavorSort(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for FlavorSort: valid values are %v", v, AllowedFlavorSortEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v FlavorSort) IsValid() bool {
+ for _, existing := range AllowedFlavorSortEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to flavor.sort value
+func (v FlavorSort) Ptr() *FlavorSort {
+ return &v
+}
+
+type NullableFlavorSort struct {
+ value *FlavorSort
+ isSet bool
+}
+
+func (v NullableFlavorSort) Get() *FlavorSort {
+ return v.value
+}
+
+func (v *NullableFlavorSort) Set(val *FlavorSort) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableFlavorSort) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableFlavorSort) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableFlavorSort(val *FlavorSort) *NullableFlavorSort {
+ return &NullableFlavorSort{value: val, isSet: true}
+}
+
+func (v NullableFlavorSort) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableFlavorSort) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_flavor_sort_test.go b/pkg/sqlserverflexalpha/model_flavor_sort_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_flavor_sort_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_flavor_storage_classes_storage_class.go b/pkg/sqlserverflexalpha/model_flavor_storage_classes_storage_class.go
new file mode 100644
index 00000000..aaf1f07e
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_flavor_storage_classes_storage_class.go
@@ -0,0 +1,214 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the FlavorStorageClassesStorageClass type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &FlavorStorageClassesStorageClass{}
+
+/*
+ types and functions for class
+*/
+
+// isNotNullableString
+type FlavorStorageClassesStorageClassGetClassAttributeType = *string
+
+func getFlavorStorageClassesStorageClassGetClassAttributeTypeOk(arg FlavorStorageClassesStorageClassGetClassAttributeType) (ret FlavorStorageClassesStorageClassGetClassRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setFlavorStorageClassesStorageClassGetClassAttributeType(arg *FlavorStorageClassesStorageClassGetClassAttributeType, val FlavorStorageClassesStorageClassGetClassRetType) {
+ *arg = &val
+}
+
+type FlavorStorageClassesStorageClassGetClassArgType = string
+type FlavorStorageClassesStorageClassGetClassRetType = string
+
+/*
+ types and functions for maxIoPerSec
+*/
+
+// isInteger
+type FlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType = *int64
+type FlavorStorageClassesStorageClassGetMaxIoPerSecArgType = int64
+type FlavorStorageClassesStorageClassGetMaxIoPerSecRetType = int64
+
+func getFlavorStorageClassesStorageClassGetMaxIoPerSecAttributeTypeOk(arg FlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType) (ret FlavorStorageClassesStorageClassGetMaxIoPerSecRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setFlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType(arg *FlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType, val FlavorStorageClassesStorageClassGetMaxIoPerSecRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for maxThroughInMb
+*/
+
+// isInteger
+type FlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType = *int64
+type FlavorStorageClassesStorageClassGetMaxThroughInMbArgType = int64
+type FlavorStorageClassesStorageClassGetMaxThroughInMbRetType = int64
+
+func getFlavorStorageClassesStorageClassGetMaxThroughInMbAttributeTypeOk(arg FlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType) (ret FlavorStorageClassesStorageClassGetMaxThroughInMbRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setFlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType(arg *FlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType, val FlavorStorageClassesStorageClassGetMaxThroughInMbRetType) {
+ *arg = &val
+}
+
+// FlavorStorageClassesStorageClass a storageClass defines how efficient the storage can work
+type FlavorStorageClassesStorageClass struct {
+ // REQUIRED
+ Class FlavorStorageClassesStorageClassGetClassAttributeType `json:"class" required:"true"`
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ MaxIoPerSec FlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType `json:"maxIoPerSec" required:"true"`
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ MaxThroughInMb FlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType `json:"maxThroughInMb" required:"true"`
+}
+
+type _FlavorStorageClassesStorageClass FlavorStorageClassesStorageClass
+
+// NewFlavorStorageClassesStorageClass instantiates a new FlavorStorageClassesStorageClass object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewFlavorStorageClassesStorageClass(class FlavorStorageClassesStorageClassGetClassArgType, maxIoPerSec FlavorStorageClassesStorageClassGetMaxIoPerSecArgType, maxThroughInMb FlavorStorageClassesStorageClassGetMaxThroughInMbArgType) *FlavorStorageClassesStorageClass {
+ this := FlavorStorageClassesStorageClass{}
+ setFlavorStorageClassesStorageClassGetClassAttributeType(&this.Class, class)
+ setFlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType(&this.MaxIoPerSec, maxIoPerSec)
+ setFlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType(&this.MaxThroughInMb, maxThroughInMb)
+ return &this
+}
+
+// NewFlavorStorageClassesStorageClassWithDefaults instantiates a new FlavorStorageClassesStorageClass object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewFlavorStorageClassesStorageClassWithDefaults() *FlavorStorageClassesStorageClass {
+ this := FlavorStorageClassesStorageClass{}
+ return &this
+}
+
+// GetClass returns the Class field value
+func (o *FlavorStorageClassesStorageClass) GetClass() (ret FlavorStorageClassesStorageClassGetClassRetType) {
+ ret, _ = o.GetClassOk()
+ return ret
+}
+
+// GetClassOk returns a tuple with the Class field value
+// and a boolean to check if the value has been set.
+func (o *FlavorStorageClassesStorageClass) GetClassOk() (ret FlavorStorageClassesStorageClassGetClassRetType, ok bool) {
+ return getFlavorStorageClassesStorageClassGetClassAttributeTypeOk(o.Class)
+}
+
+// SetClass sets field value
+func (o *FlavorStorageClassesStorageClass) SetClass(v FlavorStorageClassesStorageClassGetClassRetType) {
+ setFlavorStorageClassesStorageClassGetClassAttributeType(&o.Class, v)
+}
+
+// GetMaxIoPerSec returns the MaxIoPerSec field value
+func (o *FlavorStorageClassesStorageClass) GetMaxIoPerSec() (ret FlavorStorageClassesStorageClassGetMaxIoPerSecRetType) {
+ ret, _ = o.GetMaxIoPerSecOk()
+ return ret
+}
+
+// GetMaxIoPerSecOk returns a tuple with the MaxIoPerSec field value
+// and a boolean to check if the value has been set.
+func (o *FlavorStorageClassesStorageClass) GetMaxIoPerSecOk() (ret FlavorStorageClassesStorageClassGetMaxIoPerSecRetType, ok bool) {
+ return getFlavorStorageClassesStorageClassGetMaxIoPerSecAttributeTypeOk(o.MaxIoPerSec)
+}
+
+// SetMaxIoPerSec sets field value
+func (o *FlavorStorageClassesStorageClass) SetMaxIoPerSec(v FlavorStorageClassesStorageClassGetMaxIoPerSecRetType) {
+ setFlavorStorageClassesStorageClassGetMaxIoPerSecAttributeType(&o.MaxIoPerSec, v)
+}
+
+// GetMaxThroughInMb returns the MaxThroughInMb field value
+func (o *FlavorStorageClassesStorageClass) GetMaxThroughInMb() (ret FlavorStorageClassesStorageClassGetMaxThroughInMbRetType) {
+ ret, _ = o.GetMaxThroughInMbOk()
+ return ret
+}
+
+// GetMaxThroughInMbOk returns a tuple with the MaxThroughInMb field value
+// and a boolean to check if the value has been set.
+func (o *FlavorStorageClassesStorageClass) GetMaxThroughInMbOk() (ret FlavorStorageClassesStorageClassGetMaxThroughInMbRetType, ok bool) {
+ return getFlavorStorageClassesStorageClassGetMaxThroughInMbAttributeTypeOk(o.MaxThroughInMb)
+}
+
+// SetMaxThroughInMb sets field value
+func (o *FlavorStorageClassesStorageClass) SetMaxThroughInMb(v FlavorStorageClassesStorageClassGetMaxThroughInMbRetType) {
+ setFlavorStorageClassesStorageClassGetMaxThroughInMbAttributeType(&o.MaxThroughInMb, v)
+}
+
+func (o FlavorStorageClassesStorageClass) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getFlavorStorageClassesStorageClassGetClassAttributeTypeOk(o.Class); ok {
+ toSerialize["Class"] = val
+ }
+ if val, ok := getFlavorStorageClassesStorageClassGetMaxIoPerSecAttributeTypeOk(o.MaxIoPerSec); ok {
+ toSerialize["MaxIoPerSec"] = val
+ }
+ if val, ok := getFlavorStorageClassesStorageClassGetMaxThroughInMbAttributeTypeOk(o.MaxThroughInMb); ok {
+ toSerialize["MaxThroughInMb"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableFlavorStorageClassesStorageClass struct {
+ value *FlavorStorageClassesStorageClass
+ isSet bool
+}
+
+func (v NullableFlavorStorageClassesStorageClass) Get() *FlavorStorageClassesStorageClass {
+ return v.value
+}
+
+func (v *NullableFlavorStorageClassesStorageClass) Set(val *FlavorStorageClassesStorageClass) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableFlavorStorageClassesStorageClass) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableFlavorStorageClassesStorageClass) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableFlavorStorageClassesStorageClass(val *FlavorStorageClassesStorageClass) *NullableFlavorStorageClassesStorageClass {
+ return &NullableFlavorStorageClassesStorageClass{value: val, isSet: true}
+}
+
+func (v NullableFlavorStorageClassesStorageClass) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableFlavorStorageClassesStorageClass) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_flavor_storage_classes_storage_class_test.go b/pkg/sqlserverflexalpha/model_flavor_storage_classes_storage_class_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_flavor_storage_classes_storage_class_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_flavor_storage_range.go b/pkg/sqlserverflexalpha/model_flavor_storage_range.go
new file mode 100644
index 00000000..1abfc523
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_flavor_storage_range.go
@@ -0,0 +1,172 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the FlavorStorageRange type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &FlavorStorageRange{}
+
+/*
+ types and functions for max
+*/
+
+// isInteger
+type FlavorStorageRangeGetMaxAttributeType = *int64
+type FlavorStorageRangeGetMaxArgType = int64
+type FlavorStorageRangeGetMaxRetType = int64
+
+func getFlavorStorageRangeGetMaxAttributeTypeOk(arg FlavorStorageRangeGetMaxAttributeType) (ret FlavorStorageRangeGetMaxRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setFlavorStorageRangeGetMaxAttributeType(arg *FlavorStorageRangeGetMaxAttributeType, val FlavorStorageRangeGetMaxRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for min
+*/
+
+// isInteger
+type FlavorStorageRangeGetMinAttributeType = *int64
+type FlavorStorageRangeGetMinArgType = int64
+type FlavorStorageRangeGetMinRetType = int64
+
+func getFlavorStorageRangeGetMinAttributeTypeOk(arg FlavorStorageRangeGetMinAttributeType) (ret FlavorStorageRangeGetMinRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setFlavorStorageRangeGetMinAttributeType(arg *FlavorStorageRangeGetMinAttributeType, val FlavorStorageRangeGetMinRetType) {
+ *arg = &val
+}
+
+// FlavorStorageRange range of maximum and minimum storage which can be ordered for the flavor in Gigabyte.
+type FlavorStorageRange struct {
+ // maximum storage which can be ordered for the flavor in Gigabyte.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ Max FlavorStorageRangeGetMaxAttributeType `json:"max" required:"true"`
+ // minimum storage which is required to order in Gigabyte.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ Min FlavorStorageRangeGetMinAttributeType `json:"min" required:"true"`
+}
+
+type _FlavorStorageRange FlavorStorageRange
+
+// NewFlavorStorageRange instantiates a new FlavorStorageRange object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewFlavorStorageRange(max FlavorStorageRangeGetMaxArgType, min FlavorStorageRangeGetMinArgType) *FlavorStorageRange {
+ this := FlavorStorageRange{}
+ setFlavorStorageRangeGetMaxAttributeType(&this.Max, max)
+ setFlavorStorageRangeGetMinAttributeType(&this.Min, min)
+ return &this
+}
+
+// NewFlavorStorageRangeWithDefaults instantiates a new FlavorStorageRange object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewFlavorStorageRangeWithDefaults() *FlavorStorageRange {
+ this := FlavorStorageRange{}
+ return &this
+}
+
+// GetMax returns the Max field value
+func (o *FlavorStorageRange) GetMax() (ret FlavorStorageRangeGetMaxRetType) {
+ ret, _ = o.GetMaxOk()
+ return ret
+}
+
+// GetMaxOk returns a tuple with the Max field value
+// and a boolean to check if the value has been set.
+func (o *FlavorStorageRange) GetMaxOk() (ret FlavorStorageRangeGetMaxRetType, ok bool) {
+ return getFlavorStorageRangeGetMaxAttributeTypeOk(o.Max)
+}
+
+// SetMax sets field value
+func (o *FlavorStorageRange) SetMax(v FlavorStorageRangeGetMaxRetType) {
+ setFlavorStorageRangeGetMaxAttributeType(&o.Max, v)
+}
+
+// GetMin returns the Min field value
+func (o *FlavorStorageRange) GetMin() (ret FlavorStorageRangeGetMinRetType) {
+ ret, _ = o.GetMinOk()
+ return ret
+}
+
+// GetMinOk returns a tuple with the Min field value
+// and a boolean to check if the value has been set.
+func (o *FlavorStorageRange) GetMinOk() (ret FlavorStorageRangeGetMinRetType, ok bool) {
+ return getFlavorStorageRangeGetMinAttributeTypeOk(o.Min)
+}
+
+// SetMin sets field value
+func (o *FlavorStorageRange) SetMin(v FlavorStorageRangeGetMinRetType) {
+ setFlavorStorageRangeGetMinAttributeType(&o.Min, v)
+}
+
+func (o FlavorStorageRange) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getFlavorStorageRangeGetMaxAttributeTypeOk(o.Max); ok {
+ toSerialize["Max"] = val
+ }
+ if val, ok := getFlavorStorageRangeGetMinAttributeTypeOk(o.Min); ok {
+ toSerialize["Min"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableFlavorStorageRange struct {
+ value *FlavorStorageRange
+ isSet bool
+}
+
+func (v NullableFlavorStorageRange) Get() *FlavorStorageRange {
+ return v.value
+}
+
+func (v *NullableFlavorStorageRange) Set(val *FlavorStorageRange) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableFlavorStorageRange) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableFlavorStorageRange) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableFlavorStorageRange(val *FlavorStorageRange) *NullableFlavorStorageRange {
+ return &NullableFlavorStorageRange{value: val, isSet: true}
+}
+
+func (v NullableFlavorStorageRange) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableFlavorStorageRange) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_flavor_storage_range_test.go b/pkg/sqlserverflexalpha/model_flavor_storage_range_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_flavor_storage_range_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_get_backup_response.go b/pkg/sqlserverflexalpha/model_get_backup_response.go
new file mode 100644
index 00000000..7875d04e
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_backup_response.go
@@ -0,0 +1,436 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetBackupResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetBackupResponse{}
+
+/*
+ types and functions for completionTime
+*/
+
+//// isAny
+//type GetBackupResponseGetCompletionTimeAttributeType = any
+//type GetBackupResponseGetCompletionTimeArgType = any
+//type GetBackupResponseGetCompletionTimeRetType = any
+//
+//func getGetBackupResponseGetCompletionTimeAttributeTypeOk(arg GetBackupResponseGetCompletionTimeAttributeType) (ret GetBackupResponseGetCompletionTimeRetType, ok bool) {
+// if arg == nil {
+// return ret, false
+// }
+// return *arg, true
+//}
+//
+//func setGetBackupResponseGetCompletionTimeAttributeType(arg *GetBackupResponseGetCompletionTimeAttributeType, val GetBackupResponseGetCompletionTimeRetType) {
+// *arg = &val
+//}
+
+// isModel
+type GetBackupResponseGetCompletionTimeAttributeType = *string
+type GetBackupResponseGetCompletionTimeArgType = string
+type GetBackupResponseGetCompletionTimeRetType = string
+
+func getGetBackupResponseGetCompletionTimeAttributeTypeOk(arg GetBackupResponseGetCompletionTimeAttributeType) (ret GetBackupResponseGetCompletionTimeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetBackupResponseGetCompletionTimeAttributeType(arg *GetBackupResponseGetCompletionTimeAttributeType, val GetBackupResponseGetCompletionTimeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for id
+*/
+
+//// isAny
+//type GetBackupResponseGetIdAttributeType = any
+//type GetBackupResponseGetIdArgType = any
+//type GetBackupResponseGetIdRetType = any
+//
+//func getGetBackupResponseGetIdAttributeTypeOk(arg GetBackupResponseGetIdAttributeType) (ret GetBackupResponseGetIdRetType, ok bool) {
+// if arg == nil {
+// return ret, false
+// }
+// return *arg, true
+//}
+//
+//func setGetBackupResponseGetIdAttributeType(arg *GetBackupResponseGetIdAttributeType, val GetBackupResponseGetIdRetType) {
+// *arg = &val
+//}
+
+// isModel
+type GetBackupResponseGetIdAttributeType = *int64
+type GetBackupResponseGetIdArgType = int64
+type GetBackupResponseGetIdRetType = int64
+
+func getGetBackupResponseGetIdAttributeTypeOk(arg GetBackupResponseGetIdAttributeType) (ret GetBackupResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetBackupResponseGetIdAttributeType(arg *GetBackupResponseGetIdAttributeType, val GetBackupResponseGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+//// isAny
+//type GetBackupResponseGetNameAttributeType = any
+//type GetBackupResponseGetNameArgType = any
+//type GetBackupResponseGetNameRetType = any
+//
+//func getGetBackupResponseGetNameAttributeTypeOk(arg GetBackupResponseGetNameAttributeType) (ret GetBackupResponseGetNameRetType, ok bool) {
+// if arg == nil {
+// return ret, false
+// }
+// return *arg, true
+//}
+//
+//func setGetBackupResponseGetNameAttributeType(arg *GetBackupResponseGetNameAttributeType, val GetBackupResponseGetNameRetType) {
+// *arg = &val
+//}
+
+// isModel
+type GetBackupResponseGetNameAttributeType = *string
+type GetBackupResponseGetNameArgType = string
+type GetBackupResponseGetNameRetType = string
+
+func getGetBackupResponseGetNameAttributeTypeOk(arg GetBackupResponseGetNameAttributeType) (ret GetBackupResponseGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetBackupResponseGetNameAttributeType(arg *GetBackupResponseGetNameAttributeType, val GetBackupResponseGetNameRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for retainedUntil
+*/
+
+//// isAny
+//type GetBackupResponseGetRetainedUntilAttributeType = any
+//type GetBackupResponseGetRetainedUntilArgType = any
+//type GetBackupResponseGetRetainedUntilRetType = any
+//
+//func getGetBackupResponseGetRetainedUntilAttributeTypeOk(arg GetBackupResponseGetRetainedUntilAttributeType) (ret GetBackupResponseGetRetainedUntilRetType, ok bool) {
+// if arg == nil {
+// return ret, false
+// }
+// return *arg, true
+//}
+//
+//func setGetBackupResponseGetRetainedUntilAttributeType(arg *GetBackupResponseGetRetainedUntilAttributeType, val GetBackupResponseGetRetainedUntilRetType) {
+// *arg = &val
+//}
+
+// isModel
+type GetBackupResponseGetRetainedUntilAttributeType = *string
+type GetBackupResponseGetRetainedUntilArgType = string
+type GetBackupResponseGetRetainedUntilRetType = string
+
+func getGetBackupResponseGetRetainedUntilAttributeTypeOk(arg GetBackupResponseGetRetainedUntilAttributeType) (ret GetBackupResponseGetRetainedUntilRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetBackupResponseGetRetainedUntilAttributeType(arg *GetBackupResponseGetRetainedUntilAttributeType, val GetBackupResponseGetRetainedUntilRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for size
+*/
+
+//// isAny
+//type GetBackupResponseGetSizeAttributeType = any
+//type GetBackupResponseGetSizeArgType = any
+//type GetBackupResponseGetSizeRetType = any
+//
+//func getGetBackupResponseGetSizeAttributeTypeOk(arg GetBackupResponseGetSizeAttributeType) (ret GetBackupResponseGetSizeRetType, ok bool) {
+// if arg == nil {
+// return ret, false
+// }
+// return *arg, true
+//}
+//
+//func setGetBackupResponseGetSizeAttributeType(arg *GetBackupResponseGetSizeAttributeType, val GetBackupResponseGetSizeRetType) {
+// *arg = &val
+//}
+
+// isModel
+type GetBackupResponseGetSizeAttributeType = *int64
+type GetBackupResponseGetSizeArgType = int64
+type GetBackupResponseGetSizeRetType = int64
+
+func getGetBackupResponseGetSizeAttributeTypeOk(arg GetBackupResponseGetSizeAttributeType) (ret GetBackupResponseGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetBackupResponseGetSizeAttributeType(arg *GetBackupResponseGetSizeAttributeType, val GetBackupResponseGetSizeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for type
+*/
+
+//// isAny
+//type GetBackupResponseGetTypeAttributeType = any
+//type GetBackupResponseGetTypeArgType = any
+//type GetBackupResponseGetTypeRetType = any
+//
+//func getGetBackupResponseGetTypeAttributeTypeOk(arg GetBackupResponseGetTypeAttributeType) (ret GetBackupResponseGetTypeRetType, ok bool) {
+// if arg == nil {
+// return ret, false
+// }
+// return *arg, true
+//}
+//
+//func setGetBackupResponseGetTypeAttributeType(arg *GetBackupResponseGetTypeAttributeType, val GetBackupResponseGetTypeRetType) {
+// *arg = &val
+//}
+
+// isModel
+type GetBackupResponseGetTypeAttributeType = *string
+type GetBackupResponseGetTypeArgType = string
+type GetBackupResponseGetTypeRetType = string
+
+func getGetBackupResponseGetTypeAttributeTypeOk(arg GetBackupResponseGetTypeAttributeType) (ret GetBackupResponseGetTypeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetBackupResponseGetTypeAttributeType(arg *GetBackupResponseGetTypeAttributeType, val GetBackupResponseGetTypeRetType) {
+ *arg = &val
+}
+
+// GetBackupResponse struct for GetBackupResponse
+type GetBackupResponse struct {
+ // REQUIRED
+ CompletionTime GetBackupResponseGetCompletionTimeAttributeType `json:"completionTime" required:"true"`
+ // REQUIRED
+ Id GetBackupResponseGetIdAttributeType `json:"id" required:"true"`
+ // REQUIRED
+ Name GetBackupResponseGetNameAttributeType `json:"name" required:"true"`
+ // REQUIRED
+ RetainedUntil GetBackupResponseGetRetainedUntilAttributeType `json:"retainedUntil" required:"true"`
+ // REQUIRED
+ Size GetBackupResponseGetSizeAttributeType `json:"size" required:"true"`
+ // REQUIRED
+ Type GetBackupResponseGetTypeAttributeType `json:"type" required:"true"`
+}
+
+type _GetBackupResponse GetBackupResponse
+
+// NewGetBackupResponse instantiates a new GetBackupResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetBackupResponse(completionTime GetBackupResponseGetCompletionTimeArgType, id GetBackupResponseGetIdArgType, name GetBackupResponseGetNameArgType, retainedUntil GetBackupResponseGetRetainedUntilArgType, size GetBackupResponseGetSizeArgType, types GetBackupResponseGetTypeArgType) *GetBackupResponse {
+ this := GetBackupResponse{}
+ setGetBackupResponseGetCompletionTimeAttributeType(&this.CompletionTime, completionTime)
+ setGetBackupResponseGetIdAttributeType(&this.Id, id)
+ setGetBackupResponseGetNameAttributeType(&this.Name, name)
+ setGetBackupResponseGetRetainedUntilAttributeType(&this.RetainedUntil, retainedUntil)
+ setGetBackupResponseGetSizeAttributeType(&this.Size, size)
+ setGetBackupResponseGetTypeAttributeType(&this.Type, types)
+ return &this
+}
+
+// NewGetBackupResponseWithDefaults instantiates a new GetBackupResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetBackupResponseWithDefaults() *GetBackupResponse {
+ this := GetBackupResponse{}
+ return &this
+}
+
+// GetCompletionTime returns the CompletionTime field value
+func (o *GetBackupResponse) GetCompletionTime() (ret GetBackupResponseGetCompletionTimeRetType) {
+ ret, _ = o.GetCompletionTimeOk()
+ return ret
+}
+
+// GetCompletionTimeOk returns a tuple with the CompletionTime field value
+// and a boolean to check if the value has been set.
+func (o *GetBackupResponse) GetCompletionTimeOk() (ret GetBackupResponseGetCompletionTimeRetType, ok bool) {
+ return getGetBackupResponseGetCompletionTimeAttributeTypeOk(o.CompletionTime)
+}
+
+// SetCompletionTime sets field value
+func (o *GetBackupResponse) SetCompletionTime(v GetBackupResponseGetCompletionTimeRetType) {
+ setGetBackupResponseGetCompletionTimeAttributeType(&o.CompletionTime, v)
+}
+
+// GetId returns the Id field value
+func (o *GetBackupResponse) GetId() (ret GetBackupResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *GetBackupResponse) GetIdOk() (ret GetBackupResponseGetIdRetType, ok bool) {
+ return getGetBackupResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *GetBackupResponse) SetId(v GetBackupResponseGetIdRetType) {
+ setGetBackupResponseGetIdAttributeType(&o.Id, v)
+}
+
+// GetName returns the Name field value
+func (o *GetBackupResponse) GetName() (ret GetBackupResponseGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *GetBackupResponse) GetNameOk() (ret GetBackupResponseGetNameRetType, ok bool) {
+ return getGetBackupResponseGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *GetBackupResponse) SetName(v GetBackupResponseGetNameRetType) {
+ setGetBackupResponseGetNameAttributeType(&o.Name, v)
+}
+
+// GetRetainedUntil returns the RetainedUntil field value
+func (o *GetBackupResponse) GetRetainedUntil() (ret GetBackupResponseGetRetainedUntilRetType) {
+ ret, _ = o.GetRetainedUntilOk()
+ return ret
+}
+
+// GetRetainedUntilOk returns a tuple with the RetainedUntil field value
+// and a boolean to check if the value has been set.
+func (o *GetBackupResponse) GetRetainedUntilOk() (ret GetBackupResponseGetRetainedUntilRetType, ok bool) {
+ return getGetBackupResponseGetRetainedUntilAttributeTypeOk(o.RetainedUntil)
+}
+
+// SetRetainedUntil sets field value
+func (o *GetBackupResponse) SetRetainedUntil(v GetBackupResponseGetRetainedUntilRetType) {
+ setGetBackupResponseGetRetainedUntilAttributeType(&o.RetainedUntil, v)
+}
+
+// GetSize returns the Size field value
+func (o *GetBackupResponse) GetSize() (ret GetBackupResponseGetSizeRetType) {
+ ret, _ = o.GetSizeOk()
+ return ret
+}
+
+// GetSizeOk returns a tuple with the Size field value
+// and a boolean to check if the value has been set.
+func (o *GetBackupResponse) GetSizeOk() (ret GetBackupResponseGetSizeRetType, ok bool) {
+ return getGetBackupResponseGetSizeAttributeTypeOk(o.Size)
+}
+
+// SetSize sets field value
+func (o *GetBackupResponse) SetSize(v GetBackupResponseGetSizeRetType) {
+ setGetBackupResponseGetSizeAttributeType(&o.Size, v)
+}
+
+// GetType returns the Type field value
+func (o *GetBackupResponse) GetType() (ret GetBackupResponseGetTypeRetType) {
+ ret, _ = o.GetTypeOk()
+ return ret
+}
+
+// GetTypeOk returns a tuple with the Type field value
+// and a boolean to check if the value has been set.
+func (o *GetBackupResponse) GetTypeOk() (ret GetBackupResponseGetTypeRetType, ok bool) {
+ return getGetBackupResponseGetTypeAttributeTypeOk(o.Type)
+}
+
+// SetType sets field value
+func (o *GetBackupResponse) SetType(v GetBackupResponseGetTypeRetType) {
+ setGetBackupResponseGetTypeAttributeType(&o.Type, v)
+}
+
+func (o GetBackupResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetBackupResponseGetCompletionTimeAttributeTypeOk(o.CompletionTime); ok {
+ toSerialize["CompletionTime"] = val
+ }
+ if val, ok := getGetBackupResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getGetBackupResponseGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getGetBackupResponseGetRetainedUntilAttributeTypeOk(o.RetainedUntil); ok {
+ toSerialize["RetainedUntil"] = val
+ }
+ if val, ok := getGetBackupResponseGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ if val, ok := getGetBackupResponseGetTypeAttributeTypeOk(o.Type); ok {
+ toSerialize["Type"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetBackupResponse struct {
+ value *GetBackupResponse
+ isSet bool
+}
+
+func (v NullableGetBackupResponse) Get() *GetBackupResponse {
+ return v.value
+}
+
+func (v *NullableGetBackupResponse) Set(val *GetBackupResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetBackupResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetBackupResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetBackupResponse(val *GetBackupResponse) *NullableGetBackupResponse {
+ return &NullableGetBackupResponse{value: val, isSet: true}
+}
+
+func (v NullableGetBackupResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetBackupResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_get_backup_response_test.go b/pkg/sqlserverflexalpha/model_get_backup_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_backup_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_get_collations_response.go b/pkg/sqlserverflexalpha/model_get_collations_response.go
new file mode 100644
index 00000000..9879d9c9
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_collations_response.go
@@ -0,0 +1,126 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetCollationsResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetCollationsResponse{}
+
+/*
+ types and functions for collations
+*/
+
+// isArray
+type GetCollationsResponseGetCollationsAttributeType = *[]DatabaseGetcollation
+type GetCollationsResponseGetCollationsArgType = []DatabaseGetcollation
+type GetCollationsResponseGetCollationsRetType = []DatabaseGetcollation
+
+func getGetCollationsResponseGetCollationsAttributeTypeOk(arg GetCollationsResponseGetCollationsAttributeType) (ret GetCollationsResponseGetCollationsRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetCollationsResponseGetCollationsAttributeType(arg *GetCollationsResponseGetCollationsAttributeType, val GetCollationsResponseGetCollationsRetType) {
+ *arg = &val
+}
+
+// GetCollationsResponse struct for GetCollationsResponse
+type GetCollationsResponse struct {
+ // List of collations available for the instance.
+ // REQUIRED
+ Collations GetCollationsResponseGetCollationsAttributeType `json:"collations" required:"true"`
+}
+
+type _GetCollationsResponse GetCollationsResponse
+
+// NewGetCollationsResponse instantiates a new GetCollationsResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetCollationsResponse(collations GetCollationsResponseGetCollationsArgType) *GetCollationsResponse {
+ this := GetCollationsResponse{}
+ setGetCollationsResponseGetCollationsAttributeType(&this.Collations, collations)
+ return &this
+}
+
+// NewGetCollationsResponseWithDefaults instantiates a new GetCollationsResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetCollationsResponseWithDefaults() *GetCollationsResponse {
+ this := GetCollationsResponse{}
+ return &this
+}
+
+// GetCollations returns the Collations field value
+func (o *GetCollationsResponse) GetCollations() (ret GetCollationsResponseGetCollationsRetType) {
+ ret, _ = o.GetCollationsOk()
+ return ret
+}
+
+// GetCollationsOk returns a tuple with the Collations field value
+// and a boolean to check if the value has been set.
+func (o *GetCollationsResponse) GetCollationsOk() (ret GetCollationsResponseGetCollationsRetType, ok bool) {
+ return getGetCollationsResponseGetCollationsAttributeTypeOk(o.Collations)
+}
+
+// SetCollations sets field value
+func (o *GetCollationsResponse) SetCollations(v GetCollationsResponseGetCollationsRetType) {
+ setGetCollationsResponseGetCollationsAttributeType(&o.Collations, v)
+}
+
+func (o GetCollationsResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetCollationsResponseGetCollationsAttributeTypeOk(o.Collations); ok {
+ toSerialize["Collations"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetCollationsResponse struct {
+ value *GetCollationsResponse
+ isSet bool
+}
+
+func (v NullableGetCollationsResponse) Get() *GetCollationsResponse {
+ return v.value
+}
+
+func (v *NullableGetCollationsResponse) Set(val *GetCollationsResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetCollationsResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetCollationsResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetCollationsResponse(val *GetCollationsResponse) *NullableGetCollationsResponse {
+ return &NullableGetCollationsResponse{value: val, isSet: true}
+}
+
+func (v NullableGetCollationsResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetCollationsResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_get_collations_response_test.go b/pkg/sqlserverflexalpha/model_get_collations_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_collations_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_get_database_response.go b/pkg/sqlserverflexalpha/model_get_database_response.go
new file mode 100644
index 00000000..3f30c068
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_database_response.go
@@ -0,0 +1,306 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetDatabaseResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetDatabaseResponse{}
+
+/*
+ types and functions for collationName
+*/
+
+// isNotNullableString
+type GetDatabaseResponseGetCollationNameAttributeType = *string
+
+func getGetDatabaseResponseGetCollationNameAttributeTypeOk(arg GetDatabaseResponseGetCollationNameAttributeType) (ret GetDatabaseResponseGetCollationNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetDatabaseResponseGetCollationNameAttributeType(arg *GetDatabaseResponseGetCollationNameAttributeType, val GetDatabaseResponseGetCollationNameRetType) {
+ *arg = &val
+}
+
+type GetDatabaseResponseGetCollationNameArgType = string
+type GetDatabaseResponseGetCollationNameRetType = string
+
+/*
+ types and functions for compatibilityLevel
+*/
+
+// isInteger
+type GetDatabaseResponseGetCompatibilityLevelAttributeType = *int64
+type GetDatabaseResponseGetCompatibilityLevelArgType = int64
+type GetDatabaseResponseGetCompatibilityLevelRetType = int64
+
+func getGetDatabaseResponseGetCompatibilityLevelAttributeTypeOk(arg GetDatabaseResponseGetCompatibilityLevelAttributeType) (ret GetDatabaseResponseGetCompatibilityLevelRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetDatabaseResponseGetCompatibilityLevelAttributeType(arg *GetDatabaseResponseGetCompatibilityLevelAttributeType, val GetDatabaseResponseGetCompatibilityLevelRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type GetDatabaseResponseGetIdAttributeType = *int64
+type GetDatabaseResponseGetIdArgType = int64
+type GetDatabaseResponseGetIdRetType = int64
+
+func getGetDatabaseResponseGetIdAttributeTypeOk(arg GetDatabaseResponseGetIdAttributeType) (ret GetDatabaseResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetDatabaseResponseGetIdAttributeType(arg *GetDatabaseResponseGetIdAttributeType, val GetDatabaseResponseGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type GetDatabaseResponseGetNameAttributeType = *string
+
+func getGetDatabaseResponseGetNameAttributeTypeOk(arg GetDatabaseResponseGetNameAttributeType) (ret GetDatabaseResponseGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetDatabaseResponseGetNameAttributeType(arg *GetDatabaseResponseGetNameAttributeType, val GetDatabaseResponseGetNameRetType) {
+ *arg = &val
+}
+
+type GetDatabaseResponseGetNameArgType = string
+type GetDatabaseResponseGetNameRetType = string
+
+/*
+ types and functions for owner
+*/
+
+// isNotNullableString
+type GetDatabaseResponseGetOwnerAttributeType = *string
+
+func getGetDatabaseResponseGetOwnerAttributeTypeOk(arg GetDatabaseResponseGetOwnerAttributeType) (ret GetDatabaseResponseGetOwnerRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetDatabaseResponseGetOwnerAttributeType(arg *GetDatabaseResponseGetOwnerAttributeType, val GetDatabaseResponseGetOwnerRetType) {
+ *arg = &val
+}
+
+type GetDatabaseResponseGetOwnerArgType = string
+type GetDatabaseResponseGetOwnerRetType = string
+
+// GetDatabaseResponse struct for GetDatabaseResponse
+type GetDatabaseResponse struct {
+ // The collation of the database. This database collation should match the *collation_name* of one of the collations given by the **Get database collation list** endpoint.
+ // REQUIRED
+ CollationName GetDatabaseResponseGetCollationNameAttributeType `json:"collationName" required:"true"`
+ // CompatibilityLevel of the Database.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ CompatibilityLevel GetDatabaseResponseGetCompatibilityLevelAttributeType `json:"compatibilityLevel" required:"true"`
+ // The id of the database.
+ // REQUIRED
+ Id GetDatabaseResponseGetIdAttributeType `json:"id" required:"true"`
+ // The name of the database.
+ // REQUIRED
+ Name GetDatabaseResponseGetNameAttributeType `json:"name" required:"true"`
+ // The owner of the database.
+ // REQUIRED
+ Owner GetDatabaseResponseGetOwnerAttributeType `json:"owner" required:"true"`
+}
+
+type _GetDatabaseResponse GetDatabaseResponse
+
+// NewGetDatabaseResponse instantiates a new GetDatabaseResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetDatabaseResponse(collationName GetDatabaseResponseGetCollationNameArgType, compatibilityLevel GetDatabaseResponseGetCompatibilityLevelArgType, id GetDatabaseResponseGetIdArgType, name GetDatabaseResponseGetNameArgType, owner GetDatabaseResponseGetOwnerArgType) *GetDatabaseResponse {
+ this := GetDatabaseResponse{}
+ setGetDatabaseResponseGetCollationNameAttributeType(&this.CollationName, collationName)
+ setGetDatabaseResponseGetCompatibilityLevelAttributeType(&this.CompatibilityLevel, compatibilityLevel)
+ setGetDatabaseResponseGetIdAttributeType(&this.Id, id)
+ setGetDatabaseResponseGetNameAttributeType(&this.Name, name)
+ setGetDatabaseResponseGetOwnerAttributeType(&this.Owner, owner)
+ return &this
+}
+
+// NewGetDatabaseResponseWithDefaults instantiates a new GetDatabaseResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetDatabaseResponseWithDefaults() *GetDatabaseResponse {
+ this := GetDatabaseResponse{}
+ return &this
+}
+
+// GetCollationName returns the CollationName field value
+func (o *GetDatabaseResponse) GetCollationName() (ret GetDatabaseResponseGetCollationNameRetType) {
+ ret, _ = o.GetCollationNameOk()
+ return ret
+}
+
+// GetCollationNameOk returns a tuple with the CollationName field value
+// and a boolean to check if the value has been set.
+func (o *GetDatabaseResponse) GetCollationNameOk() (ret GetDatabaseResponseGetCollationNameRetType, ok bool) {
+ return getGetDatabaseResponseGetCollationNameAttributeTypeOk(o.CollationName)
+}
+
+// SetCollationName sets field value
+func (o *GetDatabaseResponse) SetCollationName(v GetDatabaseResponseGetCollationNameRetType) {
+ setGetDatabaseResponseGetCollationNameAttributeType(&o.CollationName, v)
+}
+
+// GetCompatibilityLevel returns the CompatibilityLevel field value
+func (o *GetDatabaseResponse) GetCompatibilityLevel() (ret GetDatabaseResponseGetCompatibilityLevelRetType) {
+ ret, _ = o.GetCompatibilityLevelOk()
+ return ret
+}
+
+// GetCompatibilityLevelOk returns a tuple with the CompatibilityLevel field value
+// and a boolean to check if the value has been set.
+func (o *GetDatabaseResponse) GetCompatibilityLevelOk() (ret GetDatabaseResponseGetCompatibilityLevelRetType, ok bool) {
+ return getGetDatabaseResponseGetCompatibilityLevelAttributeTypeOk(o.CompatibilityLevel)
+}
+
+// SetCompatibilityLevel sets field value
+func (o *GetDatabaseResponse) SetCompatibilityLevel(v GetDatabaseResponseGetCompatibilityLevelRetType) {
+ setGetDatabaseResponseGetCompatibilityLevelAttributeType(&o.CompatibilityLevel, v)
+}
+
+// GetId returns the Id field value
+func (o *GetDatabaseResponse) GetId() (ret GetDatabaseResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *GetDatabaseResponse) GetIdOk() (ret GetDatabaseResponseGetIdRetType, ok bool) {
+ return getGetDatabaseResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *GetDatabaseResponse) SetId(v GetDatabaseResponseGetIdRetType) {
+ setGetDatabaseResponseGetIdAttributeType(&o.Id, v)
+}
+
+// GetName returns the Name field value
+func (o *GetDatabaseResponse) GetName() (ret GetDatabaseResponseGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *GetDatabaseResponse) GetNameOk() (ret GetDatabaseResponseGetNameRetType, ok bool) {
+ return getGetDatabaseResponseGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *GetDatabaseResponse) SetName(v GetDatabaseResponseGetNameRetType) {
+ setGetDatabaseResponseGetNameAttributeType(&o.Name, v)
+}
+
+// GetOwner returns the Owner field value
+func (o *GetDatabaseResponse) GetOwner() (ret GetDatabaseResponseGetOwnerRetType) {
+ ret, _ = o.GetOwnerOk()
+ return ret
+}
+
+// GetOwnerOk returns a tuple with the Owner field value
+// and a boolean to check if the value has been set.
+func (o *GetDatabaseResponse) GetOwnerOk() (ret GetDatabaseResponseGetOwnerRetType, ok bool) {
+ return getGetDatabaseResponseGetOwnerAttributeTypeOk(o.Owner)
+}
+
+// SetOwner sets field value
+func (o *GetDatabaseResponse) SetOwner(v GetDatabaseResponseGetOwnerRetType) {
+ setGetDatabaseResponseGetOwnerAttributeType(&o.Owner, v)
+}
+
+func (o GetDatabaseResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetDatabaseResponseGetCollationNameAttributeTypeOk(o.CollationName); ok {
+ toSerialize["CollationName"] = val
+ }
+ if val, ok := getGetDatabaseResponseGetCompatibilityLevelAttributeTypeOk(o.CompatibilityLevel); ok {
+ toSerialize["CompatibilityLevel"] = val
+ }
+ if val, ok := getGetDatabaseResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getGetDatabaseResponseGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getGetDatabaseResponseGetOwnerAttributeTypeOk(o.Owner); ok {
+ toSerialize["Owner"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetDatabaseResponse struct {
+ value *GetDatabaseResponse
+ isSet bool
+}
+
+func (v NullableGetDatabaseResponse) Get() *GetDatabaseResponse {
+ return v.value
+}
+
+func (v *NullableGetDatabaseResponse) Set(val *GetDatabaseResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetDatabaseResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetDatabaseResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetDatabaseResponse(val *GetDatabaseResponse) *NullableGetDatabaseResponse {
+ return &NullableGetDatabaseResponse{value: val, isSet: true}
+}
+
+func (v NullableGetDatabaseResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetDatabaseResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_get_database_response_test.go b/pkg/sqlserverflexalpha/model_get_database_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_database_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_get_flavors_response.go b/pkg/sqlserverflexalpha/model_get_flavors_response.go
new file mode 100644
index 00000000..ef79544a
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_flavors_response.go
@@ -0,0 +1,169 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetFlavorsResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetFlavorsResponse{}
+
+/*
+ types and functions for flavors
+*/
+
+// isArray
+type GetFlavorsResponseGetFlavorsAttributeType = *[]ListFlavors
+type GetFlavorsResponseGetFlavorsArgType = []ListFlavors
+type GetFlavorsResponseGetFlavorsRetType = []ListFlavors
+
+func getGetFlavorsResponseGetFlavorsAttributeTypeOk(arg GetFlavorsResponseGetFlavorsAttributeType) (ret GetFlavorsResponseGetFlavorsRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetFlavorsResponseGetFlavorsAttributeType(arg *GetFlavorsResponseGetFlavorsAttributeType, val GetFlavorsResponseGetFlavorsRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for pagination
+*/
+
+// isModel
+type GetFlavorsResponseGetPaginationAttributeType = *Pagination
+type GetFlavorsResponseGetPaginationArgType = Pagination
+type GetFlavorsResponseGetPaginationRetType = Pagination
+
+func getGetFlavorsResponseGetPaginationAttributeTypeOk(arg GetFlavorsResponseGetPaginationAttributeType) (ret GetFlavorsResponseGetPaginationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetFlavorsResponseGetPaginationAttributeType(arg *GetFlavorsResponseGetPaginationAttributeType, val GetFlavorsResponseGetPaginationRetType) {
+ *arg = &val
+}
+
+// GetFlavorsResponse struct for GetFlavorsResponse
+type GetFlavorsResponse struct {
+ // List of flavors available for the project.
+ // REQUIRED
+ Flavors GetFlavorsResponseGetFlavorsAttributeType `json:"flavors" required:"true"`
+ // REQUIRED
+ Pagination GetFlavorsResponseGetPaginationAttributeType `json:"pagination" required:"true"`
+}
+
+type _GetFlavorsResponse GetFlavorsResponse
+
+// NewGetFlavorsResponse instantiates a new GetFlavorsResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetFlavorsResponse(flavors GetFlavorsResponseGetFlavorsArgType, pagination GetFlavorsResponseGetPaginationArgType) *GetFlavorsResponse {
+ this := GetFlavorsResponse{}
+ setGetFlavorsResponseGetFlavorsAttributeType(&this.Flavors, flavors)
+ setGetFlavorsResponseGetPaginationAttributeType(&this.Pagination, pagination)
+ return &this
+}
+
+// NewGetFlavorsResponseWithDefaults instantiates a new GetFlavorsResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetFlavorsResponseWithDefaults() *GetFlavorsResponse {
+ this := GetFlavorsResponse{}
+ return &this
+}
+
+// GetFlavors returns the Flavors field value
+func (o *GetFlavorsResponse) GetFlavors() (ret GetFlavorsResponseGetFlavorsRetType) {
+ ret, _ = o.GetFlavorsOk()
+ return ret
+}
+
+// GetFlavorsOk returns a tuple with the Flavors field value
+// and a boolean to check if the value has been set.
+func (o *GetFlavorsResponse) GetFlavorsOk() (ret GetFlavorsResponseGetFlavorsRetType, ok bool) {
+ return getGetFlavorsResponseGetFlavorsAttributeTypeOk(o.Flavors)
+}
+
+// SetFlavors sets field value
+func (o *GetFlavorsResponse) SetFlavors(v GetFlavorsResponseGetFlavorsRetType) {
+ setGetFlavorsResponseGetFlavorsAttributeType(&o.Flavors, v)
+}
+
+// GetPagination returns the Pagination field value
+func (o *GetFlavorsResponse) GetPagination() (ret GetFlavorsResponseGetPaginationRetType) {
+ ret, _ = o.GetPaginationOk()
+ return ret
+}
+
+// GetPaginationOk returns a tuple with the Pagination field value
+// and a boolean to check if the value has been set.
+func (o *GetFlavorsResponse) GetPaginationOk() (ret GetFlavorsResponseGetPaginationRetType, ok bool) {
+ return getGetFlavorsResponseGetPaginationAttributeTypeOk(o.Pagination)
+}
+
+// SetPagination sets field value
+func (o *GetFlavorsResponse) SetPagination(v GetFlavorsResponseGetPaginationRetType) {
+ setGetFlavorsResponseGetPaginationAttributeType(&o.Pagination, v)
+}
+
+func (o GetFlavorsResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetFlavorsResponseGetFlavorsAttributeTypeOk(o.Flavors); ok {
+ toSerialize["Flavors"] = val
+ }
+ if val, ok := getGetFlavorsResponseGetPaginationAttributeTypeOk(o.Pagination); ok {
+ toSerialize["Pagination"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetFlavorsResponse struct {
+ value *GetFlavorsResponse
+ isSet bool
+}
+
+func (v NullableGetFlavorsResponse) Get() *GetFlavorsResponse {
+ return v.value
+}
+
+func (v *NullableGetFlavorsResponse) Set(val *GetFlavorsResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetFlavorsResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetFlavorsResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetFlavorsResponse(val *GetFlavorsResponse) *NullableGetFlavorsResponse {
+ return &NullableGetFlavorsResponse{value: val, isSet: true}
+}
+
+func (v NullableGetFlavorsResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetFlavorsResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_get_flavors_response_test.go b/pkg/sqlserverflexalpha/model_get_flavors_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_flavors_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_get_instance_response.go b/pkg/sqlserverflexalpha/model_get_instance_response.go
new file mode 100644
index 00000000..d86ee586
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_instance_response.go
@@ -0,0 +1,700 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetInstanceResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetInstanceResponse{}
+
+/*
+ types and functions for acl
+*/
+
+// isArray
+type GetInstanceResponseGetAclAttributeType = *[]string
+type GetInstanceResponseGetAclArgType = []string
+type GetInstanceResponseGetAclRetType = []string
+
+func getGetInstanceResponseGetAclAttributeTypeOk(arg GetInstanceResponseGetAclAttributeType) (ret GetInstanceResponseGetAclRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetAclAttributeType(arg *GetInstanceResponseGetAclAttributeType, val GetInstanceResponseGetAclRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for backupSchedule
+*/
+
+// isNotNullableString
+type GetInstanceResponseGetBackupScheduleAttributeType = *string
+
+func getGetInstanceResponseGetBackupScheduleAttributeTypeOk(arg GetInstanceResponseGetBackupScheduleAttributeType) (ret GetInstanceResponseGetBackupScheduleRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetBackupScheduleAttributeType(arg *GetInstanceResponseGetBackupScheduleAttributeType, val GetInstanceResponseGetBackupScheduleRetType) {
+ *arg = &val
+}
+
+type GetInstanceResponseGetBackupScheduleArgType = string
+type GetInstanceResponseGetBackupScheduleRetType = string
+
+/*
+ types and functions for edition
+*/
+
+// isEnumRef
+type GetInstanceResponseGetEditionAttributeType = *InstanceEdition
+type GetInstanceResponseGetEditionArgType = InstanceEdition
+type GetInstanceResponseGetEditionRetType = InstanceEdition
+
+func getGetInstanceResponseGetEditionAttributeTypeOk(arg GetInstanceResponseGetEditionAttributeType) (ret GetInstanceResponseGetEditionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetEditionAttributeType(arg *GetInstanceResponseGetEditionAttributeType, val GetInstanceResponseGetEditionRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for encryption
+*/
+
+// isModel
+type GetInstanceResponseGetEncryptionAttributeType = *InstanceEncryption
+type GetInstanceResponseGetEncryptionArgType = InstanceEncryption
+type GetInstanceResponseGetEncryptionRetType = InstanceEncryption
+
+func getGetInstanceResponseGetEncryptionAttributeTypeOk(arg GetInstanceResponseGetEncryptionAttributeType) (ret GetInstanceResponseGetEncryptionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetEncryptionAttributeType(arg *GetInstanceResponseGetEncryptionAttributeType, val GetInstanceResponseGetEncryptionRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for flavorId
+*/
+
+// isNotNullableString
+type GetInstanceResponseGetFlavorIdAttributeType = *string
+
+func getGetInstanceResponseGetFlavorIdAttributeTypeOk(arg GetInstanceResponseGetFlavorIdAttributeType) (ret GetInstanceResponseGetFlavorIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetFlavorIdAttributeType(arg *GetInstanceResponseGetFlavorIdAttributeType, val GetInstanceResponseGetFlavorIdRetType) {
+ *arg = &val
+}
+
+type GetInstanceResponseGetFlavorIdArgType = string
+type GetInstanceResponseGetFlavorIdRetType = string
+
+/*
+ types and functions for id
+*/
+
+// isNotNullableString
+type GetInstanceResponseGetIdAttributeType = *string
+
+func getGetInstanceResponseGetIdAttributeTypeOk(arg GetInstanceResponseGetIdAttributeType) (ret GetInstanceResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetIdAttributeType(arg *GetInstanceResponseGetIdAttributeType, val GetInstanceResponseGetIdRetType) {
+ *arg = &val
+}
+
+type GetInstanceResponseGetIdArgType = string
+type GetInstanceResponseGetIdRetType = string
+
+/*
+ types and functions for isDeletable
+*/
+
+// isBoolean
+type GetInstanceResponsegetIsDeletableAttributeType = *bool
+type GetInstanceResponsegetIsDeletableArgType = bool
+type GetInstanceResponsegetIsDeletableRetType = bool
+
+func getGetInstanceResponsegetIsDeletableAttributeTypeOk(arg GetInstanceResponsegetIsDeletableAttributeType) (ret GetInstanceResponsegetIsDeletableRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponsegetIsDeletableAttributeType(arg *GetInstanceResponsegetIsDeletableAttributeType, val GetInstanceResponsegetIsDeletableRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type GetInstanceResponseGetNameAttributeType = *string
+
+func getGetInstanceResponseGetNameAttributeTypeOk(arg GetInstanceResponseGetNameAttributeType) (ret GetInstanceResponseGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetNameAttributeType(arg *GetInstanceResponseGetNameAttributeType, val GetInstanceResponseGetNameRetType) {
+ *arg = &val
+}
+
+type GetInstanceResponseGetNameArgType = string
+type GetInstanceResponseGetNameRetType = string
+
+/*
+ types and functions for network
+*/
+
+// isModel
+type GetInstanceResponseGetNetworkAttributeType = *InstanceNetwork
+type GetInstanceResponseGetNetworkArgType = InstanceNetwork
+type GetInstanceResponseGetNetworkRetType = InstanceNetwork
+
+func getGetInstanceResponseGetNetworkAttributeTypeOk(arg GetInstanceResponseGetNetworkAttributeType) (ret GetInstanceResponseGetNetworkRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetNetworkAttributeType(arg *GetInstanceResponseGetNetworkAttributeType, val GetInstanceResponseGetNetworkRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for replicas
+*/
+
+// isEnumRef
+type GetInstanceResponseGetReplicasAttributeType = *Replicas
+type GetInstanceResponseGetReplicasArgType = Replicas
+type GetInstanceResponseGetReplicasRetType = Replicas
+
+func getGetInstanceResponseGetReplicasAttributeTypeOk(arg GetInstanceResponseGetReplicasAttributeType) (ret GetInstanceResponseGetReplicasRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetReplicasAttributeType(arg *GetInstanceResponseGetReplicasAttributeType, val GetInstanceResponseGetReplicasRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for retentionDays
+*/
+
+// isInteger
+type GetInstanceResponseGetRetentionDaysAttributeType = *int64
+type GetInstanceResponseGetRetentionDaysArgType = int64
+type GetInstanceResponseGetRetentionDaysRetType = int64
+
+func getGetInstanceResponseGetRetentionDaysAttributeTypeOk(arg GetInstanceResponseGetRetentionDaysAttributeType) (ret GetInstanceResponseGetRetentionDaysRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetRetentionDaysAttributeType(arg *GetInstanceResponseGetRetentionDaysAttributeType, val GetInstanceResponseGetRetentionDaysRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for status
+*/
+
+// isEnumRef
+type GetInstanceResponseGetStatusAttributeType = *Status
+type GetInstanceResponseGetStatusArgType = Status
+type GetInstanceResponseGetStatusRetType = Status
+
+func getGetInstanceResponseGetStatusAttributeTypeOk(arg GetInstanceResponseGetStatusAttributeType) (ret GetInstanceResponseGetStatusRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetStatusAttributeType(arg *GetInstanceResponseGetStatusAttributeType, val GetInstanceResponseGetStatusRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for storage
+*/
+
+// isModel
+type GetInstanceResponseGetStorageAttributeType = *Storage
+type GetInstanceResponseGetStorageArgType = Storage
+type GetInstanceResponseGetStorageRetType = Storage
+
+func getGetInstanceResponseGetStorageAttributeTypeOk(arg GetInstanceResponseGetStorageAttributeType) (ret GetInstanceResponseGetStorageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetStorageAttributeType(arg *GetInstanceResponseGetStorageAttributeType, val GetInstanceResponseGetStorageRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for version
+*/
+
+// isEnumRef
+type GetInstanceResponseGetVersionAttributeType = *InstanceVersion
+type GetInstanceResponseGetVersionArgType = InstanceVersion
+type GetInstanceResponseGetVersionRetType = InstanceVersion
+
+func getGetInstanceResponseGetVersionAttributeTypeOk(arg GetInstanceResponseGetVersionAttributeType) (ret GetInstanceResponseGetVersionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetInstanceResponseGetVersionAttributeType(arg *GetInstanceResponseGetVersionAttributeType, val GetInstanceResponseGetVersionRetType) {
+ *arg = &val
+}
+
+// GetInstanceResponse struct for GetInstanceResponse
+type GetInstanceResponse struct {
+ // List of IPV4 cidr.
+ // REQUIRED
+ Acl GetInstanceResponseGetAclAttributeType `json:"acl" required:"true"`
+ // The schedule for on what time and how often the database backup will be created. The schedule is written as a cron schedule.
+ // REQUIRED
+ BackupSchedule GetInstanceResponseGetBackupScheduleAttributeType `json:"backupSchedule" required:"true"`
+ // REQUIRED
+ Edition GetInstanceResponseGetEditionAttributeType `json:"edition" required:"true"`
+ Encryption GetInstanceResponseGetEncryptionAttributeType `json:"encryption,omitempty"`
+ // The id of the instance flavor.
+ // REQUIRED
+ FlavorId GetInstanceResponseGetFlavorIdAttributeType `json:"flavorId" required:"true"`
+ // The ID of the instance.
+ // REQUIRED
+ Id GetInstanceResponseGetIdAttributeType `json:"id" required:"true"`
+ // Whether the instance can be deleted or not.
+ // REQUIRED
+ IsDeletable GetInstanceResponsegetIsDeletableAttributeType `json:"isDeletable" required:"true"`
+ // The name of the instance.
+ // REQUIRED
+ Name GetInstanceResponseGetNameAttributeType `json:"name" required:"true"`
+ // REQUIRED
+ Network GetInstanceResponseGetNetworkAttributeType `json:"network" required:"true"`
+ // REQUIRED
+ Replicas GetInstanceResponseGetReplicasAttributeType `json:"replicas" required:"true"`
+ // The days for how long the backup files should be stored before cleaned up. 30 to 365
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ RetentionDays GetInstanceResponseGetRetentionDaysAttributeType `json:"retentionDays" required:"true"`
+ // REQUIRED
+ Status GetInstanceResponseGetStatusAttributeType `json:"status" required:"true"`
+ // REQUIRED
+ Storage GetInstanceResponseGetStorageAttributeType `json:"storage" required:"true"`
+ // REQUIRED
+ Version GetInstanceResponseGetVersionAttributeType `json:"version" required:"true"`
+}
+
+type _GetInstanceResponse GetInstanceResponse
+
+// NewGetInstanceResponse instantiates a new GetInstanceResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetInstanceResponse(acl GetInstanceResponseGetAclArgType, backupSchedule GetInstanceResponseGetBackupScheduleArgType, edition GetInstanceResponseGetEditionArgType, flavorId GetInstanceResponseGetFlavorIdArgType, id GetInstanceResponseGetIdArgType, isDeletable GetInstanceResponsegetIsDeletableArgType, name GetInstanceResponseGetNameArgType, network GetInstanceResponseGetNetworkArgType, replicas GetInstanceResponseGetReplicasArgType, retentionDays GetInstanceResponseGetRetentionDaysArgType, status GetInstanceResponseGetStatusArgType, storage GetInstanceResponseGetStorageArgType, version GetInstanceResponseGetVersionArgType) *GetInstanceResponse {
+ this := GetInstanceResponse{}
+ setGetInstanceResponseGetAclAttributeType(&this.Acl, acl)
+ setGetInstanceResponseGetBackupScheduleAttributeType(&this.BackupSchedule, backupSchedule)
+ setGetInstanceResponseGetEditionAttributeType(&this.Edition, edition)
+ setGetInstanceResponseGetFlavorIdAttributeType(&this.FlavorId, flavorId)
+ setGetInstanceResponseGetIdAttributeType(&this.Id, id)
+ setGetInstanceResponsegetIsDeletableAttributeType(&this.IsDeletable, isDeletable)
+ setGetInstanceResponseGetNameAttributeType(&this.Name, name)
+ setGetInstanceResponseGetNetworkAttributeType(&this.Network, network)
+ setGetInstanceResponseGetReplicasAttributeType(&this.Replicas, replicas)
+ setGetInstanceResponseGetRetentionDaysAttributeType(&this.RetentionDays, retentionDays)
+ setGetInstanceResponseGetStatusAttributeType(&this.Status, status)
+ setGetInstanceResponseGetStorageAttributeType(&this.Storage, storage)
+ setGetInstanceResponseGetVersionAttributeType(&this.Version, version)
+ return &this
+}
+
+// NewGetInstanceResponseWithDefaults instantiates a new GetInstanceResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetInstanceResponseWithDefaults() *GetInstanceResponse {
+ this := GetInstanceResponse{}
+ return &this
+}
+
+// GetAcl returns the Acl field value
+func (o *GetInstanceResponse) GetAcl() (ret GetInstanceResponseGetAclRetType) {
+ ret, _ = o.GetAclOk()
+ return ret
+}
+
+// GetAclOk returns a tuple with the Acl field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetAclOk() (ret GetInstanceResponseGetAclRetType, ok bool) {
+ return getGetInstanceResponseGetAclAttributeTypeOk(o.Acl)
+}
+
+// SetAcl sets field value
+func (o *GetInstanceResponse) SetAcl(v GetInstanceResponseGetAclRetType) {
+ setGetInstanceResponseGetAclAttributeType(&o.Acl, v)
+}
+
+// GetBackupSchedule returns the BackupSchedule field value
+func (o *GetInstanceResponse) GetBackupSchedule() (ret GetInstanceResponseGetBackupScheduleRetType) {
+ ret, _ = o.GetBackupScheduleOk()
+ return ret
+}
+
+// GetBackupScheduleOk returns a tuple with the BackupSchedule field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetBackupScheduleOk() (ret GetInstanceResponseGetBackupScheduleRetType, ok bool) {
+ return getGetInstanceResponseGetBackupScheduleAttributeTypeOk(o.BackupSchedule)
+}
+
+// SetBackupSchedule sets field value
+func (o *GetInstanceResponse) SetBackupSchedule(v GetInstanceResponseGetBackupScheduleRetType) {
+ setGetInstanceResponseGetBackupScheduleAttributeType(&o.BackupSchedule, v)
+}
+
+// GetEdition returns the Edition field value
+func (o *GetInstanceResponse) GetEdition() (ret GetInstanceResponseGetEditionRetType) {
+ ret, _ = o.GetEditionOk()
+ return ret
+}
+
+// GetEditionOk returns a tuple with the Edition field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetEditionOk() (ret GetInstanceResponseGetEditionRetType, ok bool) {
+ return getGetInstanceResponseGetEditionAttributeTypeOk(o.Edition)
+}
+
+// SetEdition sets field value
+func (o *GetInstanceResponse) SetEdition(v GetInstanceResponseGetEditionRetType) {
+ setGetInstanceResponseGetEditionAttributeType(&o.Edition, v)
+}
+
+// GetEncryption returns the Encryption field value if set, zero value otherwise.
+func (o *GetInstanceResponse) GetEncryption() (res GetInstanceResponseGetEncryptionRetType) {
+ res, _ = o.GetEncryptionOk()
+ return
+}
+
+// GetEncryptionOk returns a tuple with the Encryption field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetEncryptionOk() (ret GetInstanceResponseGetEncryptionRetType, ok bool) {
+ return getGetInstanceResponseGetEncryptionAttributeTypeOk(o.Encryption)
+}
+
+// HasEncryption returns a boolean if a field has been set.
+func (o *GetInstanceResponse) HasEncryption() bool {
+ _, ok := o.GetEncryptionOk()
+ return ok
+}
+
+// SetEncryption gets a reference to the given InstanceEncryption and assigns it to the Encryption field.
+func (o *GetInstanceResponse) SetEncryption(v GetInstanceResponseGetEncryptionRetType) {
+ setGetInstanceResponseGetEncryptionAttributeType(&o.Encryption, v)
+}
+
+// GetFlavorId returns the FlavorId field value
+func (o *GetInstanceResponse) GetFlavorId() (ret GetInstanceResponseGetFlavorIdRetType) {
+ ret, _ = o.GetFlavorIdOk()
+ return ret
+}
+
+// GetFlavorIdOk returns a tuple with the FlavorId field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetFlavorIdOk() (ret GetInstanceResponseGetFlavorIdRetType, ok bool) {
+ return getGetInstanceResponseGetFlavorIdAttributeTypeOk(o.FlavorId)
+}
+
+// SetFlavorId sets field value
+func (o *GetInstanceResponse) SetFlavorId(v GetInstanceResponseGetFlavorIdRetType) {
+ setGetInstanceResponseGetFlavorIdAttributeType(&o.FlavorId, v)
+}
+
+// GetId returns the Id field value
+func (o *GetInstanceResponse) GetId() (ret GetInstanceResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetIdOk() (ret GetInstanceResponseGetIdRetType, ok bool) {
+ return getGetInstanceResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *GetInstanceResponse) SetId(v GetInstanceResponseGetIdRetType) {
+ setGetInstanceResponseGetIdAttributeType(&o.Id, v)
+}
+
+// GetIsDeletable returns the IsDeletable field value
+func (o *GetInstanceResponse) GetIsDeletable() (ret GetInstanceResponsegetIsDeletableRetType) {
+ ret, _ = o.GetIsDeletableOk()
+ return ret
+}
+
+// GetIsDeletableOk returns a tuple with the IsDeletable field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetIsDeletableOk() (ret GetInstanceResponsegetIsDeletableRetType, ok bool) {
+ return getGetInstanceResponsegetIsDeletableAttributeTypeOk(o.IsDeletable)
+}
+
+// SetIsDeletable sets field value
+func (o *GetInstanceResponse) SetIsDeletable(v GetInstanceResponsegetIsDeletableRetType) {
+ setGetInstanceResponsegetIsDeletableAttributeType(&o.IsDeletable, v)
+}
+
+// GetName returns the Name field value
+func (o *GetInstanceResponse) GetName() (ret GetInstanceResponseGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetNameOk() (ret GetInstanceResponseGetNameRetType, ok bool) {
+ return getGetInstanceResponseGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *GetInstanceResponse) SetName(v GetInstanceResponseGetNameRetType) {
+ setGetInstanceResponseGetNameAttributeType(&o.Name, v)
+}
+
+// GetNetwork returns the Network field value
+func (o *GetInstanceResponse) GetNetwork() (ret GetInstanceResponseGetNetworkRetType) {
+ ret, _ = o.GetNetworkOk()
+ return ret
+}
+
+// GetNetworkOk returns a tuple with the Network field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetNetworkOk() (ret GetInstanceResponseGetNetworkRetType, ok bool) {
+ return getGetInstanceResponseGetNetworkAttributeTypeOk(o.Network)
+}
+
+// SetNetwork sets field value
+func (o *GetInstanceResponse) SetNetwork(v GetInstanceResponseGetNetworkRetType) {
+ setGetInstanceResponseGetNetworkAttributeType(&o.Network, v)
+}
+
+// GetReplicas returns the Replicas field value
+func (o *GetInstanceResponse) GetReplicas() (ret GetInstanceResponseGetReplicasRetType) {
+ ret, _ = o.GetReplicasOk()
+ return ret
+}
+
+// GetReplicasOk returns a tuple with the Replicas field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetReplicasOk() (ret GetInstanceResponseGetReplicasRetType, ok bool) {
+ return getGetInstanceResponseGetReplicasAttributeTypeOk(o.Replicas)
+}
+
+// SetReplicas sets field value
+func (o *GetInstanceResponse) SetReplicas(v GetInstanceResponseGetReplicasRetType) {
+ setGetInstanceResponseGetReplicasAttributeType(&o.Replicas, v)
+}
+
+// GetRetentionDays returns the RetentionDays field value
+func (o *GetInstanceResponse) GetRetentionDays() (ret GetInstanceResponseGetRetentionDaysRetType) {
+ ret, _ = o.GetRetentionDaysOk()
+ return ret
+}
+
+// GetRetentionDaysOk returns a tuple with the RetentionDays field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetRetentionDaysOk() (ret GetInstanceResponseGetRetentionDaysRetType, ok bool) {
+ return getGetInstanceResponseGetRetentionDaysAttributeTypeOk(o.RetentionDays)
+}
+
+// SetRetentionDays sets field value
+func (o *GetInstanceResponse) SetRetentionDays(v GetInstanceResponseGetRetentionDaysRetType) {
+ setGetInstanceResponseGetRetentionDaysAttributeType(&o.RetentionDays, v)
+}
+
+// GetStatus returns the Status field value
+func (o *GetInstanceResponse) GetStatus() (ret GetInstanceResponseGetStatusRetType) {
+ ret, _ = o.GetStatusOk()
+ return ret
+}
+
+// GetStatusOk returns a tuple with the Status field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetStatusOk() (ret GetInstanceResponseGetStatusRetType, ok bool) {
+ return getGetInstanceResponseGetStatusAttributeTypeOk(o.Status)
+}
+
+// SetStatus sets field value
+func (o *GetInstanceResponse) SetStatus(v GetInstanceResponseGetStatusRetType) {
+ setGetInstanceResponseGetStatusAttributeType(&o.Status, v)
+}
+
+// GetStorage returns the Storage field value
+func (o *GetInstanceResponse) GetStorage() (ret GetInstanceResponseGetStorageRetType) {
+ ret, _ = o.GetStorageOk()
+ return ret
+}
+
+// GetStorageOk returns a tuple with the Storage field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetStorageOk() (ret GetInstanceResponseGetStorageRetType, ok bool) {
+ return getGetInstanceResponseGetStorageAttributeTypeOk(o.Storage)
+}
+
+// SetStorage sets field value
+func (o *GetInstanceResponse) SetStorage(v GetInstanceResponseGetStorageRetType) {
+ setGetInstanceResponseGetStorageAttributeType(&o.Storage, v)
+}
+
+// GetVersion returns the Version field value
+func (o *GetInstanceResponse) GetVersion() (ret GetInstanceResponseGetVersionRetType) {
+ ret, _ = o.GetVersionOk()
+ return ret
+}
+
+// GetVersionOk returns a tuple with the Version field value
+// and a boolean to check if the value has been set.
+func (o *GetInstanceResponse) GetVersionOk() (ret GetInstanceResponseGetVersionRetType, ok bool) {
+ return getGetInstanceResponseGetVersionAttributeTypeOk(o.Version)
+}
+
+// SetVersion sets field value
+func (o *GetInstanceResponse) SetVersion(v GetInstanceResponseGetVersionRetType) {
+ setGetInstanceResponseGetVersionAttributeType(&o.Version, v)
+}
+
+func (o GetInstanceResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetInstanceResponseGetAclAttributeTypeOk(o.Acl); ok {
+ toSerialize["Acl"] = val
+ }
+ if val, ok := getGetInstanceResponseGetBackupScheduleAttributeTypeOk(o.BackupSchedule); ok {
+ toSerialize["BackupSchedule"] = val
+ }
+ if val, ok := getGetInstanceResponseGetEditionAttributeTypeOk(o.Edition); ok {
+ toSerialize["Edition"] = val
+ }
+ if val, ok := getGetInstanceResponseGetEncryptionAttributeTypeOk(o.Encryption); ok {
+ toSerialize["Encryption"] = val
+ }
+ if val, ok := getGetInstanceResponseGetFlavorIdAttributeTypeOk(o.FlavorId); ok {
+ toSerialize["FlavorId"] = val
+ }
+ if val, ok := getGetInstanceResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getGetInstanceResponsegetIsDeletableAttributeTypeOk(o.IsDeletable); ok {
+ toSerialize["IsDeletable"] = val
+ }
+ if val, ok := getGetInstanceResponseGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getGetInstanceResponseGetNetworkAttributeTypeOk(o.Network); ok {
+ toSerialize["Network"] = val
+ }
+ if val, ok := getGetInstanceResponseGetReplicasAttributeTypeOk(o.Replicas); ok {
+ toSerialize["Replicas"] = val
+ }
+ if val, ok := getGetInstanceResponseGetRetentionDaysAttributeTypeOk(o.RetentionDays); ok {
+ toSerialize["RetentionDays"] = val
+ }
+ if val, ok := getGetInstanceResponseGetStatusAttributeTypeOk(o.Status); ok {
+ toSerialize["Status"] = val
+ }
+ if val, ok := getGetInstanceResponseGetStorageAttributeTypeOk(o.Storage); ok {
+ toSerialize["Storage"] = val
+ }
+ if val, ok := getGetInstanceResponseGetVersionAttributeTypeOk(o.Version); ok {
+ toSerialize["Version"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetInstanceResponse struct {
+ value *GetInstanceResponse
+ isSet bool
+}
+
+func (v NullableGetInstanceResponse) Get() *GetInstanceResponse {
+ return v.value
+}
+
+func (v *NullableGetInstanceResponse) Set(val *GetInstanceResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetInstanceResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetInstanceResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetInstanceResponse(val *GetInstanceResponse) *NullableGetInstanceResponse {
+ return &NullableGetInstanceResponse{value: val, isSet: true}
+}
+
+func (v NullableGetInstanceResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetInstanceResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_get_instance_response_test.go b/pkg/sqlserverflexalpha/model_get_instance_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_instance_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_get_storages_response.go b/pkg/sqlserverflexalpha/model_get_storages_response.go
new file mode 100644
index 00000000..6a1b6d53
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_storages_response.go
@@ -0,0 +1,169 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetStoragesResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetStoragesResponse{}
+
+/*
+ types and functions for storageClasses
+*/
+
+// isArray
+type GetStoragesResponseGetStorageClassesAttributeType = *[]FlavorStorageClassesStorageClass
+type GetStoragesResponseGetStorageClassesArgType = []FlavorStorageClassesStorageClass
+type GetStoragesResponseGetStorageClassesRetType = []FlavorStorageClassesStorageClass
+
+func getGetStoragesResponseGetStorageClassesAttributeTypeOk(arg GetStoragesResponseGetStorageClassesAttributeType) (ret GetStoragesResponseGetStorageClassesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetStoragesResponseGetStorageClassesAttributeType(arg *GetStoragesResponseGetStorageClassesAttributeType, val GetStoragesResponseGetStorageClassesRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for storageRange
+*/
+
+// isModel
+type GetStoragesResponseGetStorageRangeAttributeType = *FlavorStorageRange
+type GetStoragesResponseGetStorageRangeArgType = FlavorStorageRange
+type GetStoragesResponseGetStorageRangeRetType = FlavorStorageRange
+
+func getGetStoragesResponseGetStorageRangeAttributeTypeOk(arg GetStoragesResponseGetStorageRangeAttributeType) (ret GetStoragesResponseGetStorageRangeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetStoragesResponseGetStorageRangeAttributeType(arg *GetStoragesResponseGetStorageRangeAttributeType, val GetStoragesResponseGetStorageRangeRetType) {
+ *arg = &val
+}
+
+// GetStoragesResponse struct for GetStoragesResponse
+type GetStoragesResponse struct {
+ // maximum storage which can be ordered for the flavor in Gigabyte.
+ // REQUIRED
+ StorageClasses GetStoragesResponseGetStorageClassesAttributeType `json:"storageClasses" required:"true"`
+ // REQUIRED
+ StorageRange GetStoragesResponseGetStorageRangeAttributeType `json:"storageRange" required:"true"`
+}
+
+type _GetStoragesResponse GetStoragesResponse
+
+// NewGetStoragesResponse instantiates a new GetStoragesResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetStoragesResponse(storageClasses GetStoragesResponseGetStorageClassesArgType, storageRange GetStoragesResponseGetStorageRangeArgType) *GetStoragesResponse {
+ this := GetStoragesResponse{}
+ setGetStoragesResponseGetStorageClassesAttributeType(&this.StorageClasses, storageClasses)
+ setGetStoragesResponseGetStorageRangeAttributeType(&this.StorageRange, storageRange)
+ return &this
+}
+
+// NewGetStoragesResponseWithDefaults instantiates a new GetStoragesResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetStoragesResponseWithDefaults() *GetStoragesResponse {
+ this := GetStoragesResponse{}
+ return &this
+}
+
+// GetStorageClasses returns the StorageClasses field value
+func (o *GetStoragesResponse) GetStorageClasses() (ret GetStoragesResponseGetStorageClassesRetType) {
+ ret, _ = o.GetStorageClassesOk()
+ return ret
+}
+
+// GetStorageClassesOk returns a tuple with the StorageClasses field value
+// and a boolean to check if the value has been set.
+func (o *GetStoragesResponse) GetStorageClassesOk() (ret GetStoragesResponseGetStorageClassesRetType, ok bool) {
+ return getGetStoragesResponseGetStorageClassesAttributeTypeOk(o.StorageClasses)
+}
+
+// SetStorageClasses sets field value
+func (o *GetStoragesResponse) SetStorageClasses(v GetStoragesResponseGetStorageClassesRetType) {
+ setGetStoragesResponseGetStorageClassesAttributeType(&o.StorageClasses, v)
+}
+
+// GetStorageRange returns the StorageRange field value
+func (o *GetStoragesResponse) GetStorageRange() (ret GetStoragesResponseGetStorageRangeRetType) {
+ ret, _ = o.GetStorageRangeOk()
+ return ret
+}
+
+// GetStorageRangeOk returns a tuple with the StorageRange field value
+// and a boolean to check if the value has been set.
+func (o *GetStoragesResponse) GetStorageRangeOk() (ret GetStoragesResponseGetStorageRangeRetType, ok bool) {
+ return getGetStoragesResponseGetStorageRangeAttributeTypeOk(o.StorageRange)
+}
+
+// SetStorageRange sets field value
+func (o *GetStoragesResponse) SetStorageRange(v GetStoragesResponseGetStorageRangeRetType) {
+ setGetStoragesResponseGetStorageRangeAttributeType(&o.StorageRange, v)
+}
+
+func (o GetStoragesResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetStoragesResponseGetStorageClassesAttributeTypeOk(o.StorageClasses); ok {
+ toSerialize["StorageClasses"] = val
+ }
+ if val, ok := getGetStoragesResponseGetStorageRangeAttributeTypeOk(o.StorageRange); ok {
+ toSerialize["StorageRange"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetStoragesResponse struct {
+ value *GetStoragesResponse
+ isSet bool
+}
+
+func (v NullableGetStoragesResponse) Get() *GetStoragesResponse {
+ return v.value
+}
+
+func (v *NullableGetStoragesResponse) Set(val *GetStoragesResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetStoragesResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetStoragesResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetStoragesResponse(val *GetStoragesResponse) *NullableGetStoragesResponse {
+ return &NullableGetStoragesResponse{value: val, isSet: true}
+}
+
+func (v NullableGetStoragesResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetStoragesResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_get_storages_response_test.go b/pkg/sqlserverflexalpha/model_get_storages_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_storages_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_get_user_response.go b/pkg/sqlserverflexalpha/model_get_user_response.go
new file mode 100644
index 00000000..979e505f
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_user_response.go
@@ -0,0 +1,395 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetUserResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetUserResponse{}
+
+/*
+ types and functions for default_database
+*/
+
+// isNotNullableString
+type GetUserResponseGetDefaultDatabaseAttributeType = *string
+
+func getGetUserResponseGetDefaultDatabaseAttributeTypeOk(arg GetUserResponseGetDefaultDatabaseAttributeType) (ret GetUserResponseGetDefaultDatabaseRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetDefaultDatabaseAttributeType(arg *GetUserResponseGetDefaultDatabaseAttributeType, val GetUserResponseGetDefaultDatabaseRetType) {
+ *arg = &val
+}
+
+type GetUserResponseGetDefaultDatabaseArgType = string
+type GetUserResponseGetDefaultDatabaseRetType = string
+
+/*
+ types and functions for host
+*/
+
+// isNotNullableString
+type GetUserResponseGetHostAttributeType = *string
+
+func getGetUserResponseGetHostAttributeTypeOk(arg GetUserResponseGetHostAttributeType) (ret GetUserResponseGetHostRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetHostAttributeType(arg *GetUserResponseGetHostAttributeType, val GetUserResponseGetHostRetType) {
+ *arg = &val
+}
+
+type GetUserResponseGetHostArgType = string
+type GetUserResponseGetHostRetType = string
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type GetUserResponseGetIdAttributeType = *int64
+type GetUserResponseGetIdArgType = int64
+type GetUserResponseGetIdRetType = int64
+
+func getGetUserResponseGetIdAttributeTypeOk(arg GetUserResponseGetIdAttributeType) (ret GetUserResponseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetIdAttributeType(arg *GetUserResponseGetIdAttributeType, val GetUserResponseGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for port
+*/
+
+// isInteger
+type GetUserResponseGetPortAttributeType = *int64
+type GetUserResponseGetPortArgType = int64
+type GetUserResponseGetPortRetType = int64
+
+func getGetUserResponseGetPortAttributeTypeOk(arg GetUserResponseGetPortAttributeType) (ret GetUserResponseGetPortRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetPortAttributeType(arg *GetUserResponseGetPortAttributeType, val GetUserResponseGetPortRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for roles
+*/
+
+// isArray
+type GetUserResponseGetRolesAttributeType = *[]UserRole
+type GetUserResponseGetRolesArgType = []UserRole
+type GetUserResponseGetRolesRetType = []UserRole
+
+func getGetUserResponseGetRolesAttributeTypeOk(arg GetUserResponseGetRolesAttributeType) (ret GetUserResponseGetRolesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetRolesAttributeType(arg *GetUserResponseGetRolesAttributeType, val GetUserResponseGetRolesRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for status
+*/
+
+// isNotNullableString
+type GetUserResponseGetStatusAttributeType = *string
+
+func getGetUserResponseGetStatusAttributeTypeOk(arg GetUserResponseGetStatusAttributeType) (ret GetUserResponseGetStatusRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetStatusAttributeType(arg *GetUserResponseGetStatusAttributeType, val GetUserResponseGetStatusRetType) {
+ *arg = &val
+}
+
+type GetUserResponseGetStatusArgType = string
+type GetUserResponseGetStatusRetType = string
+
+/*
+ types and functions for username
+*/
+
+// isNotNullableString
+type GetUserResponseGetUsernameAttributeType = *string
+
+func getGetUserResponseGetUsernameAttributeTypeOk(arg GetUserResponseGetUsernameAttributeType) (ret GetUserResponseGetUsernameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetUserResponseGetUsernameAttributeType(arg *GetUserResponseGetUsernameAttributeType, val GetUserResponseGetUsernameRetType) {
+ *arg = &val
+}
+
+type GetUserResponseGetUsernameArgType = string
+type GetUserResponseGetUsernameRetType = string
+
+// GetUserResponse struct for GetUserResponse
+type GetUserResponse struct {
+ // The default database for a user of the instance.
+ // REQUIRED
+ DefaultDatabase GetUserResponseGetDefaultDatabaseAttributeType `json:"default_database" required:"true"`
+ // The host of the instance in which the user belongs to.
+ // REQUIRED
+ Host GetUserResponseGetHostAttributeType `json:"host" required:"true"`
+ // The ID of the user.
+ // REQUIRED
+ Id GetUserResponseGetIdAttributeType `json:"id" required:"true"`
+ // The port of the instance in which the user belongs to.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ Port GetUserResponseGetPortAttributeType `json:"port" required:"true"`
+ // A list of user roles.
+ // REQUIRED
+ Roles GetUserResponseGetRolesAttributeType `json:"roles" required:"true"`
+ // The current status of the user.
+ // REQUIRED
+ Status GetUserResponseGetStatusAttributeType `json:"status" required:"true"`
+ // The name of the user.
+ // REQUIRED
+ Username GetUserResponseGetUsernameAttributeType `json:"username" required:"true"`
+}
+
+type _GetUserResponse GetUserResponse
+
+// NewGetUserResponse instantiates a new GetUserResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetUserResponse(defaultDatabase GetUserResponseGetDefaultDatabaseArgType, host GetUserResponseGetHostArgType, id GetUserResponseGetIdArgType, port GetUserResponseGetPortArgType, roles GetUserResponseGetRolesArgType, status GetUserResponseGetStatusArgType, username GetUserResponseGetUsernameArgType) *GetUserResponse {
+ this := GetUserResponse{}
+ setGetUserResponseGetDefaultDatabaseAttributeType(&this.DefaultDatabase, defaultDatabase)
+ setGetUserResponseGetHostAttributeType(&this.Host, host)
+ setGetUserResponseGetIdAttributeType(&this.Id, id)
+ setGetUserResponseGetPortAttributeType(&this.Port, port)
+ setGetUserResponseGetRolesAttributeType(&this.Roles, roles)
+ setGetUserResponseGetStatusAttributeType(&this.Status, status)
+ setGetUserResponseGetUsernameAttributeType(&this.Username, username)
+ return &this
+}
+
+// NewGetUserResponseWithDefaults instantiates a new GetUserResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetUserResponseWithDefaults() *GetUserResponse {
+ this := GetUserResponse{}
+ return &this
+}
+
+// GetDefaultDatabase returns the DefaultDatabase field value
+func (o *GetUserResponse) GetDefaultDatabase() (ret GetUserResponseGetDefaultDatabaseRetType) {
+ ret, _ = o.GetDefaultDatabaseOk()
+ return ret
+}
+
+// GetDefaultDatabaseOk returns a tuple with the DefaultDatabase field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetDefaultDatabaseOk() (ret GetUserResponseGetDefaultDatabaseRetType, ok bool) {
+ return getGetUserResponseGetDefaultDatabaseAttributeTypeOk(o.DefaultDatabase)
+}
+
+// SetDefaultDatabase sets field value
+func (o *GetUserResponse) SetDefaultDatabase(v GetUserResponseGetDefaultDatabaseRetType) {
+ setGetUserResponseGetDefaultDatabaseAttributeType(&o.DefaultDatabase, v)
+}
+
+// GetHost returns the Host field value
+func (o *GetUserResponse) GetHost() (ret GetUserResponseGetHostRetType) {
+ ret, _ = o.GetHostOk()
+ return ret
+}
+
+// GetHostOk returns a tuple with the Host field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetHostOk() (ret GetUserResponseGetHostRetType, ok bool) {
+ return getGetUserResponseGetHostAttributeTypeOk(o.Host)
+}
+
+// SetHost sets field value
+func (o *GetUserResponse) SetHost(v GetUserResponseGetHostRetType) {
+ setGetUserResponseGetHostAttributeType(&o.Host, v)
+}
+
+// GetId returns the Id field value
+func (o *GetUserResponse) GetId() (ret GetUserResponseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetIdOk() (ret GetUserResponseGetIdRetType, ok bool) {
+ return getGetUserResponseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *GetUserResponse) SetId(v GetUserResponseGetIdRetType) {
+ setGetUserResponseGetIdAttributeType(&o.Id, v)
+}
+
+// GetPort returns the Port field value
+func (o *GetUserResponse) GetPort() (ret GetUserResponseGetPortRetType) {
+ ret, _ = o.GetPortOk()
+ return ret
+}
+
+// GetPortOk returns a tuple with the Port field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetPortOk() (ret GetUserResponseGetPortRetType, ok bool) {
+ return getGetUserResponseGetPortAttributeTypeOk(o.Port)
+}
+
+// SetPort sets field value
+func (o *GetUserResponse) SetPort(v GetUserResponseGetPortRetType) {
+ setGetUserResponseGetPortAttributeType(&o.Port, v)
+}
+
+// GetRoles returns the Roles field value
+func (o *GetUserResponse) GetRoles() (ret GetUserResponseGetRolesRetType) {
+ ret, _ = o.GetRolesOk()
+ return ret
+}
+
+// GetRolesOk returns a tuple with the Roles field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetRolesOk() (ret GetUserResponseGetRolesRetType, ok bool) {
+ return getGetUserResponseGetRolesAttributeTypeOk(o.Roles)
+}
+
+// SetRoles sets field value
+func (o *GetUserResponse) SetRoles(v GetUserResponseGetRolesRetType) {
+ setGetUserResponseGetRolesAttributeType(&o.Roles, v)
+}
+
+// GetStatus returns the Status field value
+func (o *GetUserResponse) GetStatus() (ret GetUserResponseGetStatusRetType) {
+ ret, _ = o.GetStatusOk()
+ return ret
+}
+
+// GetStatusOk returns a tuple with the Status field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetStatusOk() (ret GetUserResponseGetStatusRetType, ok bool) {
+ return getGetUserResponseGetStatusAttributeTypeOk(o.Status)
+}
+
+// SetStatus sets field value
+func (o *GetUserResponse) SetStatus(v GetUserResponseGetStatusRetType) {
+ setGetUserResponseGetStatusAttributeType(&o.Status, v)
+}
+
+// GetUsername returns the Username field value
+func (o *GetUserResponse) GetUsername() (ret GetUserResponseGetUsernameRetType) {
+ ret, _ = o.GetUsernameOk()
+ return ret
+}
+
+// GetUsernameOk returns a tuple with the Username field value
+// and a boolean to check if the value has been set.
+func (o *GetUserResponse) GetUsernameOk() (ret GetUserResponseGetUsernameRetType, ok bool) {
+ return getGetUserResponseGetUsernameAttributeTypeOk(o.Username)
+}
+
+// SetUsername sets field value
+func (o *GetUserResponse) SetUsername(v GetUserResponseGetUsernameRetType) {
+ setGetUserResponseGetUsernameAttributeType(&o.Username, v)
+}
+
+func (o GetUserResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetUserResponseGetDefaultDatabaseAttributeTypeOk(o.DefaultDatabase); ok {
+ toSerialize["DefaultDatabase"] = val
+ }
+ if val, ok := getGetUserResponseGetHostAttributeTypeOk(o.Host); ok {
+ toSerialize["Host"] = val
+ }
+ if val, ok := getGetUserResponseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getGetUserResponseGetPortAttributeTypeOk(o.Port); ok {
+ toSerialize["Port"] = val
+ }
+ if val, ok := getGetUserResponseGetRolesAttributeTypeOk(o.Roles); ok {
+ toSerialize["Roles"] = val
+ }
+ if val, ok := getGetUserResponseGetStatusAttributeTypeOk(o.Status); ok {
+ toSerialize["Status"] = val
+ }
+ if val, ok := getGetUserResponseGetUsernameAttributeTypeOk(o.Username); ok {
+ toSerialize["Username"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetUserResponse struct {
+ value *GetUserResponse
+ isSet bool
+}
+
+func (v NullableGetUserResponse) Get() *GetUserResponse {
+ return v.value
+}
+
+func (v *NullableGetUserResponse) Set(val *GetUserResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetUserResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetUserResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetUserResponse(val *GetUserResponse) *NullableGetUserResponse {
+ return &NullableGetUserResponse{value: val, isSet: true}
+}
+
+func (v NullableGetUserResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetUserResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_get_user_response_test.go b/pkg/sqlserverflexalpha/model_get_user_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_user_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_get_versions_response.go b/pkg/sqlserverflexalpha/model_get_versions_response.go
new file mode 100644
index 00000000..fda6496d
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_versions_response.go
@@ -0,0 +1,126 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the GetVersionsResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &GetVersionsResponse{}
+
+/*
+ types and functions for versions
+*/
+
+// isArray
+type GetVersionsResponseGetVersionsAttributeType = *[]Version
+type GetVersionsResponseGetVersionsArgType = []Version
+type GetVersionsResponseGetVersionsRetType = []Version
+
+func getGetVersionsResponseGetVersionsAttributeTypeOk(arg GetVersionsResponseGetVersionsAttributeType) (ret GetVersionsResponseGetVersionsRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setGetVersionsResponseGetVersionsAttributeType(arg *GetVersionsResponseGetVersionsAttributeType, val GetVersionsResponseGetVersionsRetType) {
+ *arg = &val
+}
+
+// GetVersionsResponse struct for GetVersionsResponse
+type GetVersionsResponse struct {
+ // A list containing available sqlserver versions.
+ // REQUIRED
+ Versions GetVersionsResponseGetVersionsAttributeType `json:"versions" required:"true"`
+}
+
+type _GetVersionsResponse GetVersionsResponse
+
+// NewGetVersionsResponse instantiates a new GetVersionsResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewGetVersionsResponse(versions GetVersionsResponseGetVersionsArgType) *GetVersionsResponse {
+ this := GetVersionsResponse{}
+ setGetVersionsResponseGetVersionsAttributeType(&this.Versions, versions)
+ return &this
+}
+
+// NewGetVersionsResponseWithDefaults instantiates a new GetVersionsResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewGetVersionsResponseWithDefaults() *GetVersionsResponse {
+ this := GetVersionsResponse{}
+ return &this
+}
+
+// GetVersions returns the Versions field value
+func (o *GetVersionsResponse) GetVersions() (ret GetVersionsResponseGetVersionsRetType) {
+ ret, _ = o.GetVersionsOk()
+ return ret
+}
+
+// GetVersionsOk returns a tuple with the Versions field value
+// and a boolean to check if the value has been set.
+func (o *GetVersionsResponse) GetVersionsOk() (ret GetVersionsResponseGetVersionsRetType, ok bool) {
+ return getGetVersionsResponseGetVersionsAttributeTypeOk(o.Versions)
+}
+
+// SetVersions sets field value
+func (o *GetVersionsResponse) SetVersions(v GetVersionsResponseGetVersionsRetType) {
+ setGetVersionsResponseGetVersionsAttributeType(&o.Versions, v)
+}
+
+func (o GetVersionsResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getGetVersionsResponseGetVersionsAttributeTypeOk(o.Versions); ok {
+ toSerialize["Versions"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableGetVersionsResponse struct {
+ value *GetVersionsResponse
+ isSet bool
+}
+
+func (v NullableGetVersionsResponse) Get() *GetVersionsResponse {
+ return v.value
+}
+
+func (v *NullableGetVersionsResponse) Set(val *GetVersionsResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableGetVersionsResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableGetVersionsResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableGetVersionsResponse(val *GetVersionsResponse) *NullableGetVersionsResponse {
+ return &NullableGetVersionsResponse{value: val, isSet: true}
+}
+
+func (v NullableGetVersionsResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableGetVersionsResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_get_versions_response_test.go b/pkg/sqlserverflexalpha/model_get_versions_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_get_versions_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_instance_edition.go b/pkg/sqlserverflexalpha/model_instance_edition.go
new file mode 100644
index 00000000..cab08ff0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_edition.go
@@ -0,0 +1,117 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// InstanceEdition Edition of the MSSQL server instance
+type InstanceEdition string
+
+// List of instance.edition
+const (
+ INSTANCEEDITION_STANDARD InstanceEdition = "Standard"
+ INSTANCEEDITION_ENTERPRISE_CORE InstanceEdition = "EnterpriseCore"
+ INSTANCEEDITION_DEVELOPER InstanceEdition = "developer"
+)
+
+// All allowed values of InstanceEdition enum
+var AllowedInstanceEditionEnumValues = []InstanceEdition{
+ "Standard",
+ "EnterpriseCore",
+ "developer",
+}
+
+func (v *InstanceEdition) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := InstanceEdition(value)
+ for _, existing := range AllowedInstanceEditionEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid InstanceEdition", value)
+}
+
+// NewInstanceEditionFromValue returns a pointer to a valid InstanceEdition
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewInstanceEditionFromValue(v string) (*InstanceEdition, error) {
+ ev := InstanceEdition(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for InstanceEdition: valid values are %v", v, AllowedInstanceEditionEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v InstanceEdition) IsValid() bool {
+ for _, existing := range AllowedInstanceEditionEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to instance.edition value
+func (v InstanceEdition) Ptr() *InstanceEdition {
+ return &v
+}
+
+type NullableInstanceEdition struct {
+ value *InstanceEdition
+ isSet bool
+}
+
+func (v NullableInstanceEdition) Get() *InstanceEdition {
+ return v.value
+}
+
+func (v *NullableInstanceEdition) Set(val *InstanceEdition) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInstanceEdition) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInstanceEdition) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInstanceEdition(val *InstanceEdition) *NullableInstanceEdition {
+ return &NullableInstanceEdition{value: val, isSet: true}
+}
+
+func (v NullableInstanceEdition) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInstanceEdition) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_instance_edition_test.go b/pkg/sqlserverflexalpha/model_instance_edition_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_edition_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_instance_encryption.go b/pkg/sqlserverflexalpha/model_instance_encryption.go
new file mode 100644
index 00000000..9bac54bf
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_encryption.go
@@ -0,0 +1,261 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the InstanceEncryption type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &InstanceEncryption{}
+
+/*
+ types and functions for kekKeyId
+*/
+
+// isNotNullableString
+type InstanceEncryptionGetKekKeyIdAttributeType = *string
+
+func getInstanceEncryptionGetKekKeyIdAttributeTypeOk(arg InstanceEncryptionGetKekKeyIdAttributeType) (ret InstanceEncryptionGetKekKeyIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceEncryptionGetKekKeyIdAttributeType(arg *InstanceEncryptionGetKekKeyIdAttributeType, val InstanceEncryptionGetKekKeyIdRetType) {
+ *arg = &val
+}
+
+type InstanceEncryptionGetKekKeyIdArgType = string
+type InstanceEncryptionGetKekKeyIdRetType = string
+
+/*
+ types and functions for kekKeyRingId
+*/
+
+// isNotNullableString
+type InstanceEncryptionGetKekKeyRingIdAttributeType = *string
+
+func getInstanceEncryptionGetKekKeyRingIdAttributeTypeOk(arg InstanceEncryptionGetKekKeyRingIdAttributeType) (ret InstanceEncryptionGetKekKeyRingIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceEncryptionGetKekKeyRingIdAttributeType(arg *InstanceEncryptionGetKekKeyRingIdAttributeType, val InstanceEncryptionGetKekKeyRingIdRetType) {
+ *arg = &val
+}
+
+type InstanceEncryptionGetKekKeyRingIdArgType = string
+type InstanceEncryptionGetKekKeyRingIdRetType = string
+
+/*
+ types and functions for kekKeyVersion
+*/
+
+// isNotNullableString
+type InstanceEncryptionGetKekKeyVersionAttributeType = *string
+
+func getInstanceEncryptionGetKekKeyVersionAttributeTypeOk(arg InstanceEncryptionGetKekKeyVersionAttributeType) (ret InstanceEncryptionGetKekKeyVersionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceEncryptionGetKekKeyVersionAttributeType(arg *InstanceEncryptionGetKekKeyVersionAttributeType, val InstanceEncryptionGetKekKeyVersionRetType) {
+ *arg = &val
+}
+
+type InstanceEncryptionGetKekKeyVersionArgType = string
+type InstanceEncryptionGetKekKeyVersionRetType = string
+
+/*
+ types and functions for serviceAccount
+*/
+
+// isNotNullableString
+type InstanceEncryptionGetServiceAccountAttributeType = *string
+
+func getInstanceEncryptionGetServiceAccountAttributeTypeOk(arg InstanceEncryptionGetServiceAccountAttributeType) (ret InstanceEncryptionGetServiceAccountRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceEncryptionGetServiceAccountAttributeType(arg *InstanceEncryptionGetServiceAccountAttributeType, val InstanceEncryptionGetServiceAccountRetType) {
+ *arg = &val
+}
+
+type InstanceEncryptionGetServiceAccountArgType = string
+type InstanceEncryptionGetServiceAccountRetType = string
+
+// InstanceEncryption this defines which key to use for storage encryption
+type InstanceEncryption struct {
+ // The key identifier
+ // REQUIRED
+ KekKeyId InstanceEncryptionGetKekKeyIdAttributeType `json:"kekKeyId" required:"true"`
+ // The keyring identifier
+ // REQUIRED
+ KekKeyRingId InstanceEncryptionGetKekKeyRingIdAttributeType `json:"kekKeyRingId" required:"true"`
+ // The key version
+ // REQUIRED
+ KekKeyVersion InstanceEncryptionGetKekKeyVersionAttributeType `json:"kekKeyVersion" required:"true"`
+ // REQUIRED
+ ServiceAccount InstanceEncryptionGetServiceAccountAttributeType `json:"serviceAccount" required:"true"`
+}
+
+type _InstanceEncryption InstanceEncryption
+
+// NewInstanceEncryption instantiates a new InstanceEncryption object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewInstanceEncryption(kekKeyId InstanceEncryptionGetKekKeyIdArgType, kekKeyRingId InstanceEncryptionGetKekKeyRingIdArgType, kekKeyVersion InstanceEncryptionGetKekKeyVersionArgType, serviceAccount InstanceEncryptionGetServiceAccountArgType) *InstanceEncryption {
+ this := InstanceEncryption{}
+ setInstanceEncryptionGetKekKeyIdAttributeType(&this.KekKeyId, kekKeyId)
+ setInstanceEncryptionGetKekKeyRingIdAttributeType(&this.KekKeyRingId, kekKeyRingId)
+ setInstanceEncryptionGetKekKeyVersionAttributeType(&this.KekKeyVersion, kekKeyVersion)
+ setInstanceEncryptionGetServiceAccountAttributeType(&this.ServiceAccount, serviceAccount)
+ return &this
+}
+
+// NewInstanceEncryptionWithDefaults instantiates a new InstanceEncryption object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewInstanceEncryptionWithDefaults() *InstanceEncryption {
+ this := InstanceEncryption{}
+ return &this
+}
+
+// GetKekKeyId returns the KekKeyId field value
+func (o *InstanceEncryption) GetKekKeyId() (ret InstanceEncryptionGetKekKeyIdRetType) {
+ ret, _ = o.GetKekKeyIdOk()
+ return ret
+}
+
+// GetKekKeyIdOk returns a tuple with the KekKeyId field value
+// and a boolean to check if the value has been set.
+func (o *InstanceEncryption) GetKekKeyIdOk() (ret InstanceEncryptionGetKekKeyIdRetType, ok bool) {
+ return getInstanceEncryptionGetKekKeyIdAttributeTypeOk(o.KekKeyId)
+}
+
+// SetKekKeyId sets field value
+func (o *InstanceEncryption) SetKekKeyId(v InstanceEncryptionGetKekKeyIdRetType) {
+ setInstanceEncryptionGetKekKeyIdAttributeType(&o.KekKeyId, v)
+}
+
+// GetKekKeyRingId returns the KekKeyRingId field value
+func (o *InstanceEncryption) GetKekKeyRingId() (ret InstanceEncryptionGetKekKeyRingIdRetType) {
+ ret, _ = o.GetKekKeyRingIdOk()
+ return ret
+}
+
+// GetKekKeyRingIdOk returns a tuple with the KekKeyRingId field value
+// and a boolean to check if the value has been set.
+func (o *InstanceEncryption) GetKekKeyRingIdOk() (ret InstanceEncryptionGetKekKeyRingIdRetType, ok bool) {
+ return getInstanceEncryptionGetKekKeyRingIdAttributeTypeOk(o.KekKeyRingId)
+}
+
+// SetKekKeyRingId sets field value
+func (o *InstanceEncryption) SetKekKeyRingId(v InstanceEncryptionGetKekKeyRingIdRetType) {
+ setInstanceEncryptionGetKekKeyRingIdAttributeType(&o.KekKeyRingId, v)
+}
+
+// GetKekKeyVersion returns the KekKeyVersion field value
+func (o *InstanceEncryption) GetKekKeyVersion() (ret InstanceEncryptionGetKekKeyVersionRetType) {
+ ret, _ = o.GetKekKeyVersionOk()
+ return ret
+}
+
+// GetKekKeyVersionOk returns a tuple with the KekKeyVersion field value
+// and a boolean to check if the value has been set.
+func (o *InstanceEncryption) GetKekKeyVersionOk() (ret InstanceEncryptionGetKekKeyVersionRetType, ok bool) {
+ return getInstanceEncryptionGetKekKeyVersionAttributeTypeOk(o.KekKeyVersion)
+}
+
+// SetKekKeyVersion sets field value
+func (o *InstanceEncryption) SetKekKeyVersion(v InstanceEncryptionGetKekKeyVersionRetType) {
+ setInstanceEncryptionGetKekKeyVersionAttributeType(&o.KekKeyVersion, v)
+}
+
+// GetServiceAccount returns the ServiceAccount field value
+func (o *InstanceEncryption) GetServiceAccount() (ret InstanceEncryptionGetServiceAccountRetType) {
+ ret, _ = o.GetServiceAccountOk()
+ return ret
+}
+
+// GetServiceAccountOk returns a tuple with the ServiceAccount field value
+// and a boolean to check if the value has been set.
+func (o *InstanceEncryption) GetServiceAccountOk() (ret InstanceEncryptionGetServiceAccountRetType, ok bool) {
+ return getInstanceEncryptionGetServiceAccountAttributeTypeOk(o.ServiceAccount)
+}
+
+// SetServiceAccount sets field value
+func (o *InstanceEncryption) SetServiceAccount(v InstanceEncryptionGetServiceAccountRetType) {
+ setInstanceEncryptionGetServiceAccountAttributeType(&o.ServiceAccount, v)
+}
+
+func (o InstanceEncryption) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getInstanceEncryptionGetKekKeyIdAttributeTypeOk(o.KekKeyId); ok {
+ toSerialize["KekKeyId"] = val
+ }
+ if val, ok := getInstanceEncryptionGetKekKeyRingIdAttributeTypeOk(o.KekKeyRingId); ok {
+ toSerialize["KekKeyRingId"] = val
+ }
+ if val, ok := getInstanceEncryptionGetKekKeyVersionAttributeTypeOk(o.KekKeyVersion); ok {
+ toSerialize["KekKeyVersion"] = val
+ }
+ if val, ok := getInstanceEncryptionGetServiceAccountAttributeTypeOk(o.ServiceAccount); ok {
+ toSerialize["ServiceAccount"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableInstanceEncryption struct {
+ value *InstanceEncryption
+ isSet bool
+}
+
+func (v NullableInstanceEncryption) Get() *InstanceEncryption {
+ return v.value
+}
+
+func (v *NullableInstanceEncryption) Set(val *InstanceEncryption) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInstanceEncryption) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInstanceEncryption) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInstanceEncryption(val *InstanceEncryption) *NullableInstanceEncryption {
+ return &NullableInstanceEncryption{value: val, isSet: true}
+}
+
+func (v NullableInstanceEncryption) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInstanceEncryption) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_instance_encryption_test.go b/pkg/sqlserverflexalpha/model_instance_encryption_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_encryption_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_instance_network.go b/pkg/sqlserverflexalpha/model_instance_network.go
new file mode 100644
index 00000000..8abfd38c
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_network.go
@@ -0,0 +1,273 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the InstanceNetwork type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &InstanceNetwork{}
+
+/*
+ types and functions for accessScope
+*/
+
+// isEnumRef
+type InstanceNetworkGetAccessScopeAttributeType = *InstanceNetworkAccessScope
+type InstanceNetworkGetAccessScopeArgType = InstanceNetworkAccessScope
+type InstanceNetworkGetAccessScopeRetType = InstanceNetworkAccessScope
+
+func getInstanceNetworkGetAccessScopeAttributeTypeOk(arg InstanceNetworkGetAccessScopeAttributeType) (ret InstanceNetworkGetAccessScopeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceNetworkGetAccessScopeAttributeType(arg *InstanceNetworkGetAccessScopeAttributeType, val InstanceNetworkGetAccessScopeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for acl
+*/
+
+// isArray
+type InstanceNetworkGetAclAttributeType = *[]string
+type InstanceNetworkGetAclArgType = []string
+type InstanceNetworkGetAclRetType = []string
+
+func getInstanceNetworkGetAclAttributeTypeOk(arg InstanceNetworkGetAclAttributeType) (ret InstanceNetworkGetAclRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceNetworkGetAclAttributeType(arg *InstanceNetworkGetAclAttributeType, val InstanceNetworkGetAclRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for instanceAddress
+*/
+
+// isNotNullableString
+type InstanceNetworkGetInstanceAddressAttributeType = *string
+
+func getInstanceNetworkGetInstanceAddressAttributeTypeOk(arg InstanceNetworkGetInstanceAddressAttributeType) (ret InstanceNetworkGetInstanceAddressRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceNetworkGetInstanceAddressAttributeType(arg *InstanceNetworkGetInstanceAddressAttributeType, val InstanceNetworkGetInstanceAddressRetType) {
+ *arg = &val
+}
+
+type InstanceNetworkGetInstanceAddressArgType = string
+type InstanceNetworkGetInstanceAddressRetType = string
+
+/*
+ types and functions for routerAddress
+*/
+
+// isNotNullableString
+type InstanceNetworkGetRouterAddressAttributeType = *string
+
+func getInstanceNetworkGetRouterAddressAttributeTypeOk(arg InstanceNetworkGetRouterAddressAttributeType) (ret InstanceNetworkGetRouterAddressRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setInstanceNetworkGetRouterAddressAttributeType(arg *InstanceNetworkGetRouterAddressAttributeType, val InstanceNetworkGetRouterAddressRetType) {
+ *arg = &val
+}
+
+type InstanceNetworkGetRouterAddressArgType = string
+type InstanceNetworkGetRouterAddressRetType = string
+
+// InstanceNetwork The access configuration of the instance
+type InstanceNetwork struct {
+ AccessScope InstanceNetworkGetAccessScopeAttributeType `json:"accessScope,omitempty"`
+ // List of IPV4 cidr.
+ Acl InstanceNetworkGetAclAttributeType `json:"acl,omitempty"`
+ InstanceAddress InstanceNetworkGetInstanceAddressAttributeType `json:"instanceAddress,omitempty"`
+ RouterAddress InstanceNetworkGetRouterAddressAttributeType `json:"routerAddress,omitempty"`
+}
+
+// NewInstanceNetwork instantiates a new InstanceNetwork object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewInstanceNetwork() *InstanceNetwork {
+ this := InstanceNetwork{}
+ return &this
+}
+
+// NewInstanceNetworkWithDefaults instantiates a new InstanceNetwork object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewInstanceNetworkWithDefaults() *InstanceNetwork {
+ this := InstanceNetwork{}
+ var accessScope InstanceNetworkAccessScope = INSTANCENETWORKACCESSSCOPE_PUBLIC
+ this.AccessScope = &accessScope
+ return &this
+}
+
+// GetAccessScope returns the AccessScope field value if set, zero value otherwise.
+func (o *InstanceNetwork) GetAccessScope() (res InstanceNetworkGetAccessScopeRetType) {
+ res, _ = o.GetAccessScopeOk()
+ return
+}
+
+// GetAccessScopeOk returns a tuple with the AccessScope field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *InstanceNetwork) GetAccessScopeOk() (ret InstanceNetworkGetAccessScopeRetType, ok bool) {
+ return getInstanceNetworkGetAccessScopeAttributeTypeOk(o.AccessScope)
+}
+
+// HasAccessScope returns a boolean if a field has been set.
+func (o *InstanceNetwork) HasAccessScope() bool {
+ _, ok := o.GetAccessScopeOk()
+ return ok
+}
+
+// SetAccessScope gets a reference to the given InstanceNetworkAccessScope and assigns it to the AccessScope field.
+func (o *InstanceNetwork) SetAccessScope(v InstanceNetworkGetAccessScopeRetType) {
+ setInstanceNetworkGetAccessScopeAttributeType(&o.AccessScope, v)
+}
+
+// GetAcl returns the Acl field value if set, zero value otherwise.
+func (o *InstanceNetwork) GetAcl() (res InstanceNetworkGetAclRetType) {
+ res, _ = o.GetAclOk()
+ return
+}
+
+// GetAclOk returns a tuple with the Acl field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *InstanceNetwork) GetAclOk() (ret InstanceNetworkGetAclRetType, ok bool) {
+ return getInstanceNetworkGetAclAttributeTypeOk(o.Acl)
+}
+
+// HasAcl returns a boolean if a field has been set.
+func (o *InstanceNetwork) HasAcl() bool {
+ _, ok := o.GetAclOk()
+ return ok
+}
+
+// SetAcl gets a reference to the given []string and assigns it to the Acl field.
+func (o *InstanceNetwork) SetAcl(v InstanceNetworkGetAclRetType) {
+ setInstanceNetworkGetAclAttributeType(&o.Acl, v)
+}
+
+// GetInstanceAddress returns the InstanceAddress field value if set, zero value otherwise.
+func (o *InstanceNetwork) GetInstanceAddress() (res InstanceNetworkGetInstanceAddressRetType) {
+ res, _ = o.GetInstanceAddressOk()
+ return
+}
+
+// GetInstanceAddressOk returns a tuple with the InstanceAddress field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *InstanceNetwork) GetInstanceAddressOk() (ret InstanceNetworkGetInstanceAddressRetType, ok bool) {
+ return getInstanceNetworkGetInstanceAddressAttributeTypeOk(o.InstanceAddress)
+}
+
+// HasInstanceAddress returns a boolean if a field has been set.
+func (o *InstanceNetwork) HasInstanceAddress() bool {
+ _, ok := o.GetInstanceAddressOk()
+ return ok
+}
+
+// SetInstanceAddress gets a reference to the given string and assigns it to the InstanceAddress field.
+func (o *InstanceNetwork) SetInstanceAddress(v InstanceNetworkGetInstanceAddressRetType) {
+ setInstanceNetworkGetInstanceAddressAttributeType(&o.InstanceAddress, v)
+}
+
+// GetRouterAddress returns the RouterAddress field value if set, zero value otherwise.
+func (o *InstanceNetwork) GetRouterAddress() (res InstanceNetworkGetRouterAddressRetType) {
+ res, _ = o.GetRouterAddressOk()
+ return
+}
+
+// GetRouterAddressOk returns a tuple with the RouterAddress field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *InstanceNetwork) GetRouterAddressOk() (ret InstanceNetworkGetRouterAddressRetType, ok bool) {
+ return getInstanceNetworkGetRouterAddressAttributeTypeOk(o.RouterAddress)
+}
+
+// HasRouterAddress returns a boolean if a field has been set.
+func (o *InstanceNetwork) HasRouterAddress() bool {
+ _, ok := o.GetRouterAddressOk()
+ return ok
+}
+
+// SetRouterAddress gets a reference to the given string and assigns it to the RouterAddress field.
+func (o *InstanceNetwork) SetRouterAddress(v InstanceNetworkGetRouterAddressRetType) {
+ setInstanceNetworkGetRouterAddressAttributeType(&o.RouterAddress, v)
+}
+
+func (o InstanceNetwork) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getInstanceNetworkGetAccessScopeAttributeTypeOk(o.AccessScope); ok {
+ toSerialize["AccessScope"] = val
+ }
+ if val, ok := getInstanceNetworkGetAclAttributeTypeOk(o.Acl); ok {
+ toSerialize["Acl"] = val
+ }
+ if val, ok := getInstanceNetworkGetInstanceAddressAttributeTypeOk(o.InstanceAddress); ok {
+ toSerialize["InstanceAddress"] = val
+ }
+ if val, ok := getInstanceNetworkGetRouterAddressAttributeTypeOk(o.RouterAddress); ok {
+ toSerialize["RouterAddress"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableInstanceNetwork struct {
+ value *InstanceNetwork
+ isSet bool
+}
+
+func (v NullableInstanceNetwork) Get() *InstanceNetwork {
+ return v.value
+}
+
+func (v *NullableInstanceNetwork) Set(val *InstanceNetwork) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInstanceNetwork) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInstanceNetwork) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInstanceNetwork(val *InstanceNetwork) *NullableInstanceNetwork {
+ return &NullableInstanceNetwork{value: val, isSet: true}
+}
+
+func (v NullableInstanceNetwork) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInstanceNetwork) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_instance_network_access_scope.go b/pkg/sqlserverflexalpha/model_instance_network_access_scope.go
new file mode 100644
index 00000000..c8357883
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_network_access_scope.go
@@ -0,0 +1,115 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// InstanceNetworkAccessScope The network access scope of the instance ⚠️ **Note:** This feature is in private preview. Supplying this object is only permitted for enabled accounts. If your account does not have access, the request will be rejected.
+type InstanceNetworkAccessScope string
+
+// List of instance.network.accessScope
+const (
+ INSTANCENETWORKACCESSSCOPE_PUBLIC InstanceNetworkAccessScope = "PUBLIC"
+ INSTANCENETWORKACCESSSCOPE_SNA InstanceNetworkAccessScope = "SNA"
+)
+
+// All allowed values of InstanceNetworkAccessScope enum
+var AllowedInstanceNetworkAccessScopeEnumValues = []InstanceNetworkAccessScope{
+ "PUBLIC",
+ "SNA",
+}
+
+func (v *InstanceNetworkAccessScope) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := InstanceNetworkAccessScope(value)
+ for _, existing := range AllowedInstanceNetworkAccessScopeEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid InstanceNetworkAccessScope", value)
+}
+
+// NewInstanceNetworkAccessScopeFromValue returns a pointer to a valid InstanceNetworkAccessScope
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewInstanceNetworkAccessScopeFromValue(v string) (*InstanceNetworkAccessScope, error) {
+ ev := InstanceNetworkAccessScope(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for InstanceNetworkAccessScope: valid values are %v", v, AllowedInstanceNetworkAccessScopeEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v InstanceNetworkAccessScope) IsValid() bool {
+ for _, existing := range AllowedInstanceNetworkAccessScopeEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to instance.network.accessScope value
+func (v InstanceNetworkAccessScope) Ptr() *InstanceNetworkAccessScope {
+ return &v
+}
+
+type NullableInstanceNetworkAccessScope struct {
+ value *InstanceNetworkAccessScope
+ isSet bool
+}
+
+func (v NullableInstanceNetworkAccessScope) Get() *InstanceNetworkAccessScope {
+ return v.value
+}
+
+func (v *NullableInstanceNetworkAccessScope) Set(val *InstanceNetworkAccessScope) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInstanceNetworkAccessScope) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInstanceNetworkAccessScope) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInstanceNetworkAccessScope(val *InstanceNetworkAccessScope) *NullableInstanceNetworkAccessScope {
+ return &NullableInstanceNetworkAccessScope{value: val, isSet: true}
+}
+
+func (v NullableInstanceNetworkAccessScope) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInstanceNetworkAccessScope) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_instance_network_access_scope_test.go b/pkg/sqlserverflexalpha/model_instance_network_access_scope_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_network_access_scope_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_instance_network_test.go b/pkg/sqlserverflexalpha/model_instance_network_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_network_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_instance_sort.go b/pkg/sqlserverflexalpha/model_instance_sort.go
new file mode 100644
index 00000000..74dde23d
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_sort.go
@@ -0,0 +1,131 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// InstanceSort the model 'InstanceSort'
+type InstanceSort string
+
+// List of instance.sort
+const (
+ INSTANCESORT_INDEX_DESC InstanceSort = "index.desc"
+ INSTANCESORT_INDEX_ASC InstanceSort = "index.asc"
+ INSTANCESORT_ID_DESC InstanceSort = "id.desc"
+ INSTANCESORT_ID_ASC InstanceSort = "id.asc"
+ INSTANCESORT_IS_DELETABLE_DESC InstanceSort = "is_deletable.desc"
+ INSTANCESORT_IS_DELETABLE_ASC InstanceSort = "is_deletable.asc"
+ INSTANCESORT_NAME_ASC InstanceSort = "name.asc"
+ INSTANCESORT_NAME_DESC InstanceSort = "name.desc"
+ INSTANCESORT_STATUS_ASC InstanceSort = "status.asc"
+ INSTANCESORT_STATUS_DESC InstanceSort = "status.desc"
+)
+
+// All allowed values of InstanceSort enum
+var AllowedInstanceSortEnumValues = []InstanceSort{
+ "index.desc",
+ "index.asc",
+ "id.desc",
+ "id.asc",
+ "is_deletable.desc",
+ "is_deletable.asc",
+ "name.asc",
+ "name.desc",
+ "status.asc",
+ "status.desc",
+}
+
+func (v *InstanceSort) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := InstanceSort(value)
+ for _, existing := range AllowedInstanceSortEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid InstanceSort", value)
+}
+
+// NewInstanceSortFromValue returns a pointer to a valid InstanceSort
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewInstanceSortFromValue(v string) (*InstanceSort, error) {
+ ev := InstanceSort(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for InstanceSort: valid values are %v", v, AllowedInstanceSortEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v InstanceSort) IsValid() bool {
+ for _, existing := range AllowedInstanceSortEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to instance.sort value
+func (v InstanceSort) Ptr() *InstanceSort {
+ return &v
+}
+
+type NullableInstanceSort struct {
+ value *InstanceSort
+ isSet bool
+}
+
+func (v NullableInstanceSort) Get() *InstanceSort {
+ return v.value
+}
+
+func (v *NullableInstanceSort) Set(val *InstanceSort) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInstanceSort) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInstanceSort) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInstanceSort(val *InstanceSort) *NullableInstanceSort {
+ return &NullableInstanceSort{value: val, isSet: true}
+}
+
+func (v NullableInstanceSort) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInstanceSort) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_instance_sort_test.go b/pkg/sqlserverflexalpha/model_instance_sort_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_sort_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_instance_version.go b/pkg/sqlserverflexalpha/model_instance_version.go
new file mode 100644
index 00000000..82276c45
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_version.go
@@ -0,0 +1,113 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// InstanceVersion The sqlserver version used for the instance.
+type InstanceVersion string
+
+// List of instance.version
+const (
+ INSTANCEVERSION__2022 InstanceVersion = "2022"
+)
+
+// All allowed values of InstanceVersion enum
+var AllowedInstanceVersionEnumValues = []InstanceVersion{
+ "2022",
+}
+
+func (v *InstanceVersion) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := InstanceVersion(value)
+ for _, existing := range AllowedInstanceVersionEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid InstanceVersion", value)
+}
+
+// NewInstanceVersionFromValue returns a pointer to a valid InstanceVersion
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewInstanceVersionFromValue(v string) (*InstanceVersion, error) {
+ ev := InstanceVersion(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for InstanceVersion: valid values are %v", v, AllowedInstanceVersionEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v InstanceVersion) IsValid() bool {
+ for _, existing := range AllowedInstanceVersionEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to instance.version value
+func (v InstanceVersion) Ptr() *InstanceVersion {
+ return &v
+}
+
+type NullableInstanceVersion struct {
+ value *InstanceVersion
+ isSet bool
+}
+
+func (v NullableInstanceVersion) Get() *InstanceVersion {
+ return v.value
+}
+
+func (v *NullableInstanceVersion) Set(val *InstanceVersion) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInstanceVersion) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInstanceVersion) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInstanceVersion(val *InstanceVersion) *NullableInstanceVersion {
+ return &NullableInstanceVersion{value: val, isSet: true}
+}
+
+func (v NullableInstanceVersion) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInstanceVersion) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_instance_version_opt.go b/pkg/sqlserverflexalpha/model_instance_version_opt.go
new file mode 100644
index 00000000..13c1efc9
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_version_opt.go
@@ -0,0 +1,113 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// InstanceVersionOpt the model 'InstanceVersionOpt'
+type InstanceVersionOpt string
+
+// List of instance.version.opt
+const (
+ INSTANCEVERSIONOPT__2022 InstanceVersionOpt = "2022"
+)
+
+// All allowed values of InstanceVersionOpt enum
+var AllowedInstanceVersionOptEnumValues = []InstanceVersionOpt{
+ "2022",
+}
+
+func (v *InstanceVersionOpt) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := InstanceVersionOpt(value)
+ for _, existing := range AllowedInstanceVersionOptEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid InstanceVersionOpt", value)
+}
+
+// NewInstanceVersionOptFromValue returns a pointer to a valid InstanceVersionOpt
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewInstanceVersionOptFromValue(v string) (*InstanceVersionOpt, error) {
+ ev := InstanceVersionOpt(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for InstanceVersionOpt: valid values are %v", v, AllowedInstanceVersionOptEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v InstanceVersionOpt) IsValid() bool {
+ for _, existing := range AllowedInstanceVersionOptEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to instance.version.opt value
+func (v InstanceVersionOpt) Ptr() *InstanceVersionOpt {
+ return &v
+}
+
+type NullableInstanceVersionOpt struct {
+ value *InstanceVersionOpt
+ isSet bool
+}
+
+func (v NullableInstanceVersionOpt) Get() *InstanceVersionOpt {
+ return v.value
+}
+
+func (v *NullableInstanceVersionOpt) Set(val *InstanceVersionOpt) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInstanceVersionOpt) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInstanceVersionOpt) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInstanceVersionOpt(val *InstanceVersionOpt) *NullableInstanceVersionOpt {
+ return &NullableInstanceVersionOpt{value: val, isSet: true}
+}
+
+func (v NullableInstanceVersionOpt) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInstanceVersionOpt) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_instance_version_opt_test.go b/pkg/sqlserverflexalpha/model_instance_version_opt_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_version_opt_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_instance_version_test.go b/pkg/sqlserverflexalpha/model_instance_version_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_instance_version_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_backup.go b/pkg/sqlserverflexalpha/model_list_backup.go
new file mode 100644
index 00000000..70140b92
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_backup.go
@@ -0,0 +1,436 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListBackup type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListBackup{}
+
+/*
+ types and functions for completionTime
+*/
+
+//// isAny
+//type ListBackupGetCompletionTimeAttributeType = any
+//type ListBackupGetCompletionTimeArgType = any
+//type ListBackupGetCompletionTimeRetType = any
+//
+//func getListBackupGetCompletionTimeAttributeTypeOk(arg ListBackupGetCompletionTimeAttributeType) (ret ListBackupGetCompletionTimeRetType, ok bool) {
+// if arg == nil {
+// return ret, false
+// }
+// return *arg, true
+//}
+//
+//func setListBackupGetCompletionTimeAttributeType(arg *ListBackupGetCompletionTimeAttributeType, val ListBackupGetCompletionTimeRetType) {
+// *arg = &val
+//}
+
+// isModel
+type ListBackupGetCompletionTimeAttributeType = *string
+type ListBackupGetCompletionTimeArgType = string
+type ListBackupGetCompletionTimeRetType = string
+
+func getListBackupGetCompletionTimeAttributeTypeOk(arg ListBackupGetCompletionTimeAttributeType) (ret ListBackupGetCompletionTimeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupGetCompletionTimeAttributeType(arg *ListBackupGetCompletionTimeAttributeType, val ListBackupGetCompletionTimeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for id
+*/
+
+// isAny
+//type ListBackupGetIdAttributeType = any
+//type ListBackupGetIdArgType = any
+//type ListBackupGetIdRetType = any
+//
+//func getListBackupGetIdAttributeTypeOk(arg ListBackupGetIdAttributeType) (ret ListBackupGetIdRetType, ok bool) {
+// if arg == nil {
+// return ret, false
+// }
+// return *arg, true
+//}
+//
+//func setListBackupGetIdAttributeType(arg *ListBackupGetIdAttributeType, val ListBackupGetIdRetType) {
+// *arg = &val
+//}
+
+// isModel
+type ListBackupGetIdAttributeType = *int64
+type ListBackupGetIdArgType = int64
+type ListBackupGetIdRetType = int64
+
+func getListBackupGetIdAttributeTypeOk(arg ListBackupGetIdAttributeType) (ret ListBackupGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupGetIdAttributeType(arg *ListBackupGetIdAttributeType, val ListBackupGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+//// isAny
+//type ListBackupGetNameAttributeType = any
+//type ListBackupGetNameArgType = any
+//type ListBackupGetNameRetType = any
+//
+//func getListBackupGetNameAttributeTypeOk(arg ListBackupGetNameAttributeType) (ret ListBackupGetNameRetType, ok bool) {
+// if arg == nil {
+// return ret, false
+// }
+// return *arg, true
+//}
+//
+//func setListBackupGetNameAttributeType(arg *ListBackupGetNameAttributeType, val ListBackupGetNameRetType) {
+// *arg = &val
+//}
+
+// isModel
+type ListBackupGetNameAttributeType = *string
+type ListBackupGetNameArgType = string
+type ListBackupGetNameRetType = string
+
+func getListBackupGetNameAttributeTypeOk(arg ListBackupGetNameAttributeType) (ret ListBackupGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupGetNameAttributeType(arg *ListBackupGetNameAttributeType, val ListBackupGetNameRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for retainedUntil
+*/
+
+//// isAny
+//type ListBackupGetRetainedUntilAttributeType = any
+//type ListBackupGetRetainedUntilArgType = any
+//type ListBackupGetRetainedUntilRetType = any
+//
+//func getListBackupGetRetainedUntilAttributeTypeOk(arg ListBackupGetRetainedUntilAttributeType) (ret ListBackupGetRetainedUntilRetType, ok bool) {
+// if arg == nil {
+// return ret, false
+// }
+// return *arg, true
+//}
+//
+//func setListBackupGetRetainedUntilAttributeType(arg *ListBackupGetRetainedUntilAttributeType, val ListBackupGetRetainedUntilRetType) {
+// *arg = &val
+//}
+
+// isModel
+type ListBackupGetRetainedUntilAttributeType = *string
+type ListBackupGetRetainedUntilArgType = string
+type ListBackupGetRetainedUntilRetType = string
+
+func getListBackupGetRetainedUntilAttributeTypeOk(arg ListBackupGetRetainedUntilAttributeType) (ret ListBackupGetRetainedUntilRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupGetRetainedUntilAttributeType(arg *ListBackupGetRetainedUntilAttributeType, val ListBackupGetRetainedUntilRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for size
+*/
+
+//// isAny
+//type ListBackupGetSizeAttributeType = any
+//type ListBackupGetSizeArgType = any
+//type ListBackupGetSizeRetType = any
+//
+//func getListBackupGetSizeAttributeTypeOk(arg ListBackupGetSizeAttributeType) (ret ListBackupGetSizeRetType, ok bool) {
+// if arg == nil {
+// return ret, false
+// }
+// return *arg, true
+//}
+//
+//func setListBackupGetSizeAttributeType(arg *ListBackupGetSizeAttributeType, val ListBackupGetSizeRetType) {
+// *arg = &val
+//}
+
+// isModel
+type ListBackupGetSizeAttributeType = *int64
+type ListBackupGetSizeArgType = int64
+type ListBackupGetSizeRetType = int64
+
+func getListBackupGetSizeAttributeTypeOk(arg ListBackupGetSizeAttributeType) (ret ListBackupGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupGetSizeAttributeType(arg *ListBackupGetSizeAttributeType, val ListBackupGetSizeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for type
+*/
+
+//// isAny
+//type ListBackupGetTypeAttributeType = any
+//type ListBackupGetTypeArgType = any
+//type ListBackupGetTypeRetType = any
+//
+//func getListBackupGetTypeAttributeTypeOk(arg ListBackupGetTypeAttributeType) (ret ListBackupGetTypeRetType, ok bool) {
+// if arg == nil {
+// return ret, false
+// }
+// return *arg, true
+//}
+//
+//func setListBackupGetTypeAttributeType(arg *ListBackupGetTypeAttributeType, val ListBackupGetTypeRetType) {
+// *arg = &val
+//}
+
+// isModel
+type ListBackupGetTypeAttributeType = *string
+type ListBackupGetTypeArgType = string
+type ListBackupGetTypeRetType = string
+
+func getListBackupGetTypeAttributeTypeOk(arg ListBackupGetTypeAttributeType) (ret ListBackupGetTypeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupGetTypeAttributeType(arg *ListBackupGetTypeAttributeType, val ListBackupGetTypeRetType) {
+ *arg = &val
+}
+
+// ListBackup struct for ListBackup
+type ListBackup struct {
+ // REQUIRED
+ CompletionTime ListBackupGetCompletionTimeAttributeType `json:"completionTime" required:"true"`
+ // REQUIRED
+ Id ListBackupGetIdAttributeType `json:"id" required:"true"`
+ // REQUIRED
+ Name ListBackupGetNameAttributeType `json:"name" required:"true"`
+ // REQUIRED
+ RetainedUntil ListBackupGetRetainedUntilAttributeType `json:"retainedUntil" required:"true"`
+ // REQUIRED
+ Size ListBackupGetSizeAttributeType `json:"size" required:"true"`
+ // REQUIRED
+ Type ListBackupGetTypeAttributeType `json:"type" required:"true"`
+}
+
+type _ListBackup ListBackup
+
+// NewListBackup instantiates a new ListBackup object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListBackup(completionTime ListBackupGetCompletionTimeArgType, id ListBackupGetIdArgType, name ListBackupGetNameArgType, retainedUntil ListBackupGetRetainedUntilArgType, size ListBackupGetSizeArgType, types ListBackupGetTypeArgType) *ListBackup {
+ this := ListBackup{}
+ setListBackupGetCompletionTimeAttributeType(&this.CompletionTime, completionTime)
+ setListBackupGetIdAttributeType(&this.Id, id)
+ setListBackupGetNameAttributeType(&this.Name, name)
+ setListBackupGetRetainedUntilAttributeType(&this.RetainedUntil, retainedUntil)
+ setListBackupGetSizeAttributeType(&this.Size, size)
+ setListBackupGetTypeAttributeType(&this.Type, types)
+ return &this
+}
+
+// NewListBackupWithDefaults instantiates a new ListBackup object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListBackupWithDefaults() *ListBackup {
+ this := ListBackup{}
+ return &this
+}
+
+// GetCompletionTime returns the CompletionTime field value
+func (o *ListBackup) GetCompletionTime() (ret ListBackupGetCompletionTimeRetType) {
+ ret, _ = o.GetCompletionTimeOk()
+ return ret
+}
+
+// GetCompletionTimeOk returns a tuple with the CompletionTime field value
+// and a boolean to check if the value has been set.
+func (o *ListBackup) GetCompletionTimeOk() (ret ListBackupGetCompletionTimeRetType, ok bool) {
+ return getListBackupGetCompletionTimeAttributeTypeOk(o.CompletionTime)
+}
+
+// SetCompletionTime sets field value
+func (o *ListBackup) SetCompletionTime(v ListBackupGetCompletionTimeRetType) {
+ setListBackupGetCompletionTimeAttributeType(&o.CompletionTime, v)
+}
+
+// GetId returns the Id field value
+func (o *ListBackup) GetId() (ret ListBackupGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *ListBackup) GetIdOk() (ret ListBackupGetIdRetType, ok bool) {
+ return getListBackupGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *ListBackup) SetId(v ListBackupGetIdRetType) {
+ setListBackupGetIdAttributeType(&o.Id, v)
+}
+
+// GetName returns the Name field value
+func (o *ListBackup) GetName() (ret ListBackupGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *ListBackup) GetNameOk() (ret ListBackupGetNameRetType, ok bool) {
+ return getListBackupGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *ListBackup) SetName(v ListBackupGetNameRetType) {
+ setListBackupGetNameAttributeType(&o.Name, v)
+}
+
+// GetRetainedUntil returns the RetainedUntil field value
+func (o *ListBackup) GetRetainedUntil() (ret ListBackupGetRetainedUntilRetType) {
+ ret, _ = o.GetRetainedUntilOk()
+ return ret
+}
+
+// GetRetainedUntilOk returns a tuple with the RetainedUntil field value
+// and a boolean to check if the value has been set.
+func (o *ListBackup) GetRetainedUntilOk() (ret ListBackupGetRetainedUntilRetType, ok bool) {
+ return getListBackupGetRetainedUntilAttributeTypeOk(o.RetainedUntil)
+}
+
+// SetRetainedUntil sets field value
+func (o *ListBackup) SetRetainedUntil(v ListBackupGetRetainedUntilRetType) {
+ setListBackupGetRetainedUntilAttributeType(&o.RetainedUntil, v)
+}
+
+// GetSize returns the Size field value
+func (o *ListBackup) GetSize() (ret ListBackupGetSizeRetType) {
+ ret, _ = o.GetSizeOk()
+ return ret
+}
+
+// GetSizeOk returns a tuple with the Size field value
+// and a boolean to check if the value has been set.
+func (o *ListBackup) GetSizeOk() (ret ListBackupGetSizeRetType, ok bool) {
+ return getListBackupGetSizeAttributeTypeOk(o.Size)
+}
+
+// SetSize sets field value
+func (o *ListBackup) SetSize(v ListBackupGetSizeRetType) {
+ setListBackupGetSizeAttributeType(&o.Size, v)
+}
+
+// GetType returns the Type field value
+func (o *ListBackup) GetType() (ret ListBackupGetTypeRetType) {
+ ret, _ = o.GetTypeOk()
+ return ret
+}
+
+// GetTypeOk returns a tuple with the Type field value
+// and a boolean to check if the value has been set.
+func (o *ListBackup) GetTypeOk() (ret ListBackupGetTypeRetType, ok bool) {
+ return getListBackupGetTypeAttributeTypeOk(o.Type)
+}
+
+// SetType sets field value
+func (o *ListBackup) SetType(v ListBackupGetTypeRetType) {
+ setListBackupGetTypeAttributeType(&o.Type, v)
+}
+
+func (o ListBackup) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListBackupGetCompletionTimeAttributeTypeOk(o.CompletionTime); ok {
+ toSerialize["CompletionTime"] = val
+ }
+ if val, ok := getListBackupGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getListBackupGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getListBackupGetRetainedUntilAttributeTypeOk(o.RetainedUntil); ok {
+ toSerialize["RetainedUntil"] = val
+ }
+ if val, ok := getListBackupGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ if val, ok := getListBackupGetTypeAttributeTypeOk(o.Type); ok {
+ toSerialize["Type"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListBackup struct {
+ value *ListBackup
+ isSet bool
+}
+
+func (v NullableListBackup) Get() *ListBackup {
+ return v.value
+}
+
+func (v *NullableListBackup) Set(val *ListBackup) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListBackup) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListBackup) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListBackup(val *ListBackup) *NullableListBackup {
+ return &NullableListBackup{value: val, isSet: true}
+}
+
+func (v NullableListBackup) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListBackup) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_backup_response.go b/pkg/sqlserverflexalpha/model_list_backup_response.go
new file mode 100644
index 00000000..71be5729
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_backup_response.go
@@ -0,0 +1,169 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListBackupResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListBackupResponse{}
+
+/*
+ types and functions for backups
+*/
+
+// isArray
+type ListBackupResponseGetBackupsAttributeType = *[]ListBackupsResponse
+type ListBackupResponseGetBackupsArgType = []ListBackupsResponse
+type ListBackupResponseGetBackupsRetType = []ListBackupsResponse
+
+func getListBackupResponseGetBackupsAttributeTypeOk(arg ListBackupResponseGetBackupsAttributeType) (ret ListBackupResponseGetBackupsRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupResponseGetBackupsAttributeType(arg *ListBackupResponseGetBackupsAttributeType, val ListBackupResponseGetBackupsRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for pagination
+*/
+
+// isModel
+type ListBackupResponseGetPaginationAttributeType = *Pagination
+type ListBackupResponseGetPaginationArgType = Pagination
+type ListBackupResponseGetPaginationRetType = Pagination
+
+func getListBackupResponseGetPaginationAttributeTypeOk(arg ListBackupResponseGetPaginationAttributeType) (ret ListBackupResponseGetPaginationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupResponseGetPaginationAttributeType(arg *ListBackupResponseGetPaginationAttributeType, val ListBackupResponseGetPaginationRetType) {
+ *arg = &val
+}
+
+// ListBackupResponse struct for ListBackupResponse
+type ListBackupResponse struct {
+ // The list containing the information about the backups.
+ // REQUIRED
+ Backups ListBackupResponseGetBackupsAttributeType `json:"backups" required:"true"`
+ // REQUIRED
+ Pagination ListBackupResponseGetPaginationAttributeType `json:"pagination" required:"true"`
+}
+
+type _ListBackupResponse ListBackupResponse
+
+// NewListBackupResponse instantiates a new ListBackupResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListBackupResponse(backups ListBackupResponseGetBackupsArgType, pagination ListBackupResponseGetPaginationArgType) *ListBackupResponse {
+ this := ListBackupResponse{}
+ setListBackupResponseGetBackupsAttributeType(&this.Backups, backups)
+ setListBackupResponseGetPaginationAttributeType(&this.Pagination, pagination)
+ return &this
+}
+
+// NewListBackupResponseWithDefaults instantiates a new ListBackupResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListBackupResponseWithDefaults() *ListBackupResponse {
+ this := ListBackupResponse{}
+ return &this
+}
+
+// GetBackups returns the Backups field value
+func (o *ListBackupResponse) GetBackups() (ret ListBackupResponseGetBackupsRetType) {
+ ret, _ = o.GetBackupsOk()
+ return ret
+}
+
+// GetBackupsOk returns a tuple with the Backups field value
+// and a boolean to check if the value has been set.
+func (o *ListBackupResponse) GetBackupsOk() (ret ListBackupResponseGetBackupsRetType, ok bool) {
+ return getListBackupResponseGetBackupsAttributeTypeOk(o.Backups)
+}
+
+// SetBackups sets field value
+func (o *ListBackupResponse) SetBackups(v ListBackupResponseGetBackupsRetType) {
+ setListBackupResponseGetBackupsAttributeType(&o.Backups, v)
+}
+
+// GetPagination returns the Pagination field value
+func (o *ListBackupResponse) GetPagination() (ret ListBackupResponseGetPaginationRetType) {
+ ret, _ = o.GetPaginationOk()
+ return ret
+}
+
+// GetPaginationOk returns a tuple with the Pagination field value
+// and a boolean to check if the value has been set.
+func (o *ListBackupResponse) GetPaginationOk() (ret ListBackupResponseGetPaginationRetType, ok bool) {
+ return getListBackupResponseGetPaginationAttributeTypeOk(o.Pagination)
+}
+
+// SetPagination sets field value
+func (o *ListBackupResponse) SetPagination(v ListBackupResponseGetPaginationRetType) {
+ setListBackupResponseGetPaginationAttributeType(&o.Pagination, v)
+}
+
+func (o ListBackupResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListBackupResponseGetBackupsAttributeTypeOk(o.Backups); ok {
+ toSerialize["Backups"] = val
+ }
+ if val, ok := getListBackupResponseGetPaginationAttributeTypeOk(o.Pagination); ok {
+ toSerialize["Pagination"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListBackupResponse struct {
+ value *ListBackupResponse
+ isSet bool
+}
+
+func (v NullableListBackupResponse) Get() *ListBackupResponse {
+ return v.value
+}
+
+func (v *NullableListBackupResponse) Set(val *ListBackupResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListBackupResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListBackupResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListBackupResponse(val *ListBackupResponse) *NullableListBackupResponse {
+ return &NullableListBackupResponse{value: val, isSet: true}
+}
+
+func (v NullableListBackupResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListBackupResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_backup_response_test.go b/pkg/sqlserverflexalpha/model_list_backup_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_backup_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_backup_test.go b/pkg/sqlserverflexalpha/model_list_backup_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_backup_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_backups_response.go b/pkg/sqlserverflexalpha/model_list_backups_response.go
new file mode 100644
index 00000000..9ca04238
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_backups_response.go
@@ -0,0 +1,171 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListBackupsResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListBackupsResponse{}
+
+/*
+ types and functions for backups
+*/
+
+// isArray
+type ListBackupsResponseGetBackupsAttributeType = *[]ListBackup
+type ListBackupsResponseGetBackupsArgType = []ListBackup
+type ListBackupsResponseGetBackupsRetType = []ListBackup
+
+func getListBackupsResponseGetBackupsAttributeTypeOk(arg ListBackupsResponseGetBackupsAttributeType) (ret ListBackupsResponseGetBackupsRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupsResponseGetBackupsAttributeType(arg *ListBackupsResponseGetBackupsAttributeType, val ListBackupsResponseGetBackupsRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for databaseName
+*/
+
+// isNotNullableString
+type ListBackupsResponseGetDatabaseNameAttributeType = *string
+
+func getListBackupsResponseGetDatabaseNameAttributeTypeOk(arg ListBackupsResponseGetDatabaseNameAttributeType) (ret ListBackupsResponseGetDatabaseNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListBackupsResponseGetDatabaseNameAttributeType(arg *ListBackupsResponseGetDatabaseNameAttributeType, val ListBackupsResponseGetDatabaseNameRetType) {
+ *arg = &val
+}
+
+type ListBackupsResponseGetDatabaseNameArgType = string
+type ListBackupsResponseGetDatabaseNameRetType = string
+
+// ListBackupsResponse struct for ListBackupsResponse
+type ListBackupsResponse struct {
+ // List of the backups beloning to that database
+ // REQUIRED
+ Backups ListBackupsResponseGetBackupsAttributeType `json:"backups" required:"true" validate:"required,dive"`
+ // Name of the database the backups belong to
+ // REQUIRED
+ DatabaseName ListBackupsResponseGetDatabaseNameAttributeType `json:"databaseName" required:"true" validate:"required,databaseName"`
+}
+
+type _ListBackupsResponse ListBackupsResponse
+
+// NewListBackupsResponse instantiates a new ListBackupsResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListBackupsResponse(backups ListBackupsResponseGetBackupsArgType, databaseName ListBackupsResponseGetDatabaseNameArgType) *ListBackupsResponse {
+ this := ListBackupsResponse{}
+ setListBackupsResponseGetBackupsAttributeType(&this.Backups, backups)
+ setListBackupsResponseGetDatabaseNameAttributeType(&this.DatabaseName, databaseName)
+ return &this
+}
+
+// NewListBackupsResponseWithDefaults instantiates a new ListBackupsResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListBackupsResponseWithDefaults() *ListBackupsResponse {
+ this := ListBackupsResponse{}
+ return &this
+}
+
+// GetBackups returns the Backups field value
+func (o *ListBackupsResponse) GetBackups() (ret ListBackupsResponseGetBackupsRetType) {
+ ret, _ = o.GetBackupsOk()
+ return ret
+}
+
+// GetBackupsOk returns a tuple with the Backups field value
+// and a boolean to check if the value has been set.
+func (o *ListBackupsResponse) GetBackupsOk() (ret ListBackupsResponseGetBackupsRetType, ok bool) {
+ return getListBackupsResponseGetBackupsAttributeTypeOk(o.Backups)
+}
+
+// SetBackups sets field value
+func (o *ListBackupsResponse) SetBackups(v ListBackupsResponseGetBackupsRetType) {
+ setListBackupsResponseGetBackupsAttributeType(&o.Backups, v)
+}
+
+// GetDatabaseName returns the DatabaseName field value
+func (o *ListBackupsResponse) GetDatabaseName() (ret ListBackupsResponseGetDatabaseNameRetType) {
+ ret, _ = o.GetDatabaseNameOk()
+ return ret
+}
+
+// GetDatabaseNameOk returns a tuple with the DatabaseName field value
+// and a boolean to check if the value has been set.
+func (o *ListBackupsResponse) GetDatabaseNameOk() (ret ListBackupsResponseGetDatabaseNameRetType, ok bool) {
+ return getListBackupsResponseGetDatabaseNameAttributeTypeOk(o.DatabaseName)
+}
+
+// SetDatabaseName sets field value
+func (o *ListBackupsResponse) SetDatabaseName(v ListBackupsResponseGetDatabaseNameRetType) {
+ setListBackupsResponseGetDatabaseNameAttributeType(&o.DatabaseName, v)
+}
+
+func (o ListBackupsResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListBackupsResponseGetBackupsAttributeTypeOk(o.Backups); ok {
+ toSerialize["Backups"] = val
+ }
+ if val, ok := getListBackupsResponseGetDatabaseNameAttributeTypeOk(o.DatabaseName); ok {
+ toSerialize["DatabaseName"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListBackupsResponse struct {
+ value *ListBackupsResponse
+ isSet bool
+}
+
+func (v NullableListBackupsResponse) Get() *ListBackupsResponse {
+ return v.value
+}
+
+func (v *NullableListBackupsResponse) Set(val *ListBackupsResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListBackupsResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListBackupsResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListBackupsResponse(val *ListBackupsResponse) *NullableListBackupsResponse {
+ return &NullableListBackupsResponse{value: val, isSet: true}
+}
+
+func (v NullableListBackupsResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListBackupsResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_backups_response_test.go b/pkg/sqlserverflexalpha/model_list_backups_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_backups_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_compatibility_response.go b/pkg/sqlserverflexalpha/model_list_compatibility_response.go
new file mode 100644
index 00000000..84c969f1
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_compatibility_response.go
@@ -0,0 +1,126 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListCompatibilityResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListCompatibilityResponse{}
+
+/*
+ types and functions for compatibilities
+*/
+
+// isArray
+type ListCompatibilityResponseGetCompatibilitiesAttributeType = *[]DatabaseGetcompatibility
+type ListCompatibilityResponseGetCompatibilitiesArgType = []DatabaseGetcompatibility
+type ListCompatibilityResponseGetCompatibilitiesRetType = []DatabaseGetcompatibility
+
+func getListCompatibilityResponseGetCompatibilitiesAttributeTypeOk(arg ListCompatibilityResponseGetCompatibilitiesAttributeType) (ret ListCompatibilityResponseGetCompatibilitiesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListCompatibilityResponseGetCompatibilitiesAttributeType(arg *ListCompatibilityResponseGetCompatibilitiesAttributeType, val ListCompatibilityResponseGetCompatibilitiesRetType) {
+ *arg = &val
+}
+
+// ListCompatibilityResponse struct for ListCompatibilityResponse
+type ListCompatibilityResponse struct {
+ // List of compatibilities available for a d
+ // REQUIRED
+ Compatibilities ListCompatibilityResponseGetCompatibilitiesAttributeType `json:"compatibilities" required:"true"`
+}
+
+type _ListCompatibilityResponse ListCompatibilityResponse
+
+// NewListCompatibilityResponse instantiates a new ListCompatibilityResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListCompatibilityResponse(compatibilities ListCompatibilityResponseGetCompatibilitiesArgType) *ListCompatibilityResponse {
+ this := ListCompatibilityResponse{}
+ setListCompatibilityResponseGetCompatibilitiesAttributeType(&this.Compatibilities, compatibilities)
+ return &this
+}
+
+// NewListCompatibilityResponseWithDefaults instantiates a new ListCompatibilityResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListCompatibilityResponseWithDefaults() *ListCompatibilityResponse {
+ this := ListCompatibilityResponse{}
+ return &this
+}
+
+// GetCompatibilities returns the Compatibilities field value
+func (o *ListCompatibilityResponse) GetCompatibilities() (ret ListCompatibilityResponseGetCompatibilitiesRetType) {
+ ret, _ = o.GetCompatibilitiesOk()
+ return ret
+}
+
+// GetCompatibilitiesOk returns a tuple with the Compatibilities field value
+// and a boolean to check if the value has been set.
+func (o *ListCompatibilityResponse) GetCompatibilitiesOk() (ret ListCompatibilityResponseGetCompatibilitiesRetType, ok bool) {
+ return getListCompatibilityResponseGetCompatibilitiesAttributeTypeOk(o.Compatibilities)
+}
+
+// SetCompatibilities sets field value
+func (o *ListCompatibilityResponse) SetCompatibilities(v ListCompatibilityResponseGetCompatibilitiesRetType) {
+ setListCompatibilityResponseGetCompatibilitiesAttributeType(&o.Compatibilities, v)
+}
+
+func (o ListCompatibilityResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListCompatibilityResponseGetCompatibilitiesAttributeTypeOk(o.Compatibilities); ok {
+ toSerialize["Compatibilities"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListCompatibilityResponse struct {
+ value *ListCompatibilityResponse
+ isSet bool
+}
+
+func (v NullableListCompatibilityResponse) Get() *ListCompatibilityResponse {
+ return v.value
+}
+
+func (v *NullableListCompatibilityResponse) Set(val *ListCompatibilityResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListCompatibilityResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListCompatibilityResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListCompatibilityResponse(val *ListCompatibilityResponse) *NullableListCompatibilityResponse {
+ return &NullableListCompatibilityResponse{value: val, isSet: true}
+}
+
+func (v NullableListCompatibilityResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListCompatibilityResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_compatibility_response_test.go b/pkg/sqlserverflexalpha/model_list_compatibility_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_compatibility_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_current_running_restore_jobs.go b/pkg/sqlserverflexalpha/model_list_current_running_restore_jobs.go
new file mode 100644
index 00000000..38bc475a
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_current_running_restore_jobs.go
@@ -0,0 +1,126 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListCurrentRunningRestoreJobs type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListCurrentRunningRestoreJobs{}
+
+/*
+ types and functions for runningRestores
+*/
+
+// isArray
+type ListCurrentRunningRestoreJobsGetRunningRestoresAttributeType = *[]BackupRunningRestore
+type ListCurrentRunningRestoreJobsGetRunningRestoresArgType = []BackupRunningRestore
+type ListCurrentRunningRestoreJobsGetRunningRestoresRetType = []BackupRunningRestore
+
+func getListCurrentRunningRestoreJobsGetRunningRestoresAttributeTypeOk(arg ListCurrentRunningRestoreJobsGetRunningRestoresAttributeType) (ret ListCurrentRunningRestoreJobsGetRunningRestoresRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListCurrentRunningRestoreJobsGetRunningRestoresAttributeType(arg *ListCurrentRunningRestoreJobsGetRunningRestoresAttributeType, val ListCurrentRunningRestoreJobsGetRunningRestoresRetType) {
+ *arg = &val
+}
+
+// ListCurrentRunningRestoreJobs struct for ListCurrentRunningRestoreJobs
+type ListCurrentRunningRestoreJobs struct {
+ // List of the currently running Restore jobs
+ // REQUIRED
+ RunningRestores ListCurrentRunningRestoreJobsGetRunningRestoresAttributeType `json:"runningRestores" required:"true"`
+}
+
+type _ListCurrentRunningRestoreJobs ListCurrentRunningRestoreJobs
+
+// NewListCurrentRunningRestoreJobs instantiates a new ListCurrentRunningRestoreJobs object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListCurrentRunningRestoreJobs(runningRestores ListCurrentRunningRestoreJobsGetRunningRestoresArgType) *ListCurrentRunningRestoreJobs {
+ this := ListCurrentRunningRestoreJobs{}
+ setListCurrentRunningRestoreJobsGetRunningRestoresAttributeType(&this.RunningRestores, runningRestores)
+ return &this
+}
+
+// NewListCurrentRunningRestoreJobsWithDefaults instantiates a new ListCurrentRunningRestoreJobs object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListCurrentRunningRestoreJobsWithDefaults() *ListCurrentRunningRestoreJobs {
+ this := ListCurrentRunningRestoreJobs{}
+ return &this
+}
+
+// GetRunningRestores returns the RunningRestores field value
+func (o *ListCurrentRunningRestoreJobs) GetRunningRestores() (ret ListCurrentRunningRestoreJobsGetRunningRestoresRetType) {
+ ret, _ = o.GetRunningRestoresOk()
+ return ret
+}
+
+// GetRunningRestoresOk returns a tuple with the RunningRestores field value
+// and a boolean to check if the value has been set.
+func (o *ListCurrentRunningRestoreJobs) GetRunningRestoresOk() (ret ListCurrentRunningRestoreJobsGetRunningRestoresRetType, ok bool) {
+ return getListCurrentRunningRestoreJobsGetRunningRestoresAttributeTypeOk(o.RunningRestores)
+}
+
+// SetRunningRestores sets field value
+func (o *ListCurrentRunningRestoreJobs) SetRunningRestores(v ListCurrentRunningRestoreJobsGetRunningRestoresRetType) {
+ setListCurrentRunningRestoreJobsGetRunningRestoresAttributeType(&o.RunningRestores, v)
+}
+
+func (o ListCurrentRunningRestoreJobs) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListCurrentRunningRestoreJobsGetRunningRestoresAttributeTypeOk(o.RunningRestores); ok {
+ toSerialize["RunningRestores"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListCurrentRunningRestoreJobs struct {
+ value *ListCurrentRunningRestoreJobs
+ isSet bool
+}
+
+func (v NullableListCurrentRunningRestoreJobs) Get() *ListCurrentRunningRestoreJobs {
+ return v.value
+}
+
+func (v *NullableListCurrentRunningRestoreJobs) Set(val *ListCurrentRunningRestoreJobs) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListCurrentRunningRestoreJobs) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListCurrentRunningRestoreJobs) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListCurrentRunningRestoreJobs(val *ListCurrentRunningRestoreJobs) *NullableListCurrentRunningRestoreJobs {
+ return &NullableListCurrentRunningRestoreJobs{value: val, isSet: true}
+}
+
+func (v NullableListCurrentRunningRestoreJobs) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListCurrentRunningRestoreJobs) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_current_running_restore_jobs_test.go b/pkg/sqlserverflexalpha/model_list_current_running_restore_jobs_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_current_running_restore_jobs_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_database.go b/pkg/sqlserverflexalpha/model_list_database.go
new file mode 100644
index 00000000..0960fb2f
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_database.go
@@ -0,0 +1,261 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListDatabase type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListDatabase{}
+
+/*
+ types and functions for created
+*/
+
+// isNotNullableString
+type ListDatabaseGetCreatedAttributeType = *string
+
+func getListDatabaseGetCreatedAttributeTypeOk(arg ListDatabaseGetCreatedAttributeType) (ret ListDatabaseGetCreatedRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListDatabaseGetCreatedAttributeType(arg *ListDatabaseGetCreatedAttributeType, val ListDatabaseGetCreatedRetType) {
+ *arg = &val
+}
+
+type ListDatabaseGetCreatedArgType = string
+type ListDatabaseGetCreatedRetType = string
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type ListDatabaseGetIdAttributeType = *int64
+type ListDatabaseGetIdArgType = int64
+type ListDatabaseGetIdRetType = int64
+
+func getListDatabaseGetIdAttributeTypeOk(arg ListDatabaseGetIdAttributeType) (ret ListDatabaseGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListDatabaseGetIdAttributeType(arg *ListDatabaseGetIdAttributeType, val ListDatabaseGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type ListDatabaseGetNameAttributeType = *string
+
+func getListDatabaseGetNameAttributeTypeOk(arg ListDatabaseGetNameAttributeType) (ret ListDatabaseGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListDatabaseGetNameAttributeType(arg *ListDatabaseGetNameAttributeType, val ListDatabaseGetNameRetType) {
+ *arg = &val
+}
+
+type ListDatabaseGetNameArgType = string
+type ListDatabaseGetNameRetType = string
+
+/*
+ types and functions for owner
+*/
+
+// isNotNullableString
+type ListDatabaseGetOwnerAttributeType = *string
+
+func getListDatabaseGetOwnerAttributeTypeOk(arg ListDatabaseGetOwnerAttributeType) (ret ListDatabaseGetOwnerRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListDatabaseGetOwnerAttributeType(arg *ListDatabaseGetOwnerAttributeType, val ListDatabaseGetOwnerRetType) {
+ *arg = &val
+}
+
+type ListDatabaseGetOwnerArgType = string
+type ListDatabaseGetOwnerRetType = string
+
+// ListDatabase struct for ListDatabase
+type ListDatabase struct {
+ // The date when the database was created in RFC3339 format.
+ // REQUIRED
+ Created ListDatabaseGetCreatedAttributeType `json:"created" required:"true"`
+ // The id of the database.
+ // REQUIRED
+ Id ListDatabaseGetIdAttributeType `json:"id" required:"true"`
+ // The name of the database.
+ // REQUIRED
+ Name ListDatabaseGetNameAttributeType `json:"name" required:"true"`
+ // The owner of the database.
+ // REQUIRED
+ Owner ListDatabaseGetOwnerAttributeType `json:"owner" required:"true"`
+}
+
+type _ListDatabase ListDatabase
+
+// NewListDatabase instantiates a new ListDatabase object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListDatabase(created ListDatabaseGetCreatedArgType, id ListDatabaseGetIdArgType, name ListDatabaseGetNameArgType, owner ListDatabaseGetOwnerArgType) *ListDatabase {
+ this := ListDatabase{}
+ setListDatabaseGetCreatedAttributeType(&this.Created, created)
+ setListDatabaseGetIdAttributeType(&this.Id, id)
+ setListDatabaseGetNameAttributeType(&this.Name, name)
+ setListDatabaseGetOwnerAttributeType(&this.Owner, owner)
+ return &this
+}
+
+// NewListDatabaseWithDefaults instantiates a new ListDatabase object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListDatabaseWithDefaults() *ListDatabase {
+ this := ListDatabase{}
+ return &this
+}
+
+// GetCreated returns the Created field value
+func (o *ListDatabase) GetCreated() (ret ListDatabaseGetCreatedRetType) {
+ ret, _ = o.GetCreatedOk()
+ return ret
+}
+
+// GetCreatedOk returns a tuple with the Created field value
+// and a boolean to check if the value has been set.
+func (o *ListDatabase) GetCreatedOk() (ret ListDatabaseGetCreatedRetType, ok bool) {
+ return getListDatabaseGetCreatedAttributeTypeOk(o.Created)
+}
+
+// SetCreated sets field value
+func (o *ListDatabase) SetCreated(v ListDatabaseGetCreatedRetType) {
+ setListDatabaseGetCreatedAttributeType(&o.Created, v)
+}
+
+// GetId returns the Id field value
+func (o *ListDatabase) GetId() (ret ListDatabaseGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *ListDatabase) GetIdOk() (ret ListDatabaseGetIdRetType, ok bool) {
+ return getListDatabaseGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *ListDatabase) SetId(v ListDatabaseGetIdRetType) {
+ setListDatabaseGetIdAttributeType(&o.Id, v)
+}
+
+// GetName returns the Name field value
+func (o *ListDatabase) GetName() (ret ListDatabaseGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *ListDatabase) GetNameOk() (ret ListDatabaseGetNameRetType, ok bool) {
+ return getListDatabaseGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *ListDatabase) SetName(v ListDatabaseGetNameRetType) {
+ setListDatabaseGetNameAttributeType(&o.Name, v)
+}
+
+// GetOwner returns the Owner field value
+func (o *ListDatabase) GetOwner() (ret ListDatabaseGetOwnerRetType) {
+ ret, _ = o.GetOwnerOk()
+ return ret
+}
+
+// GetOwnerOk returns a tuple with the Owner field value
+// and a boolean to check if the value has been set.
+func (o *ListDatabase) GetOwnerOk() (ret ListDatabaseGetOwnerRetType, ok bool) {
+ return getListDatabaseGetOwnerAttributeTypeOk(o.Owner)
+}
+
+// SetOwner sets field value
+func (o *ListDatabase) SetOwner(v ListDatabaseGetOwnerRetType) {
+ setListDatabaseGetOwnerAttributeType(&o.Owner, v)
+}
+
+func (o ListDatabase) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListDatabaseGetCreatedAttributeTypeOk(o.Created); ok {
+ toSerialize["Created"] = val
+ }
+ if val, ok := getListDatabaseGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getListDatabaseGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getListDatabaseGetOwnerAttributeTypeOk(o.Owner); ok {
+ toSerialize["Owner"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListDatabase struct {
+ value *ListDatabase
+ isSet bool
+}
+
+func (v NullableListDatabase) Get() *ListDatabase {
+ return v.value
+}
+
+func (v *NullableListDatabase) Set(val *ListDatabase) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListDatabase) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListDatabase) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListDatabase(val *ListDatabase) *NullableListDatabase {
+ return &NullableListDatabase{value: val, isSet: true}
+}
+
+func (v NullableListDatabase) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListDatabase) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_database_test.go b/pkg/sqlserverflexalpha/model_list_database_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_database_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_databases_response.go b/pkg/sqlserverflexalpha/model_list_databases_response.go
new file mode 100644
index 00000000..d09ba44c
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_databases_response.go
@@ -0,0 +1,169 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListDatabasesResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListDatabasesResponse{}
+
+/*
+ types and functions for databases
+*/
+
+// isArray
+type ListDatabasesResponseGetDatabasesAttributeType = *[]ListDatabase
+type ListDatabasesResponseGetDatabasesArgType = []ListDatabase
+type ListDatabasesResponseGetDatabasesRetType = []ListDatabase
+
+func getListDatabasesResponseGetDatabasesAttributeTypeOk(arg ListDatabasesResponseGetDatabasesAttributeType) (ret ListDatabasesResponseGetDatabasesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListDatabasesResponseGetDatabasesAttributeType(arg *ListDatabasesResponseGetDatabasesAttributeType, val ListDatabasesResponseGetDatabasesRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for pagination
+*/
+
+// isModel
+type ListDatabasesResponseGetPaginationAttributeType = *Pagination
+type ListDatabasesResponseGetPaginationArgType = Pagination
+type ListDatabasesResponseGetPaginationRetType = Pagination
+
+func getListDatabasesResponseGetPaginationAttributeTypeOk(arg ListDatabasesResponseGetPaginationAttributeType) (ret ListDatabasesResponseGetPaginationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListDatabasesResponseGetPaginationAttributeType(arg *ListDatabasesResponseGetPaginationAttributeType, val ListDatabasesResponseGetPaginationRetType) {
+ *arg = &val
+}
+
+// ListDatabasesResponse struct for ListDatabasesResponse
+type ListDatabasesResponse struct {
+ // A list containing all databases for the instance.
+ // REQUIRED
+ Databases ListDatabasesResponseGetDatabasesAttributeType `json:"databases" required:"true"`
+ // REQUIRED
+ Pagination ListDatabasesResponseGetPaginationAttributeType `json:"pagination" required:"true"`
+}
+
+type _ListDatabasesResponse ListDatabasesResponse
+
+// NewListDatabasesResponse instantiates a new ListDatabasesResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListDatabasesResponse(databases ListDatabasesResponseGetDatabasesArgType, pagination ListDatabasesResponseGetPaginationArgType) *ListDatabasesResponse {
+ this := ListDatabasesResponse{}
+ setListDatabasesResponseGetDatabasesAttributeType(&this.Databases, databases)
+ setListDatabasesResponseGetPaginationAttributeType(&this.Pagination, pagination)
+ return &this
+}
+
+// NewListDatabasesResponseWithDefaults instantiates a new ListDatabasesResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListDatabasesResponseWithDefaults() *ListDatabasesResponse {
+ this := ListDatabasesResponse{}
+ return &this
+}
+
+// GetDatabases returns the Databases field value
+func (o *ListDatabasesResponse) GetDatabases() (ret ListDatabasesResponseGetDatabasesRetType) {
+ ret, _ = o.GetDatabasesOk()
+ return ret
+}
+
+// GetDatabasesOk returns a tuple with the Databases field value
+// and a boolean to check if the value has been set.
+func (o *ListDatabasesResponse) GetDatabasesOk() (ret ListDatabasesResponseGetDatabasesRetType, ok bool) {
+ return getListDatabasesResponseGetDatabasesAttributeTypeOk(o.Databases)
+}
+
+// SetDatabases sets field value
+func (o *ListDatabasesResponse) SetDatabases(v ListDatabasesResponseGetDatabasesRetType) {
+ setListDatabasesResponseGetDatabasesAttributeType(&o.Databases, v)
+}
+
+// GetPagination returns the Pagination field value
+func (o *ListDatabasesResponse) GetPagination() (ret ListDatabasesResponseGetPaginationRetType) {
+ ret, _ = o.GetPaginationOk()
+ return ret
+}
+
+// GetPaginationOk returns a tuple with the Pagination field value
+// and a boolean to check if the value has been set.
+func (o *ListDatabasesResponse) GetPaginationOk() (ret ListDatabasesResponseGetPaginationRetType, ok bool) {
+ return getListDatabasesResponseGetPaginationAttributeTypeOk(o.Pagination)
+}
+
+// SetPagination sets field value
+func (o *ListDatabasesResponse) SetPagination(v ListDatabasesResponseGetPaginationRetType) {
+ setListDatabasesResponseGetPaginationAttributeType(&o.Pagination, v)
+}
+
+func (o ListDatabasesResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListDatabasesResponseGetDatabasesAttributeTypeOk(o.Databases); ok {
+ toSerialize["Databases"] = val
+ }
+ if val, ok := getListDatabasesResponseGetPaginationAttributeTypeOk(o.Pagination); ok {
+ toSerialize["Pagination"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListDatabasesResponse struct {
+ value *ListDatabasesResponse
+ isSet bool
+}
+
+func (v NullableListDatabasesResponse) Get() *ListDatabasesResponse {
+ return v.value
+}
+
+func (v *NullableListDatabasesResponse) Set(val *ListDatabasesResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListDatabasesResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListDatabasesResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListDatabasesResponse(val *ListDatabasesResponse) *NullableListDatabasesResponse {
+ return &NullableListDatabasesResponse{value: val, isSet: true}
+}
+
+func (v NullableListDatabasesResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListDatabasesResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_databases_response_test.go b/pkg/sqlserverflexalpha/model_list_databases_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_databases_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_flavors.go b/pkg/sqlserverflexalpha/model_list_flavors.go
new file mode 100644
index 00000000..799577b2
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_flavors.go
@@ -0,0 +1,439 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListFlavors type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListFlavors{}
+
+/*
+ types and functions for cpu
+*/
+
+// isLong
+type ListFlavorsGetCpuAttributeType = *int64
+type ListFlavorsGetCpuArgType = int64
+type ListFlavorsGetCpuRetType = int64
+
+func getListFlavorsGetCpuAttributeTypeOk(arg ListFlavorsGetCpuAttributeType) (ret ListFlavorsGetCpuRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetCpuAttributeType(arg *ListFlavorsGetCpuAttributeType, val ListFlavorsGetCpuRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for description
+*/
+
+// isNotNullableString
+type ListFlavorsGetDescriptionAttributeType = *string
+
+func getListFlavorsGetDescriptionAttributeTypeOk(arg ListFlavorsGetDescriptionAttributeType) (ret ListFlavorsGetDescriptionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetDescriptionAttributeType(arg *ListFlavorsGetDescriptionAttributeType, val ListFlavorsGetDescriptionRetType) {
+ *arg = &val
+}
+
+type ListFlavorsGetDescriptionArgType = string
+type ListFlavorsGetDescriptionRetType = string
+
+/*
+ types and functions for id
+*/
+
+// isNotNullableString
+type ListFlavorsGetIdAttributeType = *string
+
+func getListFlavorsGetIdAttributeTypeOk(arg ListFlavorsGetIdAttributeType) (ret ListFlavorsGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetIdAttributeType(arg *ListFlavorsGetIdAttributeType, val ListFlavorsGetIdRetType) {
+ *arg = &val
+}
+
+type ListFlavorsGetIdArgType = string
+type ListFlavorsGetIdRetType = string
+
+/*
+ types and functions for maxGB
+*/
+
+// isInteger
+type ListFlavorsGetMaxGBAttributeType = *int64
+type ListFlavorsGetMaxGBArgType = int64
+type ListFlavorsGetMaxGBRetType = int64
+
+func getListFlavorsGetMaxGBAttributeTypeOk(arg ListFlavorsGetMaxGBAttributeType) (ret ListFlavorsGetMaxGBRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetMaxGBAttributeType(arg *ListFlavorsGetMaxGBAttributeType, val ListFlavorsGetMaxGBRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for memory
+*/
+
+// isLong
+type ListFlavorsGetMemoryAttributeType = *int64
+type ListFlavorsGetMemoryArgType = int64
+type ListFlavorsGetMemoryRetType = int64
+
+func getListFlavorsGetMemoryAttributeTypeOk(arg ListFlavorsGetMemoryAttributeType) (ret ListFlavorsGetMemoryRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetMemoryAttributeType(arg *ListFlavorsGetMemoryAttributeType, val ListFlavorsGetMemoryRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for minGB
+*/
+
+// isInteger
+type ListFlavorsGetMinGBAttributeType = *int64
+type ListFlavorsGetMinGBArgType = int64
+type ListFlavorsGetMinGBRetType = int64
+
+func getListFlavorsGetMinGBAttributeTypeOk(arg ListFlavorsGetMinGBAttributeType) (ret ListFlavorsGetMinGBRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetMinGBAttributeType(arg *ListFlavorsGetMinGBAttributeType, val ListFlavorsGetMinGBRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for nodeType
+*/
+
+// isNotNullableString
+type ListFlavorsGetNodeTypeAttributeType = *string
+
+func getListFlavorsGetNodeTypeAttributeTypeOk(arg ListFlavorsGetNodeTypeAttributeType) (ret ListFlavorsGetNodeTypeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetNodeTypeAttributeType(arg *ListFlavorsGetNodeTypeAttributeType, val ListFlavorsGetNodeTypeRetType) {
+ *arg = &val
+}
+
+type ListFlavorsGetNodeTypeArgType = string
+type ListFlavorsGetNodeTypeRetType = string
+
+/*
+ types and functions for storageClasses
+*/
+
+// isArray
+type ListFlavorsGetStorageClassesAttributeType = *[]FlavorStorageClassesStorageClass
+type ListFlavorsGetStorageClassesArgType = []FlavorStorageClassesStorageClass
+type ListFlavorsGetStorageClassesRetType = []FlavorStorageClassesStorageClass
+
+func getListFlavorsGetStorageClassesAttributeTypeOk(arg ListFlavorsGetStorageClassesAttributeType) (ret ListFlavorsGetStorageClassesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListFlavorsGetStorageClassesAttributeType(arg *ListFlavorsGetStorageClassesAttributeType, val ListFlavorsGetStorageClassesRetType) {
+ *arg = &val
+}
+
+// ListFlavors The flavor of the instance containing the technical features.
+type ListFlavors struct {
+ // The cpu count of the instance.
+ // REQUIRED
+ Cpu ListFlavorsGetCpuAttributeType `json:"cpu" required:"true"`
+ // The flavor description.
+ // REQUIRED
+ Description ListFlavorsGetDescriptionAttributeType `json:"description" required:"true"`
+ // The id of the instance flavor.
+ // REQUIRED
+ Id ListFlavorsGetIdAttributeType `json:"id" required:"true"`
+ // maximum storage which can be ordered for the flavor in Gigabyte.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ MaxGB ListFlavorsGetMaxGBAttributeType `json:"maxGB" required:"true"`
+ // The memory of the instance in Gibibyte.
+ // REQUIRED
+ Memory ListFlavorsGetMemoryAttributeType `json:"memory" required:"true"`
+ // minimum storage which is required to order in Gigabyte.
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ MinGB ListFlavorsGetMinGBAttributeType `json:"minGB" required:"true"`
+ // defines the nodeType it can be either single or HA
+ // REQUIRED
+ NodeType ListFlavorsGetNodeTypeAttributeType `json:"nodeType" required:"true"`
+ // maximum storage which can be ordered for the flavor in Gigabyte.
+ // REQUIRED
+ StorageClasses ListFlavorsGetStorageClassesAttributeType `json:"storageClasses" required:"true"`
+}
+
+type _ListFlavors ListFlavors
+
+// NewListFlavors instantiates a new ListFlavors object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListFlavors(cpu ListFlavorsGetCpuArgType, description ListFlavorsGetDescriptionArgType, id ListFlavorsGetIdArgType, maxGB ListFlavorsGetMaxGBArgType, memory ListFlavorsGetMemoryArgType, minGB ListFlavorsGetMinGBArgType, nodeType ListFlavorsGetNodeTypeArgType, storageClasses ListFlavorsGetStorageClassesArgType) *ListFlavors {
+ this := ListFlavors{}
+ setListFlavorsGetCpuAttributeType(&this.Cpu, cpu)
+ setListFlavorsGetDescriptionAttributeType(&this.Description, description)
+ setListFlavorsGetIdAttributeType(&this.Id, id)
+ setListFlavorsGetMaxGBAttributeType(&this.MaxGB, maxGB)
+ setListFlavorsGetMemoryAttributeType(&this.Memory, memory)
+ setListFlavorsGetMinGBAttributeType(&this.MinGB, minGB)
+ setListFlavorsGetNodeTypeAttributeType(&this.NodeType, nodeType)
+ setListFlavorsGetStorageClassesAttributeType(&this.StorageClasses, storageClasses)
+ return &this
+}
+
+// NewListFlavorsWithDefaults instantiates a new ListFlavors object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListFlavorsWithDefaults() *ListFlavors {
+ this := ListFlavors{}
+ return &this
+}
+
+// GetCpu returns the Cpu field value
+func (o *ListFlavors) GetCpu() (ret ListFlavorsGetCpuRetType) {
+ ret, _ = o.GetCpuOk()
+ return ret
+}
+
+// GetCpuOk returns a tuple with the Cpu field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetCpuOk() (ret ListFlavorsGetCpuRetType, ok bool) {
+ return getListFlavorsGetCpuAttributeTypeOk(o.Cpu)
+}
+
+// SetCpu sets field value
+func (o *ListFlavors) SetCpu(v ListFlavorsGetCpuRetType) {
+ setListFlavorsGetCpuAttributeType(&o.Cpu, v)
+}
+
+// GetDescription returns the Description field value
+func (o *ListFlavors) GetDescription() (ret ListFlavorsGetDescriptionRetType) {
+ ret, _ = o.GetDescriptionOk()
+ return ret
+}
+
+// GetDescriptionOk returns a tuple with the Description field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetDescriptionOk() (ret ListFlavorsGetDescriptionRetType, ok bool) {
+ return getListFlavorsGetDescriptionAttributeTypeOk(o.Description)
+}
+
+// SetDescription sets field value
+func (o *ListFlavors) SetDescription(v ListFlavorsGetDescriptionRetType) {
+ setListFlavorsGetDescriptionAttributeType(&o.Description, v)
+}
+
+// GetId returns the Id field value
+func (o *ListFlavors) GetId() (ret ListFlavorsGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetIdOk() (ret ListFlavorsGetIdRetType, ok bool) {
+ return getListFlavorsGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *ListFlavors) SetId(v ListFlavorsGetIdRetType) {
+ setListFlavorsGetIdAttributeType(&o.Id, v)
+}
+
+// GetMaxGB returns the MaxGB field value
+func (o *ListFlavors) GetMaxGB() (ret ListFlavorsGetMaxGBRetType) {
+ ret, _ = o.GetMaxGBOk()
+ return ret
+}
+
+// GetMaxGBOk returns a tuple with the MaxGB field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetMaxGBOk() (ret ListFlavorsGetMaxGBRetType, ok bool) {
+ return getListFlavorsGetMaxGBAttributeTypeOk(o.MaxGB)
+}
+
+// SetMaxGB sets field value
+func (o *ListFlavors) SetMaxGB(v ListFlavorsGetMaxGBRetType) {
+ setListFlavorsGetMaxGBAttributeType(&o.MaxGB, v)
+}
+
+// GetMemory returns the Memory field value
+func (o *ListFlavors) GetMemory() (ret ListFlavorsGetMemoryRetType) {
+ ret, _ = o.GetMemoryOk()
+ return ret
+}
+
+// GetMemoryOk returns a tuple with the Memory field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetMemoryOk() (ret ListFlavorsGetMemoryRetType, ok bool) {
+ return getListFlavorsGetMemoryAttributeTypeOk(o.Memory)
+}
+
+// SetMemory sets field value
+func (o *ListFlavors) SetMemory(v ListFlavorsGetMemoryRetType) {
+ setListFlavorsGetMemoryAttributeType(&o.Memory, v)
+}
+
+// GetMinGB returns the MinGB field value
+func (o *ListFlavors) GetMinGB() (ret ListFlavorsGetMinGBRetType) {
+ ret, _ = o.GetMinGBOk()
+ return ret
+}
+
+// GetMinGBOk returns a tuple with the MinGB field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetMinGBOk() (ret ListFlavorsGetMinGBRetType, ok bool) {
+ return getListFlavorsGetMinGBAttributeTypeOk(o.MinGB)
+}
+
+// SetMinGB sets field value
+func (o *ListFlavors) SetMinGB(v ListFlavorsGetMinGBRetType) {
+ setListFlavorsGetMinGBAttributeType(&o.MinGB, v)
+}
+
+// GetNodeType returns the NodeType field value
+func (o *ListFlavors) GetNodeType() (ret ListFlavorsGetNodeTypeRetType) {
+ ret, _ = o.GetNodeTypeOk()
+ return ret
+}
+
+// GetNodeTypeOk returns a tuple with the NodeType field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetNodeTypeOk() (ret ListFlavorsGetNodeTypeRetType, ok bool) {
+ return getListFlavorsGetNodeTypeAttributeTypeOk(o.NodeType)
+}
+
+// SetNodeType sets field value
+func (o *ListFlavors) SetNodeType(v ListFlavorsGetNodeTypeRetType) {
+ setListFlavorsGetNodeTypeAttributeType(&o.NodeType, v)
+}
+
+// GetStorageClasses returns the StorageClasses field value
+func (o *ListFlavors) GetStorageClasses() (ret ListFlavorsGetStorageClassesRetType) {
+ ret, _ = o.GetStorageClassesOk()
+ return ret
+}
+
+// GetStorageClassesOk returns a tuple with the StorageClasses field value
+// and a boolean to check if the value has been set.
+func (o *ListFlavors) GetStorageClassesOk() (ret ListFlavorsGetStorageClassesRetType, ok bool) {
+ return getListFlavorsGetStorageClassesAttributeTypeOk(o.StorageClasses)
+}
+
+// SetStorageClasses sets field value
+func (o *ListFlavors) SetStorageClasses(v ListFlavorsGetStorageClassesRetType) {
+ setListFlavorsGetStorageClassesAttributeType(&o.StorageClasses, v)
+}
+
+func (o ListFlavors) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListFlavorsGetCpuAttributeTypeOk(o.Cpu); ok {
+ toSerialize["Cpu"] = val
+ }
+ if val, ok := getListFlavorsGetDescriptionAttributeTypeOk(o.Description); ok {
+ toSerialize["Description"] = val
+ }
+ if val, ok := getListFlavorsGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getListFlavorsGetMaxGBAttributeTypeOk(o.MaxGB); ok {
+ toSerialize["MaxGB"] = val
+ }
+ if val, ok := getListFlavorsGetMemoryAttributeTypeOk(o.Memory); ok {
+ toSerialize["Memory"] = val
+ }
+ if val, ok := getListFlavorsGetMinGBAttributeTypeOk(o.MinGB); ok {
+ toSerialize["MinGB"] = val
+ }
+ if val, ok := getListFlavorsGetNodeTypeAttributeTypeOk(o.NodeType); ok {
+ toSerialize["NodeType"] = val
+ }
+ if val, ok := getListFlavorsGetStorageClassesAttributeTypeOk(o.StorageClasses); ok {
+ toSerialize["StorageClasses"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListFlavors struct {
+ value *ListFlavors
+ isSet bool
+}
+
+func (v NullableListFlavors) Get() *ListFlavors {
+ return v.value
+}
+
+func (v *NullableListFlavors) Set(val *ListFlavors) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListFlavors) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListFlavors) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListFlavors(val *ListFlavors) *NullableListFlavors {
+ return &NullableListFlavors{value: val, isSet: true}
+}
+
+func (v NullableListFlavors) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListFlavors) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_flavors_test.go b/pkg/sqlserverflexalpha/model_list_flavors_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_flavors_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_instance.go b/pkg/sqlserverflexalpha/model_list_instance.go
new file mode 100644
index 00000000..07871aaa
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_instance.go
@@ -0,0 +1,259 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListInstance type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListInstance{}
+
+/*
+ types and functions for id
+*/
+
+// isNotNullableString
+type ListInstanceGetIdAttributeType = *string
+
+func getListInstanceGetIdAttributeTypeOk(arg ListInstanceGetIdAttributeType) (ret ListInstanceGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListInstanceGetIdAttributeType(arg *ListInstanceGetIdAttributeType, val ListInstanceGetIdRetType) {
+ *arg = &val
+}
+
+type ListInstanceGetIdArgType = string
+type ListInstanceGetIdRetType = string
+
+/*
+ types and functions for isDeletable
+*/
+
+// isBoolean
+type ListInstancegetIsDeletableAttributeType = *bool
+type ListInstancegetIsDeletableArgType = bool
+type ListInstancegetIsDeletableRetType = bool
+
+func getListInstancegetIsDeletableAttributeTypeOk(arg ListInstancegetIsDeletableAttributeType) (ret ListInstancegetIsDeletableRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListInstancegetIsDeletableAttributeType(arg *ListInstancegetIsDeletableAttributeType, val ListInstancegetIsDeletableRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type ListInstanceGetNameAttributeType = *string
+
+func getListInstanceGetNameAttributeTypeOk(arg ListInstanceGetNameAttributeType) (ret ListInstanceGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListInstanceGetNameAttributeType(arg *ListInstanceGetNameAttributeType, val ListInstanceGetNameRetType) {
+ *arg = &val
+}
+
+type ListInstanceGetNameArgType = string
+type ListInstanceGetNameRetType = string
+
+/*
+ types and functions for status
+*/
+
+// isEnumRef
+type ListInstanceGetStatusAttributeType = *Status
+type ListInstanceGetStatusArgType = Status
+type ListInstanceGetStatusRetType = Status
+
+func getListInstanceGetStatusAttributeTypeOk(arg ListInstanceGetStatusAttributeType) (ret ListInstanceGetStatusRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListInstanceGetStatusAttributeType(arg *ListInstanceGetStatusAttributeType, val ListInstanceGetStatusRetType) {
+ *arg = &val
+}
+
+// ListInstance struct for ListInstance
+type ListInstance struct {
+ // The ID of the instance.
+ // REQUIRED
+ Id ListInstanceGetIdAttributeType `json:"id" required:"true"`
+ // Whether the instance can be deleted or not.
+ // REQUIRED
+ IsDeletable ListInstancegetIsDeletableAttributeType `json:"isDeletable" required:"true"`
+ // The name of the instance.
+ // REQUIRED
+ Name ListInstanceGetNameAttributeType `json:"name" required:"true"`
+ // REQUIRED
+ Status ListInstanceGetStatusAttributeType `json:"status" required:"true"`
+}
+
+type _ListInstance ListInstance
+
+// NewListInstance instantiates a new ListInstance object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListInstance(id ListInstanceGetIdArgType, isDeletable ListInstancegetIsDeletableArgType, name ListInstanceGetNameArgType, status ListInstanceGetStatusArgType) *ListInstance {
+ this := ListInstance{}
+ setListInstanceGetIdAttributeType(&this.Id, id)
+ setListInstancegetIsDeletableAttributeType(&this.IsDeletable, isDeletable)
+ setListInstanceGetNameAttributeType(&this.Name, name)
+ setListInstanceGetStatusAttributeType(&this.Status, status)
+ return &this
+}
+
+// NewListInstanceWithDefaults instantiates a new ListInstance object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListInstanceWithDefaults() *ListInstance {
+ this := ListInstance{}
+ return &this
+}
+
+// GetId returns the Id field value
+func (o *ListInstance) GetId() (ret ListInstanceGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *ListInstance) GetIdOk() (ret ListInstanceGetIdRetType, ok bool) {
+ return getListInstanceGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *ListInstance) SetId(v ListInstanceGetIdRetType) {
+ setListInstanceGetIdAttributeType(&o.Id, v)
+}
+
+// GetIsDeletable returns the IsDeletable field value
+func (o *ListInstance) GetIsDeletable() (ret ListInstancegetIsDeletableRetType) {
+ ret, _ = o.GetIsDeletableOk()
+ return ret
+}
+
+// GetIsDeletableOk returns a tuple with the IsDeletable field value
+// and a boolean to check if the value has been set.
+func (o *ListInstance) GetIsDeletableOk() (ret ListInstancegetIsDeletableRetType, ok bool) {
+ return getListInstancegetIsDeletableAttributeTypeOk(o.IsDeletable)
+}
+
+// SetIsDeletable sets field value
+func (o *ListInstance) SetIsDeletable(v ListInstancegetIsDeletableRetType) {
+ setListInstancegetIsDeletableAttributeType(&o.IsDeletable, v)
+}
+
+// GetName returns the Name field value
+func (o *ListInstance) GetName() (ret ListInstanceGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *ListInstance) GetNameOk() (ret ListInstanceGetNameRetType, ok bool) {
+ return getListInstanceGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *ListInstance) SetName(v ListInstanceGetNameRetType) {
+ setListInstanceGetNameAttributeType(&o.Name, v)
+}
+
+// GetStatus returns the Status field value
+func (o *ListInstance) GetStatus() (ret ListInstanceGetStatusRetType) {
+ ret, _ = o.GetStatusOk()
+ return ret
+}
+
+// GetStatusOk returns a tuple with the Status field value
+// and a boolean to check if the value has been set.
+func (o *ListInstance) GetStatusOk() (ret ListInstanceGetStatusRetType, ok bool) {
+ return getListInstanceGetStatusAttributeTypeOk(o.Status)
+}
+
+// SetStatus sets field value
+func (o *ListInstance) SetStatus(v ListInstanceGetStatusRetType) {
+ setListInstanceGetStatusAttributeType(&o.Status, v)
+}
+
+func (o ListInstance) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListInstanceGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getListInstancegetIsDeletableAttributeTypeOk(o.IsDeletable); ok {
+ toSerialize["IsDeletable"] = val
+ }
+ if val, ok := getListInstanceGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getListInstanceGetStatusAttributeTypeOk(o.Status); ok {
+ toSerialize["Status"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListInstance struct {
+ value *ListInstance
+ isSet bool
+}
+
+func (v NullableListInstance) Get() *ListInstance {
+ return v.value
+}
+
+func (v *NullableListInstance) Set(val *ListInstance) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListInstance) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListInstance) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListInstance(val *ListInstance) *NullableListInstance {
+ return &NullableListInstance{value: val, isSet: true}
+}
+
+func (v NullableListInstance) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListInstance) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_instance_test.go b/pkg/sqlserverflexalpha/model_list_instance_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_instance_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_instances_response.go b/pkg/sqlserverflexalpha/model_list_instances_response.go
new file mode 100644
index 00000000..79ee23b0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_instances_response.go
@@ -0,0 +1,169 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListInstancesResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListInstancesResponse{}
+
+/*
+ types and functions for instances
+*/
+
+// isArray
+type ListInstancesResponseGetInstancesAttributeType = *[]ListInstance
+type ListInstancesResponseGetInstancesArgType = []ListInstance
+type ListInstancesResponseGetInstancesRetType = []ListInstance
+
+func getListInstancesResponseGetInstancesAttributeTypeOk(arg ListInstancesResponseGetInstancesAttributeType) (ret ListInstancesResponseGetInstancesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListInstancesResponseGetInstancesAttributeType(arg *ListInstancesResponseGetInstancesAttributeType, val ListInstancesResponseGetInstancesRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for pagination
+*/
+
+// isModel
+type ListInstancesResponseGetPaginationAttributeType = *Pagination
+type ListInstancesResponseGetPaginationArgType = Pagination
+type ListInstancesResponseGetPaginationRetType = Pagination
+
+func getListInstancesResponseGetPaginationAttributeTypeOk(arg ListInstancesResponseGetPaginationAttributeType) (ret ListInstancesResponseGetPaginationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListInstancesResponseGetPaginationAttributeType(arg *ListInstancesResponseGetPaginationAttributeType, val ListInstancesResponseGetPaginationRetType) {
+ *arg = &val
+}
+
+// ListInstancesResponse struct for ListInstancesResponse
+type ListInstancesResponse struct {
+ // List of owned instances and their current status.
+ // REQUIRED
+ Instances ListInstancesResponseGetInstancesAttributeType `json:"instances" required:"true"`
+ // REQUIRED
+ Pagination ListInstancesResponseGetPaginationAttributeType `json:"pagination" required:"true"`
+}
+
+type _ListInstancesResponse ListInstancesResponse
+
+// NewListInstancesResponse instantiates a new ListInstancesResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListInstancesResponse(instances ListInstancesResponseGetInstancesArgType, pagination ListInstancesResponseGetPaginationArgType) *ListInstancesResponse {
+ this := ListInstancesResponse{}
+ setListInstancesResponseGetInstancesAttributeType(&this.Instances, instances)
+ setListInstancesResponseGetPaginationAttributeType(&this.Pagination, pagination)
+ return &this
+}
+
+// NewListInstancesResponseWithDefaults instantiates a new ListInstancesResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListInstancesResponseWithDefaults() *ListInstancesResponse {
+ this := ListInstancesResponse{}
+ return &this
+}
+
+// GetInstances returns the Instances field value
+func (o *ListInstancesResponse) GetInstances() (ret ListInstancesResponseGetInstancesRetType) {
+ ret, _ = o.GetInstancesOk()
+ return ret
+}
+
+// GetInstancesOk returns a tuple with the Instances field value
+// and a boolean to check if the value has been set.
+func (o *ListInstancesResponse) GetInstancesOk() (ret ListInstancesResponseGetInstancesRetType, ok bool) {
+ return getListInstancesResponseGetInstancesAttributeTypeOk(o.Instances)
+}
+
+// SetInstances sets field value
+func (o *ListInstancesResponse) SetInstances(v ListInstancesResponseGetInstancesRetType) {
+ setListInstancesResponseGetInstancesAttributeType(&o.Instances, v)
+}
+
+// GetPagination returns the Pagination field value
+func (o *ListInstancesResponse) GetPagination() (ret ListInstancesResponseGetPaginationRetType) {
+ ret, _ = o.GetPaginationOk()
+ return ret
+}
+
+// GetPaginationOk returns a tuple with the Pagination field value
+// and a boolean to check if the value has been set.
+func (o *ListInstancesResponse) GetPaginationOk() (ret ListInstancesResponseGetPaginationRetType, ok bool) {
+ return getListInstancesResponseGetPaginationAttributeTypeOk(o.Pagination)
+}
+
+// SetPagination sets field value
+func (o *ListInstancesResponse) SetPagination(v ListInstancesResponseGetPaginationRetType) {
+ setListInstancesResponseGetPaginationAttributeType(&o.Pagination, v)
+}
+
+func (o ListInstancesResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListInstancesResponseGetInstancesAttributeTypeOk(o.Instances); ok {
+ toSerialize["Instances"] = val
+ }
+ if val, ok := getListInstancesResponseGetPaginationAttributeTypeOk(o.Pagination); ok {
+ toSerialize["Pagination"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListInstancesResponse struct {
+ value *ListInstancesResponse
+ isSet bool
+}
+
+func (v NullableListInstancesResponse) Get() *ListInstancesResponse {
+ return v.value
+}
+
+func (v *NullableListInstancesResponse) Set(val *ListInstancesResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListInstancesResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListInstancesResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListInstancesResponse(val *ListInstancesResponse) *NullableListInstancesResponse {
+ return &NullableListInstancesResponse{value: val, isSet: true}
+}
+
+func (v NullableListInstancesResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListInstancesResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_instances_response_test.go b/pkg/sqlserverflexalpha/model_list_instances_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_instances_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_roles_response.go b/pkg/sqlserverflexalpha/model_list_roles_response.go
new file mode 100644
index 00000000..102c3ced
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_roles_response.go
@@ -0,0 +1,126 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListRolesResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListRolesResponse{}
+
+/*
+ types and functions for roles
+*/
+
+// isArray
+type ListRolesResponseGetRolesAttributeType = *[]UserRole
+type ListRolesResponseGetRolesArgType = []UserRole
+type ListRolesResponseGetRolesRetType = []UserRole
+
+func getListRolesResponseGetRolesAttributeTypeOk(arg ListRolesResponseGetRolesAttributeType) (ret ListRolesResponseGetRolesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListRolesResponseGetRolesAttributeType(arg *ListRolesResponseGetRolesAttributeType, val ListRolesResponseGetRolesRetType) {
+ *arg = &val
+}
+
+// ListRolesResponse struct for ListRolesResponse
+type ListRolesResponse struct {
+ // List of roles available for an instance.
+ // REQUIRED
+ Roles ListRolesResponseGetRolesAttributeType `json:"roles" required:"true"`
+}
+
+type _ListRolesResponse ListRolesResponse
+
+// NewListRolesResponse instantiates a new ListRolesResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListRolesResponse(roles ListRolesResponseGetRolesArgType) *ListRolesResponse {
+ this := ListRolesResponse{}
+ setListRolesResponseGetRolesAttributeType(&this.Roles, roles)
+ return &this
+}
+
+// NewListRolesResponseWithDefaults instantiates a new ListRolesResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListRolesResponseWithDefaults() *ListRolesResponse {
+ this := ListRolesResponse{}
+ return &this
+}
+
+// GetRoles returns the Roles field value
+func (o *ListRolesResponse) GetRoles() (ret ListRolesResponseGetRolesRetType) {
+ ret, _ = o.GetRolesOk()
+ return ret
+}
+
+// GetRolesOk returns a tuple with the Roles field value
+// and a boolean to check if the value has been set.
+func (o *ListRolesResponse) GetRolesOk() (ret ListRolesResponseGetRolesRetType, ok bool) {
+ return getListRolesResponseGetRolesAttributeTypeOk(o.Roles)
+}
+
+// SetRoles sets field value
+func (o *ListRolesResponse) SetRoles(v ListRolesResponseGetRolesRetType) {
+ setListRolesResponseGetRolesAttributeType(&o.Roles, v)
+}
+
+func (o ListRolesResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListRolesResponseGetRolesAttributeTypeOk(o.Roles); ok {
+ toSerialize["Roles"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListRolesResponse struct {
+ value *ListRolesResponse
+ isSet bool
+}
+
+func (v NullableListRolesResponse) Get() *ListRolesResponse {
+ return v.value
+}
+
+func (v *NullableListRolesResponse) Set(val *ListRolesResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListRolesResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListRolesResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListRolesResponse(val *ListRolesResponse) *NullableListRolesResponse {
+ return &NullableListRolesResponse{value: val, isSet: true}
+}
+
+func (v NullableListRolesResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListRolesResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_roles_response_test.go b/pkg/sqlserverflexalpha/model_list_roles_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_roles_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_user.go b/pkg/sqlserverflexalpha/model_list_user.go
new file mode 100644
index 00000000..0d7d6e2e
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_user.go
@@ -0,0 +1,216 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListUser type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListUser{}
+
+/*
+ types and functions for id
+*/
+
+// isLong
+type ListUserGetIdAttributeType = *int64
+type ListUserGetIdArgType = int64
+type ListUserGetIdRetType = int64
+
+func getListUserGetIdAttributeTypeOk(arg ListUserGetIdAttributeType) (ret ListUserGetIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListUserGetIdAttributeType(arg *ListUserGetIdAttributeType, val ListUserGetIdRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for status
+*/
+
+// isNotNullableString
+type ListUserGetStatusAttributeType = *string
+
+func getListUserGetStatusAttributeTypeOk(arg ListUserGetStatusAttributeType) (ret ListUserGetStatusRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListUserGetStatusAttributeType(arg *ListUserGetStatusAttributeType, val ListUserGetStatusRetType) {
+ *arg = &val
+}
+
+type ListUserGetStatusArgType = string
+type ListUserGetStatusRetType = string
+
+/*
+ types and functions for username
+*/
+
+// isNotNullableString
+type ListUserGetUsernameAttributeType = *string
+
+func getListUserGetUsernameAttributeTypeOk(arg ListUserGetUsernameAttributeType) (ret ListUserGetUsernameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListUserGetUsernameAttributeType(arg *ListUserGetUsernameAttributeType, val ListUserGetUsernameRetType) {
+ *arg = &val
+}
+
+type ListUserGetUsernameArgType = string
+type ListUserGetUsernameRetType = string
+
+// ListUser struct for ListUser
+type ListUser struct {
+ // The ID of the user.
+ // REQUIRED
+ Id ListUserGetIdAttributeType `json:"id" required:"true"`
+ // The current status of the user.
+ // REQUIRED
+ Status ListUserGetStatusAttributeType `json:"status" required:"true"`
+ // The name of the user.
+ // REQUIRED
+ Username ListUserGetUsernameAttributeType `json:"username" required:"true"`
+}
+
+type _ListUser ListUser
+
+// NewListUser instantiates a new ListUser object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListUser(id ListUserGetIdArgType, status ListUserGetStatusArgType, username ListUserGetUsernameArgType) *ListUser {
+ this := ListUser{}
+ setListUserGetIdAttributeType(&this.Id, id)
+ setListUserGetStatusAttributeType(&this.Status, status)
+ setListUserGetUsernameAttributeType(&this.Username, username)
+ return &this
+}
+
+// NewListUserWithDefaults instantiates a new ListUser object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListUserWithDefaults() *ListUser {
+ this := ListUser{}
+ return &this
+}
+
+// GetId returns the Id field value
+func (o *ListUser) GetId() (ret ListUserGetIdRetType) {
+ ret, _ = o.GetIdOk()
+ return ret
+}
+
+// GetIdOk returns a tuple with the Id field value
+// and a boolean to check if the value has been set.
+func (o *ListUser) GetIdOk() (ret ListUserGetIdRetType, ok bool) {
+ return getListUserGetIdAttributeTypeOk(o.Id)
+}
+
+// SetId sets field value
+func (o *ListUser) SetId(v ListUserGetIdRetType) {
+ setListUserGetIdAttributeType(&o.Id, v)
+}
+
+// GetStatus returns the Status field value
+func (o *ListUser) GetStatus() (ret ListUserGetStatusRetType) {
+ ret, _ = o.GetStatusOk()
+ return ret
+}
+
+// GetStatusOk returns a tuple with the Status field value
+// and a boolean to check if the value has been set.
+func (o *ListUser) GetStatusOk() (ret ListUserGetStatusRetType, ok bool) {
+ return getListUserGetStatusAttributeTypeOk(o.Status)
+}
+
+// SetStatus sets field value
+func (o *ListUser) SetStatus(v ListUserGetStatusRetType) {
+ setListUserGetStatusAttributeType(&o.Status, v)
+}
+
+// GetUsername returns the Username field value
+func (o *ListUser) GetUsername() (ret ListUserGetUsernameRetType) {
+ ret, _ = o.GetUsernameOk()
+ return ret
+}
+
+// GetUsernameOk returns a tuple with the Username field value
+// and a boolean to check if the value has been set.
+func (o *ListUser) GetUsernameOk() (ret ListUserGetUsernameRetType, ok bool) {
+ return getListUserGetUsernameAttributeTypeOk(o.Username)
+}
+
+// SetUsername sets field value
+func (o *ListUser) SetUsername(v ListUserGetUsernameRetType) {
+ setListUserGetUsernameAttributeType(&o.Username, v)
+}
+
+func (o ListUser) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListUserGetIdAttributeTypeOk(o.Id); ok {
+ toSerialize["Id"] = val
+ }
+ if val, ok := getListUserGetStatusAttributeTypeOk(o.Status); ok {
+ toSerialize["Status"] = val
+ }
+ if val, ok := getListUserGetUsernameAttributeTypeOk(o.Username); ok {
+ toSerialize["Username"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListUser struct {
+ value *ListUser
+ isSet bool
+}
+
+func (v NullableListUser) Get() *ListUser {
+ return v.value
+}
+
+func (v *NullableListUser) Set(val *ListUser) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListUser) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListUser) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListUser(val *ListUser) *NullableListUser {
+ return &NullableListUser{value: val, isSet: true}
+}
+
+func (v NullableListUser) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListUser) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_user_response.go b/pkg/sqlserverflexalpha/model_list_user_response.go
new file mode 100644
index 00000000..ad5f0c87
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_user_response.go
@@ -0,0 +1,169 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ListUserResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ListUserResponse{}
+
+/*
+ types and functions for pagination
+*/
+
+// isModel
+type ListUserResponseGetPaginationAttributeType = *Pagination
+type ListUserResponseGetPaginationArgType = Pagination
+type ListUserResponseGetPaginationRetType = Pagination
+
+func getListUserResponseGetPaginationAttributeTypeOk(arg ListUserResponseGetPaginationAttributeType) (ret ListUserResponseGetPaginationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListUserResponseGetPaginationAttributeType(arg *ListUserResponseGetPaginationAttributeType, val ListUserResponseGetPaginationRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for users
+*/
+
+// isArray
+type ListUserResponseGetUsersAttributeType = *[]ListUser
+type ListUserResponseGetUsersArgType = []ListUser
+type ListUserResponseGetUsersRetType = []ListUser
+
+func getListUserResponseGetUsersAttributeTypeOk(arg ListUserResponseGetUsersAttributeType) (ret ListUserResponseGetUsersRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setListUserResponseGetUsersAttributeType(arg *ListUserResponseGetUsersAttributeType, val ListUserResponseGetUsersRetType) {
+ *arg = &val
+}
+
+// ListUserResponse struct for ListUserResponse
+type ListUserResponse struct {
+ // REQUIRED
+ Pagination ListUserResponseGetPaginationAttributeType `json:"pagination" required:"true"`
+ // List of all users inside an instance
+ // REQUIRED
+ Users ListUserResponseGetUsersAttributeType `json:"users" required:"true"`
+}
+
+type _ListUserResponse ListUserResponse
+
+// NewListUserResponse instantiates a new ListUserResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewListUserResponse(pagination ListUserResponseGetPaginationArgType, users ListUserResponseGetUsersArgType) *ListUserResponse {
+ this := ListUserResponse{}
+ setListUserResponseGetPaginationAttributeType(&this.Pagination, pagination)
+ setListUserResponseGetUsersAttributeType(&this.Users, users)
+ return &this
+}
+
+// NewListUserResponseWithDefaults instantiates a new ListUserResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewListUserResponseWithDefaults() *ListUserResponse {
+ this := ListUserResponse{}
+ return &this
+}
+
+// GetPagination returns the Pagination field value
+func (o *ListUserResponse) GetPagination() (ret ListUserResponseGetPaginationRetType) {
+ ret, _ = o.GetPaginationOk()
+ return ret
+}
+
+// GetPaginationOk returns a tuple with the Pagination field value
+// and a boolean to check if the value has been set.
+func (o *ListUserResponse) GetPaginationOk() (ret ListUserResponseGetPaginationRetType, ok bool) {
+ return getListUserResponseGetPaginationAttributeTypeOk(o.Pagination)
+}
+
+// SetPagination sets field value
+func (o *ListUserResponse) SetPagination(v ListUserResponseGetPaginationRetType) {
+ setListUserResponseGetPaginationAttributeType(&o.Pagination, v)
+}
+
+// GetUsers returns the Users field value
+func (o *ListUserResponse) GetUsers() (ret ListUserResponseGetUsersRetType) {
+ ret, _ = o.GetUsersOk()
+ return ret
+}
+
+// GetUsersOk returns a tuple with the Users field value
+// and a boolean to check if the value has been set.
+func (o *ListUserResponse) GetUsersOk() (ret ListUserResponseGetUsersRetType, ok bool) {
+ return getListUserResponseGetUsersAttributeTypeOk(o.Users)
+}
+
+// SetUsers sets field value
+func (o *ListUserResponse) SetUsers(v ListUserResponseGetUsersRetType) {
+ setListUserResponseGetUsersAttributeType(&o.Users, v)
+}
+
+func (o ListUserResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getListUserResponseGetPaginationAttributeTypeOk(o.Pagination); ok {
+ toSerialize["Pagination"] = val
+ }
+ if val, ok := getListUserResponseGetUsersAttributeTypeOk(o.Users); ok {
+ toSerialize["Users"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableListUserResponse struct {
+ value *ListUserResponse
+ isSet bool
+}
+
+func (v NullableListUserResponse) Get() *ListUserResponse {
+ return v.value
+}
+
+func (v *NullableListUserResponse) Set(val *ListUserResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableListUserResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableListUserResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableListUserResponse(val *ListUserResponse) *NullableListUserResponse {
+ return &NullableListUserResponse{value: val, isSet: true}
+}
+
+func (v NullableListUserResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableListUserResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_list_user_response_test.go b/pkg/sqlserverflexalpha/model_list_user_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_user_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_list_user_test.go b/pkg/sqlserverflexalpha/model_list_user_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_list_user_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_pagination.go b/pkg/sqlserverflexalpha/model_pagination.go
new file mode 100644
index 00000000..1992145d
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_pagination.go
@@ -0,0 +1,298 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the Pagination type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &Pagination{}
+
+/*
+ types and functions for page
+*/
+
+// isLong
+type PaginationGetPageAttributeType = *int64
+type PaginationGetPageArgType = int64
+type PaginationGetPageRetType = int64
+
+func getPaginationGetPageAttributeTypeOk(arg PaginationGetPageAttributeType) (ret PaginationGetPageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPaginationGetPageAttributeType(arg *PaginationGetPageAttributeType, val PaginationGetPageRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for size
+*/
+
+// isLong
+type PaginationGetSizeAttributeType = *int64
+type PaginationGetSizeArgType = int64
+type PaginationGetSizeRetType = int64
+
+func getPaginationGetSizeAttributeTypeOk(arg PaginationGetSizeAttributeType) (ret PaginationGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPaginationGetSizeAttributeType(arg *PaginationGetSizeAttributeType, val PaginationGetSizeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for sort
+*/
+
+// isNotNullableString
+type PaginationGetSortAttributeType = *string
+
+func getPaginationGetSortAttributeTypeOk(arg PaginationGetSortAttributeType) (ret PaginationGetSortRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPaginationGetSortAttributeType(arg *PaginationGetSortAttributeType, val PaginationGetSortRetType) {
+ *arg = &val
+}
+
+type PaginationGetSortArgType = string
+type PaginationGetSortRetType = string
+
+/*
+ types and functions for totalPages
+*/
+
+// isLong
+type PaginationGetTotalPagesAttributeType = *int64
+type PaginationGetTotalPagesArgType = int64
+type PaginationGetTotalPagesRetType = int64
+
+func getPaginationGetTotalPagesAttributeTypeOk(arg PaginationGetTotalPagesAttributeType) (ret PaginationGetTotalPagesRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPaginationGetTotalPagesAttributeType(arg *PaginationGetTotalPagesAttributeType, val PaginationGetTotalPagesRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for totalRows
+*/
+
+// isLong
+type PaginationGetTotalRowsAttributeType = *int64
+type PaginationGetTotalRowsArgType = int64
+type PaginationGetTotalRowsRetType = int64
+
+func getPaginationGetTotalRowsAttributeTypeOk(arg PaginationGetTotalRowsAttributeType) (ret PaginationGetTotalRowsRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setPaginationGetTotalRowsAttributeType(arg *PaginationGetTotalRowsAttributeType, val PaginationGetTotalRowsRetType) {
+ *arg = &val
+}
+
+// Pagination struct for Pagination
+type Pagination struct {
+ // REQUIRED
+ Page PaginationGetPageAttributeType `json:"page" required:"true" validate:"required"`
+ // REQUIRED
+ Size PaginationGetSizeAttributeType `json:"size" required:"true" validate:"required"`
+ // REQUIRED
+ Sort PaginationGetSortAttributeType `json:"sort" required:"true" validate:"required"`
+ // REQUIRED
+ TotalPages PaginationGetTotalPagesAttributeType `json:"totalPages" required:"true" validate:"required"`
+ // REQUIRED
+ TotalRows PaginationGetTotalRowsAttributeType `json:"totalRows" required:"true" validate:"required"`
+}
+
+type _Pagination Pagination
+
+// NewPagination instantiates a new Pagination object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewPagination(page PaginationGetPageArgType, size PaginationGetSizeArgType, sort PaginationGetSortArgType, totalPages PaginationGetTotalPagesArgType, totalRows PaginationGetTotalRowsArgType) *Pagination {
+ this := Pagination{}
+ setPaginationGetPageAttributeType(&this.Page, page)
+ setPaginationGetSizeAttributeType(&this.Size, size)
+ setPaginationGetSortAttributeType(&this.Sort, sort)
+ setPaginationGetTotalPagesAttributeType(&this.TotalPages, totalPages)
+ setPaginationGetTotalRowsAttributeType(&this.TotalRows, totalRows)
+ return &this
+}
+
+// NewPaginationWithDefaults instantiates a new Pagination object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewPaginationWithDefaults() *Pagination {
+ this := Pagination{}
+ return &this
+}
+
+// GetPage returns the Page field value
+func (o *Pagination) GetPage() (ret PaginationGetPageRetType) {
+ ret, _ = o.GetPageOk()
+ return ret
+}
+
+// GetPageOk returns a tuple with the Page field value
+// and a boolean to check if the value has been set.
+func (o *Pagination) GetPageOk() (ret PaginationGetPageRetType, ok bool) {
+ return getPaginationGetPageAttributeTypeOk(o.Page)
+}
+
+// SetPage sets field value
+func (o *Pagination) SetPage(v PaginationGetPageRetType) {
+ setPaginationGetPageAttributeType(&o.Page, v)
+}
+
+// GetSize returns the Size field value
+func (o *Pagination) GetSize() (ret PaginationGetSizeRetType) {
+ ret, _ = o.GetSizeOk()
+ return ret
+}
+
+// GetSizeOk returns a tuple with the Size field value
+// and a boolean to check if the value has been set.
+func (o *Pagination) GetSizeOk() (ret PaginationGetSizeRetType, ok bool) {
+ return getPaginationGetSizeAttributeTypeOk(o.Size)
+}
+
+// SetSize sets field value
+func (o *Pagination) SetSize(v PaginationGetSizeRetType) {
+ setPaginationGetSizeAttributeType(&o.Size, v)
+}
+
+// GetSort returns the Sort field value
+func (o *Pagination) GetSort() (ret PaginationGetSortRetType) {
+ ret, _ = o.GetSortOk()
+ return ret
+}
+
+// GetSortOk returns a tuple with the Sort field value
+// and a boolean to check if the value has been set.
+func (o *Pagination) GetSortOk() (ret PaginationGetSortRetType, ok bool) {
+ return getPaginationGetSortAttributeTypeOk(o.Sort)
+}
+
+// SetSort sets field value
+func (o *Pagination) SetSort(v PaginationGetSortRetType) {
+ setPaginationGetSortAttributeType(&o.Sort, v)
+}
+
+// GetTotalPages returns the TotalPages field value
+func (o *Pagination) GetTotalPages() (ret PaginationGetTotalPagesRetType) {
+ ret, _ = o.GetTotalPagesOk()
+ return ret
+}
+
+// GetTotalPagesOk returns a tuple with the TotalPages field value
+// and a boolean to check if the value has been set.
+func (o *Pagination) GetTotalPagesOk() (ret PaginationGetTotalPagesRetType, ok bool) {
+ return getPaginationGetTotalPagesAttributeTypeOk(o.TotalPages)
+}
+
+// SetTotalPages sets field value
+func (o *Pagination) SetTotalPages(v PaginationGetTotalPagesRetType) {
+ setPaginationGetTotalPagesAttributeType(&o.TotalPages, v)
+}
+
+// GetTotalRows returns the TotalRows field value
+func (o *Pagination) GetTotalRows() (ret PaginationGetTotalRowsRetType) {
+ ret, _ = o.GetTotalRowsOk()
+ return ret
+}
+
+// GetTotalRowsOk returns a tuple with the TotalRows field value
+// and a boolean to check if the value has been set.
+func (o *Pagination) GetTotalRowsOk() (ret PaginationGetTotalRowsRetType, ok bool) {
+ return getPaginationGetTotalRowsAttributeTypeOk(o.TotalRows)
+}
+
+// SetTotalRows sets field value
+func (o *Pagination) SetTotalRows(v PaginationGetTotalRowsRetType) {
+ setPaginationGetTotalRowsAttributeType(&o.TotalRows, v)
+}
+
+func (o Pagination) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getPaginationGetPageAttributeTypeOk(o.Page); ok {
+ toSerialize["Page"] = val
+ }
+ if val, ok := getPaginationGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ if val, ok := getPaginationGetSortAttributeTypeOk(o.Sort); ok {
+ toSerialize["Sort"] = val
+ }
+ if val, ok := getPaginationGetTotalPagesAttributeTypeOk(o.TotalPages); ok {
+ toSerialize["TotalPages"] = val
+ }
+ if val, ok := getPaginationGetTotalRowsAttributeTypeOk(o.TotalRows); ok {
+ toSerialize["TotalRows"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullablePagination struct {
+ value *Pagination
+ isSet bool
+}
+
+func (v NullablePagination) Get() *Pagination {
+ return v.value
+}
+
+func (v *NullablePagination) Set(val *Pagination) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullablePagination) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullablePagination) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullablePagination(val *Pagination) *NullablePagination {
+ return &NullablePagination{value: val, isSet: true}
+}
+
+func (v NullablePagination) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullablePagination) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_pagination_test.go b/pkg/sqlserverflexalpha/model_pagination_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_pagination_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_protect_instance_request_payload.go b/pkg/sqlserverflexalpha/model_protect_instance_request_payload.go
new file mode 100644
index 00000000..63d2de8f
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_protect_instance_request_payload.go
@@ -0,0 +1,126 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ProtectInstanceRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ProtectInstanceRequestPayload{}
+
+/*
+ types and functions for isDeletable
+*/
+
+// isBoolean
+type ProtectInstanceRequestPayloadgetIsDeletableAttributeType = *bool
+type ProtectInstanceRequestPayloadgetIsDeletableArgType = bool
+type ProtectInstanceRequestPayloadgetIsDeletableRetType = bool
+
+func getProtectInstanceRequestPayloadgetIsDeletableAttributeTypeOk(arg ProtectInstanceRequestPayloadgetIsDeletableAttributeType) (ret ProtectInstanceRequestPayloadgetIsDeletableRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setProtectInstanceRequestPayloadgetIsDeletableAttributeType(arg *ProtectInstanceRequestPayloadgetIsDeletableAttributeType, val ProtectInstanceRequestPayloadgetIsDeletableRetType) {
+ *arg = &val
+}
+
+// ProtectInstanceRequestPayload struct for ProtectInstanceRequestPayload
+type ProtectInstanceRequestPayload struct {
+ // Protect instance from deletion.
+ // REQUIRED
+ IsDeletable ProtectInstanceRequestPayloadgetIsDeletableAttributeType `json:"isDeletable" required:"true"`
+}
+
+type _ProtectInstanceRequestPayload ProtectInstanceRequestPayload
+
+// NewProtectInstanceRequestPayload instantiates a new ProtectInstanceRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewProtectInstanceRequestPayload(isDeletable ProtectInstanceRequestPayloadgetIsDeletableArgType) *ProtectInstanceRequestPayload {
+ this := ProtectInstanceRequestPayload{}
+ setProtectInstanceRequestPayloadgetIsDeletableAttributeType(&this.IsDeletable, isDeletable)
+ return &this
+}
+
+// NewProtectInstanceRequestPayloadWithDefaults instantiates a new ProtectInstanceRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewProtectInstanceRequestPayloadWithDefaults() *ProtectInstanceRequestPayload {
+ this := ProtectInstanceRequestPayload{}
+ return &this
+}
+
+// GetIsDeletable returns the IsDeletable field value
+func (o *ProtectInstanceRequestPayload) GetIsDeletable() (ret ProtectInstanceRequestPayloadgetIsDeletableRetType) {
+ ret, _ = o.GetIsDeletableOk()
+ return ret
+}
+
+// GetIsDeletableOk returns a tuple with the IsDeletable field value
+// and a boolean to check if the value has been set.
+func (o *ProtectInstanceRequestPayload) GetIsDeletableOk() (ret ProtectInstanceRequestPayloadgetIsDeletableRetType, ok bool) {
+ return getProtectInstanceRequestPayloadgetIsDeletableAttributeTypeOk(o.IsDeletable)
+}
+
+// SetIsDeletable sets field value
+func (o *ProtectInstanceRequestPayload) SetIsDeletable(v ProtectInstanceRequestPayloadgetIsDeletableRetType) {
+ setProtectInstanceRequestPayloadgetIsDeletableAttributeType(&o.IsDeletable, v)
+}
+
+func (o ProtectInstanceRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getProtectInstanceRequestPayloadgetIsDeletableAttributeTypeOk(o.IsDeletable); ok {
+ toSerialize["IsDeletable"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableProtectInstanceRequestPayload struct {
+ value *ProtectInstanceRequestPayload
+ isSet bool
+}
+
+func (v NullableProtectInstanceRequestPayload) Get() *ProtectInstanceRequestPayload {
+ return v.value
+}
+
+func (v *NullableProtectInstanceRequestPayload) Set(val *ProtectInstanceRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableProtectInstanceRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableProtectInstanceRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableProtectInstanceRequestPayload(val *ProtectInstanceRequestPayload) *NullableProtectInstanceRequestPayload {
+ return &NullableProtectInstanceRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableProtectInstanceRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableProtectInstanceRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_protect_instance_request_payload_test.go b/pkg/sqlserverflexalpha/model_protect_instance_request_payload_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_protect_instance_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_protect_instance_response.go b/pkg/sqlserverflexalpha/model_protect_instance_response.go
new file mode 100644
index 00000000..ddbe6ea8
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_protect_instance_response.go
@@ -0,0 +1,126 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ProtectInstanceResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ProtectInstanceResponse{}
+
+/*
+ types and functions for isDeletable
+*/
+
+// isBoolean
+type ProtectInstanceResponsegetIsDeletableAttributeType = *bool
+type ProtectInstanceResponsegetIsDeletableArgType = bool
+type ProtectInstanceResponsegetIsDeletableRetType = bool
+
+func getProtectInstanceResponsegetIsDeletableAttributeTypeOk(arg ProtectInstanceResponsegetIsDeletableAttributeType) (ret ProtectInstanceResponsegetIsDeletableRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setProtectInstanceResponsegetIsDeletableAttributeType(arg *ProtectInstanceResponsegetIsDeletableAttributeType, val ProtectInstanceResponsegetIsDeletableRetType) {
+ *arg = &val
+}
+
+// ProtectInstanceResponse struct for ProtectInstanceResponse
+type ProtectInstanceResponse struct {
+ // Protect instance from deletion.
+ // REQUIRED
+ IsDeletable ProtectInstanceResponsegetIsDeletableAttributeType `json:"isDeletable" required:"true"`
+}
+
+type _ProtectInstanceResponse ProtectInstanceResponse
+
+// NewProtectInstanceResponse instantiates a new ProtectInstanceResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewProtectInstanceResponse(isDeletable ProtectInstanceResponsegetIsDeletableArgType) *ProtectInstanceResponse {
+ this := ProtectInstanceResponse{}
+ setProtectInstanceResponsegetIsDeletableAttributeType(&this.IsDeletable, isDeletable)
+ return &this
+}
+
+// NewProtectInstanceResponseWithDefaults instantiates a new ProtectInstanceResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewProtectInstanceResponseWithDefaults() *ProtectInstanceResponse {
+ this := ProtectInstanceResponse{}
+ return &this
+}
+
+// GetIsDeletable returns the IsDeletable field value
+func (o *ProtectInstanceResponse) GetIsDeletable() (ret ProtectInstanceResponsegetIsDeletableRetType) {
+ ret, _ = o.GetIsDeletableOk()
+ return ret
+}
+
+// GetIsDeletableOk returns a tuple with the IsDeletable field value
+// and a boolean to check if the value has been set.
+func (o *ProtectInstanceResponse) GetIsDeletableOk() (ret ProtectInstanceResponsegetIsDeletableRetType, ok bool) {
+ return getProtectInstanceResponsegetIsDeletableAttributeTypeOk(o.IsDeletable)
+}
+
+// SetIsDeletable sets field value
+func (o *ProtectInstanceResponse) SetIsDeletable(v ProtectInstanceResponsegetIsDeletableRetType) {
+ setProtectInstanceResponsegetIsDeletableAttributeType(&o.IsDeletable, v)
+}
+
+func (o ProtectInstanceResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getProtectInstanceResponsegetIsDeletableAttributeTypeOk(o.IsDeletable); ok {
+ toSerialize["IsDeletable"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableProtectInstanceResponse struct {
+ value *ProtectInstanceResponse
+ isSet bool
+}
+
+func (v NullableProtectInstanceResponse) Get() *ProtectInstanceResponse {
+ return v.value
+}
+
+func (v *NullableProtectInstanceResponse) Set(val *ProtectInstanceResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableProtectInstanceResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableProtectInstanceResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableProtectInstanceResponse(val *ProtectInstanceResponse) *NullableProtectInstanceResponse {
+ return &NullableProtectInstanceResponse{value: val, isSet: true}
+}
+
+func (v NullableProtectInstanceResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableProtectInstanceResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_protect_instance_response_test.go b/pkg/sqlserverflexalpha/model_protect_instance_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_protect_instance_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_replicas.go b/pkg/sqlserverflexalpha/model_replicas.go
new file mode 100644
index 00000000..7871b48c
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_replicas.go
@@ -0,0 +1,115 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// Replicas How many replicas the instance should have.
+type Replicas int32
+
+// List of replicas
+const (
+ REPLICAS__1 Replicas = 1
+ REPLICAS__3 Replicas = 3
+)
+
+// All allowed values of Replicas enum
+var AllowedReplicasEnumValues = []Replicas{
+ 1,
+ 3,
+}
+
+func (v *Replicas) UnmarshalJSON(src []byte) error {
+ var value int32
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue int32
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := Replicas(value)
+ for _, existing := range AllowedReplicasEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid Replicas", value)
+}
+
+// NewReplicasFromValue returns a pointer to a valid Replicas
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewReplicasFromValue(v int32) (*Replicas, error) {
+ ev := Replicas(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for Replicas: valid values are %v", v, AllowedReplicasEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v Replicas) IsValid() bool {
+ for _, existing := range AllowedReplicasEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to replicas value
+func (v Replicas) Ptr() *Replicas {
+ return &v
+}
+
+type NullableReplicas struct {
+ value *Replicas
+ isSet bool
+}
+
+func (v NullableReplicas) Get() *Replicas {
+ return v.value
+}
+
+func (v *NullableReplicas) Set(val *Replicas) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableReplicas) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableReplicas) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableReplicas(val *Replicas) *NullableReplicas {
+ return &NullableReplicas{value: val, isSet: true}
+}
+
+func (v NullableReplicas) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableReplicas) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_replicas_opt.go b/pkg/sqlserverflexalpha/model_replicas_opt.go
new file mode 100644
index 00000000..7a8b311b
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_replicas_opt.go
@@ -0,0 +1,115 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// ReplicasOpt How many replicas the instance should have.
+type ReplicasOpt int32
+
+// List of replicas.opt
+const (
+ REPLICASOPT__1 ReplicasOpt = 1
+ REPLICASOPT__3 ReplicasOpt = 3
+)
+
+// All allowed values of ReplicasOpt enum
+var AllowedReplicasOptEnumValues = []ReplicasOpt{
+ 1,
+ 3,
+}
+
+func (v *ReplicasOpt) UnmarshalJSON(src []byte) error {
+ var value int32
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue int32
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := ReplicasOpt(value)
+ for _, existing := range AllowedReplicasOptEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid ReplicasOpt", value)
+}
+
+// NewReplicasOptFromValue returns a pointer to a valid ReplicasOpt
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewReplicasOptFromValue(v int32) (*ReplicasOpt, error) {
+ ev := ReplicasOpt(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for ReplicasOpt: valid values are %v", v, AllowedReplicasOptEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v ReplicasOpt) IsValid() bool {
+ for _, existing := range AllowedReplicasOptEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to replicas.opt value
+func (v ReplicasOpt) Ptr() *ReplicasOpt {
+ return &v
+}
+
+type NullableReplicasOpt struct {
+ value *ReplicasOpt
+ isSet bool
+}
+
+func (v NullableReplicasOpt) Get() *ReplicasOpt {
+ return v.value
+}
+
+func (v *NullableReplicasOpt) Set(val *ReplicasOpt) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableReplicasOpt) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableReplicasOpt) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableReplicasOpt(val *ReplicasOpt) *NullableReplicasOpt {
+ return &NullableReplicasOpt{value: val, isSet: true}
+}
+
+func (v NullableReplicasOpt) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableReplicasOpt) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_replicas_opt_test.go b/pkg/sqlserverflexalpha/model_replicas_opt_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_replicas_opt_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_replicas_test.go b/pkg/sqlserverflexalpha/model_replicas_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_replicas_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_reset_user_response.go b/pkg/sqlserverflexalpha/model_reset_user_response.go
new file mode 100644
index 00000000..be56cc26
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_reset_user_response.go
@@ -0,0 +1,262 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ResetUserResponse type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ResetUserResponse{}
+
+/*
+ types and functions for password
+*/
+
+// isNotNullableString
+type ResetUserResponseGetPasswordAttributeType = *string
+
+func getResetUserResponseGetPasswordAttributeTypeOk(arg ResetUserResponseGetPasswordAttributeType) (ret ResetUserResponseGetPasswordRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setResetUserResponseGetPasswordAttributeType(arg *ResetUserResponseGetPasswordAttributeType, val ResetUserResponseGetPasswordRetType) {
+ *arg = &val
+}
+
+type ResetUserResponseGetPasswordArgType = string
+type ResetUserResponseGetPasswordRetType = string
+
+/*
+ types and functions for status
+*/
+
+// isNotNullableString
+type ResetUserResponseGetStatusAttributeType = *string
+
+func getResetUserResponseGetStatusAttributeTypeOk(arg ResetUserResponseGetStatusAttributeType) (ret ResetUserResponseGetStatusRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setResetUserResponseGetStatusAttributeType(arg *ResetUserResponseGetStatusAttributeType, val ResetUserResponseGetStatusRetType) {
+ *arg = &val
+}
+
+type ResetUserResponseGetStatusArgType = string
+type ResetUserResponseGetStatusRetType = string
+
+/*
+ types and functions for uri
+*/
+
+// isNotNullableString
+type ResetUserResponseGetUriAttributeType = *string
+
+func getResetUserResponseGetUriAttributeTypeOk(arg ResetUserResponseGetUriAttributeType) (ret ResetUserResponseGetUriRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setResetUserResponseGetUriAttributeType(arg *ResetUserResponseGetUriAttributeType, val ResetUserResponseGetUriRetType) {
+ *arg = &val
+}
+
+type ResetUserResponseGetUriArgType = string
+type ResetUserResponseGetUriRetType = string
+
+/*
+ types and functions for username
+*/
+
+// isNotNullableString
+type ResetUserResponseGetUsernameAttributeType = *string
+
+func getResetUserResponseGetUsernameAttributeTypeOk(arg ResetUserResponseGetUsernameAttributeType) (ret ResetUserResponseGetUsernameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setResetUserResponseGetUsernameAttributeType(arg *ResetUserResponseGetUsernameAttributeType, val ResetUserResponseGetUsernameRetType) {
+ *arg = &val
+}
+
+type ResetUserResponseGetUsernameArgType = string
+type ResetUserResponseGetUsernameRetType = string
+
+// ResetUserResponse struct for ResetUserResponse
+type ResetUserResponse struct {
+ // The password for the user.
+ // REQUIRED
+ Password ResetUserResponseGetPasswordAttributeType `json:"password" required:"true"`
+ // The current status of the user.
+ // REQUIRED
+ Status ResetUserResponseGetStatusAttributeType `json:"status" required:"true"`
+ // The connection string for the user to the instance.
+ // REQUIRED
+ Uri ResetUserResponseGetUriAttributeType `json:"uri" required:"true"`
+ // The name of the user.
+ // REQUIRED
+ Username ResetUserResponseGetUsernameAttributeType `json:"username" required:"true"`
+}
+
+type _ResetUserResponse ResetUserResponse
+
+// NewResetUserResponse instantiates a new ResetUserResponse object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewResetUserResponse(password ResetUserResponseGetPasswordArgType, status ResetUserResponseGetStatusArgType, uri ResetUserResponseGetUriArgType, username ResetUserResponseGetUsernameArgType) *ResetUserResponse {
+ this := ResetUserResponse{}
+ setResetUserResponseGetPasswordAttributeType(&this.Password, password)
+ setResetUserResponseGetStatusAttributeType(&this.Status, status)
+ setResetUserResponseGetUriAttributeType(&this.Uri, uri)
+ setResetUserResponseGetUsernameAttributeType(&this.Username, username)
+ return &this
+}
+
+// NewResetUserResponseWithDefaults instantiates a new ResetUserResponse object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewResetUserResponseWithDefaults() *ResetUserResponse {
+ this := ResetUserResponse{}
+ return &this
+}
+
+// GetPassword returns the Password field value
+func (o *ResetUserResponse) GetPassword() (ret ResetUserResponseGetPasswordRetType) {
+ ret, _ = o.GetPasswordOk()
+ return ret
+}
+
+// GetPasswordOk returns a tuple with the Password field value
+// and a boolean to check if the value has been set.
+func (o *ResetUserResponse) GetPasswordOk() (ret ResetUserResponseGetPasswordRetType, ok bool) {
+ return getResetUserResponseGetPasswordAttributeTypeOk(o.Password)
+}
+
+// SetPassword sets field value
+func (o *ResetUserResponse) SetPassword(v ResetUserResponseGetPasswordRetType) {
+ setResetUserResponseGetPasswordAttributeType(&o.Password, v)
+}
+
+// GetStatus returns the Status field value
+func (o *ResetUserResponse) GetStatus() (ret ResetUserResponseGetStatusRetType) {
+ ret, _ = o.GetStatusOk()
+ return ret
+}
+
+// GetStatusOk returns a tuple with the Status field value
+// and a boolean to check if the value has been set.
+func (o *ResetUserResponse) GetStatusOk() (ret ResetUserResponseGetStatusRetType, ok bool) {
+ return getResetUserResponseGetStatusAttributeTypeOk(o.Status)
+}
+
+// SetStatus sets field value
+func (o *ResetUserResponse) SetStatus(v ResetUserResponseGetStatusRetType) {
+ setResetUserResponseGetStatusAttributeType(&o.Status, v)
+}
+
+// GetUri returns the Uri field value
+func (o *ResetUserResponse) GetUri() (ret ResetUserResponseGetUriRetType) {
+ ret, _ = o.GetUriOk()
+ return ret
+}
+
+// GetUriOk returns a tuple with the Uri field value
+// and a boolean to check if the value has been set.
+func (o *ResetUserResponse) GetUriOk() (ret ResetUserResponseGetUriRetType, ok bool) {
+ return getResetUserResponseGetUriAttributeTypeOk(o.Uri)
+}
+
+// SetUri sets field value
+func (o *ResetUserResponse) SetUri(v ResetUserResponseGetUriRetType) {
+ setResetUserResponseGetUriAttributeType(&o.Uri, v)
+}
+
+// GetUsername returns the Username field value
+func (o *ResetUserResponse) GetUsername() (ret ResetUserResponseGetUsernameRetType) {
+ ret, _ = o.GetUsernameOk()
+ return ret
+}
+
+// GetUsernameOk returns a tuple with the Username field value
+// and a boolean to check if the value has been set.
+func (o *ResetUserResponse) GetUsernameOk() (ret ResetUserResponseGetUsernameRetType, ok bool) {
+ return getResetUserResponseGetUsernameAttributeTypeOk(o.Username)
+}
+
+// SetUsername sets field value
+func (o *ResetUserResponse) SetUsername(v ResetUserResponseGetUsernameRetType) {
+ setResetUserResponseGetUsernameAttributeType(&o.Username, v)
+}
+
+func (o ResetUserResponse) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getResetUserResponseGetPasswordAttributeTypeOk(o.Password); ok {
+ toSerialize["Password"] = val
+ }
+ if val, ok := getResetUserResponseGetStatusAttributeTypeOk(o.Status); ok {
+ toSerialize["Status"] = val
+ }
+ if val, ok := getResetUserResponseGetUriAttributeTypeOk(o.Uri); ok {
+ toSerialize["Uri"] = val
+ }
+ if val, ok := getResetUserResponseGetUsernameAttributeTypeOk(o.Username); ok {
+ toSerialize["Username"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableResetUserResponse struct {
+ value *ResetUserResponse
+ isSet bool
+}
+
+func (v NullableResetUserResponse) Get() *ResetUserResponse {
+ return v.value
+}
+
+func (v *NullableResetUserResponse) Set(val *ResetUserResponse) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableResetUserResponse) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableResetUserResponse) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableResetUserResponse(val *ResetUserResponse) *NullableResetUserResponse {
+ return &NullableResetUserResponse{value: val, isSet: true}
+}
+
+func (v NullableResetUserResponse) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableResetUserResponse) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_reset_user_response_test.go b/pkg/sqlserverflexalpha/model_reset_user_response_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_reset_user_response_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_status.go b/pkg/sqlserverflexalpha/model_status.go
new file mode 100644
index 00000000..fb85da4a
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_status.go
@@ -0,0 +1,123 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// Status the model 'Status'
+type Status string
+
+// List of status
+const (
+ STATUS_READY Status = "READY"
+ STATUS_PENDING Status = "PENDING"
+ STATUS_PROGRESSING Status = "PROGRESSING"
+ STATUS_FAILURE Status = "FAILURE"
+ STATUS_UNKNOWN Status = "UNKNOWN"
+ STATUS_TERMINATING Status = "TERMINATING"
+)
+
+// All allowed values of Status enum
+var AllowedStatusEnumValues = []Status{
+ "READY",
+ "PENDING",
+ "PROGRESSING",
+ "FAILURE",
+ "UNKNOWN",
+ "TERMINATING",
+}
+
+func (v *Status) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := Status(value)
+ for _, existing := range AllowedStatusEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid Status", value)
+}
+
+// NewStatusFromValue returns a pointer to a valid Status
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewStatusFromValue(v string) (*Status, error) {
+ ev := Status(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for Status: valid values are %v", v, AllowedStatusEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v Status) IsValid() bool {
+ for _, existing := range AllowedStatusEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to status value
+func (v Status) Ptr() *Status {
+ return &v
+}
+
+type NullableStatus struct {
+ value *Status
+ isSet bool
+}
+
+func (v NullableStatus) Get() *Status {
+ return v.value
+}
+
+func (v *NullableStatus) Set(val *Status) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableStatus) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableStatus) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableStatus(val *Status) *NullableStatus {
+ return &NullableStatus{value: val, isSet: true}
+}
+
+func (v NullableStatus) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableStatus) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_status_test.go b/pkg/sqlserverflexalpha/model_status_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_status_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_storage.go b/pkg/sqlserverflexalpha/model_storage.go
new file mode 100644
index 00000000..a5dd0f51
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_storage.go
@@ -0,0 +1,177 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the Storage type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &Storage{}
+
+/*
+ types and functions for class
+*/
+
+// isNotNullableString
+type StorageGetClassAttributeType = *string
+
+func getStorageGetClassAttributeTypeOk(arg StorageGetClassAttributeType) (ret StorageGetClassRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setStorageGetClassAttributeType(arg *StorageGetClassAttributeType, val StorageGetClassRetType) {
+ *arg = &val
+}
+
+type StorageGetClassArgType = string
+type StorageGetClassRetType = string
+
+/*
+ types and functions for size
+*/
+
+// isLong
+type StorageGetSizeAttributeType = *int64
+type StorageGetSizeArgType = int64
+type StorageGetSizeRetType = int64
+
+func getStorageGetSizeAttributeTypeOk(arg StorageGetSizeAttributeType) (ret StorageGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setStorageGetSizeAttributeType(arg *StorageGetSizeAttributeType, val StorageGetSizeRetType) {
+ *arg = &val
+}
+
+// Storage The object containing information about the storage size and class.
+type Storage struct {
+ // The storage class for the storage.
+ Class StorageGetClassAttributeType `json:"class,omitempty"`
+ // The storage size in Gigabytes.
+ Size StorageGetSizeAttributeType `json:"size,omitempty"`
+}
+
+// NewStorage instantiates a new Storage object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewStorage() *Storage {
+ this := Storage{}
+ return &this
+}
+
+// NewStorageWithDefaults instantiates a new Storage object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewStorageWithDefaults() *Storage {
+ this := Storage{}
+ return &this
+}
+
+// GetClass returns the Class field value if set, zero value otherwise.
+func (o *Storage) GetClass() (res StorageGetClassRetType) {
+ res, _ = o.GetClassOk()
+ return
+}
+
+// GetClassOk returns a tuple with the Class field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *Storage) GetClassOk() (ret StorageGetClassRetType, ok bool) {
+ return getStorageGetClassAttributeTypeOk(o.Class)
+}
+
+// HasClass returns a boolean if a field has been set.
+func (o *Storage) HasClass() bool {
+ _, ok := o.GetClassOk()
+ return ok
+}
+
+// SetClass gets a reference to the given string and assigns it to the Class field.
+func (o *Storage) SetClass(v StorageGetClassRetType) {
+ setStorageGetClassAttributeType(&o.Class, v)
+}
+
+// GetSize returns the Size field value if set, zero value otherwise.
+func (o *Storage) GetSize() (res StorageGetSizeRetType) {
+ res, _ = o.GetSizeOk()
+ return
+}
+
+// GetSizeOk returns a tuple with the Size field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *Storage) GetSizeOk() (ret StorageGetSizeRetType, ok bool) {
+ return getStorageGetSizeAttributeTypeOk(o.Size)
+}
+
+// HasSize returns a boolean if a field has been set.
+func (o *Storage) HasSize() bool {
+ _, ok := o.GetSizeOk()
+ return ok
+}
+
+// SetSize gets a reference to the given int64 and assigns it to the Size field.
+func (o *Storage) SetSize(v StorageGetSizeRetType) {
+ setStorageGetSizeAttributeType(&o.Size, v)
+}
+
+func (o Storage) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getStorageGetClassAttributeTypeOk(o.Class); ok {
+ toSerialize["Class"] = val
+ }
+ if val, ok := getStorageGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableStorage struct {
+ value *Storage
+ isSet bool
+}
+
+func (v NullableStorage) Get() *Storage {
+ return v.value
+}
+
+func (v *NullableStorage) Set(val *Storage) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableStorage) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableStorage) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableStorage(val *Storage) *NullableStorage {
+ return &NullableStorage{value: val, isSet: true}
+}
+
+func (v NullableStorage) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableStorage) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_storage_create.go b/pkg/sqlserverflexalpha/model_storage_create.go
new file mode 100644
index 00000000..5b9031ea
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_storage_create.go
@@ -0,0 +1,171 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the StorageCreate type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &StorageCreate{}
+
+/*
+ types and functions for class
+*/
+
+// isNotNullableString
+type StorageCreateGetClassAttributeType = *string
+
+func getStorageCreateGetClassAttributeTypeOk(arg StorageCreateGetClassAttributeType) (ret StorageCreateGetClassRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setStorageCreateGetClassAttributeType(arg *StorageCreateGetClassAttributeType, val StorageCreateGetClassRetType) {
+ *arg = &val
+}
+
+type StorageCreateGetClassArgType = string
+type StorageCreateGetClassRetType = string
+
+/*
+ types and functions for size
+*/
+
+// isLong
+type StorageCreateGetSizeAttributeType = *int64
+type StorageCreateGetSizeArgType = int64
+type StorageCreateGetSizeRetType = int64
+
+func getStorageCreateGetSizeAttributeTypeOk(arg StorageCreateGetSizeAttributeType) (ret StorageCreateGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setStorageCreateGetSizeAttributeType(arg *StorageCreateGetSizeAttributeType, val StorageCreateGetSizeRetType) {
+ *arg = &val
+}
+
+// StorageCreate The object containing information about the storage size and class.
+type StorageCreate struct {
+ // The storage class for the storage.
+ // REQUIRED
+ Class StorageCreateGetClassAttributeType `json:"class" required:"true"`
+ // The storage size in Gigabytes.
+ // REQUIRED
+ Size StorageCreateGetSizeAttributeType `json:"size" required:"true"`
+}
+
+type _StorageCreate StorageCreate
+
+// NewStorageCreate instantiates a new StorageCreate object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewStorageCreate(class StorageCreateGetClassArgType, size StorageCreateGetSizeArgType) *StorageCreate {
+ this := StorageCreate{}
+ setStorageCreateGetClassAttributeType(&this.Class, class)
+ setStorageCreateGetSizeAttributeType(&this.Size, size)
+ return &this
+}
+
+// NewStorageCreateWithDefaults instantiates a new StorageCreate object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewStorageCreateWithDefaults() *StorageCreate {
+ this := StorageCreate{}
+ return &this
+}
+
+// GetClass returns the Class field value
+func (o *StorageCreate) GetClass() (ret StorageCreateGetClassRetType) {
+ ret, _ = o.GetClassOk()
+ return ret
+}
+
+// GetClassOk returns a tuple with the Class field value
+// and a boolean to check if the value has been set.
+func (o *StorageCreate) GetClassOk() (ret StorageCreateGetClassRetType, ok bool) {
+ return getStorageCreateGetClassAttributeTypeOk(o.Class)
+}
+
+// SetClass sets field value
+func (o *StorageCreate) SetClass(v StorageCreateGetClassRetType) {
+ setStorageCreateGetClassAttributeType(&o.Class, v)
+}
+
+// GetSize returns the Size field value
+func (o *StorageCreate) GetSize() (ret StorageCreateGetSizeRetType) {
+ ret, _ = o.GetSizeOk()
+ return ret
+}
+
+// GetSizeOk returns a tuple with the Size field value
+// and a boolean to check if the value has been set.
+func (o *StorageCreate) GetSizeOk() (ret StorageCreateGetSizeRetType, ok bool) {
+ return getStorageCreateGetSizeAttributeTypeOk(o.Size)
+}
+
+// SetSize sets field value
+func (o *StorageCreate) SetSize(v StorageCreateGetSizeRetType) {
+ setStorageCreateGetSizeAttributeType(&o.Size, v)
+}
+
+func (o StorageCreate) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getStorageCreateGetClassAttributeTypeOk(o.Class); ok {
+ toSerialize["Class"] = val
+ }
+ if val, ok := getStorageCreateGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableStorageCreate struct {
+ value *StorageCreate
+ isSet bool
+}
+
+func (v NullableStorageCreate) Get() *StorageCreate {
+ return v.value
+}
+
+func (v *NullableStorageCreate) Set(val *StorageCreate) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableStorageCreate) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableStorageCreate) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableStorageCreate(val *StorageCreate) *NullableStorageCreate {
+ return &NullableStorageCreate{value: val, isSet: true}
+}
+
+func (v NullableStorageCreate) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableStorageCreate) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_storage_create_test.go b/pkg/sqlserverflexalpha/model_storage_create_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_storage_create_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_storage_test.go b/pkg/sqlserverflexalpha/model_storage_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_storage_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_storage_update.go b/pkg/sqlserverflexalpha/model_storage_update.go
new file mode 100644
index 00000000..05509b6c
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_storage_update.go
@@ -0,0 +1,128 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the StorageUpdate type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &StorageUpdate{}
+
+/*
+ types and functions for size
+*/
+
+// isLong
+type StorageUpdateGetSizeAttributeType = *int64
+type StorageUpdateGetSizeArgType = int64
+type StorageUpdateGetSizeRetType = int64
+
+func getStorageUpdateGetSizeAttributeTypeOk(arg StorageUpdateGetSizeAttributeType) (ret StorageUpdateGetSizeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setStorageUpdateGetSizeAttributeType(arg *StorageUpdateGetSizeAttributeType, val StorageUpdateGetSizeRetType) {
+ *arg = &val
+}
+
+// StorageUpdate The object containing information about the storage size and class.
+type StorageUpdate struct {
+ // The storage size in Gigabytes.
+ Size StorageUpdateGetSizeAttributeType `json:"size,omitempty"`
+}
+
+// NewStorageUpdate instantiates a new StorageUpdate object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewStorageUpdate() *StorageUpdate {
+ this := StorageUpdate{}
+ return &this
+}
+
+// NewStorageUpdateWithDefaults instantiates a new StorageUpdate object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewStorageUpdateWithDefaults() *StorageUpdate {
+ this := StorageUpdate{}
+ return &this
+}
+
+// GetSize returns the Size field value if set, zero value otherwise.
+func (o *StorageUpdate) GetSize() (res StorageUpdateGetSizeRetType) {
+ res, _ = o.GetSizeOk()
+ return
+}
+
+// GetSizeOk returns a tuple with the Size field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *StorageUpdate) GetSizeOk() (ret StorageUpdateGetSizeRetType, ok bool) {
+ return getStorageUpdateGetSizeAttributeTypeOk(o.Size)
+}
+
+// HasSize returns a boolean if a field has been set.
+func (o *StorageUpdate) HasSize() bool {
+ _, ok := o.GetSizeOk()
+ return ok
+}
+
+// SetSize gets a reference to the given int64 and assigns it to the Size field.
+func (o *StorageUpdate) SetSize(v StorageUpdateGetSizeRetType) {
+ setStorageUpdateGetSizeAttributeType(&o.Size, v)
+}
+
+func (o StorageUpdate) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getStorageUpdateGetSizeAttributeTypeOk(o.Size); ok {
+ toSerialize["Size"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableStorageUpdate struct {
+ value *StorageUpdate
+ isSet bool
+}
+
+func (v NullableStorageUpdate) Get() *StorageUpdate {
+ return v.value
+}
+
+func (v *NullableStorageUpdate) Set(val *StorageUpdate) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableStorageUpdate) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableStorageUpdate) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableStorageUpdate(val *StorageUpdate) *NullableStorageUpdate {
+ return &NullableStorageUpdate{value: val, isSet: true}
+}
+
+func (v NullableStorageUpdate) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableStorageUpdate) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_storage_update_test.go b/pkg/sqlserverflexalpha/model_storage_update_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_storage_update_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_trigger_restore_request_payload.go b/pkg/sqlserverflexalpha/model_trigger_restore_request_payload.go
new file mode 100644
index 00000000..560d05ef
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_trigger_restore_request_payload.go
@@ -0,0 +1,172 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the TriggerRestoreRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &TriggerRestoreRequestPayload{}
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type TriggerRestoreRequestPayloadGetNameAttributeType = *string
+
+func getTriggerRestoreRequestPayloadGetNameAttributeTypeOk(arg TriggerRestoreRequestPayloadGetNameAttributeType) (ret TriggerRestoreRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setTriggerRestoreRequestPayloadGetNameAttributeType(arg *TriggerRestoreRequestPayloadGetNameAttributeType, val TriggerRestoreRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type TriggerRestoreRequestPayloadGetNameArgType = string
+type TriggerRestoreRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for restoreDateTime
+*/
+
+// isNotNullableString
+type TriggerRestoreRequestPayloadGetRestoreDateTimeAttributeType = *string
+
+func getTriggerRestoreRequestPayloadGetRestoreDateTimeAttributeTypeOk(arg TriggerRestoreRequestPayloadGetRestoreDateTimeAttributeType) (ret TriggerRestoreRequestPayloadGetRestoreDateTimeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setTriggerRestoreRequestPayloadGetRestoreDateTimeAttributeType(arg *TriggerRestoreRequestPayloadGetRestoreDateTimeAttributeType, val TriggerRestoreRequestPayloadGetRestoreDateTimeRetType) {
+ *arg = &val
+}
+
+type TriggerRestoreRequestPayloadGetRestoreDateTimeArgType = string
+type TriggerRestoreRequestPayloadGetRestoreDateTimeRetType = string
+
+// TriggerRestoreRequestPayload struct for TriggerRestoreRequestPayload
+type TriggerRestoreRequestPayload struct {
+ // The name of the database.
+ // REQUIRED
+ Name TriggerRestoreRequestPayloadGetNameAttributeType `json:"name" required:"true"`
+ // the time for the restore it will be calculated between first backup and last backup
+ // REQUIRED
+ RestoreDateTime TriggerRestoreRequestPayloadGetRestoreDateTimeAttributeType `json:"restoreDateTime" required:"true"`
+}
+
+type _TriggerRestoreRequestPayload TriggerRestoreRequestPayload
+
+// NewTriggerRestoreRequestPayload instantiates a new TriggerRestoreRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewTriggerRestoreRequestPayload(name TriggerRestoreRequestPayloadGetNameArgType, restoreDateTime TriggerRestoreRequestPayloadGetRestoreDateTimeArgType) *TriggerRestoreRequestPayload {
+ this := TriggerRestoreRequestPayload{}
+ setTriggerRestoreRequestPayloadGetNameAttributeType(&this.Name, name)
+ setTriggerRestoreRequestPayloadGetRestoreDateTimeAttributeType(&this.RestoreDateTime, restoreDateTime)
+ return &this
+}
+
+// NewTriggerRestoreRequestPayloadWithDefaults instantiates a new TriggerRestoreRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewTriggerRestoreRequestPayloadWithDefaults() *TriggerRestoreRequestPayload {
+ this := TriggerRestoreRequestPayload{}
+ return &this
+}
+
+// GetName returns the Name field value
+func (o *TriggerRestoreRequestPayload) GetName() (ret TriggerRestoreRequestPayloadGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *TriggerRestoreRequestPayload) GetNameOk() (ret TriggerRestoreRequestPayloadGetNameRetType, ok bool) {
+ return getTriggerRestoreRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *TriggerRestoreRequestPayload) SetName(v TriggerRestoreRequestPayloadGetNameRetType) {
+ setTriggerRestoreRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetRestoreDateTime returns the RestoreDateTime field value
+func (o *TriggerRestoreRequestPayload) GetRestoreDateTime() (ret TriggerRestoreRequestPayloadGetRestoreDateTimeRetType) {
+ ret, _ = o.GetRestoreDateTimeOk()
+ return ret
+}
+
+// GetRestoreDateTimeOk returns a tuple with the RestoreDateTime field value
+// and a boolean to check if the value has been set.
+func (o *TriggerRestoreRequestPayload) GetRestoreDateTimeOk() (ret TriggerRestoreRequestPayloadGetRestoreDateTimeRetType, ok bool) {
+ return getTriggerRestoreRequestPayloadGetRestoreDateTimeAttributeTypeOk(o.RestoreDateTime)
+}
+
+// SetRestoreDateTime sets field value
+func (o *TriggerRestoreRequestPayload) SetRestoreDateTime(v TriggerRestoreRequestPayloadGetRestoreDateTimeRetType) {
+ setTriggerRestoreRequestPayloadGetRestoreDateTimeAttributeType(&o.RestoreDateTime, v)
+}
+
+func (o TriggerRestoreRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getTriggerRestoreRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getTriggerRestoreRequestPayloadGetRestoreDateTimeAttributeTypeOk(o.RestoreDateTime); ok {
+ toSerialize["RestoreDateTime"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableTriggerRestoreRequestPayload struct {
+ value *TriggerRestoreRequestPayload
+ isSet bool
+}
+
+func (v NullableTriggerRestoreRequestPayload) Get() *TriggerRestoreRequestPayload {
+ return v.value
+}
+
+func (v *NullableTriggerRestoreRequestPayload) Set(val *TriggerRestoreRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableTriggerRestoreRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableTriggerRestoreRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableTriggerRestoreRequestPayload(val *TriggerRestoreRequestPayload) *NullableTriggerRestoreRequestPayload {
+ return &NullableTriggerRestoreRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableTriggerRestoreRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableTriggerRestoreRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_trigger_restore_request_payload_test.go b/pkg/sqlserverflexalpha/model_trigger_restore_request_payload_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_trigger_restore_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_update_instance_partially_request_payload.go b/pkg/sqlserverflexalpha/model_update_instance_partially_request_payload.go
new file mode 100644
index 00000000..cfe78435
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_update_instance_partially_request_payload.go
@@ -0,0 +1,464 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the UpdateInstancePartiallyRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &UpdateInstancePartiallyRequestPayload{}
+
+/*
+ types and functions for acl
+*/
+
+// isArray
+type UpdateInstancePartiallyRequestPayloadGetAclAttributeType = *[]string
+type UpdateInstancePartiallyRequestPayloadGetAclArgType = []string
+type UpdateInstancePartiallyRequestPayloadGetAclRetType = []string
+
+func getUpdateInstancePartiallyRequestPayloadGetAclAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetAclAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetAclRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetAclAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetAclAttributeType, val UpdateInstancePartiallyRequestPayloadGetAclRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for backupSchedule
+*/
+
+// isNotNullableString
+type UpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeType = *string
+
+func getUpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetBackupScheduleRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeType, val UpdateInstancePartiallyRequestPayloadGetBackupScheduleRetType) {
+ *arg = &val
+}
+
+type UpdateInstancePartiallyRequestPayloadGetBackupScheduleArgType = string
+type UpdateInstancePartiallyRequestPayloadGetBackupScheduleRetType = string
+
+/*
+ types and functions for flavorId
+*/
+
+// isNotNullableString
+type UpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeType = *string
+
+func getUpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetFlavorIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeType, val UpdateInstancePartiallyRequestPayloadGetFlavorIdRetType) {
+ *arg = &val
+}
+
+type UpdateInstancePartiallyRequestPayloadGetFlavorIdArgType = string
+type UpdateInstancePartiallyRequestPayloadGetFlavorIdRetType = string
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type UpdateInstancePartiallyRequestPayloadGetNameAttributeType = *string
+
+func getUpdateInstancePartiallyRequestPayloadGetNameAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetNameAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetNameAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetNameAttributeType, val UpdateInstancePartiallyRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type UpdateInstancePartiallyRequestPayloadGetNameArgType = string
+type UpdateInstancePartiallyRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for replicas
+*/
+
+// isEnumRef
+type UpdateInstancePartiallyRequestPayloadGetReplicasAttributeType = *ReplicasOpt
+type UpdateInstancePartiallyRequestPayloadGetReplicasArgType = ReplicasOpt
+type UpdateInstancePartiallyRequestPayloadGetReplicasRetType = ReplicasOpt
+
+func getUpdateInstancePartiallyRequestPayloadGetReplicasAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetReplicasAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetReplicasRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetReplicasAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetReplicasAttributeType, val UpdateInstancePartiallyRequestPayloadGetReplicasRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for retentionDays
+*/
+
+// isInteger
+type UpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeType = *int64
+type UpdateInstancePartiallyRequestPayloadGetRetentionDaysArgType = int64
+type UpdateInstancePartiallyRequestPayloadGetRetentionDaysRetType = int64
+
+func getUpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetRetentionDaysRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeType, val UpdateInstancePartiallyRequestPayloadGetRetentionDaysRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for storage
+*/
+
+// isModel
+type UpdateInstancePartiallyRequestPayloadGetStorageAttributeType = *StorageUpdate
+type UpdateInstancePartiallyRequestPayloadGetStorageArgType = StorageUpdate
+type UpdateInstancePartiallyRequestPayloadGetStorageRetType = StorageUpdate
+
+func getUpdateInstancePartiallyRequestPayloadGetStorageAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetStorageAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetStorageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetStorageAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetStorageAttributeType, val UpdateInstancePartiallyRequestPayloadGetStorageRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for version
+*/
+
+// isEnumRef
+type UpdateInstancePartiallyRequestPayloadGetVersionAttributeType = *InstanceVersionOpt
+type UpdateInstancePartiallyRequestPayloadGetVersionArgType = InstanceVersionOpt
+type UpdateInstancePartiallyRequestPayloadGetVersionRetType = InstanceVersionOpt
+
+func getUpdateInstancePartiallyRequestPayloadGetVersionAttributeTypeOk(arg UpdateInstancePartiallyRequestPayloadGetVersionAttributeType) (ret UpdateInstancePartiallyRequestPayloadGetVersionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstancePartiallyRequestPayloadGetVersionAttributeType(arg *UpdateInstancePartiallyRequestPayloadGetVersionAttributeType, val UpdateInstancePartiallyRequestPayloadGetVersionRetType) {
+ *arg = &val
+}
+
+// UpdateInstancePartiallyRequestPayload struct for UpdateInstancePartiallyRequestPayload
+type UpdateInstancePartiallyRequestPayload struct {
+ // List of IPV4 cidr.
+ Acl UpdateInstancePartiallyRequestPayloadGetAclAttributeType `json:"acl,omitempty"`
+ // The schedule for on what time and how often the database backup will be created. The schedule is written as a cron schedule.
+ BackupSchedule UpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeType `json:"backupSchedule,omitempty"`
+ // The id of the instance flavor.
+ FlavorId UpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeType `json:"flavorId,omitempty"`
+ // The name of the instance.
+ Name UpdateInstancePartiallyRequestPayloadGetNameAttributeType `json:"name,omitempty"`
+ Replicas UpdateInstancePartiallyRequestPayloadGetReplicasAttributeType `json:"replicas,omitempty"`
+ // Can be cast to int32 without loss of precision.
+ RetentionDays UpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeType `json:"retentionDays,omitempty"`
+ Storage UpdateInstancePartiallyRequestPayloadGetStorageAttributeType `json:"storage,omitempty"`
+ Version UpdateInstancePartiallyRequestPayloadGetVersionAttributeType `json:"version,omitempty"`
+}
+
+// NewUpdateInstancePartiallyRequestPayload instantiates a new UpdateInstancePartiallyRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewUpdateInstancePartiallyRequestPayload() *UpdateInstancePartiallyRequestPayload {
+ this := UpdateInstancePartiallyRequestPayload{}
+ return &this
+}
+
+// NewUpdateInstancePartiallyRequestPayloadWithDefaults instantiates a new UpdateInstancePartiallyRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewUpdateInstancePartiallyRequestPayloadWithDefaults() *UpdateInstancePartiallyRequestPayload {
+ this := UpdateInstancePartiallyRequestPayload{}
+ return &this
+}
+
+// GetAcl returns the Acl field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetAcl() (res UpdateInstancePartiallyRequestPayloadGetAclRetType) {
+ res, _ = o.GetAclOk()
+ return
+}
+
+// GetAclOk returns a tuple with the Acl field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetAclOk() (ret UpdateInstancePartiallyRequestPayloadGetAclRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetAclAttributeTypeOk(o.Acl)
+}
+
+// HasAcl returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasAcl() bool {
+ _, ok := o.GetAclOk()
+ return ok
+}
+
+// SetAcl gets a reference to the given []string and assigns it to the Acl field.
+func (o *UpdateInstancePartiallyRequestPayload) SetAcl(v UpdateInstancePartiallyRequestPayloadGetAclRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetAclAttributeType(&o.Acl, v)
+}
+
+// GetBackupSchedule returns the BackupSchedule field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetBackupSchedule() (res UpdateInstancePartiallyRequestPayloadGetBackupScheduleRetType) {
+ res, _ = o.GetBackupScheduleOk()
+ return
+}
+
+// GetBackupScheduleOk returns a tuple with the BackupSchedule field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetBackupScheduleOk() (ret UpdateInstancePartiallyRequestPayloadGetBackupScheduleRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeTypeOk(o.BackupSchedule)
+}
+
+// HasBackupSchedule returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasBackupSchedule() bool {
+ _, ok := o.GetBackupScheduleOk()
+ return ok
+}
+
+// SetBackupSchedule gets a reference to the given string and assigns it to the BackupSchedule field.
+func (o *UpdateInstancePartiallyRequestPayload) SetBackupSchedule(v UpdateInstancePartiallyRequestPayloadGetBackupScheduleRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeType(&o.BackupSchedule, v)
+}
+
+// GetFlavorId returns the FlavorId field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetFlavorId() (res UpdateInstancePartiallyRequestPayloadGetFlavorIdRetType) {
+ res, _ = o.GetFlavorIdOk()
+ return
+}
+
+// GetFlavorIdOk returns a tuple with the FlavorId field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetFlavorIdOk() (ret UpdateInstancePartiallyRequestPayloadGetFlavorIdRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeTypeOk(o.FlavorId)
+}
+
+// HasFlavorId returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasFlavorId() bool {
+ _, ok := o.GetFlavorIdOk()
+ return ok
+}
+
+// SetFlavorId gets a reference to the given string and assigns it to the FlavorId field.
+func (o *UpdateInstancePartiallyRequestPayload) SetFlavorId(v UpdateInstancePartiallyRequestPayloadGetFlavorIdRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeType(&o.FlavorId, v)
+}
+
+// GetName returns the Name field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetName() (res UpdateInstancePartiallyRequestPayloadGetNameRetType) {
+ res, _ = o.GetNameOk()
+ return
+}
+
+// GetNameOk returns a tuple with the Name field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetNameOk() (ret UpdateInstancePartiallyRequestPayloadGetNameRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// HasName returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasName() bool {
+ _, ok := o.GetNameOk()
+ return ok
+}
+
+// SetName gets a reference to the given string and assigns it to the Name field.
+func (o *UpdateInstancePartiallyRequestPayload) SetName(v UpdateInstancePartiallyRequestPayloadGetNameRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetReplicas returns the Replicas field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetReplicas() (res UpdateInstancePartiallyRequestPayloadGetReplicasRetType) {
+ res, _ = o.GetReplicasOk()
+ return
+}
+
+// GetReplicasOk returns a tuple with the Replicas field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetReplicasOk() (ret UpdateInstancePartiallyRequestPayloadGetReplicasRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetReplicasAttributeTypeOk(o.Replicas)
+}
+
+// HasReplicas returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasReplicas() bool {
+ _, ok := o.GetReplicasOk()
+ return ok
+}
+
+// SetReplicas gets a reference to the given ReplicasOpt and assigns it to the Replicas field.
+func (o *UpdateInstancePartiallyRequestPayload) SetReplicas(v UpdateInstancePartiallyRequestPayloadGetReplicasRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetReplicasAttributeType(&o.Replicas, v)
+}
+
+// GetRetentionDays returns the RetentionDays field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetRetentionDays() (res UpdateInstancePartiallyRequestPayloadGetRetentionDaysRetType) {
+ res, _ = o.GetRetentionDaysOk()
+ return
+}
+
+// GetRetentionDaysOk returns a tuple with the RetentionDays field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetRetentionDaysOk() (ret UpdateInstancePartiallyRequestPayloadGetRetentionDaysRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeTypeOk(o.RetentionDays)
+}
+
+// HasRetentionDays returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasRetentionDays() bool {
+ _, ok := o.GetRetentionDaysOk()
+ return ok
+}
+
+// SetRetentionDays gets a reference to the given int64 and assigns it to the RetentionDays field.
+func (o *UpdateInstancePartiallyRequestPayload) SetRetentionDays(v UpdateInstancePartiallyRequestPayloadGetRetentionDaysRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeType(&o.RetentionDays, v)
+}
+
+// GetStorage returns the Storage field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetStorage() (res UpdateInstancePartiallyRequestPayloadGetStorageRetType) {
+ res, _ = o.GetStorageOk()
+ return
+}
+
+// GetStorageOk returns a tuple with the Storage field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetStorageOk() (ret UpdateInstancePartiallyRequestPayloadGetStorageRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetStorageAttributeTypeOk(o.Storage)
+}
+
+// HasStorage returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasStorage() bool {
+ _, ok := o.GetStorageOk()
+ return ok
+}
+
+// SetStorage gets a reference to the given StorageUpdate and assigns it to the Storage field.
+func (o *UpdateInstancePartiallyRequestPayload) SetStorage(v UpdateInstancePartiallyRequestPayloadGetStorageRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetStorageAttributeType(&o.Storage, v)
+}
+
+// GetVersion returns the Version field value if set, zero value otherwise.
+func (o *UpdateInstancePartiallyRequestPayload) GetVersion() (res UpdateInstancePartiallyRequestPayloadGetVersionRetType) {
+ res, _ = o.GetVersionOk()
+ return
+}
+
+// GetVersionOk returns a tuple with the Version field value if set, nil otherwise
+// and a boolean to check if the value has been set.
+func (o *UpdateInstancePartiallyRequestPayload) GetVersionOk() (ret UpdateInstancePartiallyRequestPayloadGetVersionRetType, ok bool) {
+ return getUpdateInstancePartiallyRequestPayloadGetVersionAttributeTypeOk(o.Version)
+}
+
+// HasVersion returns a boolean if a field has been set.
+func (o *UpdateInstancePartiallyRequestPayload) HasVersion() bool {
+ _, ok := o.GetVersionOk()
+ return ok
+}
+
+// SetVersion gets a reference to the given InstanceVersionOpt and assigns it to the Version field.
+func (o *UpdateInstancePartiallyRequestPayload) SetVersion(v UpdateInstancePartiallyRequestPayloadGetVersionRetType) {
+ setUpdateInstancePartiallyRequestPayloadGetVersionAttributeType(&o.Version, v)
+}
+
+func (o UpdateInstancePartiallyRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetAclAttributeTypeOk(o.Acl); ok {
+ toSerialize["Acl"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetBackupScheduleAttributeTypeOk(o.BackupSchedule); ok {
+ toSerialize["BackupSchedule"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetFlavorIdAttributeTypeOk(o.FlavorId); ok {
+ toSerialize["FlavorId"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetReplicasAttributeTypeOk(o.Replicas); ok {
+ toSerialize["Replicas"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetRetentionDaysAttributeTypeOk(o.RetentionDays); ok {
+ toSerialize["RetentionDays"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetStorageAttributeTypeOk(o.Storage); ok {
+ toSerialize["Storage"] = val
+ }
+ if val, ok := getUpdateInstancePartiallyRequestPayloadGetVersionAttributeTypeOk(o.Version); ok {
+ toSerialize["Version"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableUpdateInstancePartiallyRequestPayload struct {
+ value *UpdateInstancePartiallyRequestPayload
+ isSet bool
+}
+
+func (v NullableUpdateInstancePartiallyRequestPayload) Get() *UpdateInstancePartiallyRequestPayload {
+ return v.value
+}
+
+func (v *NullableUpdateInstancePartiallyRequestPayload) Set(val *UpdateInstancePartiallyRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUpdateInstancePartiallyRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUpdateInstancePartiallyRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUpdateInstancePartiallyRequestPayload(val *UpdateInstancePartiallyRequestPayload) *NullableUpdateInstancePartiallyRequestPayload {
+ return &NullableUpdateInstancePartiallyRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableUpdateInstancePartiallyRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUpdateInstancePartiallyRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_update_instance_partially_request_payload_test.go b/pkg/sqlserverflexalpha/model_update_instance_partially_request_payload_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_update_instance_partially_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_update_instance_request_payload.go b/pkg/sqlserverflexalpha/model_update_instance_request_payload.go
new file mode 100644
index 00000000..c978ab68
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_update_instance_request_payload.go
@@ -0,0 +1,435 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the UpdateInstanceRequestPayload type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &UpdateInstanceRequestPayload{}
+
+/*
+ types and functions for acl
+*/
+
+// isArray
+type UpdateInstanceRequestPayloadGetAclAttributeType = *[]string
+type UpdateInstanceRequestPayloadGetAclArgType = []string
+type UpdateInstanceRequestPayloadGetAclRetType = []string
+
+func getUpdateInstanceRequestPayloadGetAclAttributeTypeOk(arg UpdateInstanceRequestPayloadGetAclAttributeType) (ret UpdateInstanceRequestPayloadGetAclRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetAclAttributeType(arg *UpdateInstanceRequestPayloadGetAclAttributeType, val UpdateInstanceRequestPayloadGetAclRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for backupSchedule
+*/
+
+// isNotNullableString
+type UpdateInstanceRequestPayloadGetBackupScheduleAttributeType = *string
+
+func getUpdateInstanceRequestPayloadGetBackupScheduleAttributeTypeOk(arg UpdateInstanceRequestPayloadGetBackupScheduleAttributeType) (ret UpdateInstanceRequestPayloadGetBackupScheduleRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetBackupScheduleAttributeType(arg *UpdateInstanceRequestPayloadGetBackupScheduleAttributeType, val UpdateInstanceRequestPayloadGetBackupScheduleRetType) {
+ *arg = &val
+}
+
+type UpdateInstanceRequestPayloadGetBackupScheduleArgType = string
+type UpdateInstanceRequestPayloadGetBackupScheduleRetType = string
+
+/*
+ types and functions for flavorId
+*/
+
+// isNotNullableString
+type UpdateInstanceRequestPayloadGetFlavorIdAttributeType = *string
+
+func getUpdateInstanceRequestPayloadGetFlavorIdAttributeTypeOk(arg UpdateInstanceRequestPayloadGetFlavorIdAttributeType) (ret UpdateInstanceRequestPayloadGetFlavorIdRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetFlavorIdAttributeType(arg *UpdateInstanceRequestPayloadGetFlavorIdAttributeType, val UpdateInstanceRequestPayloadGetFlavorIdRetType) {
+ *arg = &val
+}
+
+type UpdateInstanceRequestPayloadGetFlavorIdArgType = string
+type UpdateInstanceRequestPayloadGetFlavorIdRetType = string
+
+/*
+ types and functions for name
+*/
+
+// isNotNullableString
+type UpdateInstanceRequestPayloadGetNameAttributeType = *string
+
+func getUpdateInstanceRequestPayloadGetNameAttributeTypeOk(arg UpdateInstanceRequestPayloadGetNameAttributeType) (ret UpdateInstanceRequestPayloadGetNameRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetNameAttributeType(arg *UpdateInstanceRequestPayloadGetNameAttributeType, val UpdateInstanceRequestPayloadGetNameRetType) {
+ *arg = &val
+}
+
+type UpdateInstanceRequestPayloadGetNameArgType = string
+type UpdateInstanceRequestPayloadGetNameRetType = string
+
+/*
+ types and functions for replicas
+*/
+
+// isEnumRef
+type UpdateInstanceRequestPayloadGetReplicasAttributeType = *Replicas
+type UpdateInstanceRequestPayloadGetReplicasArgType = Replicas
+type UpdateInstanceRequestPayloadGetReplicasRetType = Replicas
+
+func getUpdateInstanceRequestPayloadGetReplicasAttributeTypeOk(arg UpdateInstanceRequestPayloadGetReplicasAttributeType) (ret UpdateInstanceRequestPayloadGetReplicasRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetReplicasAttributeType(arg *UpdateInstanceRequestPayloadGetReplicasAttributeType, val UpdateInstanceRequestPayloadGetReplicasRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for retentionDays
+*/
+
+// isInteger
+type UpdateInstanceRequestPayloadGetRetentionDaysAttributeType = *int64
+type UpdateInstanceRequestPayloadGetRetentionDaysArgType = int64
+type UpdateInstanceRequestPayloadGetRetentionDaysRetType = int64
+
+func getUpdateInstanceRequestPayloadGetRetentionDaysAttributeTypeOk(arg UpdateInstanceRequestPayloadGetRetentionDaysAttributeType) (ret UpdateInstanceRequestPayloadGetRetentionDaysRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetRetentionDaysAttributeType(arg *UpdateInstanceRequestPayloadGetRetentionDaysAttributeType, val UpdateInstanceRequestPayloadGetRetentionDaysRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for storage
+*/
+
+// isModel
+type UpdateInstanceRequestPayloadGetStorageAttributeType = *StorageUpdate
+type UpdateInstanceRequestPayloadGetStorageArgType = StorageUpdate
+type UpdateInstanceRequestPayloadGetStorageRetType = StorageUpdate
+
+func getUpdateInstanceRequestPayloadGetStorageAttributeTypeOk(arg UpdateInstanceRequestPayloadGetStorageAttributeType) (ret UpdateInstanceRequestPayloadGetStorageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetStorageAttributeType(arg *UpdateInstanceRequestPayloadGetStorageAttributeType, val UpdateInstanceRequestPayloadGetStorageRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for version
+*/
+
+// isEnumRef
+type UpdateInstanceRequestPayloadGetVersionAttributeType = *InstanceVersion
+type UpdateInstanceRequestPayloadGetVersionArgType = InstanceVersion
+type UpdateInstanceRequestPayloadGetVersionRetType = InstanceVersion
+
+func getUpdateInstanceRequestPayloadGetVersionAttributeTypeOk(arg UpdateInstanceRequestPayloadGetVersionAttributeType) (ret UpdateInstanceRequestPayloadGetVersionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setUpdateInstanceRequestPayloadGetVersionAttributeType(arg *UpdateInstanceRequestPayloadGetVersionAttributeType, val UpdateInstanceRequestPayloadGetVersionRetType) {
+ *arg = &val
+}
+
+// UpdateInstanceRequestPayload struct for UpdateInstanceRequestPayload
+type UpdateInstanceRequestPayload struct {
+ // List of IPV4 cidr.
+ // REQUIRED
+ Acl UpdateInstanceRequestPayloadGetAclAttributeType `json:"acl" required:"true"`
+ // The schedule for on what time and how often the database backup will be created. The schedule is written as a cron schedule.
+ // REQUIRED
+ BackupSchedule UpdateInstanceRequestPayloadGetBackupScheduleAttributeType `json:"backupSchedule" required:"true"`
+ // The id of the instance flavor.
+ // REQUIRED
+ FlavorId UpdateInstanceRequestPayloadGetFlavorIdAttributeType `json:"flavorId" required:"true"`
+ // The name of the instance.
+ // REQUIRED
+ Name UpdateInstanceRequestPayloadGetNameAttributeType `json:"name" required:"true"`
+ // REQUIRED
+ Replicas UpdateInstanceRequestPayloadGetReplicasAttributeType `json:"replicas" required:"true"`
+ // The days for how long the backup files should be stored before cleaned up. 30 to 365
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ RetentionDays UpdateInstanceRequestPayloadGetRetentionDaysAttributeType `json:"retentionDays" required:"true"`
+ // REQUIRED
+ Storage UpdateInstanceRequestPayloadGetStorageAttributeType `json:"storage" required:"true"`
+ // REQUIRED
+ Version UpdateInstanceRequestPayloadGetVersionAttributeType `json:"version" required:"true"`
+}
+
+type _UpdateInstanceRequestPayload UpdateInstanceRequestPayload
+
+// NewUpdateInstanceRequestPayload instantiates a new UpdateInstanceRequestPayload object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewUpdateInstanceRequestPayload(acl UpdateInstanceRequestPayloadGetAclArgType, backupSchedule UpdateInstanceRequestPayloadGetBackupScheduleArgType, flavorId UpdateInstanceRequestPayloadGetFlavorIdArgType, name UpdateInstanceRequestPayloadGetNameArgType, replicas UpdateInstanceRequestPayloadGetReplicasArgType, retentionDays UpdateInstanceRequestPayloadGetRetentionDaysArgType, storage UpdateInstanceRequestPayloadGetStorageArgType, version UpdateInstanceRequestPayloadGetVersionArgType) *UpdateInstanceRequestPayload {
+ this := UpdateInstanceRequestPayload{}
+ setUpdateInstanceRequestPayloadGetAclAttributeType(&this.Acl, acl)
+ setUpdateInstanceRequestPayloadGetBackupScheduleAttributeType(&this.BackupSchedule, backupSchedule)
+ setUpdateInstanceRequestPayloadGetFlavorIdAttributeType(&this.FlavorId, flavorId)
+ setUpdateInstanceRequestPayloadGetNameAttributeType(&this.Name, name)
+ setUpdateInstanceRequestPayloadGetReplicasAttributeType(&this.Replicas, replicas)
+ setUpdateInstanceRequestPayloadGetRetentionDaysAttributeType(&this.RetentionDays, retentionDays)
+ setUpdateInstanceRequestPayloadGetStorageAttributeType(&this.Storage, storage)
+ setUpdateInstanceRequestPayloadGetVersionAttributeType(&this.Version, version)
+ return &this
+}
+
+// NewUpdateInstanceRequestPayloadWithDefaults instantiates a new UpdateInstanceRequestPayload object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewUpdateInstanceRequestPayloadWithDefaults() *UpdateInstanceRequestPayload {
+ this := UpdateInstanceRequestPayload{}
+ return &this
+}
+
+// GetAcl returns the Acl field value
+func (o *UpdateInstanceRequestPayload) GetAcl() (ret UpdateInstanceRequestPayloadGetAclRetType) {
+ ret, _ = o.GetAclOk()
+ return ret
+}
+
+// GetAclOk returns a tuple with the Acl field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetAclOk() (ret UpdateInstanceRequestPayloadGetAclRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetAclAttributeTypeOk(o.Acl)
+}
+
+// SetAcl sets field value
+func (o *UpdateInstanceRequestPayload) SetAcl(v UpdateInstanceRequestPayloadGetAclRetType) {
+ setUpdateInstanceRequestPayloadGetAclAttributeType(&o.Acl, v)
+}
+
+// GetBackupSchedule returns the BackupSchedule field value
+func (o *UpdateInstanceRequestPayload) GetBackupSchedule() (ret UpdateInstanceRequestPayloadGetBackupScheduleRetType) {
+ ret, _ = o.GetBackupScheduleOk()
+ return ret
+}
+
+// GetBackupScheduleOk returns a tuple with the BackupSchedule field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetBackupScheduleOk() (ret UpdateInstanceRequestPayloadGetBackupScheduleRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetBackupScheduleAttributeTypeOk(o.BackupSchedule)
+}
+
+// SetBackupSchedule sets field value
+func (o *UpdateInstanceRequestPayload) SetBackupSchedule(v UpdateInstanceRequestPayloadGetBackupScheduleRetType) {
+ setUpdateInstanceRequestPayloadGetBackupScheduleAttributeType(&o.BackupSchedule, v)
+}
+
+// GetFlavorId returns the FlavorId field value
+func (o *UpdateInstanceRequestPayload) GetFlavorId() (ret UpdateInstanceRequestPayloadGetFlavorIdRetType) {
+ ret, _ = o.GetFlavorIdOk()
+ return ret
+}
+
+// GetFlavorIdOk returns a tuple with the FlavorId field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetFlavorIdOk() (ret UpdateInstanceRequestPayloadGetFlavorIdRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetFlavorIdAttributeTypeOk(o.FlavorId)
+}
+
+// SetFlavorId sets field value
+func (o *UpdateInstanceRequestPayload) SetFlavorId(v UpdateInstanceRequestPayloadGetFlavorIdRetType) {
+ setUpdateInstanceRequestPayloadGetFlavorIdAttributeType(&o.FlavorId, v)
+}
+
+// GetName returns the Name field value
+func (o *UpdateInstanceRequestPayload) GetName() (ret UpdateInstanceRequestPayloadGetNameRetType) {
+ ret, _ = o.GetNameOk()
+ return ret
+}
+
+// GetNameOk returns a tuple with the Name field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetNameOk() (ret UpdateInstanceRequestPayloadGetNameRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetNameAttributeTypeOk(o.Name)
+}
+
+// SetName sets field value
+func (o *UpdateInstanceRequestPayload) SetName(v UpdateInstanceRequestPayloadGetNameRetType) {
+ setUpdateInstanceRequestPayloadGetNameAttributeType(&o.Name, v)
+}
+
+// GetReplicas returns the Replicas field value
+func (o *UpdateInstanceRequestPayload) GetReplicas() (ret UpdateInstanceRequestPayloadGetReplicasRetType) {
+ ret, _ = o.GetReplicasOk()
+ return ret
+}
+
+// GetReplicasOk returns a tuple with the Replicas field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetReplicasOk() (ret UpdateInstanceRequestPayloadGetReplicasRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetReplicasAttributeTypeOk(o.Replicas)
+}
+
+// SetReplicas sets field value
+func (o *UpdateInstanceRequestPayload) SetReplicas(v UpdateInstanceRequestPayloadGetReplicasRetType) {
+ setUpdateInstanceRequestPayloadGetReplicasAttributeType(&o.Replicas, v)
+}
+
+// GetRetentionDays returns the RetentionDays field value
+func (o *UpdateInstanceRequestPayload) GetRetentionDays() (ret UpdateInstanceRequestPayloadGetRetentionDaysRetType) {
+ ret, _ = o.GetRetentionDaysOk()
+ return ret
+}
+
+// GetRetentionDaysOk returns a tuple with the RetentionDays field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetRetentionDaysOk() (ret UpdateInstanceRequestPayloadGetRetentionDaysRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetRetentionDaysAttributeTypeOk(o.RetentionDays)
+}
+
+// SetRetentionDays sets field value
+func (o *UpdateInstanceRequestPayload) SetRetentionDays(v UpdateInstanceRequestPayloadGetRetentionDaysRetType) {
+ setUpdateInstanceRequestPayloadGetRetentionDaysAttributeType(&o.RetentionDays, v)
+}
+
+// GetStorage returns the Storage field value
+func (o *UpdateInstanceRequestPayload) GetStorage() (ret UpdateInstanceRequestPayloadGetStorageRetType) {
+ ret, _ = o.GetStorageOk()
+ return ret
+}
+
+// GetStorageOk returns a tuple with the Storage field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetStorageOk() (ret UpdateInstanceRequestPayloadGetStorageRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetStorageAttributeTypeOk(o.Storage)
+}
+
+// SetStorage sets field value
+func (o *UpdateInstanceRequestPayload) SetStorage(v UpdateInstanceRequestPayloadGetStorageRetType) {
+ setUpdateInstanceRequestPayloadGetStorageAttributeType(&o.Storage, v)
+}
+
+// GetVersion returns the Version field value
+func (o *UpdateInstanceRequestPayload) GetVersion() (ret UpdateInstanceRequestPayloadGetVersionRetType) {
+ ret, _ = o.GetVersionOk()
+ return ret
+}
+
+// GetVersionOk returns a tuple with the Version field value
+// and a boolean to check if the value has been set.
+func (o *UpdateInstanceRequestPayload) GetVersionOk() (ret UpdateInstanceRequestPayloadGetVersionRetType, ok bool) {
+ return getUpdateInstanceRequestPayloadGetVersionAttributeTypeOk(o.Version)
+}
+
+// SetVersion sets field value
+func (o *UpdateInstanceRequestPayload) SetVersion(v UpdateInstanceRequestPayloadGetVersionRetType) {
+ setUpdateInstanceRequestPayloadGetVersionAttributeType(&o.Version, v)
+}
+
+func (o UpdateInstanceRequestPayload) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getUpdateInstanceRequestPayloadGetAclAttributeTypeOk(o.Acl); ok {
+ toSerialize["Acl"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetBackupScheduleAttributeTypeOk(o.BackupSchedule); ok {
+ toSerialize["BackupSchedule"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetFlavorIdAttributeTypeOk(o.FlavorId); ok {
+ toSerialize["FlavorId"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetNameAttributeTypeOk(o.Name); ok {
+ toSerialize["Name"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetReplicasAttributeTypeOk(o.Replicas); ok {
+ toSerialize["Replicas"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetRetentionDaysAttributeTypeOk(o.RetentionDays); ok {
+ toSerialize["RetentionDays"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetStorageAttributeTypeOk(o.Storage); ok {
+ toSerialize["Storage"] = val
+ }
+ if val, ok := getUpdateInstanceRequestPayloadGetVersionAttributeTypeOk(o.Version); ok {
+ toSerialize["Version"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableUpdateInstanceRequestPayload struct {
+ value *UpdateInstanceRequestPayload
+ isSet bool
+}
+
+func (v NullableUpdateInstanceRequestPayload) Get() *UpdateInstanceRequestPayload {
+ return v.value
+}
+
+func (v *NullableUpdateInstanceRequestPayload) Set(val *UpdateInstanceRequestPayload) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUpdateInstanceRequestPayload) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUpdateInstanceRequestPayload) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUpdateInstanceRequestPayload(val *UpdateInstanceRequestPayload) *NullableUpdateInstanceRequestPayload {
+ return &NullableUpdateInstanceRequestPayload{value: val, isSet: true}
+}
+
+func (v NullableUpdateInstanceRequestPayload) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUpdateInstanceRequestPayload) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_update_instance_request_payload_test.go b/pkg/sqlserverflexalpha/model_update_instance_request_payload_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_update_instance_request_payload_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_user_role.go b/pkg/sqlserverflexalpha/model_user_role.go
new file mode 100644
index 00000000..7687df2a
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_user_role.go
@@ -0,0 +1,115 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// UserRole The user role for the instance.
+type UserRole string
+
+// List of user.role
+const (
+ USERROLE_LOGIN_MANAGER UserRole = "##STACKIT_LoginManager##"
+ USERROLE_DATABASE_MANAGER UserRole = "##STACKIT_DatabaseManager##"
+)
+
+// All allowed values of UserRole enum
+var AllowedUserRoleEnumValues = []UserRole{
+ "##STACKIT_LoginManager##",
+ "##STACKIT_DatabaseManager##",
+}
+
+func (v *UserRole) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := UserRole(value)
+ for _, existing := range AllowedUserRoleEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid UserRole", value)
+}
+
+// NewUserRoleFromValue returns a pointer to a valid UserRole
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewUserRoleFromValue(v string) (*UserRole, error) {
+ ev := UserRole(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for UserRole: valid values are %v", v, AllowedUserRoleEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v UserRole) IsValid() bool {
+ for _, existing := range AllowedUserRoleEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to user.role value
+func (v UserRole) Ptr() *UserRole {
+ return &v
+}
+
+type NullableUserRole struct {
+ value *UserRole
+ isSet bool
+}
+
+func (v NullableUserRole) Get() *UserRole {
+ return v.value
+}
+
+func (v *NullableUserRole) Set(val *UserRole) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUserRole) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUserRole) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUserRole(val *UserRole) *NullableUserRole {
+ return &NullableUserRole{value: val, isSet: true}
+}
+
+func (v NullableUserRole) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUserRole) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_user_role_test.go b/pkg/sqlserverflexalpha/model_user_role_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_user_role_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_user_sort.go b/pkg/sqlserverflexalpha/model_user_sort.go
new file mode 100644
index 00000000..64827ce7
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_user_sort.go
@@ -0,0 +1,127 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "fmt"
+)
+
+// UserSort the model 'UserSort'
+type UserSort string
+
+// List of user.sort
+const (
+ USERSORT_ID_ASC UserSort = "id.asc"
+ USERSORT_ID_DESC UserSort = "id.desc"
+ USERSORT_INDEX_DESC UserSort = "index.desc"
+ USERSORT_INDEX_ASC UserSort = "index.asc"
+ USERSORT_NAME_DESC UserSort = "name.desc"
+ USERSORT_NAME_ASC UserSort = "name.asc"
+ USERSORT_STATUS_DESC UserSort = "status.desc"
+ USERSORT_STATUS_ASC UserSort = "status.asc"
+)
+
+// All allowed values of UserSort enum
+var AllowedUserSortEnumValues = []UserSort{
+ "id.asc",
+ "id.desc",
+ "index.desc",
+ "index.asc",
+ "name.desc",
+ "name.asc",
+ "status.desc",
+ "status.asc",
+}
+
+func (v *UserSort) UnmarshalJSON(src []byte) error {
+ var value string
+ err := json.Unmarshal(src, &value)
+ if err != nil {
+ return err
+ }
+ // Allow unmarshalling zero value for testing purposes
+ var zeroValue string
+ if value == zeroValue {
+ return nil
+ }
+ enumTypeValue := UserSort(value)
+ for _, existing := range AllowedUserSortEnumValues {
+ if existing == enumTypeValue {
+ *v = enumTypeValue
+ return nil
+ }
+ }
+
+ return fmt.Errorf("%+v is not a valid UserSort", value)
+}
+
+// NewUserSortFromValue returns a pointer to a valid UserSort
+// for the value passed as argument, or an error if the value passed is not allowed by the enum
+func NewUserSortFromValue(v string) (*UserSort, error) {
+ ev := UserSort(v)
+ if ev.IsValid() {
+ return &ev, nil
+ } else {
+ return nil, fmt.Errorf("invalid value '%v' for UserSort: valid values are %v", v, AllowedUserSortEnumValues)
+ }
+}
+
+// IsValid return true if the value is valid for the enum, false otherwise
+func (v UserSort) IsValid() bool {
+ for _, existing := range AllowedUserSortEnumValues {
+ if existing == v {
+ return true
+ }
+ }
+ return false
+}
+
+// Ptr returns reference to user.sort value
+func (v UserSort) Ptr() *UserSort {
+ return &v
+}
+
+type NullableUserSort struct {
+ value *UserSort
+ isSet bool
+}
+
+func (v NullableUserSort) Get() *UserSort {
+ return v.value
+}
+
+func (v *NullableUserSort) Set(val *UserSort) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableUserSort) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableUserSort) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableUserSort(val *UserSort) *NullableUserSort {
+ return &NullableUserSort{value: val, isSet: true}
+}
+
+func (v NullableUserSort) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableUserSort) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_user_sort_test.go b/pkg/sqlserverflexalpha/model_user_sort_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_user_sort_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_validation_error.go b/pkg/sqlserverflexalpha/model_validation_error.go
new file mode 100644
index 00000000..6d72ce43
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_validation_error.go
@@ -0,0 +1,171 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ValidationError type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ValidationError{}
+
+/*
+ types and functions for code
+*/
+
+// isInteger
+type ValidationErrorGetCodeAttributeType = *int64
+type ValidationErrorGetCodeArgType = int64
+type ValidationErrorGetCodeRetType = int64
+
+func getValidationErrorGetCodeAttributeTypeOk(arg ValidationErrorGetCodeAttributeType) (ret ValidationErrorGetCodeRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setValidationErrorGetCodeAttributeType(arg *ValidationErrorGetCodeAttributeType, val ValidationErrorGetCodeRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for validation
+*/
+
+// isArray
+type ValidationErrorGetValidationAttributeType = *[]ValidationErrorValidationInner
+type ValidationErrorGetValidationArgType = []ValidationErrorValidationInner
+type ValidationErrorGetValidationRetType = []ValidationErrorValidationInner
+
+func getValidationErrorGetValidationAttributeTypeOk(arg ValidationErrorGetValidationAttributeType) (ret ValidationErrorGetValidationRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setValidationErrorGetValidationAttributeType(arg *ValidationErrorGetValidationAttributeType, val ValidationErrorGetValidationRetType) {
+ *arg = &val
+}
+
+// ValidationError struct for ValidationError
+type ValidationError struct {
+ // the http error should be always 422 for validationError
+ // Can be cast to int32 without loss of precision.
+ // REQUIRED
+ Code ValidationErrorGetCodeAttributeType `json:"code" required:"true"`
+ // errors for all fields where the error happened
+ // REQUIRED
+ Validation ValidationErrorGetValidationAttributeType `json:"validation" required:"true"`
+}
+
+type _ValidationError ValidationError
+
+// NewValidationError instantiates a new ValidationError object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewValidationError(code ValidationErrorGetCodeArgType, validation ValidationErrorGetValidationArgType) *ValidationError {
+ this := ValidationError{}
+ setValidationErrorGetCodeAttributeType(&this.Code, code)
+ setValidationErrorGetValidationAttributeType(&this.Validation, validation)
+ return &this
+}
+
+// NewValidationErrorWithDefaults instantiates a new ValidationError object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewValidationErrorWithDefaults() *ValidationError {
+ this := ValidationError{}
+ return &this
+}
+
+// GetCode returns the Code field value
+func (o *ValidationError) GetCode() (ret ValidationErrorGetCodeRetType) {
+ ret, _ = o.GetCodeOk()
+ return ret
+}
+
+// GetCodeOk returns a tuple with the Code field value
+// and a boolean to check if the value has been set.
+func (o *ValidationError) GetCodeOk() (ret ValidationErrorGetCodeRetType, ok bool) {
+ return getValidationErrorGetCodeAttributeTypeOk(o.Code)
+}
+
+// SetCode sets field value
+func (o *ValidationError) SetCode(v ValidationErrorGetCodeRetType) {
+ setValidationErrorGetCodeAttributeType(&o.Code, v)
+}
+
+// GetValidation returns the Validation field value
+func (o *ValidationError) GetValidation() (ret ValidationErrorGetValidationRetType) {
+ ret, _ = o.GetValidationOk()
+ return ret
+}
+
+// GetValidationOk returns a tuple with the Validation field value
+// and a boolean to check if the value has been set.
+func (o *ValidationError) GetValidationOk() (ret ValidationErrorGetValidationRetType, ok bool) {
+ return getValidationErrorGetValidationAttributeTypeOk(o.Validation)
+}
+
+// SetValidation sets field value
+func (o *ValidationError) SetValidation(v ValidationErrorGetValidationRetType) {
+ setValidationErrorGetValidationAttributeType(&o.Validation, v)
+}
+
+func (o ValidationError) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getValidationErrorGetCodeAttributeTypeOk(o.Code); ok {
+ toSerialize["Code"] = val
+ }
+ if val, ok := getValidationErrorGetValidationAttributeTypeOk(o.Validation); ok {
+ toSerialize["Validation"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableValidationError struct {
+ value *ValidationError
+ isSet bool
+}
+
+func (v NullableValidationError) Get() *ValidationError {
+ return v.value
+}
+
+func (v *NullableValidationError) Set(val *ValidationError) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableValidationError) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableValidationError) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableValidationError(val *ValidationError) *NullableValidationError {
+ return &NullableValidationError{value: val, isSet: true}
+}
+
+func (v NullableValidationError) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableValidationError) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_validation_error_test.go b/pkg/sqlserverflexalpha/model_validation_error_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_validation_error_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_validation_error_validation_inner.go b/pkg/sqlserverflexalpha/model_validation_error_validation_inner.go
new file mode 100644
index 00000000..7b54ff1d
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_validation_error_validation_inner.go
@@ -0,0 +1,170 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the ValidationErrorValidationInner type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &ValidationErrorValidationInner{}
+
+/*
+ types and functions for field
+*/
+
+// isNotNullableString
+type ValidationErrorValidationInnerGetFieldAttributeType = *string
+
+func getValidationErrorValidationInnerGetFieldAttributeTypeOk(arg ValidationErrorValidationInnerGetFieldAttributeType) (ret ValidationErrorValidationInnerGetFieldRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setValidationErrorValidationInnerGetFieldAttributeType(arg *ValidationErrorValidationInnerGetFieldAttributeType, val ValidationErrorValidationInnerGetFieldRetType) {
+ *arg = &val
+}
+
+type ValidationErrorValidationInnerGetFieldArgType = string
+type ValidationErrorValidationInnerGetFieldRetType = string
+
+/*
+ types and functions for message
+*/
+
+// isNotNullableString
+type ValidationErrorValidationInnerGetMessageAttributeType = *string
+
+func getValidationErrorValidationInnerGetMessageAttributeTypeOk(arg ValidationErrorValidationInnerGetMessageAttributeType) (ret ValidationErrorValidationInnerGetMessageRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setValidationErrorValidationInnerGetMessageAttributeType(arg *ValidationErrorValidationInnerGetMessageAttributeType, val ValidationErrorValidationInnerGetMessageRetType) {
+ *arg = &val
+}
+
+type ValidationErrorValidationInnerGetMessageArgType = string
+type ValidationErrorValidationInnerGetMessageRetType = string
+
+// ValidationErrorValidationInner struct for ValidationErrorValidationInner
+type ValidationErrorValidationInner struct {
+ // REQUIRED
+ Field ValidationErrorValidationInnerGetFieldAttributeType `json:"field" required:"true"`
+ // REQUIRED
+ Message ValidationErrorValidationInnerGetMessageAttributeType `json:"message" required:"true"`
+}
+
+type _ValidationErrorValidationInner ValidationErrorValidationInner
+
+// NewValidationErrorValidationInner instantiates a new ValidationErrorValidationInner object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewValidationErrorValidationInner(field ValidationErrorValidationInnerGetFieldArgType, message ValidationErrorValidationInnerGetMessageArgType) *ValidationErrorValidationInner {
+ this := ValidationErrorValidationInner{}
+ setValidationErrorValidationInnerGetFieldAttributeType(&this.Field, field)
+ setValidationErrorValidationInnerGetMessageAttributeType(&this.Message, message)
+ return &this
+}
+
+// NewValidationErrorValidationInnerWithDefaults instantiates a new ValidationErrorValidationInner object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewValidationErrorValidationInnerWithDefaults() *ValidationErrorValidationInner {
+ this := ValidationErrorValidationInner{}
+ return &this
+}
+
+// GetField returns the Field field value
+func (o *ValidationErrorValidationInner) GetField() (ret ValidationErrorValidationInnerGetFieldRetType) {
+ ret, _ = o.GetFieldOk()
+ return ret
+}
+
+// GetFieldOk returns a tuple with the Field field value
+// and a boolean to check if the value has been set.
+func (o *ValidationErrorValidationInner) GetFieldOk() (ret ValidationErrorValidationInnerGetFieldRetType, ok bool) {
+ return getValidationErrorValidationInnerGetFieldAttributeTypeOk(o.Field)
+}
+
+// SetField sets field value
+func (o *ValidationErrorValidationInner) SetField(v ValidationErrorValidationInnerGetFieldRetType) {
+ setValidationErrorValidationInnerGetFieldAttributeType(&o.Field, v)
+}
+
+// GetMessage returns the Message field value
+func (o *ValidationErrorValidationInner) GetMessage() (ret ValidationErrorValidationInnerGetMessageRetType) {
+ ret, _ = o.GetMessageOk()
+ return ret
+}
+
+// GetMessageOk returns a tuple with the Message field value
+// and a boolean to check if the value has been set.
+func (o *ValidationErrorValidationInner) GetMessageOk() (ret ValidationErrorValidationInnerGetMessageRetType, ok bool) {
+ return getValidationErrorValidationInnerGetMessageAttributeTypeOk(o.Message)
+}
+
+// SetMessage sets field value
+func (o *ValidationErrorValidationInner) SetMessage(v ValidationErrorValidationInnerGetMessageRetType) {
+ setValidationErrorValidationInnerGetMessageAttributeType(&o.Message, v)
+}
+
+func (o ValidationErrorValidationInner) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getValidationErrorValidationInnerGetFieldAttributeTypeOk(o.Field); ok {
+ toSerialize["Field"] = val
+ }
+ if val, ok := getValidationErrorValidationInnerGetMessageAttributeTypeOk(o.Message); ok {
+ toSerialize["Message"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableValidationErrorValidationInner struct {
+ value *ValidationErrorValidationInner
+ isSet bool
+}
+
+func (v NullableValidationErrorValidationInner) Get() *ValidationErrorValidationInner {
+ return v.value
+}
+
+func (v *NullableValidationErrorValidationInner) Set(val *ValidationErrorValidationInner) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableValidationErrorValidationInner) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableValidationErrorValidationInner) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableValidationErrorValidationInner(val *ValidationErrorValidationInner) *NullableValidationErrorValidationInner {
+ return &NullableValidationErrorValidationInner{value: val, isSet: true}
+}
+
+func (v NullableValidationErrorValidationInner) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableValidationErrorValidationInner) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_validation_error_validation_inner_test.go b/pkg/sqlserverflexalpha/model_validation_error_validation_inner_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_validation_error_validation_inner_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/model_version.go b/pkg/sqlserverflexalpha/model_version.go
new file mode 100644
index 00000000..578d7ade
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_version.go
@@ -0,0 +1,260 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+)
+
+// checks if the Version type satisfies the MappedNullable interface at compile time
+var _ MappedNullable = &Version{}
+
+/*
+ types and functions for beta
+*/
+
+// isBoolean
+type VersiongetBetaAttributeType = *bool
+type VersiongetBetaArgType = bool
+type VersiongetBetaRetType = bool
+
+func getVersiongetBetaAttributeTypeOk(arg VersiongetBetaAttributeType) (ret VersiongetBetaRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setVersiongetBetaAttributeType(arg *VersiongetBetaAttributeType, val VersiongetBetaRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for deprecated
+*/
+
+// isNotNullableString
+type VersionGetDeprecatedAttributeType = *string
+
+func getVersionGetDeprecatedAttributeTypeOk(arg VersionGetDeprecatedAttributeType) (ret VersionGetDeprecatedRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setVersionGetDeprecatedAttributeType(arg *VersionGetDeprecatedAttributeType, val VersionGetDeprecatedRetType) {
+ *arg = &val
+}
+
+type VersionGetDeprecatedArgType = string
+type VersionGetDeprecatedRetType = string
+
+/*
+ types and functions for recommend
+*/
+
+// isBoolean
+type VersiongetRecommendAttributeType = *bool
+type VersiongetRecommendArgType = bool
+type VersiongetRecommendRetType = bool
+
+func getVersiongetRecommendAttributeTypeOk(arg VersiongetRecommendAttributeType) (ret VersiongetRecommendRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setVersiongetRecommendAttributeType(arg *VersiongetRecommendAttributeType, val VersiongetRecommendRetType) {
+ *arg = &val
+}
+
+/*
+ types and functions for version
+*/
+
+// isNotNullableString
+type VersionGetVersionAttributeType = *string
+
+func getVersionGetVersionAttributeTypeOk(arg VersionGetVersionAttributeType) (ret VersionGetVersionRetType, ok bool) {
+ if arg == nil {
+ return ret, false
+ }
+ return *arg, true
+}
+
+func setVersionGetVersionAttributeType(arg *VersionGetVersionAttributeType, val VersionGetVersionRetType) {
+ *arg = &val
+}
+
+type VersionGetVersionArgType = string
+type VersionGetVersionRetType = string
+
+// Version The version of the sqlserver instance and more details.
+type Version struct {
+ // Flag if the version is a beta version. If set the version may contain bugs and is not fully tested.
+ // REQUIRED
+ Beta VersiongetBetaAttributeType `json:"beta" required:"true"`
+ // Timestamp in RFC3339 format which says when the version will no longer be supported by STACKIT.
+ // REQUIRED
+ Deprecated VersionGetDeprecatedAttributeType `json:"deprecated" required:"true"`
+ // Flag if the version is recommend by the STACKIT Team.
+ // REQUIRED
+ Recommend VersiongetRecommendAttributeType `json:"recommend" required:"true"`
+ // The sqlserver version used for the instance.
+ // REQUIRED
+ Version VersionGetVersionAttributeType `json:"version" required:"true"`
+}
+
+type _Version Version
+
+// NewVersion instantiates a new Version object
+// This constructor will assign default values to properties that have it defined,
+// and makes sure properties required by API are set, but the set of arguments
+// will change when the set of required properties is changed
+func NewVersion(beta VersiongetBetaArgType, deprecated VersionGetDeprecatedArgType, recommend VersiongetRecommendArgType, version VersionGetVersionArgType) *Version {
+ this := Version{}
+ setVersiongetBetaAttributeType(&this.Beta, beta)
+ setVersionGetDeprecatedAttributeType(&this.Deprecated, deprecated)
+ setVersiongetRecommendAttributeType(&this.Recommend, recommend)
+ setVersionGetVersionAttributeType(&this.Version, version)
+ return &this
+}
+
+// NewVersionWithDefaults instantiates a new Version object
+// This constructor will only assign default values to properties that have it defined,
+// but it doesn't guarantee that properties required by API are set
+func NewVersionWithDefaults() *Version {
+ this := Version{}
+ return &this
+}
+
+// GetBeta returns the Beta field value
+func (o *Version) GetBeta() (ret VersiongetBetaRetType) {
+ ret, _ = o.GetBetaOk()
+ return ret
+}
+
+// GetBetaOk returns a tuple with the Beta field value
+// and a boolean to check if the value has been set.
+func (o *Version) GetBetaOk() (ret VersiongetBetaRetType, ok bool) {
+ return getVersiongetBetaAttributeTypeOk(o.Beta)
+}
+
+// SetBeta sets field value
+func (o *Version) SetBeta(v VersiongetBetaRetType) {
+ setVersiongetBetaAttributeType(&o.Beta, v)
+}
+
+// GetDeprecated returns the Deprecated field value
+func (o *Version) GetDeprecated() (ret VersionGetDeprecatedRetType) {
+ ret, _ = o.GetDeprecatedOk()
+ return ret
+}
+
+// GetDeprecatedOk returns a tuple with the Deprecated field value
+// and a boolean to check if the value has been set.
+func (o *Version) GetDeprecatedOk() (ret VersionGetDeprecatedRetType, ok bool) {
+ return getVersionGetDeprecatedAttributeTypeOk(o.Deprecated)
+}
+
+// SetDeprecated sets field value
+func (o *Version) SetDeprecated(v VersionGetDeprecatedRetType) {
+ setVersionGetDeprecatedAttributeType(&o.Deprecated, v)
+}
+
+// GetRecommend returns the Recommend field value
+func (o *Version) GetRecommend() (ret VersiongetRecommendRetType) {
+ ret, _ = o.GetRecommendOk()
+ return ret
+}
+
+// GetRecommendOk returns a tuple with the Recommend field value
+// and a boolean to check if the value has been set.
+func (o *Version) GetRecommendOk() (ret VersiongetRecommendRetType, ok bool) {
+ return getVersiongetRecommendAttributeTypeOk(o.Recommend)
+}
+
+// SetRecommend sets field value
+func (o *Version) SetRecommend(v VersiongetRecommendRetType) {
+ setVersiongetRecommendAttributeType(&o.Recommend, v)
+}
+
+// GetVersion returns the Version field value
+func (o *Version) GetVersion() (ret VersionGetVersionRetType) {
+ ret, _ = o.GetVersionOk()
+ return ret
+}
+
+// GetVersionOk returns a tuple with the Version field value
+// and a boolean to check if the value has been set.
+func (o *Version) GetVersionOk() (ret VersionGetVersionRetType, ok bool) {
+ return getVersionGetVersionAttributeTypeOk(o.Version)
+}
+
+// SetVersion sets field value
+func (o *Version) SetVersion(v VersionGetVersionRetType) {
+ setVersionGetVersionAttributeType(&o.Version, v)
+}
+
+func (o Version) ToMap() (map[string]interface{}, error) {
+ toSerialize := map[string]interface{}{}
+ if val, ok := getVersiongetBetaAttributeTypeOk(o.Beta); ok {
+ toSerialize["Beta"] = val
+ }
+ if val, ok := getVersionGetDeprecatedAttributeTypeOk(o.Deprecated); ok {
+ toSerialize["Deprecated"] = val
+ }
+ if val, ok := getVersiongetRecommendAttributeTypeOk(o.Recommend); ok {
+ toSerialize["Recommend"] = val
+ }
+ if val, ok := getVersionGetVersionAttributeTypeOk(o.Version); ok {
+ toSerialize["Version"] = val
+ }
+ return toSerialize, nil
+}
+
+type NullableVersion struct {
+ value *Version
+ isSet bool
+}
+
+func (v NullableVersion) Get() *Version {
+ return v.value
+}
+
+func (v *NullableVersion) Set(val *Version) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableVersion) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableVersion) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableVersion(val *Version) *NullableVersion {
+ return &NullableVersion{value: val, isSet: true}
+}
+
+func (v NullableVersion) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableVersion) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
diff --git a/pkg/sqlserverflexalpha/model_version_test.go b/pkg/sqlserverflexalpha/model_version_test.go
new file mode 100644
index 00000000..f551e1f0
--- /dev/null
+++ b/pkg/sqlserverflexalpha/model_version_test.go
@@ -0,0 +1,11 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
diff --git a/pkg/sqlserverflexalpha/utils.go b/pkg/sqlserverflexalpha/utils.go
new file mode 100644
index 00000000..5d52a8ba
--- /dev/null
+++ b/pkg/sqlserverflexalpha/utils.go
@@ -0,0 +1,385 @@
+/*
+STACKIT MSSQL Service API
+
+This is the documentation for the STACKIT MSSQL service
+
+API version: 3alpha1
+*/
+
+// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
+
+package sqlserverflexalpha
+
+import (
+ "encoding/json"
+ "math/rand"
+ "reflect"
+ "time"
+)
+
+// PtrBool is a helper routine that returns a pointer to given boolean value.
+func PtrBool(v bool) *bool { return &v }
+
+// PtrInt is a helper routine that returns a pointer to given integer value.
+func PtrInt(v int) *int { return &v }
+
+// PtrInt32 is a helper routine that returns a pointer to given integer value.
+func PtrInt32(v int32) *int32 { return &v }
+
+// PtrInt64 is a helper routine that returns a pointer to given integer value.
+func PtrInt64(v int64) *int64 { return &v }
+
+// PtrFloat32 is a helper routine that returns a pointer to given float value.
+func PtrFloat32(v float32) *float32 { return &v }
+
+// PtrFloat64 is a helper routine that returns a pointer to given float value.
+func PtrFloat64(v float64) *float64 { return &v }
+
+// PtrString is a helper routine that returns a pointer to given string value.
+func PtrString(v string) *string { return &v }
+
+// PtrTime is helper routine that returns a pointer to given Time value.
+func PtrTime(v time.Time) *time.Time { return &v }
+
+type NullableValue[T any] struct {
+ value *T
+ isSet bool
+}
+
+func (v NullableValue[T]) Get() *T {
+ return v.value
+}
+
+func (v *NullableValue[T]) Set(val *T) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableValue[T]) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableValue[T]) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+type NullableBool struct {
+ value *bool
+ isSet bool
+}
+
+func (v NullableBool) Get() *bool {
+ return v.value
+}
+
+func (v *NullableBool) Set(val *bool) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableBool) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableBool) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableBool(val *bool) *NullableBool {
+ return &NullableBool{value: val, isSet: true}
+}
+
+func (v NullableBool) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableBool) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableInt struct {
+ value *int
+ isSet bool
+}
+
+func (v NullableInt) Get() *int {
+ return v.value
+}
+
+func (v *NullableInt) Set(val *int) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInt) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInt) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInt(val *int) *NullableInt {
+ return &NullableInt{value: val, isSet: true}
+}
+
+func (v NullableInt) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInt) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableInt32 struct {
+ value *int32
+ isSet bool
+}
+
+func (v NullableInt32) Get() *int32 {
+ return v.value
+}
+
+func (v *NullableInt32) Set(val *int32) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInt32) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInt32) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInt32(val *int32) *NullableInt32 {
+ return &NullableInt32{value: val, isSet: true}
+}
+
+func (v NullableInt32) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInt32) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableInt64 struct {
+ value *int64
+ isSet bool
+}
+
+func (v NullableInt64) Get() *int64 {
+ return v.value
+}
+
+func (v *NullableInt64) Set(val *int64) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableInt64) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableInt64) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableInt64(val *int64) *NullableInt64 {
+ return &NullableInt64{value: val, isSet: true}
+}
+
+func (v NullableInt64) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableInt64) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableFloat32 struct {
+ value *float32
+ isSet bool
+}
+
+func (v NullableFloat32) Get() *float32 {
+ return v.value
+}
+
+func (v *NullableFloat32) Set(val *float32) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableFloat32) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableFloat32) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableFloat32(val *float32) *NullableFloat32 {
+ return &NullableFloat32{value: val, isSet: true}
+}
+
+func (v NullableFloat32) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableFloat32) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableFloat64 struct {
+ value *float64
+ isSet bool
+}
+
+func (v NullableFloat64) Get() *float64 {
+ return v.value
+}
+
+func (v *NullableFloat64) Set(val *float64) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableFloat64) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableFloat64) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableFloat64(val *float64) *NullableFloat64 {
+ return &NullableFloat64{value: val, isSet: true}
+}
+
+func (v NullableFloat64) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableFloat64) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableString struct {
+ value *string
+ isSet bool
+}
+
+func (v NullableString) Get() *string {
+ return v.value
+}
+
+func (v *NullableString) Set(val *string) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableString) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableString) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableString(val *string) *NullableString {
+ return &NullableString{value: val, isSet: true}
+}
+
+func (v NullableString) MarshalJSON() ([]byte, error) {
+ return json.Marshal(v.value)
+}
+
+func (v *NullableString) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+type NullableTime struct {
+ value *time.Time
+ isSet bool
+}
+
+func (v NullableTime) Get() *time.Time {
+ return v.value
+}
+
+func (v *NullableTime) Set(val *time.Time) {
+ v.value = val
+ v.isSet = true
+}
+
+func (v NullableTime) IsSet() bool {
+ return v.isSet
+}
+
+func (v *NullableTime) Unset() {
+ v.value = nil
+ v.isSet = false
+}
+
+func NewNullableTime(val *time.Time) *NullableTime {
+ return &NullableTime{value: val, isSet: true}
+}
+
+func (v NullableTime) MarshalJSON() ([]byte, error) {
+ return v.value.MarshalJSON()
+}
+
+func (v *NullableTime) UnmarshalJSON(src []byte) error {
+ v.isSet = true
+ return json.Unmarshal(src, &v.value)
+}
+
+// IsNil checks if an input is nil
+func IsNil(i interface{}) bool {
+ if i == nil {
+ return true
+ }
+ if t, ok := i.(interface{ IsSet() bool }); ok {
+ return !t.IsSet()
+ }
+ switch reflect.TypeOf(i).Kind() {
+ case reflect.Chan, reflect.Func, reflect.Map, reflect.Ptr, reflect.UnsafePointer, reflect.Interface, reflect.Slice:
+ return reflect.ValueOf(i).IsNil()
+ case reflect.Array:
+ return reflect.ValueOf(i).IsZero()
+ }
+ return false
+}
+
+type MappedNullable interface {
+ ToMap() (map[string]interface{}, error)
+}
+
+const letterRunes = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
+
+// randString returns a random string with a specified length. It panics if n <= 0.
+func randString(n int) string {
+ b := make([]byte, n)
+ for i := range b {
+ b[i] = letterRunes[rand.Intn(len(letterRunes))]
+ }
+ return string(b)
+}
diff --git a/pkg/sqlserverflexalpha/wait/wait.go b/pkg/sqlserverflexalpha/wait/wait.go
new file mode 100644
index 00000000..025720e5
--- /dev/null
+++ b/pkg/sqlserverflexalpha/wait/wait.go
@@ -0,0 +1,101 @@
+package wait
+
+import (
+ "context"
+ "errors"
+ "fmt"
+ "net/http"
+ "strings"
+ "time"
+
+ "github.com/stackitcloud/stackit-sdk-go/core/oapierror"
+ "github.com/stackitcloud/stackit-sdk-go/core/wait"
+ sqlserverflex "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+)
+
+const (
+ InstanceStateEmpty = ""
+ InstanceStateProcessing = "Progressing"
+ InstanceStateUnknown = "Unknown"
+ InstanceStateSuccess = "Ready"
+ InstanceStateFailed = "Failed"
+)
+
+// Interface needed for tests
+type APIClientInstanceInterface interface {
+ GetInstanceRequestExecute(ctx context.Context, projectId, region, instanceId string) (*sqlserverflex.GetInstanceResponse, error)
+}
+
+// CreateInstanceWaitHandler will wait for instance creation
+func CreateInstanceWaitHandler(ctx context.Context, a APIClientInstanceInterface, projectId, instanceId, region string) *wait.AsyncActionHandler[sqlserverflex.GetInstanceResponse] {
+ handler := wait.New(func() (waitFinished bool, response *sqlserverflex.GetInstanceResponse, err error) {
+ s, err := a.GetInstanceRequestExecute(ctx, projectId, region, instanceId)
+ if err != nil {
+ return false, nil, err
+ }
+ if s == nil || s.Id == nil || *s.Id != instanceId || s.Status == nil {
+ return false, nil, nil
+ }
+ switch strings.ToLower(string(*s.Status)) {
+ case strings.ToLower(InstanceStateSuccess):
+ return true, s, nil
+ case strings.ToLower(InstanceStateUnknown), strings.ToLower(InstanceStateFailed):
+ return true, s, fmt.Errorf("create failed for instance with id %s", instanceId)
+ default:
+ return false, s, nil
+ }
+ })
+ handler.SetTimeout(45 * time.Minute)
+ handler.SetSleepBeforeWait(5 * time.Second)
+ return handler
+}
+
+// UpdateInstanceWaitHandler will wait for instance update
+func UpdateInstanceWaitHandler(ctx context.Context, a APIClientInstanceInterface, projectId, instanceId, region string) *wait.AsyncActionHandler[sqlserverflex.GetInstanceResponse] {
+ handler := wait.New(func() (waitFinished bool, response *sqlserverflex.GetInstanceResponse, err error) {
+ s, err := a.GetInstanceRequestExecute(ctx, projectId, region, instanceId)
+ if err != nil {
+ return false, nil, err
+ }
+ if s == nil || s.Id == nil || *s.Id != instanceId || s.Status == nil {
+ return false, nil, nil
+ }
+ switch strings.ToLower(string(*s.Status)) {
+ case strings.ToLower(InstanceStateSuccess):
+ return true, s, nil
+ case strings.ToLower(InstanceStateUnknown), strings.ToLower(InstanceStateFailed):
+ return true, s, fmt.Errorf("update failed for instance with id %s", instanceId)
+ default:
+ return false, s, nil
+ }
+ })
+ handler.SetSleepBeforeWait(2 * time.Second)
+ handler.SetTimeout(45 * time.Minute)
+ return handler
+}
+
+// PartialUpdateInstanceWaitHandler will wait for instance update
+func PartialUpdateInstanceWaitHandler(ctx context.Context, a APIClientInstanceInterface, projectId, instanceId, region string) *wait.AsyncActionHandler[sqlserverflex.GetInstanceResponse] {
+ return UpdateInstanceWaitHandler(ctx, a, projectId, instanceId, region)
+}
+
+// DeleteInstanceWaitHandler will wait for instance deletion
+func DeleteInstanceWaitHandler(ctx context.Context, a APIClientInstanceInterface, projectId, instanceId, region string) *wait.AsyncActionHandler[struct{}] {
+ handler := wait.New(func() (waitFinished bool, response *struct{}, err error) {
+ _, err = a.GetInstanceRequestExecute(ctx, projectId, region, instanceId)
+ if err == nil {
+ return false, nil, nil
+ }
+ var oapiErr *oapierror.GenericOpenAPIError
+ ok := errors.As(err, &oapiErr)
+ if !ok {
+ return false, nil, fmt.Errorf("could not convert error to oapierror.GenericOpenAPIError")
+ }
+ if oapiErr.StatusCode != http.StatusNotFound {
+ return false, nil, err
+ }
+ return true, nil, nil
+ })
+ handler.SetTimeout(15 * time.Minute)
+ return handler
+}
diff --git a/pkg/sqlserverflexalpha/wait/wait_test.go b/pkg/sqlserverflexalpha/wait/wait_test.go
new file mode 100644
index 00000000..2d194112
--- /dev/null
+++ b/pkg/sqlserverflexalpha/wait/wait_test.go
@@ -0,0 +1,236 @@
+package wait
+
+import (
+ "context"
+ "testing"
+ "time"
+
+ "github.com/google/go-cmp/cmp"
+ "github.com/stackitcloud/stackit-sdk-go/core/oapierror"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+ sqlserverflex "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+)
+
+// Used for testing instance operations
+type apiClientInstanceMocked struct {
+ instanceId string
+ instanceState string
+ instanceIsDeleted bool
+ instanceGetFails bool
+}
+
+func (a *apiClientInstanceMocked) GetInstanceRequestExecute(_ context.Context, _, _, _ string) (*sqlserverflex.GetInstanceResponse, error) {
+ if a.instanceGetFails {
+ return nil, &oapierror.GenericOpenAPIError{
+ StatusCode: 500,
+ }
+ }
+
+ if a.instanceIsDeleted {
+ return nil, &oapierror.GenericOpenAPIError{
+ StatusCode: 404,
+ }
+ }
+
+ return &sqlserverflex.GetInstanceResponse{
+ Id: &a.instanceId,
+ Status: sqlserverflex.GetInstanceResponseGetStatusAttributeType(&a.instanceState),
+ }, nil
+}
+func TestCreateInstanceWaitHandler(t *testing.T) {
+ tests := []struct {
+ desc string
+ instanceGetFails bool
+ instanceState string
+ usersGetErrorStatus int
+ wantErr bool
+ wantResp bool
+ }{
+ {
+ desc: "create_succeeded",
+ instanceGetFails: false,
+ instanceState: InstanceStateSuccess,
+ wantErr: false,
+ wantResp: true,
+ },
+ {
+ desc: "create_failed",
+ instanceGetFails: false,
+ instanceState: InstanceStateFailed,
+ wantErr: true,
+ wantResp: true,
+ },
+ {
+ desc: "create_failed_2",
+ instanceGetFails: false,
+ instanceState: InstanceStateEmpty,
+ wantErr: true,
+ wantResp: true,
+ },
+ {
+ desc: "instance_get_fails",
+ instanceGetFails: true,
+ wantErr: true,
+ wantResp: false,
+ },
+ {
+ desc: "timeout",
+ instanceGetFails: false,
+ instanceState: InstanceStateProcessing,
+ wantErr: true,
+ wantResp: true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.desc, func(t *testing.T) {
+ instanceId := "foo-bar"
+
+ apiClient := &apiClientInstanceMocked{
+ instanceId: instanceId,
+ instanceState: tt.instanceState,
+ instanceGetFails: tt.instanceGetFails,
+ }
+
+ var wantRes *sqlserverflex.GetInstanceResponse
+ if tt.wantResp {
+ wantRes = &sqlserverflex.GetInstanceResponse{
+ Id: &instanceId,
+ Status: sqlserverflex.GetInstanceResponseGetStatusAttributeType(utils.Ptr(tt.instanceState)),
+ }
+ }
+
+ handler := CreateInstanceWaitHandler(context.Background(), apiClient, "", instanceId, "")
+
+ gotRes, err := handler.SetTimeout(10 * time.Millisecond).SetSleepBeforeWait(1 * time.Millisecond).WaitWithContext(context.Background())
+
+ if (err != nil) != tt.wantErr {
+ t.Fatalf("handler error = %v, wantErr %v", err, tt.wantErr)
+ }
+ if !cmp.Equal(gotRes, wantRes) {
+ t.Fatalf("handler gotRes = %v, want %v", gotRes, wantRes)
+ }
+ })
+ }
+}
+
+func TestUpdateInstanceWaitHandler(t *testing.T) {
+ tests := []struct {
+ desc string
+ instanceGetFails bool
+ instanceState string
+ wantErr bool
+ wantResp bool
+ }{
+ {
+ desc: "update_succeeded",
+ instanceGetFails: false,
+ instanceState: InstanceStateSuccess,
+ wantErr: false,
+ wantResp: true,
+ },
+ {
+ desc: "update_failed",
+ instanceGetFails: false,
+ instanceState: InstanceStateFailed,
+ wantErr: true,
+ wantResp: true,
+ },
+ {
+ desc: "update_failed_2",
+ instanceGetFails: false,
+ instanceState: InstanceStateEmpty,
+ wantErr: true,
+ wantResp: true,
+ },
+ {
+ desc: "get_fails",
+ instanceGetFails: true,
+ wantErr: true,
+ wantResp: false,
+ },
+ {
+ desc: "timeout",
+ instanceGetFails: false,
+ instanceState: InstanceStateProcessing,
+ wantErr: true,
+ wantResp: true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.desc, func(t *testing.T) {
+ instanceId := "foo-bar"
+
+ apiClient := &apiClientInstanceMocked{
+ instanceId: instanceId,
+ instanceState: tt.instanceState,
+ instanceGetFails: tt.instanceGetFails,
+ }
+
+ var wantRes *sqlserverflex.GetInstanceResponse
+ if tt.wantResp {
+ wantRes = &sqlserverflex.GetInstanceResponse{
+ Id: &instanceId,
+ Status: sqlserverflex.GetInstanceResponseGetStatusAttributeType(utils.Ptr(tt.instanceState)),
+ }
+ }
+
+ handler := UpdateInstanceWaitHandler(context.Background(), apiClient, "", instanceId, "")
+
+ gotRes, err := handler.SetTimeout(10 * time.Millisecond).SetSleepBeforeWait(1 * time.Millisecond).WaitWithContext(context.Background())
+
+ if (err != nil) != tt.wantErr {
+ t.Fatalf("handler error = %v, wantErr %v", err, tt.wantErr)
+ }
+ if !cmp.Equal(gotRes, wantRes) {
+ t.Fatalf("handler gotRes = %v, want %v", gotRes, wantRes)
+ }
+ })
+ }
+}
+
+func TestDeleteInstanceWaitHandler(t *testing.T) {
+ tests := []struct {
+ desc string
+ instanceGetFails bool
+ instanceState string
+ wantErr bool
+ }{
+ {
+ desc: "delete_succeeded",
+ instanceGetFails: false,
+ instanceState: InstanceStateSuccess,
+ wantErr: false,
+ },
+ {
+ desc: "delete_failed",
+ instanceGetFails: false,
+ instanceState: InstanceStateFailed,
+ wantErr: true,
+ },
+ {
+ desc: "get_fails",
+ instanceGetFails: true,
+ wantErr: true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.desc, func(t *testing.T) {
+ instanceId := "foo-bar"
+
+ apiClient := &apiClientInstanceMocked{
+ instanceGetFails: tt.instanceGetFails,
+ instanceIsDeleted: tt.instanceState == InstanceStateSuccess,
+ instanceId: instanceId,
+ instanceState: tt.instanceState,
+ }
+
+ handler := DeleteInstanceWaitHandler(context.Background(), apiClient, "", instanceId, "")
+
+ _, err := handler.SetTimeout(10 * time.Millisecond).WaitWithContext(context.Background())
+
+ if (err != nil) != tt.wantErr {
+ t.Fatalf("handler error = %v, wantErr %v", err, tt.wantErr)
+ }
+ })
+ }
+}
diff --git a/sample/.gitignore b/sample/.gitignore
new file mode 100644
index 00000000..47c8ccc7
--- /dev/null
+++ b/sample/.gitignore
@@ -0,0 +1,7 @@
+*.json
+*.bak
+*.tfstate
+*.tfstate.backup
+terraform
+variables.tf
+*.tfrc
diff --git a/sample/main.tf b/sample/main.tf
new file mode 100644
index 00000000..f87ce3f9
--- /dev/null
+++ b/sample/main.tf
@@ -0,0 +1,43 @@
+# Copyright (c) STACKIT
+
+resource "stackitalpha_kms_keyring" "keyring" {
+ project_id = var.project_id
+ display_name = "keyring01"
+ description = "This is a test keyring for private endpoints"
+}
+
+resource "stackitalpha_kms_key" "key" {
+ project_id = var.project_id
+ keyring_id = stackitalpha_kms_keyring.keyring.keyring_id
+ display_name = "key01"
+ protection = "software"
+ algorithm = "aes_256_gcm"
+ purpose = "symmetric_encrypt_decrypt"
+ access_scope = "SNA"
+}
+
+resource "stackitalpha_postgresflexalpha_instance" "ptlsdbsrv" {
+ project_id = var.project_id
+ name = "example-instance"
+ acl = ["0.0.0.0/0"]
+ backup_schedule = "0 0 * * *"
+ flavor = {
+ cpu = 2
+ ram = 4
+ }
+ replicas = 3
+ storage = {
+ class = "premium-perf12-stackit"
+ size = 5
+ }
+ version = 14
+ encryption = {
+ key_id = stackitalpha_kms_key.key.id
+ key_ring_id = stackitalpha_kms_keyring.keyring.keyring_id
+ key_version = "1"
+ service_account = var.sa_email
+ }
+ network = {
+ access_scope = "SNA"
+ }
+}
diff --git a/sample/providers.tf b/sample/providers.tf
new file mode 100644
index 00000000..8af98505
--- /dev/null
+++ b/sample/providers.tf
@@ -0,0 +1,16 @@
+# Copyright (c) STACKIT
+
+terraform {
+ required_providers {
+ stackitalpha = {
+ source = "registry.terraform.io/stackitcloud/stackitalpha"
+ version = "~> 0.1"
+ }
+ }
+}
+
+provider "stackitalpha" {
+ default_region = "eu01"
+ enable_beta_resources = true
+ service_account_key_path = "./service_account.json"
+}
diff --git a/sample/sample.tfrc.example b/sample/sample.tfrc.example
new file mode 100644
index 00000000..98ddc32d
--- /dev/null
+++ b/sample/sample.tfrc.example
@@ -0,0 +1,10 @@
+provider_installation {
+ dev_overrides {
+ "registry.terraform.io/stackitcloud/stackitalpha" = "/bin/"
+ }
+
+ # For all other providers, install them directly from their origin provider
+ # registries as normal. If you omit this, Terraform will _only_ use
+ # the dev_overrides block, and so no other providers will be available.
+ direct {}
+}
diff --git a/sample/tf.sh b/sample/tf.sh
new file mode 100755
index 00000000..9f597428
--- /dev/null
+++ b/sample/tf.sh
@@ -0,0 +1,9 @@
+#!/usr/bin/env bash
+# Copyright (c) STACKIT
+
+
+# copy or rename sample.tfrc.example and adjust it
+TERRAFORM_CONFIG=$(pwd)/sample.tfrc
+export TERRAFORM_CONFIG
+
+terraform "$1"
diff --git a/sample/tofu.sh b/sample/tofu.sh
new file mode 100755
index 00000000..bea0e72c
--- /dev/null
+++ b/sample/tofu.sh
@@ -0,0 +1,9 @@
+#!/usr/bin/env bash
+# Copyright (c) STACKIT
+
+
+# copy or rename sample.tfrc.example and adjust it
+TERRAFORM_CONFIG=$(pwd)/sample.tfrc
+export TERRAFORM_CONFIG
+
+tofu "$1"
diff --git a/sample/user.tf b/sample/user.tf
new file mode 100644
index 00000000..5729307b
--- /dev/null
+++ b/sample/user.tf
@@ -0,0 +1,8 @@
+# Copyright (c) STACKIT
+
+resource "stackit_sqlserverflexalpha_user" "ptlsdbuser" {
+ project_id = stackitalpha_postgresflexalpha_instance.ptlsdbsrv.project_id
+ instance_id = stackitalpha_postgresflexalpha_instance.ptlsdbsrv.id
+ username = var.db_username
+ roles = ["createdb", "login", "createrole"]
+}
\ No newline at end of file
diff --git a/sample/variables.tf.example b/sample/variables.tf.example
new file mode 100644
index 00000000..51a70be4
--- /dev/null
+++ b/sample/variables.tf.example
@@ -0,0 +1,11 @@
+variable "project_id" {
+ default = ""
+}
+
+variable "sa_email" {
+ default = ""
+}
+
+variable "db_username" {
+ default = ""
+}
diff --git a/scripts/check-docs.sh b/scripts/check-docs.sh
new file mode 100755
index 00000000..602244cf
--- /dev/null
+++ b/scripts/check-docs.sh
@@ -0,0 +1,23 @@
+#!/usr/bin/env bash
+# Copyright (c) STACKIT
+
+
+# This script is used to ensure for PRs the docs are up-to-date via the CI pipeline
+# Usage: ./check-docs.sh
+set -eo pipefail
+
+ROOT_DIR=$(git rev-parse --show-toplevel)
+
+before_hash=$(find docs -type f -exec sha256sum {} \; | sort | sha256sum | awk '{print $1}')
+
+# re-generate the docs
+$ROOT_DIR/scripts/tfplugindocs.sh
+
+after_hash=$(find docs -type f -exec sha256sum {} \; | sort | sha256sum | awk '{print $1}')
+
+if [[ "$before_hash" == "$after_hash" ]]; then
+ echo "Docs are up-to-date"
+else
+ echo "Changes detected. Docs are *not* up-to-date."
+ exit 1
+fi
diff --git a/scripts/lint-golangci-lint.sh b/scripts/lint-golangci-lint.sh
new file mode 100755
index 00000000..b9e07251
--- /dev/null
+++ b/scripts/lint-golangci-lint.sh
@@ -0,0 +1,20 @@
+#!/usr/bin/env bash
+# Copyright (c) STACKIT
+
+# This script lints the SDK modules and the internal examples
+# Pre-requisites: golangci-lint
+set -eo pipefail
+
+ROOT_DIR=$(git rev-parse --show-toplevel)
+GOLANG_CI_YAML_PATH="${ROOT_DIR}/golang-ci.yaml"
+GOLANG_CI_ARGS="--allow-parallel-runners --timeout=5m --config=${GOLANG_CI_YAML_PATH}"
+
+if type -p golangci-lint >/dev/null; then
+ :
+else
+ echo "golangci-lint not installed, unable to proceed."
+ exit 1
+fi
+
+cd ${ROOT_DIR}
+golangci-lint run ${GOLANG_CI_ARGS}
diff --git a/scripts/project.sh b/scripts/project.sh
new file mode 100755
index 00000000..159ba952
--- /dev/null
+++ b/scripts/project.sh
@@ -0,0 +1,25 @@
+#!/usr/bin/env bash
+# Copyright (c) STACKIT
+
+
+# This script is used to manage the project, only used for installing the required tools for now
+# Usage: ./project.sh [action]
+# * tools: Install required tools to run the project
+set -eo pipefail
+
+ROOT_DIR=$(git rev-parse --show-toplevel)
+
+action=$1
+
+if [ "$action" = "help" ]; then
+ [ -f "$0".man ] && man "$0".man || echo "No help, please read the script in ${script}, we will add help later"
+elif [ "$action" = "tools" ]; then
+ cd ${ROOT_DIR}
+
+ go mod download
+
+ go install github.com/golangci/golangci-lint/cmd/golangci-lint@v1.62.0
+ go install github.com/hashicorp/terraform-plugin-docs/cmd/tfplugindocs@v0.21.0
+else
+ echo "Invalid action: '$action', please use $0 help for help"
+fi
diff --git a/scripts/replace.sh b/scripts/replace.sh
new file mode 100755
index 00000000..953ac6e0
--- /dev/null
+++ b/scripts/replace.sh
@@ -0,0 +1,59 @@
+#!/usr/bin/env bash
+# Copyright (c) STACKIT
+
+# Add replace directives to local files to go.work
+set -eo pipefail
+
+while getopts "s:" option; do
+ case "${option}" in
+ s)
+ SDK_DIR=${OPTARG}
+ ;;
+
+ *)
+ echo "call: $0 [-s sdk-dir] "
+ exit 0
+ ;;
+ esac
+done
+shift $((OPTIND-1))
+
+if [ -z "$SDK_DIR" ]; then
+ SDK_DIR=../stackit-sdk-generator/sdk-repo-updated
+ echo "No SDK_DIR set, using $SDK_DIR"
+fi
+
+
+if [ ! -f go.work ]; then
+ go work init
+ go work use .
+else
+ echo "go.work already exists"
+fi
+
+if [ $# -gt 0 ];then
+ # modules passed via commandline
+ for service in $*; do
+ if [ ! -d $SDK_DIR/services/$service ]; then
+ echo "service directory $SDK_DIR/services/$service does not exist"
+ exit 1
+ fi
+ echo "replacing selected service $service"
+ if [ "$service" = "core" ]; then
+ go work edit -replace github.com/stackitcloud/stackit-sdk-go/core=$SDK_DIR/core
+ else
+ go work edit -replace github.com/stackitcloud/stackit-sdk-go/services/$service=$SDK_DIR/services/$service
+ fi
+ done
+else
+ # replace all modules
+ echo "replacing all services"
+ go work edit -replace github.com/stackitcloud/stackit-sdk-go/core=$SDK_DIR/core
+ for n in $(find ${SDK_DIR}/services -name go.mod);do
+ service=$(dirname $n)
+ service=${service#${SDK_DIR}/services/}
+ go work edit -replace github.com/stackitcloud/stackit-sdk-go/services/$service=$(dirname $n)
+ done
+fi
+go work edit -fmt
+go work sync
diff --git a/scripts/tfplugindocs.sh b/scripts/tfplugindocs.sh
new file mode 100755
index 00000000..8c79e7ef
--- /dev/null
+++ b/scripts/tfplugindocs.sh
@@ -0,0 +1,19 @@
+#!/usr/bin/env bash
+# Copyright (c) STACKIT
+
+# Pre-requisites: tfplugindocs
+set -eo pipefail
+
+ROOT_DIR=$(git rev-parse --show-toplevel)
+EXAMPLES_DIR="${ROOT_DIR}/examples"
+PROVIDER_NAME="stackitprivatepreview"
+
+# Create a new empty directory for the docs
+if [ -d ${ROOT_DIR}/docs ]; then
+ rm -rf ${ROOT_DIR}/docs
+fi
+mkdir -p ${ROOT_DIR}/docs
+
+echo ">> Generating documentation"
+tfplugindocs generate \
+ --provider-name "stackitprivatepreview"
diff --git a/stackit/internal/conversion/conversion.go b/stackit/internal/conversion/conversion.go
new file mode 100644
index 00000000..bdcacdfd
--- /dev/null
+++ b/stackit/internal/conversion/conversion.go
@@ -0,0 +1,201 @@
+// Copyright (c) STACKIT
+
+package conversion
+
+import (
+ "context"
+ "fmt"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+)
+
+func ToString(ctx context.Context, v attr.Value) (string, error) {
+ if t := v.Type(ctx); t != types.StringType {
+ return "", fmt.Errorf("type mismatch. expected 'types.StringType' but got '%s'", t.String())
+ }
+ if v.IsNull() || v.IsUnknown() {
+ return "", fmt.Errorf("value is unknown or null")
+ }
+ tv, err := v.ToTerraformValue(ctx)
+ if err != nil {
+ return "", err
+ }
+ var s string
+ if err := tv.Copy().As(&s); err != nil {
+ return "", err
+ }
+ return s, nil
+}
+
+func ToOptStringMap(tfMap map[string]attr.Value) (*map[string]string, error) { //nolint: gocritic //pointer needed to map optional fields
+ labels := make(map[string]string, len(tfMap))
+ for l, v := range tfMap {
+ valueString, ok := v.(types.String)
+ if !ok {
+ return nil, fmt.Errorf("error converting map value: expected to string, got %v", v)
+ }
+ labels[l] = valueString.ValueString()
+ }
+
+ labelsPointer := &labels
+ if len(labels) == 0 {
+ labelsPointer = nil
+ }
+ return labelsPointer, nil
+}
+
+func ToTerraformStringMap(ctx context.Context, m map[string]string) (basetypes.MapValue, error) {
+ labels := make(map[string]attr.Value, len(m))
+ for l, v := range m {
+ stringValue := types.StringValue(v)
+ labels[l] = stringValue
+ }
+ res, diags := types.MapValueFrom(ctx, types.StringType, m)
+ if diags.HasError() {
+ return types.MapNull(types.StringType), fmt.Errorf("converting to MapValue: %v", diags.Errors())
+ }
+
+ return res, nil
+}
+
+// ToStringInterfaceMap converts a basetypes.MapValue of Strings to a map[string]interface{}.
+func ToStringInterfaceMap(ctx context.Context, m basetypes.MapValue) (map[string]interface{}, error) {
+ labels := map[string]string{}
+ diags := m.ElementsAs(ctx, &labels, false)
+ if diags.HasError() {
+ return nil, fmt.Errorf("converting from MapValue: %w", core.DiagsToError(diags))
+ }
+
+ interfaceMap := make(map[string]interface{}, len(labels))
+ for k, v := range labels {
+ interfaceMap[k] = v
+ }
+
+ return interfaceMap, nil
+}
+
+// StringValueToPointer converts basetypes.StringValue to a pointer to string.
+// It returns nil if the value is null or unknown.
+func StringValueToPointer(s basetypes.StringValue) *string {
+ if s.IsNull() || s.IsUnknown() {
+ return nil
+ }
+ value := s.ValueString()
+ return &value
+}
+
+// Int64ValueToPointer converts basetypes.Int64Value to a pointer to int64.
+// It returns nil if the value is null or unknown.
+func Int64ValueToPointer(s basetypes.Int64Value) *int64 {
+ if s.IsNull() || s.IsUnknown() {
+ return nil
+ }
+ value := s.ValueInt64()
+ return &value
+}
+
+// Float64ValueToPointer converts basetypes.Float64Value to a pointer to float64.
+// It returns nil if the value is null or unknown.
+func Float64ValueToPointer(s basetypes.Float64Value) *float64 {
+ if s.IsNull() || s.IsUnknown() {
+ return nil
+ }
+ value := s.ValueFloat64()
+ return &value
+}
+
+// BoolValueToPointer converts basetypes.BoolValue to a pointer to bool.
+// It returns nil if the value is null or unknown.
+func BoolValueToPointer(s basetypes.BoolValue) *bool {
+ if s.IsNull() || s.IsUnknown() {
+ return nil
+ }
+ value := s.ValueBool()
+ return &value
+}
+
+// StringListToPointer converts basetypes.ListValue to a pointer to a list of strings.
+// It returns nil if the value is null or unknown.
+func StringListToPointer(list basetypes.ListValue) (*[]string, error) {
+ if list.IsNull() || list.IsUnknown() {
+ return nil, nil
+ }
+
+ listStr := []string{}
+ for i, el := range list.Elements() {
+ elStr, ok := el.(types.String)
+ if !ok {
+ return nil, fmt.Errorf("element %d is not a string", i)
+ }
+ listStr = append(listStr, elStr.ValueString())
+ }
+
+ return &listStr, nil
+}
+
+// ToJSONMApPartialUpdatePayload returns a map[string]interface{} to be used in a PATCH request payload.
+// It takes a current map as it is in the terraform state and a desired map as it is in the user configuratiom
+// and builds a map which sets to null keys that should be removed, updates the values of existing keys and adds new keys
+// This method is needed because in partial updates, e.g. if the key is not provided it is ignored and not removed
+func ToJSONMapPartialUpdatePayload(ctx context.Context, current, desired types.Map) (map[string]interface{}, error) {
+ currentMap, err := ToStringInterfaceMap(ctx, current)
+ if err != nil {
+ return nil, fmt.Errorf("converting to Go map: %w", err)
+ }
+
+ desiredMap, err := ToStringInterfaceMap(ctx, desired)
+ if err != nil {
+ return nil, fmt.Errorf("converting to Go map: %w", err)
+ }
+
+ mapPayload := map[string]interface{}{}
+ // Update and remove existing keys
+ for k := range currentMap {
+ if desiredValue, ok := desiredMap[k]; ok {
+ mapPayload[k] = desiredValue
+ } else {
+ mapPayload[k] = nil
+ }
+ }
+
+ // Add new keys
+ for k, desiredValue := range desiredMap {
+ if _, ok := mapPayload[k]; !ok {
+ mapPayload[k] = desiredValue
+ }
+ }
+ return mapPayload, nil
+}
+
+func ParseProviderData(ctx context.Context, providerData any, diags *diag.Diagnostics) (core.ProviderData, bool) {
+ // Prevent panic if the provider has not been configured.
+ if providerData == nil {
+ return core.ProviderData{}, false
+ }
+
+ stackitProviderData, ok := providerData.(core.ProviderData)
+ if !ok {
+ core.LogAndAddError(ctx, diags, "Error configuring API client", fmt.Sprintf("Expected configure type core.ProviderData, got %T", providerData))
+ return core.ProviderData{}, false
+ }
+ return stackitProviderData, true
+}
+
+func ParseEphemeralProviderData(ctx context.Context, providerData any, diags *diag.Diagnostics) (core.EphemeralProviderData, bool) {
+ // Prevent panic if the provider has not been configured.
+ if providerData == nil {
+ return core.EphemeralProviderData{}, false
+ }
+
+ stackitProviderData, ok := providerData.(core.EphemeralProviderData)
+ if !ok {
+ core.LogAndAddError(ctx, diags, "Error configuring API client", "Expected configure type core.EphemeralProviderData")
+ return core.EphemeralProviderData{}, false
+ }
+ return stackitProviderData, true
+}
diff --git a/stackit/internal/conversion/conversion_test.go b/stackit/internal/conversion/conversion_test.go
new file mode 100644
index 00000000..53fd738a
--- /dev/null
+++ b/stackit/internal/conversion/conversion_test.go
@@ -0,0 +1,396 @@
+// Copyright (c) STACKIT
+
+package conversion
+
+import (
+ "context"
+ "reflect"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+
+ "github.com/google/go-cmp/cmp"
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+)
+
+func TestFromTerraformStringMapToInterfaceMap(t *testing.T) {
+ type args struct {
+ ctx context.Context
+ m basetypes.MapValue
+ }
+ tests := []struct {
+ name string
+ args args
+ want map[string]interface{}
+ wantErr bool
+ }{
+ {
+ name: "base",
+ args: args{
+ ctx: context.Background(),
+ m: types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("value"),
+ "key2": types.StringValue("value2"),
+ "key3": types.StringValue("value3"),
+ }),
+ },
+ want: map[string]interface{}{
+ "key": "value",
+ "key2": "value2",
+ "key3": "value3",
+ },
+ wantErr: false,
+ },
+ {
+ name: "empty",
+ args: args{
+ ctx: context.Background(),
+ m: types.MapValueMust(types.StringType, map[string]attr.Value{}),
+ },
+ want: map[string]interface{}{},
+ wantErr: false,
+ },
+ {
+ name: "nil",
+ args: args{
+ ctx: context.Background(),
+ m: types.MapNull(types.StringType),
+ },
+ want: map[string]interface{}{},
+ wantErr: false,
+ },
+ {
+ name: "invalid type map (non-string)",
+ args: args{
+ ctx: context.Background(),
+ m: types.MapValueMust(types.Int64Type, map[string]attr.Value{
+ "key": types.Int64Value(1),
+ }),
+ },
+ wantErr: true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ got, err := ToStringInterfaceMap(tt.args.ctx, tt.args.m)
+ if (err != nil) != tt.wantErr {
+ t.Errorf("FromTerraformStringMapToInterfaceMap() error = %v, wantErr %v", err, tt.wantErr)
+ return
+ }
+ if !reflect.DeepEqual(got, tt.want) {
+ t.Errorf("FromTerraformStringMapToInterfaceMap() = %v, want %v", got, tt.want)
+ }
+ })
+ }
+}
+
+func TestToJSONMapUpdatePayload(t *testing.T) {
+ tests := []struct {
+ description string
+ currentLabels types.Map
+ desiredLabels types.Map
+ expected map[string]interface{}
+ isValid bool
+ }{
+ {
+ "nothing_to_update",
+ types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("value"),
+ }),
+ types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("value"),
+ }),
+ map[string]interface{}{
+ "key": "value",
+ },
+ true,
+ },
+ {
+ "update_key_value",
+ types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("value"),
+ }),
+ types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("updated_value"),
+ }),
+ map[string]interface{}{
+ "key": "updated_value",
+ },
+ true,
+ },
+ {
+ "remove_key",
+ types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("value"),
+ "key2": types.StringValue("value2"),
+ }),
+ types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("value"),
+ }),
+ map[string]interface{}{
+ "key": "value",
+ "key2": nil,
+ },
+ true,
+ },
+ {
+ "add_new_key",
+ types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("value"),
+ }),
+ types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("value"),
+ "key2": types.StringValue("value2"),
+ }),
+ map[string]interface{}{
+ "key": "value",
+ "key2": "value2",
+ },
+ true,
+ },
+ {
+ "empty_desired_map",
+ types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("value"),
+ "key2": types.StringValue("value2"),
+ }),
+ types.MapValueMust(types.StringType, map[string]attr.Value{}),
+ map[string]interface{}{
+ "key": nil,
+ "key2": nil,
+ },
+ true,
+ },
+ {
+ "nil_desired_map",
+ types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("value"),
+ "key2": types.StringValue("value2"),
+ }),
+ types.MapNull(types.StringType),
+ map[string]interface{}{
+ "key": nil,
+ "key2": nil,
+ },
+ true,
+ },
+ {
+ "empty_current_map",
+ types.MapValueMust(types.StringType, map[string]attr.Value{}),
+ types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("value"),
+ "key2": types.StringValue("value2"),
+ }),
+ map[string]interface{}{
+ "key": "value",
+ "key2": "value2",
+ },
+ true,
+ },
+ {
+ "nil_current_map",
+ types.MapNull(types.StringType),
+ types.MapValueMust(types.StringType, map[string]attr.Value{
+ "key": types.StringValue("value"),
+ "key2": types.StringValue("value2"),
+ }),
+ map[string]interface{}{
+ "key": "value",
+ "key2": "value2",
+ },
+ true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ output, err := ToJSONMapPartialUpdatePayload(context.Background(), tt.currentLabels, tt.desiredLabels)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(output, tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ })
+ }
+}
+
+func TestParseProviderData(t *testing.T) {
+ type args struct {
+ providerData any
+ }
+ type want struct {
+ ok bool
+ providerData core.ProviderData
+ }
+ tests := []struct {
+ name string
+ args args
+ want want
+ wantErr bool
+ }{
+ {
+ name: "provider has not been configured",
+ args: args{
+ providerData: nil,
+ },
+ want: want{
+ ok: false,
+ },
+ wantErr: false,
+ },
+ {
+ name: "invalid provider data",
+ args: args{
+ providerData: struct{}{},
+ },
+ want: want{
+ ok: false,
+ },
+ wantErr: true,
+ },
+ {
+ name: "valid provider data 1",
+ args: args{
+ providerData: core.ProviderData{},
+ },
+ want: want{
+ ok: true,
+ providerData: core.ProviderData{},
+ },
+ wantErr: false,
+ },
+ {
+ name: "valid provider data 2",
+ args: args{
+ providerData: core.ProviderData{
+ DefaultRegion: "eu02",
+ RabbitMQCustomEndpoint: "https://rabbitmq-custom-endpoint.api.stackit.cloud",
+ Version: "1.2.3",
+ },
+ },
+ want: want{
+ ok: true,
+ providerData: core.ProviderData{
+ DefaultRegion: "eu02",
+ RabbitMQCustomEndpoint: "https://rabbitmq-custom-endpoint.api.stackit.cloud",
+ Version: "1.2.3",
+ },
+ },
+ wantErr: false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ ctx := context.Background()
+ diags := diag.Diagnostics{}
+
+ actual, ok := ParseProviderData(ctx, tt.args.providerData, &diags)
+ if diags.HasError() != tt.wantErr {
+ t.Errorf("ConfigureClient() error = %v, want %v", diags.HasError(), tt.wantErr)
+ }
+ if ok != tt.want.ok {
+ t.Errorf("ParseProviderData() got = %v, want %v", ok, tt.want.ok)
+ }
+ if !reflect.DeepEqual(actual, tt.want.providerData) {
+ t.Errorf("ParseProviderData() got = %v, want %v", actual, tt.want)
+ }
+ })
+ }
+}
+
+func TestParseEphemeralProviderData(t *testing.T) {
+ type args struct {
+ providerData any
+ }
+ type want struct {
+ ok bool
+ providerData core.EphemeralProviderData
+ }
+ tests := []struct {
+ name string
+ args args
+ want want
+ wantErr bool
+ }{
+ {
+ name: "provider has not been configured",
+ args: args{
+ providerData: nil,
+ },
+ want: want{
+ ok: false,
+ },
+ wantErr: false,
+ },
+ {
+ name: "invalid provider data",
+ args: args{
+ providerData: struct{}{},
+ },
+ want: want{
+ ok: false,
+ },
+ wantErr: true,
+ },
+ {
+ name: "valid provider data 1",
+ args: args{
+ providerData: core.EphemeralProviderData{},
+ },
+ want: want{
+ ok: true,
+ providerData: core.EphemeralProviderData{},
+ },
+ wantErr: false,
+ },
+ {
+ name: "valid provider data 2",
+ args: args{
+ providerData: core.EphemeralProviderData{
+ PrivateKey: "",
+ PrivateKeyPath: "/home/dev/foo/private-key.json",
+ ServiceAccountKey: "",
+ ServiceAccountKeyPath: "/home/dev/foo/key.json",
+ TokenCustomEndpoint: "",
+ },
+ },
+ want: want{
+ ok: true,
+ providerData: core.EphemeralProviderData{
+ PrivateKey: "",
+ PrivateKeyPath: "/home/dev/foo/private-key.json",
+ ServiceAccountKey: "",
+ ServiceAccountKeyPath: "/home/dev/foo/key.json",
+ TokenCustomEndpoint: "",
+ },
+ },
+ wantErr: false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ ctx := context.Background()
+ diags := diag.Diagnostics{}
+
+ actual, ok := ParseEphemeralProviderData(ctx, tt.args.providerData, &diags)
+ if diags.HasError() != tt.wantErr {
+ t.Errorf("ConfigureClient() error = %v, want %v", diags.HasError(), tt.wantErr)
+ }
+ if ok != tt.want.ok {
+ t.Errorf("ParseProviderData() got = %v, want %v", ok, tt.want.ok)
+ }
+ if !reflect.DeepEqual(actual, tt.want.providerData) {
+ t.Errorf("ParseProviderData() got = %v, want %v", actual, tt.want)
+ }
+ })
+ }
+}
diff --git a/stackit/internal/core/core.go b/stackit/internal/core/core.go
new file mode 100644
index 00000000..d3ea252c
--- /dev/null
+++ b/stackit/internal/core/core.go
@@ -0,0 +1,168 @@
+// Copyright (c) STACKIT
+
+package core
+
+import (
+ "context"
+ "fmt"
+ "net/http"
+ "strings"
+
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/core/runtime"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+)
+
+type ResourceType string
+
+const (
+ Resource ResourceType = "resource"
+ Datasource ResourceType = "datasource"
+ EphemeralResource ResourceType = "ephemeral-resource"
+
+ // Separator used for concatenation of TF-internal resource ID
+ Separator = ","
+
+ ResourceRegionFallbackDocstring = "Uses the `default_region` specified in the provider configuration as a fallback in case no `region` is defined on resource level."
+ DatasourceRegionFallbackDocstring = "Uses the `default_region` specified in the provider configuration as a fallback in case no `region` is defined on datasource level."
+)
+
+type EphemeralProviderData struct {
+ ProviderData
+
+ PrivateKey string
+ PrivateKeyPath string
+ ServiceAccountKey string
+ ServiceAccountKeyPath string
+ TokenCustomEndpoint string
+}
+
+type ProviderData struct {
+ RoundTripper http.RoundTripper
+ ServiceAccountEmail string // Deprecated: ServiceAccountEmail is not required and will be removed after 12th June 2025.
+ // Deprecated: Use DefaultRegion instead
+ Region string
+ DefaultRegion string
+ AuthorizationCustomEndpoint string
+ CdnCustomEndpoint string
+ DnsCustomEndpoint string
+ GitCustomEndpoint string
+ IaaSCustomEndpoint string
+ KMSCustomEndpoint string
+ LoadBalancerCustomEndpoint string
+ LogMeCustomEndpoint string
+ MariaDBCustomEndpoint string
+ MongoDBFlexCustomEndpoint string
+ ModelServingCustomEndpoint string
+ ObjectStorageCustomEndpoint string
+ ObservabilityCustomEndpoint string
+ OpenSearchCustomEndpoint string
+ PostgresFlexCustomEndpoint string
+ RabbitMQCustomEndpoint string
+ RedisCustomEndpoint string
+ ResourceManagerCustomEndpoint string
+ ScfCustomEndpoint string
+ SecretsManagerCustomEndpoint string
+ SQLServerFlexCustomEndpoint string
+ ServerBackupCustomEndpoint string
+ ServerUpdateCustomEndpoint string
+ SKECustomEndpoint string
+ ServiceEnablementCustomEndpoint string
+ ServiceAccountCustomEndpoint string
+ EnableBetaResources bool
+ Experiments []string
+
+ Version string // version of the STACKIT Terraform provider
+}
+
+// GetRegion returns the effective region for the provider, falling back to the deprecated _region_ attribute
+func (pd *ProviderData) GetRegion() string {
+ if pd.DefaultRegion != "" {
+ return pd.DefaultRegion
+ } else if pd.Region != "" {
+ return pd.Region
+ }
+ // final fallback
+ return "eu01"
+}
+
+func (pd *ProviderData) GetRegionWithOverride(overrideRegion types.String) string {
+ if overrideRegion.IsUnknown() || overrideRegion.IsNull() {
+ return pd.GetRegion()
+ }
+ return overrideRegion.ValueString()
+}
+
+// DiagsToError Converts TF diagnostics' errors into an error with a human-readable description.
+// If there are no errors, the output is nil
+func DiagsToError(diags diag.Diagnostics) error {
+ if !diags.HasError() {
+ return nil
+ }
+
+ diagsError := diags.Errors()
+ diagsStrings := make([]string, 0)
+ for _, diagnostic := range diagsError {
+ diagsStrings = append(diagsStrings, fmt.Sprintf(
+ "(%s) %s",
+ diagnostic.Summary(),
+ diagnostic.Detail(),
+ ))
+ }
+ return fmt.Errorf("%s", strings.Join(diagsStrings, ";"))
+}
+
+// LogAndAddError Logs the error and adds it to the diags
+func LogAndAddError(ctx context.Context, diags *diag.Diagnostics, summary, detail string) {
+ if traceId := runtime.GetTraceId(ctx); traceId != "" {
+ detail = fmt.Sprintf("%s\nTrace ID: %q", detail, traceId)
+ }
+
+ tflog.Error(ctx, fmt.Sprintf("%s | %s", summary, detail))
+ diags.AddError(summary, detail)
+}
+
+// LogAndAddWarning Logs the warning and adds it to the diags
+func LogAndAddWarning(ctx context.Context, diags *diag.Diagnostics, summary, detail string) {
+ if traceId := runtime.GetTraceId(ctx); traceId != "" {
+ detail = fmt.Sprintf("%s\nTrace ID: %q", detail, traceId)
+ }
+
+ tflog.Warn(ctx, fmt.Sprintf("%s | %s", summary, detail))
+ diags.AddWarning(summary, detail)
+}
+
+func LogAndAddWarningBeta(ctx context.Context, diags *diag.Diagnostics, name string, resourceType ResourceType) {
+ warnTitle := fmt.Sprintf("The %s %q is in beta", resourceType, name)
+ warnContent := fmt.Sprintf("The %s %q is in beta and may be subject to breaking changes in the future. Use with caution.", resourceType, name)
+ tflog.Warn(ctx, fmt.Sprintf("%s | %s", warnTitle, warnContent))
+ diags.AddWarning(warnTitle, warnContent)
+}
+
+func LogAndAddErrorBeta(ctx context.Context, diags *diag.Diagnostics, name string, resourceType ResourceType) {
+ errTitle := fmt.Sprintf("The %s %q is in beta and beta is not enabled", resourceType, name)
+ errContent := fmt.Sprintf(`The %s %q is in beta and the beta functionality is currently not enabled. To enable it, set the environment variable STACKIT_TF_ENABLE_BETA_RESOURCES to "true" or set the "enable_beta_resources" provider field to true.`, resourceType, name)
+ tflog.Error(ctx, fmt.Sprintf("%s | %s", errTitle, errContent))
+ diags.AddError(errTitle, errContent)
+}
+
+// InitProviderContext extends the context to capture the http response
+func InitProviderContext(ctx context.Context) context.Context {
+ // Capture http response to get trace-id
+ var httpResp *http.Response
+ return runtime.WithCaptureHTTPResponse(ctx, &httpResp)
+}
+
+// LogResponse logs the trace-id of the last request
+func LogResponse(ctx context.Context) context.Context {
+ // Logs the trace-id of the request
+ traceId := runtime.GetTraceId(ctx)
+ ctx = tflog.SetField(ctx, "x-trace-id", traceId)
+
+ tflog.Info(ctx, "response data", map[string]interface{}{
+ "x-trace-id": traceId,
+ })
+ return ctx
+}
diff --git a/stackit/internal/core/core_test.go b/stackit/internal/core/core_test.go
new file mode 100644
index 00000000..0905899e
--- /dev/null
+++ b/stackit/internal/core/core_test.go
@@ -0,0 +1,102 @@
+// Copyright (c) STACKIT
+
+package core
+
+import (
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-framework/types"
+)
+
+func TestProviderData_GetRegionWithOverride(t *testing.T) {
+ type args struct {
+ overrideRegion types.String
+ }
+ tests := []struct {
+ name string
+ providerData *ProviderData
+ args args
+ want string
+ }{
+ {
+ name: "override region is null string",
+ providerData: &ProviderData{
+ DefaultRegion: "eu02",
+ },
+ args: args{
+ types.StringNull(),
+ },
+ want: "eu02",
+ },
+ {
+ name: "override region is unknown string",
+ providerData: &ProviderData{
+ DefaultRegion: "eu02",
+ },
+ args: args{
+ types.StringUnknown(),
+ },
+ want: "eu02",
+ },
+ {
+ name: "override region is set",
+ providerData: &ProviderData{
+ DefaultRegion: "eu02",
+ },
+ args: args{
+ types.StringValue("eu01"),
+ },
+ want: "eu01",
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ if got := tt.providerData.GetRegionWithOverride(tt.args.overrideRegion); got != tt.want {
+ t.Errorf("GetRegionWithOverride() = %v, want %v", got, tt.want)
+ }
+ })
+ }
+}
+
+func TestProviderData_GetRegion(t *testing.T) {
+ tests := []struct {
+ name string
+ providerData *ProviderData
+ want string
+ }{
+ {
+ name: "default region is set",
+ providerData: &ProviderData{
+ DefaultRegion: "eu02",
+ },
+ want: "eu02",
+ },
+ {
+ name: "(legacy) region is set",
+ providerData: &ProviderData{
+ Region: "eu02",
+ },
+ want: "eu02",
+ },
+ {
+ name: "default region wins over (legacy) region",
+ providerData: &ProviderData{
+ DefaultRegion: "eu02",
+ Region: "eu01",
+ },
+ want: "eu02",
+ },
+ {
+ name: "final fallback - neither region (legacy) nor default region is set",
+ providerData: &ProviderData{},
+ want: "eu01",
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ if got := tt.providerData.GetRegion(); got != tt.want {
+ t.Errorf("GetRegion() = %v, want %v", got, tt.want)
+ }
+ })
+ }
+}
diff --git a/stackit/internal/features/beta.go b/stackit/internal/features/beta.go
new file mode 100644
index 00000000..f0615eaa
--- /dev/null
+++ b/stackit/internal/features/beta.go
@@ -0,0 +1,59 @@
+// Copyright (c) STACKIT
+
+package features
+
+import (
+ "context"
+ "fmt"
+ "os"
+ "strings"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+)
+
+// BetaResourcesEnabled returns whether this provider has beta functionality enabled.
+//
+// In order of precedence, beta functionality can be managed by:
+// - Environment Variable `STACKIT_TF_ENABLE_BETA_RESOURCES` - `true` is enabled, `false` is disabled.
+// - Provider configuration feature flag `enable_beta` - `true` is enabled, `false` is disabled.
+func BetaResourcesEnabled(ctx context.Context, data *core.ProviderData, diags *diag.Diagnostics) bool {
+ value, set := os.LookupEnv("STACKIT_TF_ENABLE_BETA_RESOURCES")
+ if set {
+ if strings.EqualFold(value, "true") {
+ return true
+ }
+ if strings.EqualFold(value, "false") {
+ return false
+ }
+ warnDetails := fmt.Sprintf(`The value of the environment variable that enables beta functionality must be either "true" or "false", got %q.
+Defaulting to the provider feature flag.`, value)
+ core.LogAndAddWarning(ctx, diags, "Invalid value for STACKIT_TF_ENABLE_BETA_RESOURCES environment variable.", warnDetails)
+ }
+ // ProviderData should always be set, but we check just in case
+ if data == nil {
+ return false
+ }
+ return data.EnableBetaResources
+}
+
+// CheckBetaResourcesEnabled is a helper function to log and add a warning or error if the beta functionality is not enabled.
+//
+// Should be called in the Configure method of a beta resource.
+// Then, check for Errors in the diags using the diags.HasError() method.
+func CheckBetaResourcesEnabled(ctx context.Context, data *core.ProviderData, diags *diag.Diagnostics, resourceName string, resourceType core.ResourceType) {
+ if !BetaResourcesEnabled(ctx, data, diags) {
+ core.LogAndAddErrorBeta(ctx, diags, resourceName, resourceType)
+ return
+ }
+ core.LogAndAddWarningBeta(ctx, diags, resourceName, resourceType)
+}
+
+func AddBetaDescription(description string, resourceType core.ResourceType) string {
+ // Callout block: https://developer.hashicorp.com/terraform/registry/providers/docs#callouts
+ return fmt.Sprintf("%s\n\n~> %s %s",
+ description,
+ fmt.Sprintf("This %s is in beta and may be subject to breaking changes in the future. Use with caution.", resourceType),
+ "See our [guide](https://registry.terraform.io/providers/stackitcloud/stackit/latest/docs/guides/opting_into_beta_resources) for how to opt-in to use beta resources.",
+ )
+}
diff --git a/stackit/internal/features/beta_test.go b/stackit/internal/features/beta_test.go
new file mode 100644
index 00000000..4ea67e10
--- /dev/null
+++ b/stackit/internal/features/beta_test.go
@@ -0,0 +1,218 @@
+// Copyright (c) STACKIT
+
+package features
+
+import (
+ "context"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+)
+
+func TestBetaResourcesEnabled(t *testing.T) {
+ tests := []struct {
+ description string
+ data *core.ProviderData
+ envSet bool
+ envValue string
+ expected bool
+ expectWarn bool
+ }{
+ {
+ description: "Feature flag enabled, env var not set",
+ data: &core.ProviderData{
+ EnableBetaResources: true,
+ },
+ expected: true,
+ },
+ {
+ description: "Feature flag is disabled, env var not set",
+ data: &core.ProviderData{
+ EnableBetaResources: false,
+ },
+ expected: false,
+ },
+ {
+ description: "Feature flag, Env var not set",
+ data: &core.ProviderData{},
+ expected: false,
+ },
+ {
+ description: "Feature flag not set, Env var is true",
+ data: &core.ProviderData{},
+ envSet: true,
+ envValue: "true",
+ expected: true,
+ },
+ {
+ description: "Feature flag not set, Env var is false",
+ data: &core.ProviderData{},
+ envSet: true,
+ envValue: "false",
+ expected: false,
+ },
+ {
+ description: "Feature flag not set, Env var is empty",
+ data: &core.ProviderData{},
+ envSet: true,
+ envValue: "",
+ expectWarn: true,
+ expected: false,
+ },
+ {
+ description: "Feature flag not set, Env var is gibberish",
+ data: &core.ProviderData{},
+ envSet: true,
+ envValue: "gibberish",
+ expectWarn: true,
+ expected: false,
+ },
+ {
+ description: "Feature flag enabled, Env var is true",
+ data: &core.ProviderData{
+ EnableBetaResources: true,
+ },
+ envSet: true,
+ envValue: "true",
+ expected: true,
+ },
+ {
+ description: "Feature flag enabled, Env var is false",
+ data: &core.ProviderData{
+ EnableBetaResources: true,
+ },
+ envSet: true,
+ envValue: "false",
+ expected: false,
+ },
+ {
+ description: "Feature flag enabled, Env var is empty",
+ data: &core.ProviderData{
+ EnableBetaResources: true,
+ },
+ envSet: true,
+ envValue: "",
+ expectWarn: true,
+ expected: true,
+ },
+ {
+ description: "Feature flag enabled, Env var is gibberish",
+ data: &core.ProviderData{
+ EnableBetaResources: true,
+ },
+ envSet: true,
+ envValue: "gibberish",
+ expectWarn: true,
+ expected: true,
+ },
+ {
+ description: "Feature flag disabled, Env var is true",
+ data: &core.ProviderData{
+ EnableBetaResources: false,
+ },
+ envSet: true,
+ envValue: "true",
+ expected: true,
+ },
+ {
+ description: "Feature flag disabled, Env var is false",
+ data: &core.ProviderData{
+ EnableBetaResources: false,
+ },
+ envSet: true,
+ envValue: "false",
+ expected: false,
+ },
+ {
+ description: "Feature flag disabled, Env var is empty",
+ data: &core.ProviderData{
+ EnableBetaResources: false,
+ },
+ envSet: true,
+ envValue: "",
+ expectWarn: true,
+ expected: false,
+ },
+ {
+ description: "Feature flag disabled, Env var is gibberish",
+ data: &core.ProviderData{
+ EnableBetaResources: false,
+ },
+ envSet: true,
+ envValue: "gibberish",
+ expectWarn: true,
+ expected: false,
+ },
+ }
+
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ if tt.envSet {
+ t.Setenv("STACKIT_TF_ENABLE_BETA_RESOURCES", tt.envValue)
+ }
+ diags := diag.Diagnostics{}
+
+ result := BetaResourcesEnabled(context.Background(), tt.data, &diags)
+ if result != tt.expected {
+ t.Fatalf("Expected %t, got %t", tt.expected, result)
+ }
+
+ if tt.expectWarn && diags.WarningsCount() == 0 {
+ t.Fatalf("Expected warning, got none")
+ }
+ if !tt.expectWarn && diags.WarningsCount() > 0 {
+ t.Fatalf("Expected no warning, got %d", diags.WarningsCount())
+ }
+ })
+ }
+}
+
+func TestCheckBetaResourcesEnabled(t *testing.T) {
+ tests := []struct {
+ description string
+ betaEnabled bool
+ expectError bool
+ expectWarn bool
+ }{
+ {
+ description: "Beta enabled, show warning",
+ betaEnabled: true,
+ expectWarn: true,
+ },
+ {
+ description: "Beta disabled, show error",
+ betaEnabled: false,
+ expectError: true,
+ },
+ }
+
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ var envValue string
+ if tt.betaEnabled {
+ envValue = "true"
+ } else {
+ envValue = "false"
+ }
+ t.Setenv("STACKIT_TF_ENABLE_BETA_RESOURCES", envValue)
+
+ diags := diag.Diagnostics{}
+ CheckBetaResourcesEnabled(context.Background(), &core.ProviderData{}, &diags, "stackit_test", "resource")
+
+ if tt.expectError && diags.ErrorsCount() == 0 {
+ t.Fatalf("Expected error, got none")
+ }
+ if !tt.expectError && diags.ErrorsCount() > 0 {
+ t.Fatalf("Expected no error, got %d", diags.ErrorsCount())
+ }
+
+ if tt.expectWarn && diags.WarningsCount() == 0 {
+ t.Fatalf("Expected warning, got none")
+ }
+ if !tt.expectWarn && diags.WarningsCount() > 0 {
+ t.Fatalf("Expected no warning, got %d", diags.WarningsCount())
+ }
+ })
+ }
+}
diff --git a/stackit/internal/features/experiments.go b/stackit/internal/features/experiments.go
new file mode 100644
index 00000000..6f56fb64
--- /dev/null
+++ b/stackit/internal/features/experiments.go
@@ -0,0 +1,78 @@
+// Copyright (c) STACKIT
+
+package features
+
+import (
+ "context"
+ "fmt"
+ "slices"
+ "strings"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+)
+
+const (
+ RoutingTablesExperiment = "routing-tables"
+ NetworkExperiment = "network"
+ IamExperiment = "iam"
+)
+
+var AvailableExperiments = []string{IamExperiment, RoutingTablesExperiment, NetworkExperiment}
+
+// Check if an experiment is valid.
+func ValidExperiment(experiment string, diags *diag.Diagnostics) bool {
+ validExperiment := slices.ContainsFunc(AvailableExperiments, func(e string) bool {
+ return strings.EqualFold(e, experiment)
+ })
+ if !validExperiment {
+ diags.AddError("Invalid Experiment", fmt.Sprintf("The Experiment %s is invalid. This is most likely a bug in the STACKIT Provider. Please open an issue. Available Experiments: %v", experiment, AvailableExperiments))
+ }
+
+ return validExperiment
+}
+
+// Check if an experiment is enabled.
+func CheckExperimentEnabled(ctx context.Context, data *core.ProviderData, experiment, resourceName string, resourceType core.ResourceType, diags *diag.Diagnostics) {
+ if CheckExperimentEnabledWithoutError(ctx, data, experiment, resourceName, resourceType, diags) {
+ return
+ }
+ errTitle := fmt.Sprintf("%s is part of the %s experiment, which is currently disabled by default", resourceName, experiment)
+ errContent := fmt.Sprintf(`Enable the %s experiment by adding it into your provider block.`, experiment)
+ tflog.Error(ctx, fmt.Sprintf("%s | %s", errTitle, errContent))
+ diags.AddError(errTitle, errContent)
+}
+
+func CheckExperimentEnabledWithoutError(ctx context.Context, data *core.ProviderData, experiment, resourceName string, resourceType core.ResourceType, diags *diag.Diagnostics) bool {
+ if !ValidExperiment(experiment, diags) {
+ errTitle := fmt.Sprintf("The experiment %s does not exist.", experiment)
+ errContent := "This is a bug in the STACKIT Terraform Provider. Please open an issue here: https://github.com/stackitcloud/terraform-provider-stackit/issues"
+ diags.AddError(errTitle, errContent)
+ return false
+ }
+ experimentActive := slices.ContainsFunc(data.Experiments, func(e string) bool {
+ return strings.EqualFold(e, experiment)
+ })
+
+ if experimentActive {
+ warnTitle := fmt.Sprintf("%s is part of the %s experiment.", resourceName, experiment)
+ warnContent := fmt.Sprintf("This %s is part of the %s experiment and is likely going to undergo significant changes or be removed in the future. Use it at your own discretion.", resourceType, experiment)
+ tflog.Warn(ctx, fmt.Sprintf("%s | %s", warnTitle, warnContent))
+ diags.AddWarning(warnTitle, warnContent)
+ return true
+ }
+ return false
+}
+
+func AddExperimentDescription(description, experiment string, resourceType core.ResourceType) string {
+ // Callout block: https://developer.hashicorp.com/terraform/registry/providers/docs#callouts
+ return fmt.Sprintf("%s\n\n~> %s%s%s%s%s",
+ description,
+ "This ",
+ resourceType,
+ " is part of the ",
+ experiment,
+ " experiment and is likely going to undergo significant changes or be removed in the future. Use it at your own discretion.",
+ )
+}
diff --git a/stackit/internal/features/experiments_test.go b/stackit/internal/features/experiments_test.go
new file mode 100644
index 00000000..256055ca
--- /dev/null
+++ b/stackit/internal/features/experiments_test.go
@@ -0,0 +1,254 @@
+// Copyright (c) STACKIT
+
+package features
+
+import (
+ "context"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+)
+
+func TestValidExperiment(t *testing.T) {
+ type args struct {
+ experiment string
+ diags *diag.Diagnostics
+ }
+ tests := []struct {
+ name string
+ args args
+ want bool
+ }{
+ {
+ name: "valid",
+ args: args{
+ experiment: IamExperiment,
+ diags: &diag.Diagnostics{},
+ },
+ want: true,
+ },
+ {
+ name: "invalid",
+ args: args{
+ experiment: "foo",
+ diags: &diag.Diagnostics{},
+ },
+ want: false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ if got := ValidExperiment(tt.args.experiment, tt.args.diags); got != tt.want {
+ t.Errorf("ValidExperiment() = %v, want %v", got, tt.want)
+ }
+ })
+ }
+}
+
+func TestCheckExperimentEnabled(t *testing.T) {
+ type args struct {
+ ctx context.Context
+ data *core.ProviderData
+ experiment string
+ resourceName string
+ resourceType core.ResourceType
+ diags *diag.Diagnostics
+ }
+ tests := []struct {
+ name string
+ args args
+ wantDiagsErr bool
+ wantDiagsWarning bool
+ }{
+ {
+ name: "enabled",
+ args: args{
+ ctx: context.Background(),
+ data: &core.ProviderData{
+ Experiments: []string{IamExperiment},
+ },
+ experiment: IamExperiment,
+ resourceType: core.Resource,
+ diags: &diag.Diagnostics{},
+ },
+ wantDiagsErr: false,
+ wantDiagsWarning: true,
+ },
+ {
+ name: "disabled",
+ args: args{
+ ctx: context.Background(),
+ data: &core.ProviderData{
+ Experiments: []string{},
+ },
+ experiment: IamExperiment,
+ resourceType: core.Resource,
+ diags: &diag.Diagnostics{},
+ },
+ wantDiagsErr: true,
+ wantDiagsWarning: false,
+ },
+ {
+ name: "invalid experiment",
+ args: args{
+ ctx: context.Background(),
+ data: &core.ProviderData{
+ Experiments: []string{IamExperiment},
+ },
+ experiment: "foobar",
+ resourceType: core.Resource,
+ diags: &diag.Diagnostics{},
+ },
+ wantDiagsErr: true,
+ wantDiagsWarning: false,
+ },
+ {
+ name: "enabled multiple experiment",
+ args: args{
+ ctx: context.Background(),
+ data: &core.ProviderData{
+ Experiments: []string{IamExperiment, NetworkExperiment, RoutingTablesExperiment},
+ },
+ experiment: NetworkExperiment,
+ resourceType: core.Resource,
+ diags: &diag.Diagnostics{},
+ },
+ wantDiagsErr: false,
+ wantDiagsWarning: true,
+ },
+ {
+ name: "enabled multiple experiment - without the required experiment",
+ args: args{
+ ctx: context.Background(),
+ data: &core.ProviderData{
+ Experiments: []string{IamExperiment, RoutingTablesExperiment},
+ },
+ experiment: NetworkExperiment,
+ resourceType: core.Resource,
+ diags: &diag.Diagnostics{},
+ },
+ wantDiagsErr: true,
+ wantDiagsWarning: false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ CheckExperimentEnabled(tt.args.ctx, tt.args.data, tt.args.experiment, tt.args.resourceName, tt.args.resourceType, tt.args.diags)
+ if got := tt.args.diags.HasError(); got != tt.wantDiagsErr {
+ t.Errorf("CheckExperimentEnabled() diags.HasError() = %v, want %v", got, tt.wantDiagsErr)
+ }
+ if got := tt.args.diags.WarningsCount() > 0; got != tt.wantDiagsWarning {
+ t.Errorf("CheckExperimentEnabled() diags.WarningsCount() > 0 = %v, want %v", got, tt.wantDiagsErr)
+ }
+ })
+ }
+}
+
+func TestCheckExperimentEnabledWithoutError(t *testing.T) {
+ type args struct {
+ ctx context.Context
+ data *core.ProviderData
+ experiment string
+ resourceName string
+ resourceType core.ResourceType
+ diags *diag.Diagnostics
+ }
+ tests := []struct {
+ name string
+ args args
+ wantEnabled bool
+ wantDiagsErr bool
+ wantDiagsWarning bool
+ }{
+
+ {
+ name: "enabled",
+ args: args{
+ ctx: context.Background(),
+ data: &core.ProviderData{
+ Experiments: []string{IamExperiment},
+ },
+ experiment: IamExperiment,
+ resourceType: core.Resource,
+ diags: &diag.Diagnostics{},
+ },
+ wantEnabled: true,
+ wantDiagsErr: false,
+ wantDiagsWarning: true,
+ },
+ {
+ name: "disabled - no error",
+ args: args{
+ ctx: context.Background(),
+ data: &core.ProviderData{
+ Experiments: []string{},
+ },
+ experiment: NetworkExperiment,
+ resourceType: core.Resource,
+ diags: &diag.Diagnostics{},
+ },
+ wantEnabled: false,
+ wantDiagsErr: false,
+ wantDiagsWarning: false,
+ },
+ {
+ name: "invalid experiment",
+ args: args{
+ ctx: context.Background(),
+ data: &core.ProviderData{
+ Experiments: []string{IamExperiment},
+ },
+ experiment: "foobar",
+ resourceType: core.Resource,
+ diags: &diag.Diagnostics{},
+ },
+ wantEnabled: false,
+ wantDiagsErr: true,
+ wantDiagsWarning: false,
+ },
+ {
+ name: "enabled multiple experiment",
+ args: args{
+ ctx: context.Background(),
+ data: &core.ProviderData{
+ Experiments: []string{IamExperiment, NetworkExperiment, RoutingTablesExperiment},
+ },
+ experiment: NetworkExperiment,
+ resourceType: core.Resource,
+ diags: &diag.Diagnostics{},
+ },
+ wantEnabled: true,
+ wantDiagsErr: false,
+ wantDiagsWarning: true,
+ },
+ {
+ name: "enabled multiple experiment - without the required experiment",
+ args: args{
+ ctx: context.Background(),
+ data: &core.ProviderData{
+ Experiments: []string{IamExperiment, RoutingTablesExperiment},
+ },
+ experiment: NetworkExperiment,
+ resourceType: core.Resource,
+ diags: &diag.Diagnostics{},
+ },
+ wantEnabled: false,
+ wantDiagsErr: false,
+ wantDiagsWarning: false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ if got := CheckExperimentEnabledWithoutError(tt.args.ctx, tt.args.data, tt.args.experiment, tt.args.resourceName, tt.args.resourceType, tt.args.diags); got != tt.wantEnabled {
+ t.Errorf("CheckExperimentEnabledWithoutError() = %v, want %v", got, tt.wantEnabled)
+ }
+ if got := tt.args.diags.HasError(); got != tt.wantDiagsErr {
+ t.Errorf("CheckExperimentEnabled() diags.HasError() = %v, want %v", got, tt.wantDiagsErr)
+ }
+ if got := tt.args.diags.WarningsCount() > 0; got != tt.wantDiagsWarning {
+ t.Errorf("CheckExperimentEnabled() diags.WarningsCount() > 0 = %v, want %v", got, tt.wantDiagsErr)
+ }
+ })
+ }
+}
diff --git a/stackit/internal/services/postgresflexalpha/database/datasource.go.bak b/stackit/internal/services/postgresflexalpha/database/datasource.go.bak
new file mode 100644
index 00000000..e4a2f197
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/database/datasource.go.bak
@@ -0,0 +1,171 @@
+package postgresflexa
+
+import (
+ "context"
+ "fmt"
+ "net/http"
+
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/conversion"
+ postgresflexUtils "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/postgresflexalpha/utils"
+
+ "github.com/hashicorp/terraform-plugin-framework/datasource"
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/validate"
+
+ "github.com/hashicorp/terraform-plugin-framework/datasource/schema"
+ "github.com/stackitcloud/terraform-provider-stackit/pkg/postgresflexalpha"
+)
+
+// Ensure the implementation satisfies the expected interfaces.
+var (
+ _ datasource.DataSource = &databaseDataSource{}
+)
+
+// NewDatabaseDataSource is a helper function to simplify the provider implementation.
+func NewDatabaseDataSource() datasource.DataSource {
+ return &databaseDataSource{}
+}
+
+// databaseDataSource is the data source implementation.
+type databaseDataSource struct {
+ client *postgresflexalpha.APIClient
+ providerData core.ProviderData
+}
+
+// Metadata returns the data source type name.
+func (r *databaseDataSource) Metadata(_ context.Context, req datasource.MetadataRequest, resp *datasource.MetadataResponse) {
+ resp.TypeName = req.ProviderTypeName + "_postgresflexalpha_database"
+}
+
+// Configure adds the provider configured client to the data source.
+func (r *databaseDataSource) Configure(ctx context.Context, req datasource.ConfigureRequest, resp *datasource.ConfigureResponse) {
+ var ok bool
+ r.providerData, ok = conversion.ParseProviderData(ctx, req.ProviderData, &resp.Diagnostics)
+ if !ok {
+ return
+ }
+
+ apiClient := postgresflexUtils.ConfigureClient(ctx, &r.providerData, &resp.Diagnostics)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ r.client = apiClient
+ tflog.Info(ctx, "Postgres Flex database client configured")
+}
+
+// Schema defines the schema for the data source.
+func (r *databaseDataSource) Schema(_ context.Context, _ datasource.SchemaRequest, resp *datasource.SchemaResponse) {
+ descriptions := map[string]string{
+ "main": "Postgres Flex database resource schema. Must have a `region` specified in the provider configuration.",
+ "id": "Terraform's internal resource ID. It is structured as \"`project_id`,`region`,`instance_id`,`database_id`\".",
+ "database_id": "Database ID.",
+ "instance_id": "ID of the Postgres Flex instance.",
+ "project_id": "STACKIT project ID to which the instance is associated.",
+ "name": "Database name.",
+ "owner": "Username of the database owner.",
+ "region": "The resource region. If not defined, the provider region is used.",
+ }
+
+ resp.Schema = schema.Schema{
+ Description: descriptions["main"],
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Description: descriptions["id"],
+ Computed: true,
+ },
+ "database_id": schema.StringAttribute{
+ Description: descriptions["database_id"],
+ Required: true,
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ "instance_id": schema.StringAttribute{
+ Description: descriptions["instance_id"],
+ Required: true,
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "project_id": schema.StringAttribute{
+ Description: descriptions["project_id"],
+ Required: true,
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "name": schema.StringAttribute{
+ Description: descriptions["name"],
+ Computed: true,
+ },
+ "owner": schema.StringAttribute{
+ Description: descriptions["owner"],
+ Computed: true,
+ },
+ "region": schema.StringAttribute{
+ // the region cannot be found, so it has to be passed
+ Optional: true,
+ Description: descriptions["region"],
+ },
+ },
+ }
+}
+
+// Read refreshes the Terraform state with the latest data.
+func (r *databaseDataSource) Read(ctx context.Context, req datasource.ReadRequest, resp *datasource.ReadResponse) { // nolint:gocritic // function signature required by Terraform
+ var model Model
+ diags := req.Config.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ databaseId := model.DatabaseId.ValueString()
+ region := r.providerData.GetRegionWithOverride(model.Region)
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "database_id", databaseId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ databaseResp, err := getDatabase(ctx, r.client, projectId, region, instanceId, databaseId)
+ if err != nil {
+ utils.LogError(
+ ctx,
+ &resp.Diagnostics,
+ err,
+ "Reading database",
+ fmt.Sprintf("Database with ID %q or instance with ID %q does not exist in project %q.", databaseId, instanceId, projectId),
+ map[int]string{
+ http.StatusForbidden: fmt.Sprintf("Project with ID %q not found or forbidden access", projectId),
+ },
+ )
+ resp.State.RemoveResource(ctx)
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ // Map response body to schema and populate Computed attribute values
+ err = mapFields(databaseResp, &model, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading database", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+
+ // Set refreshed state
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "Postgres Flex database read")
+}
diff --git a/stackit/internal/services/postgresflexalpha/database/resource.go.bak b/stackit/internal/services/postgresflexalpha/database/resource.go.bak
new file mode 100644
index 00000000..44fe2157
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/database/resource.go.bak
@@ -0,0 +1,447 @@
+package postgresflexa
+
+import (
+ "context"
+ "errors"
+ "fmt"
+ "net/http"
+ "strings"
+
+ "github.com/stackitcloud/stackit-sdk-go/services/postgresflex"
+ "github.com/stackitcloud/terraform-provider-stackit/pkg/postgresflexalpha"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/conversion"
+ postgresflexUtils "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/postgresflexalpha/utils"
+
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/validate"
+
+ "github.com/hashicorp/terraform-plugin-framework/path"
+ "github.com/hashicorp/terraform-plugin-framework/resource"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/planmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/stringplanmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/core/oapierror"
+)
+
+// Ensure the implementation satisfies the expected interfaces.
+var (
+ _ resource.Resource = &databaseResource{}
+ _ resource.ResourceWithConfigure = &databaseResource{}
+ _ resource.ResourceWithImportState = &databaseResource{}
+ _ resource.ResourceWithModifyPlan = &databaseResource{}
+)
+
+type Model struct {
+ Id types.String `tfsdk:"id"` // needed by TF
+ DatabaseId types.String `tfsdk:"database_id"`
+ InstanceId types.String `tfsdk:"instance_id"`
+ ProjectId types.String `tfsdk:"project_id"`
+ Name types.String `tfsdk:"name"`
+ Owner types.String `tfsdk:"owner"`
+ Region types.String `tfsdk:"region"`
+ Encryption encryptionModel `tfsdk:"encryption"`
+}
+
+type encryptionModel struct {
+ KeyId types.String `tfsdk:"key_id"`
+ //keyringid = xxxx
+ //keyversion = xxxx
+ //serviceaccount = xxxx
+}
+
+// NewDatabaseResource is a helper function to simplify the provider implementation.
+func NewDatabaseResource() resource.Resource {
+ return &databaseResource{}
+}
+
+// databaseResource is the resource implementation.
+type databaseResource struct {
+ client *postgresflexalpha.APIClient
+ providerData core.ProviderData
+}
+
+// ModifyPlan implements resource.ResourceWithModifyPlan.
+// Use the modifier to set the effective region in the current plan.
+func (r *databaseResource) ModifyPlan(ctx context.Context, req resource.ModifyPlanRequest, resp *resource.ModifyPlanResponse) { // nolint:gocritic // function signature required by Terraform
+ var configModel Model
+ // skip initial empty configuration to avoid follow-up errors
+ if req.Config.Raw.IsNull() {
+ return
+ }
+ resp.Diagnostics.Append(req.Config.Get(ctx, &configModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ var planModel Model
+ resp.Diagnostics.Append(req.Plan.Get(ctx, &planModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ utils.AdaptRegion(ctx, configModel.Region, &planModel.Region, r.providerData.GetRegion(), resp)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ resp.Diagnostics.Append(resp.Plan.Set(ctx, planModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+}
+
+// Metadata returns the resource type name.
+func (r *databaseResource) Metadata(_ context.Context, req resource.MetadataRequest, resp *resource.MetadataResponse) {
+ resp.TypeName = req.ProviderTypeName + "_postgresflex_database"
+}
+
+// Configure adds the provider configured client to the resource.
+func (r *databaseResource) Configure(ctx context.Context, req resource.ConfigureRequest, resp *resource.ConfigureResponse) {
+ var ok bool
+ r.providerData, ok = conversion.ParseProviderData(ctx, req.ProviderData, &resp.Diagnostics)
+ if !ok {
+ return
+ }
+
+ apiClient := postgresflexUtils.ConfigureClient(ctx, &r.providerData, &resp.Diagnostics)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ r.client = apiClient
+ tflog.Info(ctx, "Postgres Flex database client configured")
+}
+
+// Schema defines the schema for the resource.
+func (r *databaseResource) Schema(_ context.Context, _ resource.SchemaRequest, resp *resource.SchemaResponse) {
+ descriptions := map[string]string{
+ "main": "Postgres Flex database resource schema. Must have a `region` specified in the provider configuration.",
+ "id": "Terraform's internal resource ID. It is structured as \"`project_id`,`region`,`instance_id`,`database_id`\".",
+ "database_id": "Database ID.",
+ "instance_id": "ID of the Postgres Flex instance.",
+ "project_id": "STACKIT project ID to which the instance is associated.",
+ "name": "Database name.",
+ "owner": "Username of the database owner.",
+ "region": "The resource region. If not defined, the provider region is used.",
+ }
+
+ resp.Schema = schema.Schema{
+ Description: descriptions["main"],
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Description: descriptions["id"],
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "database_id": schema.StringAttribute{
+ Description: descriptions["database_id"],
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ "instance_id": schema.StringAttribute{
+ Description: descriptions["instance_id"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "project_id": schema.StringAttribute{
+ Description: descriptions["project_id"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "name": schema.StringAttribute{
+ Description: descriptions["name"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ },
+ "owner": schema.StringAttribute{
+ Description: descriptions["owner"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ },
+ "region": schema.StringAttribute{
+ Optional: true,
+ // must be computed to allow for storing the override value from the provider
+ Computed: true,
+ Description: descriptions["region"],
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ },
+ },
+ }
+}
+
+// Create creates the resource and sets the initial Terraform state.
+func (r *databaseResource) Create(ctx context.Context, req resource.CreateRequest, resp *resource.CreateResponse) { // nolint:gocritic // function signature required by Terraform
+ var model Model
+ diags := req.Plan.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ region := model.Region.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ // Generate API request body from model
+ payload, err := toCreatePayload(&model)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating database", fmt.Sprintf("Creating API payload: %v", err))
+ return
+ }
+ // Create new database
+ databaseResp, err := r.client.CreateDatabaseRequest(ctx, projectId, region, instanceId).CreateDatabaseRequestPayload(*payload).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating database", fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ if databaseResp == nil || databaseResp.Id == nil || *databaseResp.Id == "" {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating database", "API didn't return database Id. A database might have been created")
+ return
+ }
+ databaseId := *databaseResp.Id
+ ctx = tflog.SetField(ctx, "database_id", databaseId)
+
+ database, err := getDatabase(ctx, r.client, projectId, region, instanceId, databaseId)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating database", fmt.Sprintf("Getting database details after creation: %v", err))
+ return
+ }
+
+ // Map response body to schema
+ err = mapFields(database, &model, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating database", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+ // Set state to fully populated data
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "Postgres Flex database created")
+}
+
+// Read refreshes the Terraform state with the latest data.
+func (r *databaseResource) Read(ctx context.Context, req resource.ReadRequest, resp *resource.ReadResponse) { // nolint:gocritic // function signature required by Terraform
+ var model Model
+ diags := req.State.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ databaseId := model.DatabaseId.ValueString()
+ region := r.providerData.GetRegionWithOverride(model.Region)
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "database_id", databaseId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ databaseResp, err := getDatabase(ctx, r.client, projectId, region, instanceId, databaseId)
+ if err != nil {
+ oapiErr, ok := err.(*oapierror.GenericOpenAPIError) //nolint:errorlint //complaining that error.As should be used to catch wrapped errors, but this error should not be wrapped
+ if (ok && oapiErr.StatusCode == http.StatusNotFound) || errors.Is(err, databaseNotFoundErr) {
+ resp.State.RemoveResource(ctx)
+ return
+ }
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading database", fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ // Map response body to schema
+ err = mapFields(databaseResp, &model, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading database", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+
+ // Set refreshed state
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "Postgres Flex database read")
+}
+
+// Update updates the resource and sets the updated Terraform state on success.
+func (r *databaseResource) Update(ctx context.Context, _ resource.UpdateRequest, resp *resource.UpdateResponse) { // nolint:gocritic // function signature required by Terraform
+ // Update shouldn't be called
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating database", "Database can't be updated")
+}
+
+// Delete deletes the resource and removes the Terraform state on success.
+func (r *databaseResource) Delete(ctx context.Context, req resource.DeleteRequest, resp *resource.DeleteResponse) { // nolint:gocritic // function signature required by Terraform
+ // Retrieve values from plan
+ var model Model
+ diags := req.State.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ databaseId := model.DatabaseId.ValueString()
+ region := model.Region.ValueString()
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "database_id", databaseId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ // Delete existing record set
+ err := r.client.DeleteDatabase(ctx, projectId, region, instanceId, databaseId).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error deleting database", fmt.Sprintf("Calling API: %v", err))
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ tflog.Info(ctx, "Postgres Flex database deleted")
+}
+
+// ImportState imports a resource into the Terraform state on success.
+// The expected format of the resource import identifier is: project_id,zone_id,record_set_id
+func (r *databaseResource) ImportState(ctx context.Context, req resource.ImportStateRequest, resp *resource.ImportStateResponse) {
+ idParts := strings.Split(req.ID, core.Separator)
+ if len(idParts) != 4 || idParts[0] == "" || idParts[1] == "" || idParts[2] == "" || idParts[3] == "" {
+ core.LogAndAddError(ctx, &resp.Diagnostics,
+ "Error importing database",
+ fmt.Sprintf("Expected import identifier with format [project_id],[region],[instance_id],[database_id], got %q", req.ID),
+ )
+ return
+ }
+
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("project_id"), idParts[0])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("region"), idParts[1])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("instance_id"), idParts[2])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("database_id"), idParts[3])...)
+ core.LogAndAddWarning(ctx, &resp.Diagnostics,
+ "Postgresflex database imported with empty password",
+ "The database password is not imported as it is only available upon creation of a new database. The password field will be empty.",
+ )
+ tflog.Info(ctx, "Postgres Flex database state imported")
+}
+
+func mapFields(databaseResp *postgresflex.InstanceDatabase, model *Model, region string) error {
+ if databaseResp == nil {
+ return fmt.Errorf("response is nil")
+ }
+ if databaseResp.Id == nil || *databaseResp.Id == "" {
+ return fmt.Errorf("id not present")
+ }
+ if model == nil {
+ return fmt.Errorf("model input is nil")
+ }
+
+ var databaseId string
+ if model.DatabaseId.ValueString() != "" {
+ databaseId = model.DatabaseId.ValueString()
+ } else if databaseResp.Id != nil {
+ databaseId = *databaseResp.Id
+ } else {
+ return fmt.Errorf("database id not present")
+ }
+ model.Id = utils.BuildInternalTerraformId(
+ model.ProjectId.ValueString(), region, model.InstanceId.ValueString(), databaseId,
+ )
+ model.DatabaseId = types.StringValue(databaseId)
+ model.Name = types.StringPointerValue(databaseResp.Name)
+ model.Region = types.StringValue(region)
+
+ if databaseResp.Options != nil {
+ owner, ok := (*databaseResp.Options)["owner"]
+ if ok {
+ ownerStr, ok := owner.(string)
+ if !ok {
+ return fmt.Errorf("owner is not a string")
+ }
+ // If the field is returned between with quotes, we trim them to prevent an inconsistent result after apply
+ ownerStr = strings.TrimPrefix(ownerStr, `"`)
+ ownerStr = strings.TrimSuffix(ownerStr, `"`)
+ model.Owner = types.StringValue(ownerStr)
+ }
+ }
+
+ return nil
+}
+
+func toCreatePayload(model *Model) (*postgresflexalpha.CreateDatabaseRequestPayload, error) {
+ if model == nil {
+ return nil, fmt.Errorf("nil model")
+ }
+
+ return &postgresflexalpha.CreateDatabaseRequestPayload{
+ Name: model.Name.ValueStringPointer(),
+ // TODO
+ //Options: &map[string]string{
+ // "owner": model.Owner.ValueString(),
+ //},
+ }, nil
+}
+
+var databaseNotFoundErr = errors.New("database not found")
+
+// The API does not have a GetDatabase endpoint, only ListDatabases
+func getDatabase(ctx context.Context, client *postgresflexalpha.APIClient, projectId, region, instanceId, databaseId string) (*postgresflex.InstanceDatabase, error) {
+ resp, err := client.ListDatabasesRequest(ctx, projectId, region, instanceId).Execute()
+ if err != nil {
+ return nil, err
+ }
+ if resp == nil || resp.Databases == nil {
+ return nil, fmt.Errorf("response is nil")
+ }
+ for _, database := range *resp.Databases {
+ if database.Id != nil && *database.Id == databaseId {
+ return &database, nil
+ }
+ }
+ return nil, databaseNotFoundErr
+}
diff --git a/stackit/internal/services/postgresflexalpha/database/resource_test.go.bak b/stackit/internal/services/postgresflexalpha/database/resource_test.go.bak
new file mode 100644
index 00000000..c2cf6d96
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/database/resource_test.go.bak
@@ -0,0 +1,192 @@
+// Copyright (c) STACKIT
+
+package postgresflexa
+
+import (
+ "testing"
+
+ "github.com/google/go-cmp/cmp"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+ "github.com/stackitcloud/stackit-sdk-go/services/postgresflex"
+)
+
+func TestMapFields(t *testing.T) {
+ const testRegion = "region"
+ tests := []struct {
+ description string
+ input *postgresflex.InstanceDatabase
+ region string
+ expected Model
+ isValid bool
+ }{
+ {
+ "default_values",
+ &postgresflex.InstanceDatabase{
+ Id: utils.Ptr("uid"),
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,uid"),
+ DatabaseId: types.StringValue("uid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Name: types.StringNull(),
+ Owner: types.StringNull(),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "simple_values",
+ &postgresflex.InstanceDatabase{
+ Id: utils.Ptr("uid"),
+ Name: utils.Ptr("dbname"),
+ Options: &map[string]interface{}{
+ "owner": "username",
+ },
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,uid"),
+ DatabaseId: types.StringValue("uid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Name: types.StringValue("dbname"),
+ Owner: types.StringValue("username"),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "null_fields_and_int_conversions",
+ &postgresflex.InstanceDatabase{
+ Id: utils.Ptr("uid"),
+ Name: utils.Ptr(""),
+ Options: &map[string]interface{}{
+ "owner": "",
+ },
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,uid"),
+ DatabaseId: types.StringValue("uid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Name: types.StringValue(""),
+ Owner: types.StringValue(""),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "nil_response",
+ nil,
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "empty_response",
+ &postgresflex.InstanceDatabase{},
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "no_resource_id",
+ &postgresflex.InstanceDatabase{
+ Id: utils.Ptr(""),
+ Name: utils.Ptr("dbname"),
+ Options: &map[string]interface{}{
+ "owner": "username",
+ },
+ },
+ testRegion,
+ Model{},
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ state := &Model{
+ ProjectId: tt.expected.ProjectId,
+ InstanceId: tt.expected.InstanceId,
+ }
+ err := mapFields(tt.input, state, tt.region)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(state, &tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ })
+ }
+}
+
+func TestToCreatePayload(t *testing.T) {
+ tests := []struct {
+ description string
+ input *Model
+ expected *postgresflex.CreateDatabasePayload
+ isValid bool
+ }{
+ {
+ "default_values",
+ &Model{
+ Name: types.StringValue("dbname"),
+ Owner: types.StringValue("username"),
+ },
+ &postgresflex.CreateDatabasePayload{
+ Name: utils.Ptr("dbname"),
+ Options: &map[string]string{
+ "owner": "username",
+ },
+ },
+ true,
+ },
+ {
+ "null_fields",
+ &Model{
+ Name: types.StringNull(),
+ Owner: types.StringNull(),
+ },
+ &postgresflex.CreateDatabasePayload{
+ Name: nil,
+ Options: &map[string]string{
+ "owner": "",
+ },
+ },
+ true,
+ },
+ {
+ "nil_model",
+ nil,
+ nil,
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ output, err := toCreatePayload(tt.input)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(output, tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ })
+ }
+}
diff --git a/stackit/internal/services/postgresflexalpha/instance/datasource.go.bak b/stackit/internal/services/postgresflexalpha/instance/datasource.go.bak
new file mode 100644
index 00000000..8ca8098d
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/instance/datasource.go.bak
@@ -0,0 +1,222 @@
+package postgresflexa
+
+import (
+ "context"
+ "fmt"
+ "net/http"
+
+ "github.com/stackitcloud/terraform-provider-stackit/pkg/postgresflexalpha"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/conversion"
+ postgresflexUtils "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/postgresflexalpha/utils"
+
+ "github.com/hashicorp/terraform-plugin-framework/datasource"
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/validate"
+
+ "github.com/hashicorp/terraform-plugin-framework/datasource/schema"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/terraform-provider-stackit/pkg/postgresflexalpha/wait"
+)
+
+// Ensure the implementation satisfies the expected interfaces.
+var (
+ _ datasource.DataSource = &instanceDataSource{}
+)
+
+// NewInstanceDataSource is a helper function to simplify the provider implementation.
+func NewInstanceDataSource() datasource.DataSource {
+ return &instanceDataSource{}
+}
+
+// instanceDataSource is the data source implementation.
+type instanceDataSource struct {
+ client *postgresflexalpha.APIClient
+ providerData core.ProviderData
+}
+
+// Metadata returns the data source type name.
+func (r *instanceDataSource) Metadata(_ context.Context, req datasource.MetadataRequest, resp *datasource.MetadataResponse) {
+ resp.TypeName = req.ProviderTypeName + "_postgresflexalpha_instance"
+}
+
+// Configure adds the provider configured client to the data source.
+func (r *instanceDataSource) Configure(ctx context.Context, req datasource.ConfigureRequest, resp *datasource.ConfigureResponse) {
+ var ok bool
+ r.providerData, ok = conversion.ParseProviderData(ctx, req.ProviderData, &resp.Diagnostics)
+ if !ok {
+ return
+ }
+
+ apiClient := postgresflexUtils.ConfigureClient(ctx, &r.providerData, &resp.Diagnostics)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ r.client = apiClient
+ tflog.Info(ctx, "Postgres Flex instance client configured")
+}
+
+// Schema defines the schema for the data source.
+func (r *instanceDataSource) Schema(_ context.Context, _ datasource.SchemaRequest, resp *datasource.SchemaResponse) {
+ descriptions := map[string]string{
+ "main": "Postgres Flex instance data source schema. Must have a `region` specified in the provider configuration.",
+ "id": "Terraform's internal data source. ID. It is structured as \"`project_id`,`region`,`instance_id`\".",
+ "instance_id": "ID of the PostgresFlex instance.",
+ "project_id": "STACKIT project ID to which the instance is associated.",
+ "name": "Instance name.",
+ "acl": "The Access Control List (ACL) for the PostgresFlex instance.",
+ "region": "The resource region. If not defined, the provider region is used.",
+ }
+
+ resp.Schema = schema.Schema{
+ Description: descriptions["main"],
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Description: descriptions["id"],
+ Computed: true,
+ },
+ "instance_id": schema.StringAttribute{
+ Description: descriptions["instance_id"],
+ Required: true,
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "project_id": schema.StringAttribute{
+ Description: descriptions["project_id"],
+ Required: true,
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "name": schema.StringAttribute{
+ Description: descriptions["name"],
+ Computed: true,
+ },
+ "acl": schema.ListAttribute{
+ Description: descriptions["acl"],
+ ElementType: types.StringType,
+ Computed: true,
+ },
+ "backup_schedule": schema.StringAttribute{
+ Computed: true,
+ },
+ "flavor": schema.SingleNestedAttribute{
+ Computed: true,
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Computed: true,
+ },
+ "description": schema.StringAttribute{
+ Computed: true,
+ },
+ "cpu": schema.Int64Attribute{
+ Computed: true,
+ },
+ "ram": schema.Int64Attribute{
+ Computed: true,
+ },
+ },
+ },
+ "replicas": schema.Int64Attribute{
+ Computed: true,
+ },
+ "storage": schema.SingleNestedAttribute{
+ Computed: true,
+ Attributes: map[string]schema.Attribute{
+ "class": schema.StringAttribute{
+ Computed: true,
+ },
+ "size": schema.Int64Attribute{
+ Computed: true,
+ },
+ },
+ },
+ "version": schema.StringAttribute{
+ Computed: true,
+ },
+ "region": schema.StringAttribute{
+ // the region cannot be found, so it has to be passed
+ Optional: true,
+ Description: descriptions["region"],
+ },
+ },
+ }
+}
+
+// Read refreshes the Terraform state with the latest data.
+func (r *instanceDataSource) Read(ctx context.Context, req datasource.ReadRequest, resp *datasource.ReadResponse) { // nolint:gocritic // function signature required by Terraform
+ var model Model
+ diags := req.Config.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ region := r.providerData.GetRegionWithOverride(model.Region)
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "region", region)
+ instanceResp, err := r.client.GetInstanceRequest(ctx, projectId, region, instanceId).Execute()
+ if err != nil {
+ utils.LogError(
+ ctx,
+ &resp.Diagnostics,
+ err,
+ "Reading instance",
+ fmt.Sprintf("Instance with ID %q does not exist in project %q.", instanceId, projectId),
+ map[int]string{
+ http.StatusForbidden: fmt.Sprintf("Project with ID %q not found or forbidden access", projectId),
+ },
+ )
+ resp.State.RemoveResource(ctx)
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ if instanceResp != nil && instanceResp.Status != nil && *instanceResp.Status == wait.InstanceStateDeleted {
+ resp.State.RemoveResource(ctx)
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading instance", "Instance was deleted successfully")
+ return
+ }
+
+ var flavor = &flavorModel{}
+ if !(model.Flavor.IsNull() || model.Flavor.IsUnknown()) {
+ diags = model.Flavor.As(ctx, flavor, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+ var storage = &storageModel{}
+ if !(model.Storage.IsNull() || model.Storage.IsUnknown()) {
+ diags = model.Storage.As(ctx, storage, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ err = mapFields(ctx, instanceResp, &model, flavor, storage, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading instance", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+ // Set refreshed state
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "Postgres Flex instance read")
+}
diff --git a/stackit/internal/services/postgresflexalpha/instance/resource.go b/stackit/internal/services/postgresflexalpha/instance/resource.go
new file mode 100644
index 00000000..2c5d6e08
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/instance/resource.go
@@ -0,0 +1,893 @@
+package postgresflex
+
+import (
+ "context"
+ "fmt"
+ "net/http"
+ "regexp"
+ "strings"
+ "time"
+
+ "github.com/stackitcloud/terraform-provider-stackit/pkg/postgresflexalpha"
+ "github.com/stackitcloud/terraform-provider-stackit/pkg/postgresflexalpha/wait"
+ postgresflexUtils "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/postgresflexalpha/utils"
+
+ "github.com/hashicorp/terraform-plugin-framework-validators/stringvalidator"
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/conversion"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/validate"
+
+ "github.com/hashicorp/terraform-plugin-framework/path"
+ "github.com/hashicorp/terraform-plugin-framework/resource"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/planmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/stringplanmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/core/oapierror"
+)
+
+// Ensure the implementation satisfies the expected interfaces.
+var (
+ _ resource.Resource = &instanceResource{}
+ _ resource.ResourceWithConfigure = &instanceResource{}
+ _ resource.ResourceWithImportState = &instanceResource{}
+ _ resource.ResourceWithModifyPlan = &instanceResource{}
+)
+
+type Model struct {
+ Id types.String `tfsdk:"id"` // needed by TF
+ InstanceId types.String `tfsdk:"instance_id"`
+ ProjectId types.String `tfsdk:"project_id"`
+ Name types.String `tfsdk:"name"`
+ ACL types.List `tfsdk:"acl"`
+ BackupSchedule types.String `tfsdk:"backup_schedule"`
+ Flavor types.Object `tfsdk:"flavor"`
+ Replicas types.Int64 `tfsdk:"replicas"`
+ Storage types.Object `tfsdk:"storage"`
+ Version types.String `tfsdk:"version"`
+ Region types.String `tfsdk:"region"`
+ Encryption types.Object `tfsdk:"encryption"`
+ Network types.Object `tfsdk:"network"`
+}
+
+type encryptionModel struct {
+ KeyRingId types.String `tfsdk:"keyring_id"`
+ KeyId types.String `tfsdk:"key_id"`
+ KeyVersion types.String `tfsdk:"key_version"`
+ ServiceAccount types.String `tfsdk:"service_account"`
+}
+
+var encryptionTypes = map[string]attr.Type{
+ "keyring_id": basetypes.StringType{},
+ "key_id": basetypes.StringType{},
+ "key_version": basetypes.StringType{},
+ "service_account": basetypes.StringType{},
+}
+
+type networkModel struct {
+ AccessScope types.String `tfsdk:"access_scope"`
+}
+
+var networkTypes = map[string]attr.Type{
+ "access_scope": basetypes.StringType{},
+}
+
+// Struct corresponding to Model.Flavor
+type flavorModel struct {
+ Id types.String `tfsdk:"id"`
+ Description types.String `tfsdk:"description"`
+ CPU types.Int64 `tfsdk:"cpu"`
+ RAM types.Int64 `tfsdk:"ram"`
+}
+
+// Types corresponding to flavorModel
+var flavorTypes = map[string]attr.Type{
+ "id": basetypes.StringType{},
+ "description": basetypes.StringType{},
+ "cpu": basetypes.Int64Type{},
+ "ram": basetypes.Int64Type{},
+}
+
+// Struct corresponding to Model.Storage
+type storageModel struct {
+ Class types.String `tfsdk:"class"`
+ Size types.Int64 `tfsdk:"size"`
+}
+
+// Types corresponding to storageModel
+var storageTypes = map[string]attr.Type{
+ "class": basetypes.StringType{},
+ "size": basetypes.Int64Type{},
+}
+
+// NewInstanceResource is a helper function to simplify the provider implementation.
+func NewInstanceResource() resource.Resource {
+ return &instanceResource{}
+}
+
+// instanceResource is the resource implementation.
+type instanceResource struct {
+ client *postgresflexalpha.APIClient
+ providerData core.ProviderData
+}
+
+// ModifyPlan implements resource.ResourceWithModifyPlan.
+// Use the modifier to set the effective region in the current plan.
+func (r *instanceResource) ModifyPlan(ctx context.Context, req resource.ModifyPlanRequest, resp *resource.ModifyPlanResponse) { // nolint:gocritic // function signature required by Terraform
+ var configModel Model
+ // skip initial empty configuration to avoid follow-up errors
+ if req.Config.Raw.IsNull() {
+ return
+ }
+ resp.Diagnostics.Append(req.Config.Get(ctx, &configModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ var planModel Model
+ resp.Diagnostics.Append(req.Plan.Get(ctx, &planModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ utils.AdaptRegion(ctx, configModel.Region, &planModel.Region, r.providerData.GetRegion(), resp)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ resp.Diagnostics.Append(resp.Plan.Set(ctx, planModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+}
+
+// Metadata returns the resource type name.
+func (r *instanceResource) Metadata(_ context.Context, req resource.MetadataRequest, resp *resource.MetadataResponse) {
+ resp.TypeName = req.ProviderTypeName + "_postgresflexalpha_instance"
+}
+
+// Configure adds the provider configured client to the resource.
+func (r *instanceResource) Configure(ctx context.Context, req resource.ConfigureRequest, resp *resource.ConfigureResponse) {
+ var ok bool
+ r.providerData, ok = conversion.ParseProviderData(ctx, req.ProviderData, &resp.Diagnostics)
+ if !ok {
+ return
+ }
+
+ apiClient := postgresflexUtils.ConfigureClient(ctx, &r.providerData, &resp.Diagnostics)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ r.client = apiClient
+ tflog.Info(ctx, "Postgres Flex instance client configured")
+}
+
+// Schema defines the schema for the resource.
+func (r *instanceResource) Schema(_ context.Context, req resource.SchemaRequest, resp *resource.SchemaResponse) {
+ descriptions := map[string]string{
+ "main": "Postgres Flex instance resource schema. Must have a `region` specified in the provider configuration.",
+ "id": "Terraform's internal resource ID. It is structured as \"`project_id`,`region`,`instance_id`\".",
+ "instance_id": "ID of the PostgresFlex instance.",
+ "project_id": "STACKIT project ID to which the instance is associated.",
+ "name": "Instance name.",
+ "acl": "The Access Control List (ACL) for the PostgresFlex instance.",
+ "region": "The resource region. If not defined, the provider region is used.",
+ "encryption": "The encryption block.",
+ "key_id": "Key ID of the encryption key.",
+ }
+
+ resp.Schema = schema.Schema{
+ Description: descriptions["main"],
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Description: descriptions["id"],
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "instance_id": schema.StringAttribute{
+ Description: descriptions["instance_id"],
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "project_id": schema.StringAttribute{
+ Description: descriptions["project_id"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "name": schema.StringAttribute{
+ Description: descriptions["name"],
+ Required: true,
+ Validators: []validator.String{
+ stringvalidator.LengthAtLeast(1),
+ stringvalidator.RegexMatches(
+ regexp.MustCompile("^[a-z]([-a-z0-9]*[a-z0-9])?$"),
+ "must start with a letter, must have lower case letters, numbers or hyphens, and no hyphen at the end",
+ ),
+ },
+ },
+ "acl": schema.ListAttribute{
+ Description: descriptions["acl"],
+ ElementType: types.StringType,
+ Required: true,
+ },
+ "backup_schedule": schema.StringAttribute{
+ Required: true,
+ },
+ "flavor": schema.SingleNestedAttribute{
+ Required: true,
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ UseStateForUnknownIfFlavorUnchanged(req),
+ },
+ },
+ "description": schema.StringAttribute{
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ UseStateForUnknownIfFlavorUnchanged(req),
+ },
+ },
+ "cpu": schema.Int64Attribute{
+ Required: true,
+ },
+ "ram": schema.Int64Attribute{
+ Required: true,
+ },
+ },
+ },
+ "replicas": schema.Int64Attribute{
+ Required: true,
+ },
+ "storage": schema.SingleNestedAttribute{
+ Required: true,
+ Attributes: map[string]schema.Attribute{
+ "class": schema.StringAttribute{
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ },
+ "size": schema.Int64Attribute{
+ Required: true,
+ },
+ },
+ },
+ "version": schema.StringAttribute{
+ Required: true,
+ },
+ "region": schema.StringAttribute{
+ Optional: true,
+ // must be computed to allow for storing the override value from the provider
+ Computed: true,
+ Description: descriptions["region"],
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ },
+ "encryption": schema.SingleNestedAttribute{
+ Required: true,
+ Attributes: map[string]schema.Attribute{
+ "key_id": schema.StringAttribute{
+ Description: descriptions["key_id"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ "key_version": schema.StringAttribute{
+ Description: descriptions["key_version"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ "key_ring_id": schema.StringAttribute{
+ Description: descriptions["key_ring_id"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ "service_account": schema.StringAttribute{
+ Description: descriptions["service_account"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ },
+ //Blocks: nil,
+ //CustomType: nil,
+ Description: descriptions["encryption"],
+ //MarkdownDescription: "",
+ //DeprecationMessage: "",
+ //Validators: nil,
+ PlanModifiers: []planmodifier.Object{},
+ },
+ "network": schema.SingleNestedAttribute{
+ Required: true,
+ Attributes: map[string]schema.Attribute{
+ "access_scope": schema.StringAttribute{
+ Description: descriptions["access_scope"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ },
+ //Blocks: nil,
+ //CustomType: nil,
+ Description: descriptions["network"],
+ //MarkdownDescription: "",
+ //DeprecationMessage: "",
+ //Validators: nil,
+ PlanModifiers: []planmodifier.Object{},
+ },
+ },
+ }
+}
+
+// Create creates the resource and sets the initial Terraform state.
+func (r *instanceResource) Create(ctx context.Context, req resource.CreateRequest, resp *resource.CreateResponse) { // nolint:gocritic // function signature required by Terraform
+ // Retrieve values from plan
+ var model Model
+ diags := req.Plan.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ region := model.Region.ValueString()
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ var acl []string
+ if !(model.ACL.IsNull() || model.ACL.IsUnknown()) {
+ diags = model.ACL.ElementsAs(ctx, &acl, false)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+ var flavor = &flavorModel{}
+ if !(model.Flavor.IsNull() || model.Flavor.IsUnknown()) {
+ diags = model.Flavor.As(ctx, flavor, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ err := loadFlavorId(ctx, r.client, &model, flavor)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating instance", fmt.Sprintf("Loading flavor ID: %v", err))
+ return
+ }
+ }
+ var storage = &storageModel{}
+ if !(model.Storage.IsNull() || model.Storage.IsUnknown()) {
+ diags = model.Storage.As(ctx, storage, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ var encryption = &encryptionModel{}
+ if !(model.Encryption.IsNull() || model.Encryption.IsUnknown()) {
+ diags = model.Encryption.As(ctx, encryption, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ var network = &networkModel{}
+ if !(model.Network.IsNull() || model.Network.IsUnknown()) {
+ diags = model.Network.As(ctx, network, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ // Generate API request body from model
+ payload, err := toCreatePayload(&model, acl, flavor, storage, encryption, network)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating instance", fmt.Sprintf("Creating API payload: %v", err))
+ return
+ }
+ // Create new instance
+ createResp, err := r.client.CreateInstanceRequest(ctx, projectId, region).CreateInstanceRequestPayload(*payload).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating instance", fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ instanceId := *createResp.Id
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ waitResp, err := wait.CreateInstanceWaitHandler(ctx, r.client, projectId, region, instanceId).WaitWithContext(ctx)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating instance", fmt.Sprintf("Instance creation waiting: %v", err))
+ return
+ }
+
+ // Map response body to schema
+ err = mapFields(ctx, waitResp, &model, flavor, storage, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating instance", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+ // Set state to fully populated data
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "Postgres Flex instance created")
+}
+
+// Read refreshes the Terraform state with the latest data.
+func (r *instanceResource) Read(ctx context.Context, req resource.ReadRequest, resp *resource.ReadResponse) { // nolint:gocritic // function signature required by Terraform
+ var model Model
+ diags := req.State.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ region := r.providerData.GetRegionWithOverride(model.Region)
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ var flavor = &flavorModel{}
+ if !(model.Flavor.IsNull() || model.Flavor.IsUnknown()) {
+ diags = model.Flavor.As(ctx, flavor, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+ var storage = &storageModel{}
+ if !(model.Storage.IsNull() || model.Storage.IsUnknown()) {
+ diags = model.Storage.As(ctx, storage, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ instanceResp, err := r.client.GetInstanceRequest(ctx, projectId, region, instanceId).Execute()
+ if err != nil {
+ oapiErr, ok := err.(*oapierror.GenericOpenAPIError) //nolint:errorlint //complaining that error.As should be used to catch wrapped errors, but this error should not be wrapped
+ if ok && oapiErr.StatusCode == http.StatusNotFound {
+ resp.State.RemoveResource(ctx)
+ return
+ }
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading instance", err.Error())
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ if instanceResp != nil && instanceResp.Status != nil && *instanceResp.Status == wait.InstanceStateDeleted {
+ resp.State.RemoveResource(ctx)
+ return
+ }
+
+ // Map response body to schema
+ err = mapFields(ctx, instanceResp, &model, flavor, storage, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading instance", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+ // Set refreshed state
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "Postgres Flex instance read")
+}
+
+// Update updates the resource and sets the updated Terraform state on success.
+func (r *instanceResource) Update(ctx context.Context, req resource.UpdateRequest, resp *resource.UpdateResponse) { // nolint:gocritic // function signature required by Terraform
+ // Retrieve values from plan
+ var model Model
+ diags := req.Plan.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ region := model.Region.ValueString()
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ var acl []string
+ if !(model.ACL.IsNull() || model.ACL.IsUnknown()) {
+ diags = model.ACL.ElementsAs(ctx, &acl, false)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+ var flavor = &flavorModel{}
+ if !(model.Flavor.IsNull() || model.Flavor.IsUnknown()) {
+ diags = model.Flavor.As(ctx, flavor, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ err := loadFlavorId(ctx, r.client, &model, flavor)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating instance", fmt.Sprintf("Loading flavor ID: %v", err))
+ return
+ }
+ }
+ var storage = &storageModel{}
+ if !(model.Storage.IsNull() || model.Storage.IsUnknown()) {
+ diags = model.Storage.As(ctx, storage, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ // Generate API request body from model
+ payload, err := toUpdatePayload(&model, acl, flavor, storage)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating instance", fmt.Sprintf("Creating API payload: %v", err))
+ return
+ }
+ // Update existing instance
+ err = r.client.UpdateInstancePartiallyRequest(ctx, projectId, region, instanceId).UpdateInstancePartiallyRequestPayload(*payload).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating instance", err.Error())
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ waitResp, err := wait.PartialUpdateInstanceWaitHandler(ctx, r.client, projectId, region, instanceId).WaitWithContext(ctx)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating instance", fmt.Sprintf("Instance update waiting: %v", err))
+ return
+ }
+
+ // Map response body to schema
+ err = mapFields(ctx, waitResp, &model, flavor, storage, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating instance", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "Postgresflex instance updated")
+}
+
+// Delete deletes the resource and removes the Terraform state on success.
+func (r *instanceResource) Delete(ctx context.Context, req resource.DeleteRequest, resp *resource.DeleteResponse) { // nolint:gocritic // function signature required by Terraform
+ // Retrieve values from state
+ var model Model
+ diags := req.State.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ region := model.Region.ValueString()
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ // Delete existing instance
+ err := r.client.DeleteInstanceRequest(ctx, projectId, region, instanceId).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error deleting instance", fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ _, err = wait.DeleteInstanceWaitHandler(ctx, r.client, projectId, region, instanceId).SetTimeout(45 * time.Minute).WaitWithContext(ctx)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error deleting instance", fmt.Sprintf("Instance deletion waiting: %v", err))
+ return
+ }
+ tflog.Info(ctx, "Postgres Flex instance deleted")
+}
+
+// ImportState imports a resource into the Terraform state on success.
+// The expected format of the resource import identifier is: project_id,instance_id
+func (r *instanceResource) ImportState(ctx context.Context, req resource.ImportStateRequest, resp *resource.ImportStateResponse) {
+ idParts := strings.Split(req.ID, core.Separator)
+
+ if len(idParts) != 3 || idParts[0] == "" || idParts[1] == "" || idParts[2] == "" {
+ core.LogAndAddError(ctx, &resp.Diagnostics,
+ "Error importing instance",
+ fmt.Sprintf("Expected import identifier with format: [project_id],[region],[instance_id] Got: %q", req.ID),
+ )
+ return
+ }
+
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("project_id"), idParts[0])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("region"), idParts[1])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("instance_id"), idParts[2])...)
+ tflog.Info(ctx, "Postgres Flex instance state imported")
+}
+
+func mapFields(ctx context.Context, resp *postgresflexalpha.GetInstanceResponse, model *Model, flavor *flavorModel, storage *storageModel, region string) error {
+ if resp == nil {
+ return fmt.Errorf("response input is nil")
+ }
+ if model == nil {
+ return fmt.Errorf("model input is nil")
+ }
+ instance := resp
+
+ var instanceId string
+ if model.InstanceId.ValueString() != "" {
+ instanceId = model.InstanceId.ValueString()
+ } else if instance.Id != nil {
+ instanceId = *instance.Id
+ } else {
+ return fmt.Errorf("instance id not present")
+ }
+
+ var aclList basetypes.ListValue
+ var diags diag.Diagnostics
+ if instance.Acl == nil {
+ aclList = types.ListNull(types.StringType)
+ } else {
+ respACL := *instance.Acl
+ modelACL, err := utils.ListValuetoStringSlice(model.ACL)
+ if err != nil {
+ return err
+ }
+
+ reconciledACL := utils.ReconcileStringSlices(modelACL, respACL)
+
+ aclList, diags = types.ListValueFrom(ctx, types.StringType, reconciledACL)
+ if diags.HasError() {
+ return fmt.Errorf("mapping ACL: %w", core.DiagsToError(diags))
+ }
+ }
+
+ var flavorValues map[string]attr.Value
+ if instance.FlavorId == nil {
+ flavorValues = map[string]attr.Value{
+ "id": flavor.Id,
+ "description": flavor.Description,
+ "cpu": flavor.CPU,
+ "ram": flavor.RAM,
+ }
+ } else {
+ // TODO
+ //flavorValues = map[string]attr.Value{
+ // "id": types.StringValue(*instance.FlavorId),
+ // "description": types.StringValue(*instance.Flavor.Description),
+ // "cpu": types.Int64PointerValue(instance.Flavor.Cpu),
+ // "ram": types.Int64PointerValue(instance.Flavor.Memory),
+ //}
+ }
+ flavorObject, diags := types.ObjectValue(flavorTypes, flavorValues)
+ if diags.HasError() {
+ return fmt.Errorf("creating flavor: %w", core.DiagsToError(diags))
+ }
+
+ var storageValues map[string]attr.Value
+ if instance.Storage == nil {
+ storageValues = map[string]attr.Value{
+ "class": storage.Class,
+ "size": storage.Size,
+ }
+ } else {
+ storageValues = map[string]attr.Value{
+ "class": types.StringValue(*instance.Storage.PerformanceClass),
+ "size": types.Int64PointerValue(instance.Storage.Size),
+ }
+ }
+ storageObject, diags := types.ObjectValue(storageTypes, storageValues)
+ if diags.HasError() {
+ return fmt.Errorf("creating storage: %w", core.DiagsToError(diags))
+ }
+
+ model.Id = utils.BuildInternalTerraformId(model.ProjectId.ValueString(), region, instanceId)
+ model.InstanceId = types.StringValue(instanceId)
+ model.Name = types.StringPointerValue(instance.Name)
+ model.ACL = aclList
+ model.BackupSchedule = types.StringPointerValue(instance.BackupSchedule)
+ model.Flavor = flavorObject
+ // TODO - verify working
+ model.Replicas = types.Int64Value(int64(*instance.Replicas))
+ model.Storage = storageObject
+ model.Version = types.StringPointerValue(instance.Version)
+ model.Region = types.StringValue(region)
+ //model.Encryption = types.ObjectValue()
+ //model.Network = networkModel
+ return nil
+}
+
+func toCreatePayload(model *Model, acl []string, flavor *flavorModel, storage *storageModel, enc *encryptionModel, net *networkModel) (*postgresflexalpha.CreateInstanceRequestPayload, error) {
+ if model == nil {
+ return nil, fmt.Errorf("nil model")
+ }
+ if acl == nil {
+ return nil, fmt.Errorf("nil acl")
+ }
+ if flavor == nil {
+ return nil, fmt.Errorf("nil flavor")
+ }
+ if storage == nil {
+ return nil, fmt.Errorf("nil storage")
+ }
+
+ replVal := int32(model.Replicas.ValueInt64())
+ return &postgresflexalpha.CreateInstanceRequestPayload{
+ // TODO - verify working
+ Acl: &[]string{
+ strings.Join(acl, ","),
+ },
+ BackupSchedule: conversion.StringValueToPointer(model.BackupSchedule),
+ FlavorId: conversion.StringValueToPointer(flavor.Id),
+ Name: conversion.StringValueToPointer(model.Name),
+ // TODO - verify working
+ Replicas: postgresflexalpha.CreateInstanceRequestPayloadGetReplicasAttributeType(&replVal),
+ // TODO - verify working
+ Storage: postgresflexalpha.CreateInstanceRequestPayloadGetStorageAttributeType(&postgresflexalpha.Storage{
+ PerformanceClass: conversion.StringValueToPointer(storage.Class),
+ Size: conversion.Int64ValueToPointer(storage.Size),
+ }),
+ Version: conversion.StringValueToPointer(model.Version),
+ // TODO - verify working
+ Encryption: postgresflexalpha.CreateInstanceRequestPayloadGetEncryptionAttributeType(
+ &postgresflexalpha.InstanceEncryption{
+ KekKeyId: conversion.StringValueToPointer(enc.KeyId), // model.Encryption.Attributes(),
+ KekKeyRingId: conversion.StringValueToPointer(enc.KeyRingId),
+ KekKeyVersion: conversion.StringValueToPointer(enc.KeyVersion),
+ ServiceAccount: conversion.StringValueToPointer(enc.ServiceAccount),
+ },
+ ),
+ Network: &postgresflexalpha.InstanceNetwork{
+ AccessScope: postgresflexalpha.InstanceNetworkGetAccessScopeAttributeType(
+ conversion.StringValueToPointer(net.AccessScope),
+ ),
+ },
+ }, nil
+}
+
+func toUpdatePayload(model *Model, acl []string, flavor *flavorModel, storage *storageModel) (*postgresflexalpha.UpdateInstancePartiallyRequestPayload, error) {
+ if model == nil {
+ return nil, fmt.Errorf("nil model")
+ }
+ if acl == nil {
+ return nil, fmt.Errorf("nil acl")
+ }
+ if flavor == nil {
+ return nil, fmt.Errorf("nil flavor")
+ }
+ if storage == nil {
+ return nil, fmt.Errorf("nil storage")
+ }
+
+ return &postgresflexalpha.UpdateInstancePartiallyRequestPayload{
+ //Acl: postgresflexalpha.UpdateInstancePartiallyRequestPayloadGetAclAttributeType{
+ // Items: &acl,
+ //},
+ BackupSchedule: conversion.StringValueToPointer(model.BackupSchedule),
+ FlavorId: conversion.StringValueToPointer(flavor.Id),
+ Name: conversion.StringValueToPointer(model.Name),
+ //Replicas: conversion.Int64ValueToPointer(model.Replicas),
+ Storage: &postgresflexalpha.StorageUpdate{
+ Size: conversion.Int64ValueToPointer(storage.Size),
+ },
+ Version: conversion.StringValueToPointer(model.Version),
+ }, nil
+}
+
+type postgresflexClient interface {
+ GetFlavorsRequestExecute(ctx context.Context, projectId string, region string) (*postgresflexalpha.GetFlavorsResponse, error)
+}
+
+func loadFlavorId(ctx context.Context, client postgresflexClient, model *Model, flavor *flavorModel) error {
+ if model == nil {
+ return fmt.Errorf("nil model")
+ }
+ if flavor == nil {
+ return fmt.Errorf("nil flavor")
+ }
+ cpu := conversion.Int64ValueToPointer(flavor.CPU)
+ if cpu == nil {
+ return fmt.Errorf("nil CPU")
+ }
+ ram := conversion.Int64ValueToPointer(flavor.RAM)
+ if ram == nil {
+ return fmt.Errorf("nil RAM")
+ }
+
+ projectId := model.ProjectId.ValueString()
+ region := model.Region.ValueString()
+ res, err := client.GetFlavorsRequestExecute(ctx, projectId, region)
+ if err != nil {
+ return fmt.Errorf("listing postgresflex flavors: %w", err)
+ }
+
+ avl := ""
+ if res.Flavors == nil {
+ return fmt.Errorf("finding flavors for project %s", projectId)
+ }
+ for _, f := range *res.Flavors {
+ if f.Id == nil || f.Cpu == nil || f.Memory == nil {
+ continue
+ }
+ if *f.Cpu == *cpu && *f.Memory == *ram {
+ flavor.Id = types.StringValue(*f.Id)
+ flavor.Description = types.StringValue(*f.Description)
+ break
+ }
+ avl = fmt.Sprintf("%s\n- %d CPU, %d GB RAM", avl, *f.Cpu, *f.Memory)
+ }
+ if flavor.Id.ValueString() == "" {
+ return fmt.Errorf("couldn't find flavor, available specs are:%s", avl)
+ }
+
+ return nil
+}
diff --git a/stackit/internal/services/postgresflexalpha/instance/resource_test.go b/stackit/internal/services/postgresflexalpha/instance/resource_test.go
new file mode 100644
index 00000000..f0d37367
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/instance/resource_test.go
@@ -0,0 +1,768 @@
+// Copyright (c) STACKIT
+
+package postgresflex
+
+import (
+ "context"
+ "fmt"
+ "testing"
+
+ "github.com/google/go-cmp/cmp"
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+ postgresflex "github.com/stackitcloud/terraform-provider-stackit/pkg/postgresflexalpha"
+)
+
+type postgresFlexClientMocked struct {
+ returnError bool
+ getFlavorsResp *postgresflex.GetFlavorsResponse
+}
+
+func (c *postgresFlexClientMocked) ListFlavorsExecute(_ context.Context, _, _ string) (*postgresflex.GetFlavorsResponse, error) {
+ if c.returnError {
+ return nil, fmt.Errorf("get flavors failed")
+ }
+
+ return c.getFlavorsResp, nil
+}
+
+func TestMapFields(t *testing.T) {
+ const testRegion = "region"
+ tests := []struct {
+ description string
+ state Model
+ input *postgresflex.GetInstanceResponse
+ flavor *flavorModel
+ storage *storageModel
+ region string
+ expected Model
+ isValid bool
+ }{
+ {
+ "default_values",
+ Model{
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ },
+ &postgresflex.GetInstanceResponse{},
+ &flavorModel{},
+ &storageModel{},
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Name: types.StringNull(),
+ ACL: types.ListNull(types.StringType),
+ BackupSchedule: types.StringNull(),
+ Flavor: types.ObjectValueMust(flavorTypes, map[string]attr.Value{
+ "id": types.StringNull(),
+ "description": types.StringNull(),
+ "cpu": types.Int64Null(),
+ "ram": types.Int64Null(),
+ }),
+ Replicas: types.Int64Null(),
+ Storage: types.ObjectValueMust(storageTypes, map[string]attr.Value{
+ "class": types.StringNull(),
+ "size": types.Int64Null(),
+ }),
+ Version: types.StringNull(),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "simple_values",
+ Model{
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ },
+ &postgresflex.GetInstanceResponse{
+ Acl: &[]string{
+ "ip1",
+ "ip2",
+ "",
+ },
+ BackupSchedule: utils.Ptr("schedule"),
+ //Flavor: &postgresflex.Flavor{
+ // Cpu: utils.Ptr(int64(12)),
+ // Description: utils.Ptr("description"),
+ // Id: utils.Ptr("flavor_id"),
+ // Memory: utils.Ptr(int64(34)),
+ //},
+ Id: utils.Ptr("iid"),
+ Name: utils.Ptr("name"),
+ Replicas: postgresflex.GetInstanceResponseGetReplicasAttributeType(utils.Ptr(int32(56))),
+ Status: postgresflex.GetInstanceResponseGetStatusAttributeType(utils.Ptr("status")),
+ Storage: &postgresflex.Storage{
+ PerformanceClass: utils.Ptr("class"),
+ Size: utils.Ptr(int64(78)),
+ },
+ Version: utils.Ptr("version"),
+ },
+ &flavorModel{},
+ &storageModel{},
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Name: types.StringValue("name"),
+ ACL: types.ListValueMust(types.StringType, []attr.Value{
+ types.StringValue("ip1"),
+ types.StringValue("ip2"),
+ types.StringValue(""),
+ }),
+ BackupSchedule: types.StringValue("schedule"),
+ Flavor: types.ObjectValueMust(flavorTypes, map[string]attr.Value{
+ "id": types.StringValue("flavor_id"),
+ "description": types.StringValue("description"),
+ "cpu": types.Int64Value(12),
+ "ram": types.Int64Value(34),
+ }),
+ Replicas: types.Int64Value(56),
+ Storage: types.ObjectValueMust(storageTypes, map[string]attr.Value{
+ "class": types.StringValue("class"),
+ "size": types.Int64Value(78),
+ }),
+ Version: types.StringValue("version"),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "simple_values_no_flavor_and_storage",
+ Model{
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ },
+ &postgresflex.GetInstanceResponse{
+ Acl: &[]string{
+ "ip1",
+ "ip2",
+ "",
+ },
+ BackupSchedule: utils.Ptr("schedule"),
+ FlavorId: nil,
+ Id: utils.Ptr("iid"),
+ Name: utils.Ptr("name"),
+ Replicas: postgresflex.GetInstanceResponseGetReplicasAttributeType(utils.Ptr(int32(56))),
+ Status: postgresflex.GetInstanceResponseGetStatusAttributeType(utils.Ptr("status")),
+ Storage: nil,
+ Version: utils.Ptr("version"),
+ },
+ &flavorModel{
+ CPU: types.Int64Value(12),
+ RAM: types.Int64Value(34),
+ },
+ &storageModel{
+ Class: types.StringValue("class"),
+ Size: types.Int64Value(78),
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Name: types.StringValue("name"),
+ ACL: types.ListValueMust(types.StringType, []attr.Value{
+ types.StringValue("ip1"),
+ types.StringValue("ip2"),
+ types.StringValue(""),
+ }),
+ BackupSchedule: types.StringValue("schedule"),
+ Flavor: types.ObjectValueMust(flavorTypes, map[string]attr.Value{
+ "id": types.StringNull(),
+ "description": types.StringNull(),
+ "cpu": types.Int64Value(12),
+ "ram": types.Int64Value(34),
+ }),
+ Replicas: types.Int64Value(56),
+ Storage: types.ObjectValueMust(storageTypes, map[string]attr.Value{
+ "class": types.StringValue("class"),
+ "size": types.Int64Value(78),
+ }),
+ Version: types.StringValue("version"),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "acl_unordered",
+ Model{
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ ACL: types.ListValueMust(types.StringType, []attr.Value{
+ types.StringValue("ip2"),
+ types.StringValue(""),
+ types.StringValue("ip1"),
+ }),
+ },
+ &postgresflex.GetInstanceResponse{
+ Acl: &[]string{
+ "",
+ "ip1",
+ "ip2",
+ },
+ BackupSchedule: utils.Ptr("schedule"),
+ FlavorId: nil,
+ Id: utils.Ptr("iid"),
+ Name: utils.Ptr("name"),
+ Replicas: postgresflex.GetInstanceResponseGetReplicasAttributeType(utils.Ptr(int32(56))),
+ Status: postgresflex.GetInstanceResponseGetStatusAttributeType(utils.Ptr("status")),
+ Storage: nil,
+ Version: utils.Ptr("version"),
+ },
+ &flavorModel{
+ CPU: types.Int64Value(12),
+ RAM: types.Int64Value(34),
+ },
+ &storageModel{
+ Class: types.StringValue("class"),
+ Size: types.Int64Value(78),
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Name: types.StringValue("name"),
+ ACL: types.ListValueMust(types.StringType, []attr.Value{
+ types.StringValue("ip2"),
+ types.StringValue(""),
+ types.StringValue("ip1"),
+ }),
+ BackupSchedule: types.StringValue("schedule"),
+ Flavor: types.ObjectValueMust(flavorTypes, map[string]attr.Value{
+ "id": types.StringNull(),
+ "description": types.StringNull(),
+ "cpu": types.Int64Value(12),
+ "ram": types.Int64Value(34),
+ }),
+ Replicas: types.Int64Value(56),
+ Storage: types.ObjectValueMust(storageTypes, map[string]attr.Value{
+ "class": types.StringValue("class"),
+ "size": types.Int64Value(78),
+ }),
+ Version: types.StringValue("version"),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "nil_response",
+ Model{
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ },
+ nil,
+ &flavorModel{},
+ &storageModel{},
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "no_resource_id",
+ Model{
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ },
+ &postgresflex.GetInstanceResponse{},
+ &flavorModel{},
+ &storageModel{},
+ testRegion,
+ Model{},
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ err := mapFields(context.Background(), tt.input, &tt.state, tt.flavor, tt.storage, tt.region)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(tt.state, tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ })
+ }
+}
+
+func TestToCreatePayload(t *testing.T) {
+ tests := []struct {
+ description string
+ input *Model
+ inputAcl []string
+ inputFlavor *flavorModel
+ inputStorage *storageModel
+ inputEncryption *encryptionModel
+ inputNetwork *networkModel
+ expected *postgresflex.CreateInstanceRequestPayload
+ isValid bool
+ }{
+ {
+ "default_values",
+ &Model{},
+ []string{},
+ &flavorModel{},
+ &storageModel{},
+ &encryptionModel{},
+ &networkModel{},
+ &postgresflex.CreateInstanceRequestPayload{
+ Acl: &[]string{},
+ Storage: postgresflex.CreateInstanceRequestPayloadGetStorageAttributeType(&postgresflex.Storage{}),
+ },
+ true,
+ },
+ {
+ "simple_values",
+ &Model{
+ BackupSchedule: types.StringValue("schedule"),
+ Name: types.StringValue("name"),
+ Replicas: types.Int64Value(12),
+ Version: types.StringValue("version"),
+ },
+ []string{
+ "ip_1",
+ "ip_2",
+ },
+ &flavorModel{
+ Id: types.StringValue("flavor_id"),
+ },
+ &storageModel{
+ Class: types.StringValue("class"),
+ Size: types.Int64Value(34),
+ },
+ &encryptionModel{},
+ &networkModel{},
+ &postgresflex.CreateInstanceRequestPayload{
+ Acl: &[]string{
+ "ip_1",
+ "ip_2",
+ },
+ BackupSchedule: utils.Ptr("schedule"),
+ FlavorId: utils.Ptr("flavor_id"),
+ Name: utils.Ptr("name"),
+ Replicas: postgresflex.CreateInstanceRequestPayloadGetReplicasAttributeType(utils.Ptr(int32(56))),
+ Storage: postgresflex.CreateInstanceRequestPayloadGetStorageAttributeType(&postgresflex.Storage{
+ PerformanceClass: utils.Ptr("class"),
+ Size: utils.Ptr(int64(34)),
+ }),
+ Version: utils.Ptr("version"),
+ },
+ true,
+ },
+ {
+ "null_fields_and_int_conversions",
+ &Model{
+ BackupSchedule: types.StringNull(),
+ Name: types.StringNull(),
+ Replicas: types.Int64Value(2123456789),
+ Version: types.StringNull(),
+ },
+ []string{
+ "",
+ },
+ &flavorModel{
+ Id: types.StringNull(),
+ },
+ &storageModel{
+ Class: types.StringNull(),
+ Size: types.Int64Null(),
+ },
+ &encryptionModel{},
+ &networkModel{},
+ &postgresflex.CreateInstanceRequestPayload{
+ Acl: &[]string{
+ "",
+ },
+ BackupSchedule: nil,
+ FlavorId: nil,
+ Name: nil,
+ Replicas: postgresflex.CreateInstanceRequestPayloadGetReplicasAttributeType(utils.Ptr(int32(2123456789))),
+ Storage: postgresflex.CreateInstanceRequestPayloadGetStorageAttributeType(&postgresflex.Storage{
+ PerformanceClass: nil,
+ Size: nil,
+ }),
+ Version: nil,
+ },
+ true,
+ },
+ {
+ "nil_model",
+ nil,
+ []string{},
+ &flavorModel{},
+ &storageModel{},
+ &encryptionModel{},
+ &networkModel{},
+ nil,
+ false,
+ },
+ {
+ "nil_acl",
+ &Model{},
+ nil,
+ &flavorModel{},
+ &storageModel{},
+ &encryptionModel{},
+ &networkModel{},
+ nil,
+ false,
+ },
+ {
+ "nil_flavor",
+ &Model{},
+ []string{},
+ nil,
+ &storageModel{},
+ &encryptionModel{},
+ &networkModel{},
+ nil,
+ false,
+ },
+ {
+ "nil_storage",
+ &Model{},
+ []string{},
+ &flavorModel{},
+ nil,
+ &encryptionModel{},
+ &networkModel{},
+ nil,
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ output, err := toCreatePayload(tt.input, tt.inputAcl, tt.inputFlavor, tt.inputStorage, tt.inputEncryption, tt.inputNetwork)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(output, tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ })
+ }
+}
+
+//func TestToUpdatePayload(t *testing.T) {
+// tests := []struct {
+// description string
+// input *Model
+// inputAcl []string
+// inputFlavor *flavorModel
+// inputStorage *storageModel
+// expected *postgresflex.PartialUpdateInstancePayload
+// isValid bool
+// }{
+// {
+// "default_values",
+// &Model{},
+// []string{},
+// &flavorModel{},
+// &storageModel{},
+// &postgresflex.PartialUpdateInstancePayload{
+// Acl: &postgresflex.ACL{
+// Items: &[]string{},
+// },
+// Storage: &postgresflex.Storage{},
+// },
+// true,
+// },
+// {
+// "simple_values",
+// &Model{
+// BackupSchedule: types.StringValue("schedule"),
+// Name: types.StringValue("name"),
+// Replicas: types.Int64Value(12),
+// Version: types.StringValue("version"),
+// },
+// []string{
+// "ip_1",
+// "ip_2",
+// },
+// &flavorModel{
+// Id: types.StringValue("flavor_id"),
+// },
+// &storageModel{
+// Class: types.StringValue("class"),
+// Size: types.Int64Value(34),
+// },
+// &postgresflex.PartialUpdateInstancePayload{
+// Acl: &postgresflex.ACL{
+// Items: &[]string{
+// "ip_1",
+// "ip_2",
+// },
+// },
+// BackupSchedule: utils.Ptr("schedule"),
+// FlavorId: utils.Ptr("flavor_id"),
+// Name: utils.Ptr("name"),
+// Replicas: utils.Ptr(int64(12)),
+// Storage: &postgresflex.Storage{
+// Class: utils.Ptr("class"),
+// Size: utils.Ptr(int64(34)),
+// },
+// Version: utils.Ptr("version"),
+// },
+// true,
+// },
+// {
+// "null_fields_and_int_conversions",
+// &Model{
+// BackupSchedule: types.StringNull(),
+// Name: types.StringNull(),
+// Replicas: types.Int64Value(2123456789),
+// Version: types.StringNull(),
+// },
+// []string{
+// "",
+// },
+// &flavorModel{
+// Id: types.StringNull(),
+// },
+// &storageModel{
+// Class: types.StringNull(),
+// Size: types.Int64Null(),
+// },
+// &postgresflex.PartialUpdateInstancePayload{
+// Acl: &postgresflex.ACL{
+// Items: &[]string{
+// "",
+// },
+// },
+// BackupSchedule: nil,
+// FlavorId: nil,
+// Name: nil,
+// Replicas: utils.Ptr(int64(2123456789)),
+// Storage: &postgresflex.Storage{
+// Class: nil,
+// Size: nil,
+// },
+// Version: nil,
+// },
+// true,
+// },
+// {
+// "nil_model",
+// nil,
+// []string{},
+// &flavorModel{},
+// &storageModel{},
+// nil,
+// false,
+// },
+// {
+// "nil_acl",
+// &Model{},
+// nil,
+// &flavorModel{},
+// &storageModel{},
+// nil,
+// false,
+// },
+// {
+// "nil_flavor",
+// &Model{},
+// []string{},
+// nil,
+// &storageModel{},
+// nil,
+// false,
+// },
+// {
+// "nil_storage",
+// &Model{},
+// []string{},
+// &flavorModel{},
+// nil,
+// nil,
+// false,
+// },
+// }
+// for _, tt := range tests {
+// t.Run(tt.description, func(t *testing.T) {
+// output, err := toUpdatePayload(tt.input, tt.inputAcl, tt.inputFlavor, tt.inputStorage)
+// if !tt.isValid && err == nil {
+// t.Fatalf("Should have failed")
+// }
+// if tt.isValid && err != nil {
+// t.Fatalf("Should not have failed: %v", err)
+// }
+// if tt.isValid {
+// diff := cmp.Diff(output, tt.expected)
+// if diff != "" {
+// t.Fatalf("Data does not match: %s", diff)
+// }
+// }
+// })
+// }
+//}
+//
+//func TestLoadFlavorId(t *testing.T) {
+// tests := []struct {
+// description string
+// inputFlavor *flavorModel
+// mockedResp *postgresflex.ListFlavorsResponse
+// expected *flavorModel
+// getFlavorsFails bool
+// isValid bool
+// }{
+// {
+// "ok_flavor",
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// &postgresflex.ListFlavorsResponse{
+// Flavors: &[]postgresflex.Flavor{
+// {
+// Id: utils.Ptr("fid-1"),
+// Cpu: utils.Ptr(int64(2)),
+// Description: utils.Ptr("description"),
+// Memory: utils.Ptr(int64(8)),
+// },
+// },
+// },
+// &flavorModel{
+// Id: types.StringValue("fid-1"),
+// Description: types.StringValue("description"),
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// false,
+// true,
+// },
+// {
+// "ok_flavor_2",
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// &postgresflex.ListFlavorsResponse{
+// Flavors: &[]postgresflex.Flavor{
+// {
+// Id: utils.Ptr("fid-1"),
+// Cpu: utils.Ptr(int64(2)),
+// Description: utils.Ptr("description"),
+// Memory: utils.Ptr(int64(8)),
+// },
+// {
+// Id: utils.Ptr("fid-2"),
+// Cpu: utils.Ptr(int64(1)),
+// Description: utils.Ptr("description"),
+// Memory: utils.Ptr(int64(4)),
+// },
+// },
+// },
+// &flavorModel{
+// Id: types.StringValue("fid-1"),
+// Description: types.StringValue("description"),
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// false,
+// true,
+// },
+// {
+// "no_matching_flavor",
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// &postgresflex.ListFlavorsResponse{
+// Flavors: &[]postgresflex.Flavor{
+// {
+// Id: utils.Ptr("fid-1"),
+// Cpu: utils.Ptr(int64(1)),
+// Description: utils.Ptr("description"),
+// Memory: utils.Ptr(int64(8)),
+// },
+// {
+// Id: utils.Ptr("fid-2"),
+// Cpu: utils.Ptr(int64(1)),
+// Description: utils.Ptr("description"),
+// Memory: utils.Ptr(int64(4)),
+// },
+// },
+// },
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// false,
+// false,
+// },
+// {
+// "nil_response",
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// &postgresflex.ListFlavorsResponse{},
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// false,
+// false,
+// },
+// {
+// "error_response",
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// &postgresflex.ListFlavorsResponse{},
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// true,
+// false,
+// },
+// }
+// for _, tt := range tests {
+// t.Run(tt.description, func(t *testing.T) {
+// client := &postgresFlexClientMocked{
+// returnError: tt.getFlavorsFails,
+// getFlavorsResp: tt.mockedResp,
+// }
+// model := &Model{
+// ProjectId: types.StringValue("pid"),
+// }
+// flavorModel := &flavorModel{
+// CPU: tt.inputFlavor.CPU,
+// RAM: tt.inputFlavor.RAM,
+// }
+// err := loadFlavorId(context.Background(), client, model, flavorModel)
+// if !tt.isValid && err == nil {
+// t.Fatalf("Should have failed")
+// }
+// if tt.isValid && err != nil {
+// t.Fatalf("Should not have failed: %v", err)
+// }
+// if tt.isValid {
+// diff := cmp.Diff(flavorModel, tt.expected)
+// if diff != "" {
+// t.Fatalf("Data does not match: %s", diff)
+// }
+// }
+// })
+// }
+//}
diff --git a/stackit/internal/services/postgresflexalpha/instance/use_state_for_unknown_if_flavor_unchanged_modifier.go b/stackit/internal/services/postgresflexalpha/instance/use_state_for_unknown_if_flavor_unchanged_modifier.go
new file mode 100644
index 00000000..f6dce5ab
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/instance/use_state_for_unknown_if_flavor_unchanged_modifier.go
@@ -0,0 +1,87 @@
+// Copyright (c) STACKIT
+
+package postgresflex
+
+import (
+ "context"
+
+ "github.com/hashicorp/terraform-plugin-framework/resource"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/planmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+)
+
+type useStateForUnknownIfFlavorUnchangedModifier struct {
+ Req resource.SchemaRequest
+}
+
+// UseStateForUnknownIfFlavorUnchanged returns a plan modifier similar to UseStateForUnknown
+// if the RAM and CPU values are not changed in the plan. Otherwise, the plan modifier does nothing.
+func UseStateForUnknownIfFlavorUnchanged(req resource.SchemaRequest) planmodifier.String {
+ return useStateForUnknownIfFlavorUnchangedModifier{
+ Req: req,
+ }
+}
+
+func (m useStateForUnknownIfFlavorUnchangedModifier) Description(context.Context) string {
+ return "UseStateForUnknownIfFlavorUnchanged returns a plan modifier similar to UseStateForUnknown if the RAM and CPU values are not changed in the plan. Otherwise, the plan modifier does nothing."
+}
+
+func (m useStateForUnknownIfFlavorUnchangedModifier) MarkdownDescription(ctx context.Context) string {
+ return m.Description(ctx)
+}
+
+func (m useStateForUnknownIfFlavorUnchangedModifier) PlanModifyString(ctx context.Context, req planmodifier.StringRequest, resp *planmodifier.StringResponse) { // nolint:gocritic // function signature required by Terraform
+ // Do nothing if there is no state value.
+ if req.StateValue.IsNull() {
+ return
+ }
+
+ // Do nothing if there is a known planned value.
+ if !req.PlanValue.IsUnknown() {
+ return
+ }
+
+ // Do nothing if there is an unknown configuration value, otherwise interpolation gets messed up.
+ if req.ConfigValue.IsUnknown() {
+ return
+ }
+
+ // The above checks are taken from the UseStateForUnknown plan modifier implementation
+ // (https://github.com/hashicorp/terraform-plugin-framework/blob/main/resource/schema/stringplanmodifier/use_state_for_unknown.go#L38)
+
+ var stateModel Model
+ diags := req.State.Get(ctx, &stateModel)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ var stateFlavor = &flavorModel{}
+ if !(stateModel.Flavor.IsNull() || stateModel.Flavor.IsUnknown()) {
+ diags = stateModel.Flavor.As(ctx, stateFlavor, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ var planModel Model
+ diags = req.Plan.Get(ctx, &planModel)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ var planFlavor = &flavorModel{}
+ if !(planModel.Flavor.IsNull() || planModel.Flavor.IsUnknown()) {
+ diags = planModel.Flavor.As(ctx, planFlavor, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ if planFlavor.CPU == stateFlavor.CPU && planFlavor.RAM == stateFlavor.RAM {
+ resp.PlanValue = req.StateValue
+ }
+}
diff --git a/stackit/internal/services/postgresflexalpha/postgresflex_acc_test.go b/stackit/internal/services/postgresflexalpha/postgresflex_acc_test.go
new file mode 100644
index 00000000..4601ed11
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/postgresflex_acc_test.go
@@ -0,0 +1,371 @@
+// Copyright (c) STACKIT
+
+package postgresflex_test
+
+import (
+ "context"
+ "fmt"
+ "strings"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-testing/helper/acctest"
+ "github.com/hashicorp/terraform-plugin-testing/helper/resource"
+ "github.com/hashicorp/terraform-plugin-testing/terraform"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+ "github.com/stackitcloud/stackit-sdk-go/services/postgresflex"
+ "github.com/stackitcloud/stackit-sdk-go/services/postgresflex/wait"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/testutil"
+)
+
+// Instance resource data
+var instanceResource = map[string]string{
+ "project_id": testutil.ProjectId,
+ "name": fmt.Sprintf("tf-acc-%s", acctest.RandStringFromCharSet(7, acctest.CharSetAlphaNum)),
+ "acl": "192.168.0.0/16",
+ "backup_schedule": "00 16 * * *",
+ "backup_schedule_updated": "00 12 * * *",
+ "flavor_cpu": "2",
+ "flavor_ram": "4",
+ "flavor_description": "Small, Compute optimized",
+ "replicas": "1",
+ "storage_class": "premium-perf12-stackit",
+ "storage_size": "5",
+ "version": "14",
+ "flavor_id": "2.4",
+}
+
+// User resource data
+var userResource = map[string]string{
+ "username": fmt.Sprintf("tfaccuser%s", acctest.RandStringFromCharSet(4, acctest.CharSetAlpha)),
+ "role": "createdb",
+ "project_id": instanceResource["project_id"],
+}
+
+// Database resource data
+var databaseResource = map[string]string{
+ "name": fmt.Sprintf("tfaccdb%s", acctest.RandStringFromCharSet(4, acctest.CharSetAlphaNum)),
+}
+
+func configResources(backupSchedule string, region *string) string {
+ var regionConfig string
+ if region != nil {
+ regionConfig = fmt.Sprintf(`region = %q`, *region)
+ }
+ return fmt.Sprintf(`
+ %s
+
+ resource "stackit_postgresflex_instance" "instance" {
+ project_id = "%s"
+ name = "%s"
+ acl = ["%s"]
+ backup_schedule = "%s"
+ flavor = {
+ cpu = %s
+ ram = %s
+ }
+ replicas = %s
+ storage = {
+ class = "%s"
+ size = %s
+ }
+ version = "%s"
+ %s
+ }
+
+ resource "stackit_postgresflex_user" "user" {
+ project_id = stackit_postgresflex_instance.instance.project_id
+ instance_id = stackit_postgresflex_instance.instance.instance_id
+ username = "%s"
+ roles = ["%s"]
+ }
+
+ resource "stackit_postgresflex_database" "database" {
+ project_id = stackit_postgresflex_instance.instance.project_id
+ instance_id = stackit_postgresflex_instance.instance.instance_id
+ name = "%s"
+ owner = stackit_postgresflex_user.user.username
+ }
+ `,
+ testutil.PostgresFlexProviderConfig(),
+ instanceResource["project_id"],
+ instanceResource["name"],
+ instanceResource["acl"],
+ backupSchedule,
+ instanceResource["flavor_cpu"],
+ instanceResource["flavor_ram"],
+ instanceResource["replicas"],
+ instanceResource["storage_class"],
+ instanceResource["storage_size"],
+ instanceResource["version"],
+ regionConfig,
+ userResource["username"],
+ userResource["role"],
+ databaseResource["name"],
+ )
+}
+
+func TestAccPostgresFlexFlexResource(t *testing.T) {
+ resource.Test(t, resource.TestCase{
+ ProtoV6ProviderFactories: testutil.TestAccProtoV6ProviderFactories,
+ CheckDestroy: testAccCheckPostgresFlexDestroy,
+ Steps: []resource.TestStep{
+ // Creation
+ {
+ Config: configResources(instanceResource["backup_schedule"], &testutil.Region),
+ Check: resource.ComposeAggregateTestCheckFunc(
+ // Instance
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "project_id", instanceResource["project_id"]),
+ resource.TestCheckResourceAttrSet("stackit_postgresflex_instance.instance", "instance_id"),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "name", instanceResource["name"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "acl.#", "1"),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "acl.0", instanceResource["acl"]),
+ resource.TestCheckResourceAttrSet("stackit_postgresflex_instance.instance", "flavor.id"),
+ resource.TestCheckResourceAttrSet("stackit_postgresflex_instance.instance", "flavor.description"),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "backup_schedule", instanceResource["backup_schedule"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "flavor.cpu", instanceResource["flavor_cpu"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "flavor.ram", instanceResource["flavor_ram"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "replicas", instanceResource["replicas"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "storage.class", instanceResource["storage_class"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "storage.size", instanceResource["storage_size"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "version", instanceResource["version"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "region", testutil.Region),
+
+ // User
+ resource.TestCheckResourceAttrPair(
+ "stackit_postgresflex_user.user", "project_id",
+ "stackit_postgresflex_instance.instance", "project_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "stackit_postgresflex_user.user", "instance_id",
+ "stackit_postgresflex_instance.instance", "instance_id",
+ ),
+ resource.TestCheckResourceAttrSet("stackit_postgresflex_user.user", "user_id"),
+ resource.TestCheckResourceAttrSet("stackit_postgresflex_user.user", "password"),
+
+ // Database
+ resource.TestCheckResourceAttrPair(
+ "stackit_postgresflex_database.database", "project_id",
+ "stackit_postgresflex_instance.instance", "project_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "stackit_postgresflex_database.database", "instance_id",
+ "stackit_postgresflex_instance.instance", "instance_id",
+ ),
+ resource.TestCheckResourceAttr("stackit_postgresflex_database.database", "name", databaseResource["name"]),
+ resource.TestCheckResourceAttrPair(
+ "stackit_postgresflex_database.database", "owner",
+ "stackit_postgresflex_user.user", "username",
+ ),
+ ),
+ },
+ // data source
+ {
+ Config: fmt.Sprintf(`
+ %s
+
+ data "stackit_postgresflex_instance" "instance" {
+ project_id = stackit_postgresflex_instance.instance.project_id
+ instance_id = stackit_postgresflex_instance.instance.instance_id
+ }
+
+ data "stackit_postgresflex_user" "user" {
+ project_id = stackit_postgresflex_instance.instance.project_id
+ instance_id = stackit_postgresflex_instance.instance.instance_id
+ user_id = stackit_postgresflex_user.user.user_id
+ }
+
+ data "stackit_postgresflex_database" "database" {
+ project_id = stackit_postgresflex_instance.instance.project_id
+ instance_id = stackit_postgresflex_instance.instance.instance_id
+ database_id = stackit_postgresflex_database.database.database_id
+ }
+ `,
+ configResources(instanceResource["backup_schedule"], nil),
+ ),
+ Check: resource.ComposeAggregateTestCheckFunc(
+ // Instance data
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_instance.instance", "project_id", instanceResource["project_id"]),
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_instance.instance", "name", instanceResource["name"]),
+ resource.TestCheckResourceAttrPair(
+ "data.stackit_postgresflex_instance.instance", "project_id",
+ "stackit_postgresflex_instance.instance", "project_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "data.stackit_postgresflex_instance.instance", "instance_id",
+ "stackit_postgresflex_instance.instance", "instance_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "data.stackit_postgresflex_user.user", "instance_id",
+ "stackit_postgresflex_user.user", "instance_id",
+ ),
+
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_instance.instance", "acl.#", "1"),
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_instance.instance", "acl.0", instanceResource["acl"]),
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_instance.instance", "backup_schedule", instanceResource["backup_schedule"]),
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_instance.instance", "flavor.id", instanceResource["flavor_id"]),
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_instance.instance", "flavor.description", instanceResource["flavor_description"]),
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_instance.instance", "flavor.cpu", instanceResource["flavor_cpu"]),
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_instance.instance", "flavor.ram", instanceResource["flavor_ram"]),
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_instance.instance", "replicas", instanceResource["replicas"]),
+
+ // User data
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_user.user", "project_id", userResource["project_id"]),
+ resource.TestCheckResourceAttrSet("data.stackit_postgresflex_user.user", "user_id"),
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_user.user", "username", userResource["username"]),
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_user.user", "roles.#", "1"),
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_user.user", "roles.0", userResource["role"]),
+ resource.TestCheckResourceAttrSet("data.stackit_postgresflex_user.user", "host"),
+ resource.TestCheckResourceAttrSet("data.stackit_postgresflex_user.user", "port"),
+
+ // Database data
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_database.database", "project_id", instanceResource["project_id"]),
+ resource.TestCheckResourceAttr("data.stackit_postgresflex_database.database", "name", databaseResource["name"]),
+ resource.TestCheckResourceAttrPair(
+ "data.stackit_postgresflex_database.database", "instance_id",
+ "stackit_postgresflex_instance.instance", "instance_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "data.stackit_postgresflex_database.database", "owner",
+ "data.stackit_postgresflex_user.user", "username",
+ ),
+ ),
+ },
+ // Import
+ {
+ ResourceName: "stackit_postgresflex_instance.instance",
+ ImportStateIdFunc: func(s *terraform.State) (string, error) {
+ r, ok := s.RootModule().Resources["stackit_postgresflex_instance.instance"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find resource stackit_postgresflex_instance.instance")
+ }
+ instanceId, ok := r.Primary.Attributes["instance_id"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find attribute instance_id")
+ }
+
+ return fmt.Sprintf("%s,%s,%s", testutil.ProjectId, testutil.Region, instanceId), nil
+ },
+ ImportState: true,
+ ImportStateVerify: true,
+ ImportStateVerifyIgnore: []string{"password"},
+ },
+ {
+ ResourceName: "stackit_postgresflex_user.user",
+ ImportStateIdFunc: func(s *terraform.State) (string, error) {
+ r, ok := s.RootModule().Resources["stackit_postgresflex_user.user"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find resource stackit_postgresflex_user.user")
+ }
+ instanceId, ok := r.Primary.Attributes["instance_id"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find attribute instance_id")
+ }
+ userId, ok := r.Primary.Attributes["user_id"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find attribute user_id")
+ }
+
+ return fmt.Sprintf("%s,%s,%s,%s", testutil.ProjectId, testutil.Region, instanceId, userId), nil
+ },
+ ImportState: true,
+ ImportStateVerify: true,
+ ImportStateVerifyIgnore: []string{"password", "uri"},
+ },
+ {
+ ResourceName: "stackit_postgresflex_database.database",
+ ImportStateIdFunc: func(s *terraform.State) (string, error) {
+ r, ok := s.RootModule().Resources["stackit_postgresflex_database.database"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find resource stackit_postgresflex_database.database")
+ }
+ instanceId, ok := r.Primary.Attributes["instance_id"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find attribute instance_id")
+ }
+ databaseId, ok := r.Primary.Attributes["database_id"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find attribute database_id")
+ }
+
+ return fmt.Sprintf("%s,%s,%s,%s", testutil.ProjectId, testutil.Region, instanceId, databaseId), nil
+ },
+ ImportState: true,
+ ImportStateVerify: true,
+ },
+ // Update
+ {
+ Config: configResources(instanceResource["backup_schedule_updated"], nil),
+ Check: resource.ComposeAggregateTestCheckFunc(
+ // Instance data
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "project_id", instanceResource["project_id"]),
+ resource.TestCheckResourceAttrSet("stackit_postgresflex_instance.instance", "instance_id"),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "name", instanceResource["name"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "acl.#", "1"),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "acl.0", instanceResource["acl"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "backup_schedule", instanceResource["backup_schedule_updated"]),
+ resource.TestCheckResourceAttrSet("stackit_postgresflex_instance.instance", "flavor.id"),
+ resource.TestCheckResourceAttrSet("stackit_postgresflex_instance.instance", "flavor.description"),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "flavor.cpu", instanceResource["flavor_cpu"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "flavor.ram", instanceResource["flavor_ram"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "replicas", instanceResource["replicas"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "storage.class", instanceResource["storage_class"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "storage.size", instanceResource["storage_size"]),
+ resource.TestCheckResourceAttr("stackit_postgresflex_instance.instance", "version", instanceResource["version"]),
+ ),
+ },
+ // Deletion is done by the framework implicitly
+ },
+ })
+}
+
+func testAccCheckPostgresFlexDestroy(s *terraform.State) error {
+ ctx := context.Background()
+ var client *postgresflex.APIClient
+ var err error
+ if testutil.PostgresFlexCustomEndpoint == "" {
+ client, err = postgresflex.NewAPIClient()
+ } else {
+ client, err = postgresflex.NewAPIClient(
+ config.WithEndpoint(testutil.PostgresFlexCustomEndpoint),
+ )
+ }
+ if err != nil {
+ return fmt.Errorf("creating client: %w", err)
+ }
+
+ instancesToDestroy := []string{}
+ for _, rs := range s.RootModule().Resources {
+ if rs.Type != "stackit_postgresflex_instance" {
+ continue
+ }
+ // instance terraform ID: = "[project_id],[region],[instance_id]"
+ instanceId := strings.Split(rs.Primary.ID, core.Separator)[2]
+ instancesToDestroy = append(instancesToDestroy, instanceId)
+ }
+
+ instancesResp, err := client.ListInstances(ctx, testutil.ProjectId, testutil.Region).Execute()
+ if err != nil {
+ return fmt.Errorf("getting instancesResp: %w", err)
+ }
+
+ items := *instancesResp.Items
+ for i := range items {
+ if items[i].Id == nil {
+ continue
+ }
+ if utils.Contains(instancesToDestroy, *items[i].Id) {
+ err := client.ForceDeleteInstanceExecute(ctx, testutil.ProjectId, testutil.Region, *items[i].Id)
+ if err != nil {
+ return fmt.Errorf("deleting instance %s during CheckDestroy: %w", *items[i].Id, err)
+ }
+ _, err = wait.DeleteInstanceWaitHandler(ctx, client, testutil.ProjectId, testutil.Region, *items[i].Id).WaitWithContext(ctx)
+ if err != nil {
+ return fmt.Errorf("deleting instance %s during CheckDestroy: waiting for deletion %w", *items[i].Id, err)
+ }
+ }
+ }
+ return nil
+}
diff --git a/stackit/internal/services/postgresflexalpha/user/datasource.go b/stackit/internal/services/postgresflexalpha/user/datasource.go
new file mode 100644
index 00000000..79861e19
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/user/datasource.go
@@ -0,0 +1,232 @@
+// Copyright (c) STACKIT
+
+package postgresflexa
+
+import (
+ "context"
+ "fmt"
+ "net/http"
+
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/conversion"
+ postgresflexUtils "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/postgresflex/utils"
+
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/datasource"
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/validate"
+
+ "github.com/hashicorp/terraform-plugin-framework/datasource/schema"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/services/postgresflex"
+)
+
+// Ensure the implementation satisfies the expected interfaces.
+var (
+ _ datasource.DataSource = &userDataSource{}
+)
+
+type DataSourceModel struct {
+ Id types.String `tfsdk:"id"` // needed by TF
+ UserId types.String `tfsdk:"user_id"`
+ InstanceId types.String `tfsdk:"instance_id"`
+ ProjectId types.String `tfsdk:"project_id"`
+ Username types.String `tfsdk:"username"`
+ Roles types.Set `tfsdk:"roles"`
+ Host types.String `tfsdk:"host"`
+ Port types.Int64 `tfsdk:"port"`
+ Region types.String `tfsdk:"region"`
+}
+
+// NewUserDataSource is a helper function to simplify the provider implementation.
+func NewUserDataSource() datasource.DataSource {
+ return &userDataSource{}
+}
+
+// userDataSource is the data source implementation.
+type userDataSource struct {
+ client *postgresflex.APIClient
+ providerData core.ProviderData
+}
+
+// Metadata returns the data source type name.
+func (r *userDataSource) Metadata(_ context.Context, req datasource.MetadataRequest, resp *datasource.MetadataResponse) {
+ resp.TypeName = req.ProviderTypeName + "_postgresflex_user"
+}
+
+// Configure adds the provider configured client to the data source.
+func (r *userDataSource) Configure(ctx context.Context, req datasource.ConfigureRequest, resp *datasource.ConfigureResponse) {
+ var ok bool
+ r.providerData, ok = conversion.ParseProviderData(ctx, req.ProviderData, &resp.Diagnostics)
+ if !ok {
+ return
+ }
+
+ apiClient := postgresflexUtils.ConfigureClient(ctx, &r.providerData, &resp.Diagnostics)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ r.client = apiClient
+ tflog.Info(ctx, "Postgres Flex user client configured")
+}
+
+// Schema defines the schema for the data source.
+func (r *userDataSource) Schema(_ context.Context, _ datasource.SchemaRequest, resp *datasource.SchemaResponse) {
+ descriptions := map[string]string{
+ "main": "Postgres Flex user data source schema. Must have a `region` specified in the provider configuration.",
+ "id": "Terraform's internal data source. ID. It is structured as \"`project_id`,`region`,`instance_id`,`user_id`\".",
+ "user_id": "User ID.",
+ "instance_id": "ID of the PostgresFlex instance.",
+ "project_id": "STACKIT project ID to which the instance is associated.",
+ "region": "The resource region. If not defined, the provider region is used.",
+ }
+
+ resp.Schema = schema.Schema{
+ Description: descriptions["main"],
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Description: descriptions["id"],
+ Computed: true,
+ },
+ "user_id": schema.StringAttribute{
+ Description: descriptions["user_id"],
+ Required: true,
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ "instance_id": schema.StringAttribute{
+ Description: descriptions["instance_id"],
+ Required: true,
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "project_id": schema.StringAttribute{
+ Description: descriptions["project_id"],
+ Required: true,
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "username": schema.StringAttribute{
+ Computed: true,
+ },
+ "roles": schema.SetAttribute{
+ ElementType: types.StringType,
+ Computed: true,
+ },
+ "host": schema.StringAttribute{
+ Computed: true,
+ },
+ "port": schema.Int64Attribute{
+ Computed: true,
+ },
+ "region": schema.StringAttribute{
+ // the region cannot be found automatically, so it has to be passed
+ Optional: true,
+ Description: descriptions["region"],
+ },
+ },
+ }
+}
+
+// Read refreshes the Terraform state with the latest data.
+func (r *userDataSource) Read(ctx context.Context, req datasource.ReadRequest, resp *datasource.ReadResponse) { // nolint:gocritic // function signature required by Terraform
+ var model DataSourceModel
+ diags := req.Config.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ userId := model.UserId.ValueString()
+ region := r.providerData.GetRegionWithOverride(model.Region)
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "user_id", userId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ recordSetResp, err := r.client.GetUser(ctx, projectId, region, instanceId, userId).Execute()
+ if err != nil {
+ utils.LogError(
+ ctx,
+ &resp.Diagnostics,
+ err,
+ "Reading user",
+ fmt.Sprintf("User with ID %q or instance with ID %q does not exist in project %q.", userId, instanceId, projectId),
+ map[int]string{
+ http.StatusForbidden: fmt.Sprintf("Project with ID %q not found or forbidden access", projectId),
+ },
+ )
+ resp.State.RemoveResource(ctx)
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ // Map response body to schema and populate Computed attribute values
+ err = mapDataSourceFields(recordSetResp, &model, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading user", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+
+ // Set refreshed state
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "Postgres Flex user read")
+}
+
+func mapDataSourceFields(userResp *postgresflex.GetUserResponse, model *DataSourceModel, region string) error {
+ if userResp == nil || userResp.Item == nil {
+ return fmt.Errorf("response is nil")
+ }
+ if model == nil {
+ return fmt.Errorf("model input is nil")
+ }
+ user := userResp.Item
+
+ var userId string
+ if model.UserId.ValueString() != "" {
+ userId = model.UserId.ValueString()
+ } else if user.Id != nil {
+ userId = *user.Id
+ } else {
+ return fmt.Errorf("user id not present")
+ }
+ model.Id = utils.BuildInternalTerraformId(
+ model.ProjectId.ValueString(), region, model.InstanceId.ValueString(), userId,
+ )
+ model.UserId = types.StringValue(userId)
+ model.Username = types.StringPointerValue(user.Username)
+
+ if user.Roles == nil {
+ model.Roles = types.SetNull(types.StringType)
+ } else {
+ roles := []attr.Value{}
+ for _, role := range *user.Roles {
+ roles = append(roles, types.StringValue(role))
+ }
+ rolesSet, diags := types.SetValue(types.StringType, roles)
+ if diags.HasError() {
+ return fmt.Errorf("failed to map roles: %w", core.DiagsToError(diags))
+ }
+ model.Roles = rolesSet
+ }
+ model.Host = types.StringPointerValue(user.Host)
+ model.Port = types.Int64PointerValue(user.Port)
+ model.Region = types.StringValue(region)
+ return nil
+}
diff --git a/stackit/internal/services/postgresflexalpha/user/datasource_test.go b/stackit/internal/services/postgresflexalpha/user/datasource_test.go
new file mode 100644
index 00000000..d49ef243
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/user/datasource_test.go
@@ -0,0 +1,146 @@
+// Copyright (c) STACKIT
+
+package postgresflexa
+
+import (
+ "testing"
+
+ "github.com/google/go-cmp/cmp"
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+ "github.com/stackitcloud/stackit-sdk-go/services/postgresflex"
+)
+
+func TestMapDataSourceFields(t *testing.T) {
+ const testRegion = "region"
+ tests := []struct {
+ description string
+ input *postgresflex.GetUserResponse
+ region string
+ expected DataSourceModel
+ isValid bool
+ }{
+ {
+ "default_values",
+ &postgresflex.GetUserResponse{
+ Item: &postgresflex.UserResponse{},
+ },
+ testRegion,
+ DataSourceModel{
+ Id: types.StringValue("pid,region,iid,uid"),
+ UserId: types.StringValue("uid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringNull(),
+ Roles: types.SetNull(types.StringType),
+ Host: types.StringNull(),
+ Port: types.Int64Null(),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "simple_values",
+ &postgresflex.GetUserResponse{
+ Item: &postgresflex.UserResponse{
+ Roles: &[]string{
+ "role_1",
+ "role_2",
+ "",
+ },
+ Username: utils.Ptr("username"),
+ Host: utils.Ptr("host"),
+ Port: utils.Ptr(int64(1234)),
+ },
+ },
+ testRegion,
+ DataSourceModel{
+ Id: types.StringValue("pid,region,iid,uid"),
+ UserId: types.StringValue("uid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringValue("username"),
+ Roles: types.SetValueMust(types.StringType, []attr.Value{
+ types.StringValue("role_1"),
+ types.StringValue("role_2"),
+ types.StringValue(""),
+ }),
+ Host: types.StringValue("host"),
+ Port: types.Int64Value(1234),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "null_fields_and_int_conversions",
+ &postgresflex.GetUserResponse{
+ Item: &postgresflex.UserResponse{
+ Id: utils.Ptr("uid"),
+ Roles: &[]string{},
+ Username: nil,
+ Host: nil,
+ Port: utils.Ptr(int64(2123456789)),
+ },
+ },
+ testRegion,
+ DataSourceModel{
+ Id: types.StringValue("pid,region,iid,uid"),
+ UserId: types.StringValue("uid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringNull(),
+ Roles: types.SetValueMust(types.StringType, []attr.Value{}),
+ Host: types.StringNull(),
+ Port: types.Int64Value(2123456789),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "nil_response",
+ nil,
+ testRegion,
+ DataSourceModel{},
+ false,
+ },
+ {
+ "nil_response_2",
+ &postgresflex.GetUserResponse{},
+ testRegion,
+ DataSourceModel{},
+ false,
+ },
+ {
+ "no_resource_id",
+ &postgresflex.GetUserResponse{
+ Item: &postgresflex.UserResponse{},
+ },
+ testRegion,
+ DataSourceModel{},
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ state := &DataSourceModel{
+ ProjectId: tt.expected.ProjectId,
+ InstanceId: tt.expected.InstanceId,
+ UserId: tt.expected.UserId,
+ }
+ err := mapDataSourceFields(tt.input, state, tt.region)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(state, &tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ })
+ }
+}
diff --git a/stackit/internal/services/postgresflexalpha/user/resource.go b/stackit/internal/services/postgresflexalpha/user/resource.go
new file mode 100644
index 00000000..fbc3035c
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/user/resource.go
@@ -0,0 +1,579 @@
+// Copyright (c) STACKIT
+
+package postgresflexa
+
+import (
+ "context"
+ "fmt"
+ "net/http"
+ "strings"
+
+ postgresflexUtils "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/postgresflex/utils"
+
+ "github.com/hashicorp/terraform-plugin-framework-validators/setvalidator"
+ "github.com/hashicorp/terraform-plugin-framework-validators/stringvalidator"
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/conversion"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/validate"
+
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/path"
+ "github.com/hashicorp/terraform-plugin-framework/resource"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/planmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/stringplanmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/core/oapierror"
+ "github.com/stackitcloud/stackit-sdk-go/services/postgresflex"
+ "github.com/stackitcloud/stackit-sdk-go/services/postgresflex/wait"
+)
+
+// Ensure the implementation satisfies the expected interfaces.
+var (
+ _ resource.Resource = &userResource{}
+ _ resource.ResourceWithConfigure = &userResource{}
+ _ resource.ResourceWithImportState = &userResource{}
+ _ resource.ResourceWithModifyPlan = &userResource{}
+)
+
+type Model struct {
+ Id types.String `tfsdk:"id"` // needed by TF
+ UserId types.String `tfsdk:"user_id"`
+ InstanceId types.String `tfsdk:"instance_id"`
+ ProjectId types.String `tfsdk:"project_id"`
+ Username types.String `tfsdk:"username"`
+ Roles types.Set `tfsdk:"roles"`
+ Password types.String `tfsdk:"password"`
+ Host types.String `tfsdk:"host"`
+ Port types.Int64 `tfsdk:"port"`
+ Uri types.String `tfsdk:"uri"`
+ Region types.String `tfsdk:"region"`
+}
+
+// NewUserResource is a helper function to simplify the provider implementation.
+func NewUserResource() resource.Resource {
+ return &userResource{}
+}
+
+// userResource is the resource implementation.
+type userResource struct {
+ client *postgresflex.APIClient
+ providerData core.ProviderData
+}
+
+// ModifyPlan implements resource.ResourceWithModifyPlan.
+// Use the modifier to set the effective region in the current plan.
+func (r *userResource) ModifyPlan(ctx context.Context, req resource.ModifyPlanRequest, resp *resource.ModifyPlanResponse) { // nolint:gocritic // function signature required by Terraform
+ var configModel Model
+ // skip initial empty configuration to avoid follow-up errors
+ if req.Config.Raw.IsNull() {
+ return
+ }
+ resp.Diagnostics.Append(req.Config.Get(ctx, &configModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ var planModel Model
+ resp.Diagnostics.Append(req.Plan.Get(ctx, &planModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ utils.AdaptRegion(ctx, configModel.Region, &planModel.Region, r.providerData.GetRegion(), resp)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ resp.Diagnostics.Append(resp.Plan.Set(ctx, planModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+}
+
+// Metadata returns the resource type name.
+func (r *userResource) Metadata(_ context.Context, req resource.MetadataRequest, resp *resource.MetadataResponse) {
+ resp.TypeName = req.ProviderTypeName + "_postgresflex_user"
+}
+
+// Configure adds the provider configured client to the resource.
+func (r *userResource) Configure(ctx context.Context, req resource.ConfigureRequest, resp *resource.ConfigureResponse) {
+ var ok bool
+ r.providerData, ok = conversion.ParseProviderData(ctx, req.ProviderData, &resp.Diagnostics)
+ if !ok {
+ return
+ }
+
+ apiClient := postgresflexUtils.ConfigureClient(ctx, &r.providerData, &resp.Diagnostics)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ r.client = apiClient
+ tflog.Info(ctx, "Postgres Flex user client configured")
+}
+
+// Schema defines the schema for the resource.
+func (r *userResource) Schema(_ context.Context, _ resource.SchemaRequest, resp *resource.SchemaResponse) {
+ rolesOptions := []string{"login", "createdb"}
+
+ descriptions := map[string]string{
+ "main": "Postgres Flex user resource schema. Must have a `region` specified in the provider configuration.",
+ "id": "Terraform's internal resource ID. It is structured as \"`project_id`,`region`,`instance_id`,`user_id`\".",
+ "user_id": "User ID.",
+ "instance_id": "ID of the PostgresFlex instance.",
+ "project_id": "STACKIT project ID to which the instance is associated.",
+ "roles": "Database access levels for the user. " + utils.FormatPossibleValues(rolesOptions...),
+ "region": "The resource region. If not defined, the provider region is used.",
+ }
+
+ resp.Schema = schema.Schema{
+ Description: descriptions["main"],
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Description: descriptions["id"],
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "user_id": schema.StringAttribute{
+ Description: descriptions["user_id"],
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ "instance_id": schema.StringAttribute{
+ Description: descriptions["instance_id"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "project_id": schema.StringAttribute{
+ Description: descriptions["project_id"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "username": schema.StringAttribute{
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ },
+ "roles": schema.SetAttribute{
+ Description: descriptions["roles"],
+ ElementType: types.StringType,
+ Required: true,
+ Validators: []validator.Set{
+ setvalidator.ValueStringsAre(
+ stringvalidator.OneOf("login", "createdb"),
+ ),
+ },
+ },
+ "password": schema.StringAttribute{
+ Computed: true,
+ Sensitive: true,
+ },
+ "host": schema.StringAttribute{
+ Computed: true,
+ },
+ "port": schema.Int64Attribute{
+ Computed: true,
+ },
+ "uri": schema.StringAttribute{
+ Computed: true,
+ Sensitive: true,
+ },
+ "region": schema.StringAttribute{
+ Optional: true,
+ // must be computed to allow for storing the override value from the provider
+ Computed: true,
+ Description: descriptions["region"],
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ },
+ },
+ }
+}
+
+// Create creates the resource and sets the initial Terraform state.
+func (r *userResource) Create(ctx context.Context, req resource.CreateRequest, resp *resource.CreateResponse) { // nolint:gocritic // function signature required by Terraform
+ var model Model
+ diags := req.Plan.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ region := model.Region.ValueString()
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ var roles []string
+ if !(model.Roles.IsNull() || model.Roles.IsUnknown()) {
+ diags = model.Roles.ElementsAs(ctx, &roles, false)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ // Generate API request body from model
+ payload, err := toCreatePayload(&model, roles)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating user", fmt.Sprintf("Creating API payload: %v", err))
+ return
+ }
+ // Create new user
+ userResp, err := r.client.CreateUser(ctx, projectId, region, instanceId).CreateUserPayload(*payload).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating user", fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ if userResp == nil || userResp.Item == nil || userResp.Item.Id == nil || *userResp.Item.Id == "" {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating user", "API didn't return user Id. A user might have been created")
+ return
+ }
+ userId := *userResp.Item.Id
+ ctx = tflog.SetField(ctx, "user_id", userId)
+
+ // Map response body to schema
+ err = mapFieldsCreate(userResp, &model, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating user", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+ // Set state to fully populated data
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "Postgres Flex user created")
+}
+
+// Read refreshes the Terraform state with the latest data.
+func (r *userResource) Read(ctx context.Context, req resource.ReadRequest, resp *resource.ReadResponse) { // nolint:gocritic // function signature required by Terraform
+ var model Model
+ diags := req.State.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ userId := model.UserId.ValueString()
+ region := r.providerData.GetRegionWithOverride(model.Region)
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "user_id", userId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ recordSetResp, err := r.client.GetUser(ctx, projectId, region, instanceId, userId).Execute()
+ if err != nil {
+ oapiErr, ok := err.(*oapierror.GenericOpenAPIError) //nolint:errorlint //complaining that error.As should be used to catch wrapped errors, but this error should not be wrapped
+ if ok && oapiErr.StatusCode == http.StatusNotFound {
+ resp.State.RemoveResource(ctx)
+ return
+ }
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading user", fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ // Map response body to schema
+ err = mapFields(recordSetResp, &model, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading user", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+
+ // Set refreshed state
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "Postgres Flex user read")
+}
+
+// Update updates the resource and sets the updated Terraform state on success.
+func (r *userResource) Update(ctx context.Context, req resource.UpdateRequest, resp *resource.UpdateResponse) { // nolint:gocritic // function signature required by Terraform
+ // Retrieve values from plan
+ var model Model
+ diags := req.Plan.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ userId := model.UserId.ValueString()
+ region := model.Region.ValueString()
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "user_id", userId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ // Retrieve values from state
+ var stateModel Model
+ diags = req.State.Get(ctx, &stateModel)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ var roles []string
+ if !(model.Roles.IsNull() || model.Roles.IsUnknown()) {
+ diags = model.Roles.ElementsAs(ctx, &roles, false)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ // Generate API request body from model
+ payload, err := toUpdatePayload(&model, roles)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating user", fmt.Sprintf("Updating API payload: %v", err))
+ return
+ }
+
+ // Update existing instance
+ err = r.client.UpdateUser(ctx, projectId, region, instanceId, userId).UpdateUserPayload(*payload).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating user", err.Error())
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ userResp, err := r.client.GetUser(ctx, projectId, region, instanceId, userId).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating user", fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ // Map response body to schema
+ err = mapFields(userResp, &stateModel, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating user", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+
+ // Set state to fully populated data
+ diags = resp.State.Set(ctx, stateModel)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "Postgres Flex user updated")
+}
+
+// Delete deletes the resource and removes the Terraform state on success.
+func (r *userResource) Delete(ctx context.Context, req resource.DeleteRequest, resp *resource.DeleteResponse) { // nolint:gocritic // function signature required by Terraform
+ // Retrieve values from plan
+ var model Model
+ diags := req.State.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ userId := model.UserId.ValueString()
+ region := model.Region.ValueString()
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "user_id", userId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ // Delete existing record set
+ err := r.client.DeleteUser(ctx, projectId, region, instanceId, userId).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error deleting user", fmt.Sprintf("Calling API: %v", err))
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ _, err = wait.DeleteUserWaitHandler(ctx, r.client, projectId, region, instanceId, userId).WaitWithContext(ctx)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error deleting user", fmt.Sprintf("Instance deletion waiting: %v", err))
+ return
+ }
+ tflog.Info(ctx, "Postgres Flex user deleted")
+}
+
+// ImportState imports a resource into the Terraform state on success.
+// The expected format of the resource import identifier is: project_id,zone_id,record_set_id
+func (r *userResource) ImportState(ctx context.Context, req resource.ImportStateRequest, resp *resource.ImportStateResponse) {
+ idParts := strings.Split(req.ID, core.Separator)
+ if len(idParts) != 4 || idParts[0] == "" || idParts[1] == "" || idParts[2] == "" || idParts[3] == "" {
+ core.LogAndAddError(ctx, &resp.Diagnostics,
+ "Error importing user",
+ fmt.Sprintf("Expected import identifier with format [project_id],[region],[instance_id],[user_id], got %q", req.ID),
+ )
+ return
+ }
+
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("project_id"), idParts[0])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("region"), idParts[1])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("instance_id"), idParts[2])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("user_id"), idParts[3])...)
+ core.LogAndAddWarning(ctx, &resp.Diagnostics,
+ "Postgresflex user imported with empty password and empty uri",
+ "The user password and uri are not imported as they are only available upon creation of a new user. The password and uri fields will be empty.",
+ )
+ tflog.Info(ctx, "Postgresflex user state imported")
+}
+
+func mapFieldsCreate(userResp *postgresflex.CreateUserResponse, model *Model, region string) error {
+ if userResp == nil || userResp.Item == nil {
+ return fmt.Errorf("response is nil")
+ }
+ if model == nil {
+ return fmt.Errorf("model input is nil")
+ }
+ user := userResp.Item
+
+ if user.Id == nil {
+ return fmt.Errorf("user id not present")
+ }
+ userId := *user.Id
+ model.Id = utils.BuildInternalTerraformId(
+ model.ProjectId.ValueString(), region, model.InstanceId.ValueString(), userId,
+ )
+ model.UserId = types.StringValue(userId)
+ model.Username = types.StringPointerValue(user.Username)
+
+ if user.Password == nil {
+ return fmt.Errorf("user password not present")
+ }
+ model.Password = types.StringValue(*user.Password)
+
+ if user.Roles == nil {
+ model.Roles = types.SetNull(types.StringType)
+ } else {
+ roles := []attr.Value{}
+ for _, role := range *user.Roles {
+ roles = append(roles, types.StringValue(role))
+ }
+ rolesSet, diags := types.SetValue(types.StringType, roles)
+ if diags.HasError() {
+ return fmt.Errorf("failed to map roles: %w", core.DiagsToError(diags))
+ }
+ model.Roles = rolesSet
+ }
+ model.Host = types.StringPointerValue(user.Host)
+ model.Port = types.Int64PointerValue(user.Port)
+ model.Uri = types.StringPointerValue(user.Uri)
+ model.Region = types.StringValue(region)
+ return nil
+}
+
+func mapFields(userResp *postgresflex.GetUserResponse, model *Model, region string) error {
+ if userResp == nil || userResp.Item == nil {
+ return fmt.Errorf("response is nil")
+ }
+ if model == nil {
+ return fmt.Errorf("model input is nil")
+ }
+ user := userResp.Item
+
+ var userId string
+ if model.UserId.ValueString() != "" {
+ userId = model.UserId.ValueString()
+ } else if user.Id != nil {
+ userId = *user.Id
+ } else {
+ return fmt.Errorf("user id not present")
+ }
+ model.Id = utils.BuildInternalTerraformId(
+ model.ProjectId.ValueString(), region, model.InstanceId.ValueString(), userId,
+ )
+ model.UserId = types.StringValue(userId)
+ model.Username = types.StringPointerValue(user.Username)
+
+ if user.Roles == nil {
+ model.Roles = types.SetNull(types.StringType)
+ } else {
+ roles := []attr.Value{}
+ for _, role := range *user.Roles {
+ roles = append(roles, types.StringValue(role))
+ }
+ rolesSet, diags := types.SetValue(types.StringType, roles)
+ if diags.HasError() {
+ return fmt.Errorf("failed to map roles: %w", core.DiagsToError(diags))
+ }
+ model.Roles = rolesSet
+ }
+ model.Host = types.StringPointerValue(user.Host)
+ model.Port = types.Int64PointerValue(user.Port)
+ model.Region = types.StringValue(region)
+ return nil
+}
+
+func toCreatePayload(model *Model, roles []string) (*postgresflex.CreateUserPayload, error) {
+ if model == nil {
+ return nil, fmt.Errorf("nil model")
+ }
+ if roles == nil {
+ return nil, fmt.Errorf("nil roles")
+ }
+
+ return &postgresflex.CreateUserPayload{
+ Roles: &roles,
+ Username: conversion.StringValueToPointer(model.Username),
+ }, nil
+}
+
+func toUpdatePayload(model *Model, roles []string) (*postgresflex.UpdateUserPayload, error) {
+ if model == nil {
+ return nil, fmt.Errorf("nil model")
+ }
+ if roles == nil {
+ return nil, fmt.Errorf("nil roles")
+ }
+
+ return &postgresflex.UpdateUserPayload{
+ Roles: &roles,
+ }, nil
+}
diff --git a/stackit/internal/services/postgresflexalpha/user/resource_test.go b/stackit/internal/services/postgresflexalpha/user/resource_test.go
new file mode 100644
index 00000000..6dbe2e18
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/user/resource_test.go
@@ -0,0 +1,472 @@
+// Copyright (c) STACKIT
+
+package postgresflexa
+
+import (
+ "testing"
+
+ "github.com/google/go-cmp/cmp"
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+ "github.com/stackitcloud/stackit-sdk-go/services/postgresflex"
+)
+
+func TestMapFieldsCreate(t *testing.T) {
+ const testRegion = "region"
+ tests := []struct {
+ description string
+ input *postgresflex.CreateUserResponse
+ region string
+ expected Model
+ isValid bool
+ }{
+ {
+ "default_values",
+ &postgresflex.CreateUserResponse{
+ Item: &postgresflex.User{
+ Id: utils.Ptr("uid"),
+ Password: utils.Ptr(""),
+ },
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,uid"),
+ UserId: types.StringValue("uid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringNull(),
+ Roles: types.SetNull(types.StringType),
+ Password: types.StringValue(""),
+ Host: types.StringNull(),
+ Port: types.Int64Null(),
+ Uri: types.StringNull(),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "simple_values",
+ &postgresflex.CreateUserResponse{
+ Item: &postgresflex.User{
+ Id: utils.Ptr("uid"),
+ Roles: &[]string{
+ "role_1",
+ "role_2",
+ "",
+ },
+ Username: utils.Ptr("username"),
+ Password: utils.Ptr("password"),
+ Host: utils.Ptr("host"),
+ Port: utils.Ptr(int64(1234)),
+ Uri: utils.Ptr("uri"),
+ },
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,uid"),
+ UserId: types.StringValue("uid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringValue("username"),
+ Roles: types.SetValueMust(types.StringType, []attr.Value{
+ types.StringValue("role_1"),
+ types.StringValue("role_2"),
+ types.StringValue(""),
+ }),
+ Password: types.StringValue("password"),
+ Host: types.StringValue("host"),
+ Port: types.Int64Value(1234),
+ Uri: types.StringValue("uri"),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "null_fields_and_int_conversions",
+ &postgresflex.CreateUserResponse{
+ Item: &postgresflex.User{
+ Id: utils.Ptr("uid"),
+ Roles: &[]string{},
+ Username: nil,
+ Password: utils.Ptr(""),
+ Host: nil,
+ Port: utils.Ptr(int64(2123456789)),
+ Uri: nil,
+ },
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,uid"),
+ UserId: types.StringValue("uid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringNull(),
+ Roles: types.SetValueMust(types.StringType, []attr.Value{}),
+ Password: types.StringValue(""),
+ Host: types.StringNull(),
+ Port: types.Int64Value(2123456789),
+ Uri: types.StringNull(),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "nil_response",
+ nil,
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "nil_response_2",
+ &postgresflex.CreateUserResponse{},
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "no_resource_id",
+ &postgresflex.CreateUserResponse{
+ Item: &postgresflex.User{},
+ },
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "no_password",
+ &postgresflex.CreateUserResponse{
+ Item: &postgresflex.User{
+ Id: utils.Ptr("uid"),
+ },
+ },
+ testRegion,
+ Model{},
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ state := &Model{
+ ProjectId: tt.expected.ProjectId,
+ InstanceId: tt.expected.InstanceId,
+ }
+ err := mapFieldsCreate(tt.input, state, tt.region)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(state, &tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ })
+ }
+}
+
+func TestMapFields(t *testing.T) {
+ const testRegion = "region"
+ tests := []struct {
+ description string
+ input *postgresflex.GetUserResponse
+ region string
+ expected Model
+ isValid bool
+ }{
+ {
+ "default_values",
+ &postgresflex.GetUserResponse{
+ Item: &postgresflex.UserResponse{},
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,uid"),
+ UserId: types.StringValue("uid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringNull(),
+ Roles: types.SetNull(types.StringType),
+ Host: types.StringNull(),
+ Port: types.Int64Null(),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "simple_values",
+ &postgresflex.GetUserResponse{
+ Item: &postgresflex.UserResponse{
+ Roles: &[]string{
+ "role_1",
+ "role_2",
+ "",
+ },
+ Username: utils.Ptr("username"),
+ Host: utils.Ptr("host"),
+ Port: utils.Ptr(int64(1234)),
+ },
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,uid"),
+ UserId: types.StringValue("uid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringValue("username"),
+ Roles: types.SetValueMust(types.StringType, []attr.Value{
+ types.StringValue("role_1"),
+ types.StringValue("role_2"),
+ types.StringValue(""),
+ }),
+ Host: types.StringValue("host"),
+ Port: types.Int64Value(1234),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "null_fields_and_int_conversions",
+ &postgresflex.GetUserResponse{
+ Item: &postgresflex.UserResponse{
+ Id: utils.Ptr("uid"),
+ Roles: &[]string{},
+ Username: nil,
+ Host: nil,
+ Port: utils.Ptr(int64(2123456789)),
+ },
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,uid"),
+ UserId: types.StringValue("uid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringNull(),
+ Roles: types.SetValueMust(types.StringType, []attr.Value{}),
+ Host: types.StringNull(),
+ Port: types.Int64Value(2123456789),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "nil_response",
+ nil,
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "nil_response_2",
+ &postgresflex.GetUserResponse{},
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "no_resource_id",
+ &postgresflex.GetUserResponse{
+ Item: &postgresflex.UserResponse{},
+ },
+ testRegion,
+ Model{},
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ state := &Model{
+ ProjectId: tt.expected.ProjectId,
+ InstanceId: tt.expected.InstanceId,
+ UserId: tt.expected.UserId,
+ }
+ err := mapFields(tt.input, state, tt.region)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(state, &tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ })
+ }
+}
+
+func TestToCreatePayload(t *testing.T) {
+ tests := []struct {
+ description string
+ input *Model
+ inputRoles []string
+ expected *postgresflex.CreateUserPayload
+ isValid bool
+ }{
+ {
+ "default_values",
+ &Model{},
+ []string{},
+ &postgresflex.CreateUserPayload{
+ Roles: &[]string{},
+ Username: nil,
+ },
+ true,
+ },
+ {
+ "default_values",
+ &Model{
+ Username: types.StringValue("username"),
+ },
+ []string{
+ "role_1",
+ "role_2",
+ },
+ &postgresflex.CreateUserPayload{
+ Roles: &[]string{
+ "role_1",
+ "role_2",
+ },
+ Username: utils.Ptr("username"),
+ },
+ true,
+ },
+ {
+ "null_fields_and_int_conversions",
+ &Model{
+ Username: types.StringNull(),
+ },
+ []string{
+ "",
+ },
+ &postgresflex.CreateUserPayload{
+ Roles: &[]string{
+ "",
+ },
+ Username: nil,
+ },
+ true,
+ },
+ {
+ "nil_model",
+ nil,
+ []string{},
+ nil,
+ false,
+ },
+ {
+ "nil_roles",
+ &Model{},
+ nil,
+ nil,
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ output, err := toCreatePayload(tt.input, tt.inputRoles)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(output, tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ })
+ }
+}
+
+func TestToUpdatePayload(t *testing.T) {
+ tests := []struct {
+ description string
+ input *Model
+ inputRoles []string
+ expected *postgresflex.UpdateUserPayload
+ isValid bool
+ }{
+ {
+ "default_values",
+ &Model{},
+ []string{},
+ &postgresflex.UpdateUserPayload{
+ Roles: &[]string{},
+ },
+ true,
+ },
+ {
+ "default_values",
+ &Model{
+ Username: types.StringValue("username"),
+ },
+ []string{
+ "role_1",
+ "role_2",
+ },
+ &postgresflex.UpdateUserPayload{
+ Roles: &[]string{
+ "role_1",
+ "role_2",
+ },
+ },
+ true,
+ },
+ {
+ "null_fields_and_int_conversions",
+ &Model{
+ Username: types.StringNull(),
+ },
+ []string{
+ "",
+ },
+ &postgresflex.UpdateUserPayload{
+ Roles: &[]string{
+ "",
+ },
+ },
+ true,
+ },
+ {
+ "nil_model",
+ nil,
+ []string{},
+ nil,
+ false,
+ },
+ {
+ "nil_roles",
+ &Model{},
+ nil,
+ nil,
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ output, err := toUpdatePayload(tt.input, tt.inputRoles)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(output, tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ })
+ }
+}
diff --git a/stackit/internal/services/postgresflexalpha/utils/util.go b/stackit/internal/services/postgresflexalpha/utils/util.go
new file mode 100644
index 00000000..e15548fa
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/utils/util.go
@@ -0,0 +1,34 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "context"
+ "fmt"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+ postgresflex "github.com/stackitcloud/terraform-provider-stackit/pkg/postgresflexalpha"
+
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+)
+
+func ConfigureClient(ctx context.Context, providerData *core.ProviderData, diags *diag.Diagnostics) *postgresflex.APIClient {
+ apiClientConfigOptions := []config.ConfigurationOption{
+ config.WithCustomAuth(providerData.RoundTripper),
+ utils.UserAgentConfigOption(providerData.Version),
+ }
+ if providerData.PostgresFlexCustomEndpoint != "" {
+ apiClientConfigOptions = append(apiClientConfigOptions, config.WithEndpoint(providerData.PostgresFlexCustomEndpoint))
+ } else {
+ apiClientConfigOptions = append(apiClientConfigOptions, config.WithRegion(providerData.GetRegion()))
+ }
+ apiClient, err := postgresflex.NewAPIClient(apiClientConfigOptions...)
+ if err != nil {
+ core.LogAndAddError(ctx, diags, "Error configuring API client", fmt.Sprintf("Configuring client: %v. This is an error related to the provider configuration, not to the resource configuration", err))
+ return nil
+ }
+
+ return apiClient
+}
diff --git a/stackit/internal/services/postgresflexalpha/utils/util_test.go b/stackit/internal/services/postgresflexalpha/utils/util_test.go
new file mode 100644
index 00000000..a5f17e37
--- /dev/null
+++ b/stackit/internal/services/postgresflexalpha/utils/util_test.go
@@ -0,0 +1,96 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "context"
+ "os"
+ "reflect"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ sdkClients "github.com/stackitcloud/stackit-sdk-go/core/clients"
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+ "github.com/stackitcloud/stackit-sdk-go/services/postgresflex"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+)
+
+const (
+ testVersion = "1.2.3"
+ testCustomEndpoint = "https://postgresflex-custom-endpoint.api.stackit.cloud"
+)
+
+func TestConfigureClient(t *testing.T) {
+ /* mock authentication by setting service account token env variable */
+ os.Clearenv()
+ err := os.Setenv(sdkClients.ServiceAccountToken, "mock-val")
+ if err != nil {
+ t.Errorf("error setting env variable: %v", err)
+ }
+
+ type args struct {
+ providerData *core.ProviderData
+ }
+ tests := []struct {
+ name string
+ args args
+ wantErr bool
+ expected *postgresflex.APIClient
+ }{
+ {
+ name: "default endpoint",
+ args: args{
+ providerData: &core.ProviderData{
+ Version: testVersion,
+ },
+ },
+ expected: func() *postgresflex.APIClient {
+ apiClient, err := postgresflex.NewAPIClient(
+ config.WithRegion("eu01"),
+ utils.UserAgentConfigOption(testVersion),
+ )
+ if err != nil {
+ t.Errorf("error configuring client: %v", err)
+ }
+ return apiClient
+ }(),
+ wantErr: false,
+ },
+ {
+ name: "custom endpoint",
+ args: args{
+ providerData: &core.ProviderData{
+ Version: testVersion,
+ PostgresFlexCustomEndpoint: testCustomEndpoint,
+ },
+ },
+ expected: func() *postgresflex.APIClient {
+ apiClient, err := postgresflex.NewAPIClient(
+ utils.UserAgentConfigOption(testVersion),
+ config.WithEndpoint(testCustomEndpoint),
+ )
+ if err != nil {
+ t.Errorf("error configuring client: %v", err)
+ }
+ return apiClient
+ }(),
+ wantErr: false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ ctx := context.Background()
+ diags := diag.Diagnostics{}
+
+ actual := ConfigureClient(ctx, tt.args.providerData, &diags)
+ if diags.HasError() != tt.wantErr {
+ t.Errorf("ConfigureClient() error = %v, want %v", diags.HasError(), tt.wantErr)
+ }
+
+ if !reflect.DeepEqual(actual, tt.expected) {
+ t.Errorf("ConfigureClient() = %v, want %v", actual, tt.expected)
+ }
+ })
+ }
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/instance/datasource.go b/stackit/internal/services/sqlserverflexalpha/instance/datasource.go
new file mode 100644
index 00000000..6cac7466
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/instance/datasource.go
@@ -0,0 +1,295 @@
+package sqlserverflex
+
+import (
+ "context"
+ "fmt"
+ "net/http"
+
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/conversion"
+ sqlserverflexUtils "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/sqlserverflexalpha/utils"
+
+ sqlserverflex "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+
+ "github.com/hashicorp/terraform-plugin-framework/datasource"
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/validate"
+
+ "github.com/hashicorp/terraform-plugin-framework/datasource/schema"
+)
+
+// Ensure the implementation satisfies the expected interfaces.
+var (
+ _ datasource.DataSource = &instanceDataSource{}
+)
+
+// NewInstanceDataSource is a helper function to simplify the provider implementation.
+func NewInstanceDataSource() datasource.DataSource {
+ return &instanceDataSource{}
+}
+
+// instanceDataSource is the data source implementation.
+type instanceDataSource struct {
+ client *sqlserverflex.APIClient
+ providerData core.ProviderData
+}
+
+// Metadata returns the data source type name.
+func (r *instanceDataSource) Metadata(_ context.Context, req datasource.MetadataRequest, resp *datasource.MetadataResponse) {
+ resp.TypeName = req.ProviderTypeName + "_sqlserverflexalpha_instance"
+}
+
+// Configure adds the provider configured client to the data source.
+func (r *instanceDataSource) Configure(ctx context.Context, req datasource.ConfigureRequest, resp *datasource.ConfigureResponse) {
+ var ok bool
+ r.providerData, ok = conversion.ParseProviderData(ctx, req.ProviderData, &resp.Diagnostics)
+ if !ok {
+ return
+ }
+
+ apiClient := sqlserverflexUtils.ConfigureClient(ctx, &r.providerData, &resp.Diagnostics)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ r.client = apiClient
+ tflog.Info(ctx, "SQLServer Flex instance client configured")
+}
+
+// Schema defines the schema for the data source.
+func (r *instanceDataSource) Schema(_ context.Context, _ datasource.SchemaRequest, resp *datasource.SchemaResponse) {
+ descriptions := map[string]string{
+ "main": "SQLServer Flex instance data source schema. Must have a `region` specified in the provider configuration.",
+ "id": "Terraform's internal data source. ID. It is structured as \"`project_id`,`region`,`instance_id`\".",
+ "instance_id": "ID of the SQLServer Flex instance.",
+ "project_id": "STACKIT project ID to which the instance is associated.",
+ "name": "Instance name.",
+ "acl": "The Access Control List (ACL) for the SQLServer Flex instance.",
+ "backup_schedule": `The backup schedule. Should follow the cron scheduling system format (e.g. "0 0 * * *").`,
+ "options": "Custom parameters for the SQLServer Flex instance.",
+ "region": "The resource region. If not defined, the provider region is used.",
+ // TODO
+ }
+
+ resp.Schema = schema.Schema{
+ Description: descriptions["main"],
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Description: descriptions["id"],
+ Computed: true,
+ },
+ "instance_id": schema.StringAttribute{
+ Description: descriptions["instance_id"],
+ Required: true,
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "project_id": schema.StringAttribute{
+ Description: descriptions["project_id"],
+ Required: true,
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "name": schema.StringAttribute{
+ Description: descriptions["name"],
+ Computed: true,
+ },
+ "backup_schedule": schema.StringAttribute{
+ Description: descriptions["backup_schedule"],
+ Computed: true,
+ },
+ "flavor": schema.SingleNestedAttribute{
+ Computed: true,
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Computed: true,
+ },
+ "description": schema.StringAttribute{
+ Computed: true,
+ },
+ "cpu": schema.Int64Attribute{
+ Computed: true,
+ },
+ "ram": schema.Int64Attribute{
+ Computed: true,
+ },
+ },
+ },
+ "replicas": schema.Int64Attribute{
+ Computed: true,
+ },
+ "storage": schema.SingleNestedAttribute{
+ Computed: true,
+ Attributes: map[string]schema.Attribute{
+ "class": schema.StringAttribute{
+ Computed: true,
+ },
+ "size": schema.Int64Attribute{
+ Computed: true,
+ },
+ },
+ },
+ "version": schema.StringAttribute{
+ Computed: true,
+ },
+ "status": schema.StringAttribute{
+ Computed: true,
+ },
+ "edition": schema.StringAttribute{
+ Computed: true,
+ },
+ "retention_days": schema.Int64Attribute{
+ Computed: true,
+ },
+ "region": schema.StringAttribute{
+ // the region cannot be found, so it has to be passed
+ Optional: true,
+ Description: descriptions["region"],
+ },
+ "encryption": schema.SingleNestedAttribute{
+ Computed: true,
+ Attributes: map[string]schema.Attribute{
+ "key_id": schema.StringAttribute{
+ Description: descriptions["key_id"],
+ Computed: true,
+ },
+ "key_version": schema.StringAttribute{
+ Description: descriptions["key_version"],
+ Computed: true,
+ },
+ "keyring_id": schema.StringAttribute{
+ Description: descriptions["keyring_id"],
+ Computed: true,
+ },
+ "service_account": schema.StringAttribute{
+ Description: descriptions["service_account"],
+ Computed: true,
+ },
+ },
+ Description: descriptions["encryption"],
+ },
+ "network": schema.SingleNestedAttribute{
+ Computed: true,
+ Attributes: map[string]schema.Attribute{
+ "access_scope": schema.StringAttribute{
+ Description: descriptions["access_scope"],
+ Computed: true,
+ },
+ "instance_address": schema.StringAttribute{
+ Description: descriptions["instance_address"],
+ Computed: true,
+ },
+ "router_address": schema.StringAttribute{
+ Description: descriptions["router_address"],
+ Computed: true,
+ },
+ "acl": schema.ListAttribute{
+ Description: descriptions["acl"],
+ ElementType: types.StringType,
+ Computed: true,
+ },
+ },
+ Description: descriptions["network"],
+ },
+ },
+ }
+}
+
+// Read refreshes the Terraform state with the latest data.
+func (r *instanceDataSource) Read(ctx context.Context, req datasource.ReadRequest, resp *datasource.ReadResponse) { // nolint:gocritic // function signature required by Terraform
+ var model Model
+ diags := req.Config.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ region := r.providerData.GetRegionWithOverride(model.Region)
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "region", region)
+ instanceResp, err := r.client.GetInstanceRequest(ctx, projectId, region, instanceId).Execute()
+ if err != nil {
+ utils.LogError(
+ ctx,
+ &resp.Diagnostics,
+ err,
+ "Reading instance",
+ fmt.Sprintf("Instance with ID %q does not exist in project %q.", instanceId, projectId),
+ map[int]string{
+ http.StatusForbidden: fmt.Sprintf("Project with ID %q not found or forbidden access", projectId),
+ },
+ )
+ resp.State.RemoveResource(ctx)
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ var flavor = &flavorModel{}
+ if model.Flavor.IsNull() || model.Flavor.IsUnknown() {
+ flavor.Id = types.StringValue(*instanceResp.FlavorId)
+ if flavor.Id.IsNull() || flavor.Id.IsUnknown() || flavor.Id.String() == "" {
+ panic("WTF FlavorId can not be null or empty string")
+ }
+ err = getFlavorModelById(ctx, r.client, &model, flavor)
+ if err != nil {
+ resp.Diagnostics.AddError(err.Error(), err.Error())
+ return
+ }
+ if flavor.CPU.IsNull() || flavor.CPU.IsUnknown() || flavor.CPU.String() == "" {
+ panic("WTF FlavorId can not be null or empty string")
+ }
+ }
+
+ var storage = &storageModel{}
+ if !(model.Storage.IsNull() || model.Storage.IsUnknown()) {
+ diags = model.Storage.As(ctx, storage, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ var encryption = &encryptionModel{}
+ if !(model.Encryption.IsNull() || model.Encryption.IsUnknown()) {
+ diags = model.Encryption.As(ctx, encryption, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ var network = &networkModel{}
+ if !(model.Network.IsNull() || model.Network.IsUnknown()) {
+ diags = model.Network.As(ctx, network, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ err = mapFields(ctx, instanceResp, &model, flavor, storage, encryption, network, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading instance", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+ // Set refreshed state
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "SQLServer Flex instance read")
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/instance/functions.go b/stackit/internal/services/sqlserverflexalpha/instance/functions.go
new file mode 100644
index 00000000..5675a2d9
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/instance/functions.go
@@ -0,0 +1,430 @@
+package sqlserverflex
+
+import (
+ "context"
+ "fmt"
+ "strings"
+
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+ sqlserverflex "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/conversion"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+)
+
+type sqlserverflexClient interface {
+ GetFlavorsRequestExecute(ctx context.Context, projectId, region string, page, size *int64, sort sqlserverflex.FlavorSort) (*sqlserverflex.GetFlavorsResponse, error)
+}
+
+func mapFields(ctx context.Context, resp *sqlserverflex.GetInstanceResponse, model *Model, flavor *flavorModel, storage *storageModel, encryption *encryptionModel, network *networkModel, region string) error {
+ if resp == nil {
+ return fmt.Errorf("response input is nil")
+ }
+ if model == nil {
+ return fmt.Errorf("model input is nil")
+ }
+ instance := resp
+
+ var instanceId string
+ if model.InstanceId.ValueString() != "" {
+ instanceId = model.InstanceId.ValueString()
+ } else if instance.Id != nil {
+ instanceId = *instance.Id
+ } else {
+ return fmt.Errorf("instance id not present")
+ }
+
+ var flavorValues map[string]attr.Value
+ if instance.FlavorId == nil {
+ return fmt.Errorf("instance has no flavor id")
+ }
+ if *instance.FlavorId != flavor.Id.ValueString() {
+ return fmt.Errorf("instance has different flavor id %s - %s", *instance.FlavorId, flavor.Id.ValueString())
+ }
+
+ flavorValues = map[string]attr.Value{
+ "id": flavor.Id,
+ "description": flavor.Description,
+ "cpu": flavor.CPU,
+ "ram": flavor.RAM,
+ "node_type": flavor.NodeType,
+ }
+ flavorObject, diags := types.ObjectValue(flavorTypes, flavorValues)
+ if diags.HasError() {
+ return fmt.Errorf("creating flavor: %w", core.DiagsToError(diags))
+ }
+
+ var storageValues map[string]attr.Value
+ if instance.Storage == nil {
+ storageValues = map[string]attr.Value{
+ "class": storage.Class,
+ "size": storage.Size,
+ }
+ } else {
+ storageValues = map[string]attr.Value{
+ "class": types.StringValue(*instance.Storage.Class),
+ "size": types.Int64PointerValue(instance.Storage.Size),
+ }
+ }
+ storageObject, diags := types.ObjectValue(storageTypes, storageValues)
+ if diags.HasError() {
+ return fmt.Errorf("creating storage: %w", core.DiagsToError(diags))
+ }
+
+ var encryptionValues map[string]attr.Value
+ if instance.Encryption == nil {
+ encryptionValues = map[string]attr.Value{
+ "keyring_id": encryption.KeyRingId,
+ "key_id": encryption.KeyId,
+ "key_version": encryption.KeyVersion,
+ "service_account": encryption.ServiceAccount,
+ }
+ } else {
+ encryptionValues = map[string]attr.Value{
+ "keyring_id": types.StringValue(*instance.Encryption.KekKeyRingId),
+ "key_id": types.StringValue(*instance.Encryption.KekKeyId),
+ "key_version": types.StringValue(*instance.Encryption.KekKeyVersion),
+ "service_account": types.StringValue(*instance.Encryption.ServiceAccount),
+ }
+ }
+ encryptionObject, diags := types.ObjectValue(encryptionTypes, encryptionValues)
+ if diags.HasError() {
+ return fmt.Errorf("creating encryption: %w", core.DiagsToError(diags))
+ }
+
+ var networkValues map[string]attr.Value
+ if instance.Network == nil {
+ networkValues = map[string]attr.Value{
+ "acl": network.ACL,
+ "access_scope": network.AccessScope,
+ "instance_address": network.InstanceAddress,
+ "router_address": network.RouterAddress,
+ }
+ } else {
+ aclList, diags := types.ListValueFrom(ctx, types.StringType, *instance.Network.Acl)
+ if diags.HasError() {
+ return fmt.Errorf("creating network (acl list): %w", core.DiagsToError(diags))
+ }
+
+ var routerAddress string
+ if instance.Network.RouterAddress != nil {
+ routerAddress = *instance.Network.RouterAddress
+ diags.AddWarning("field missing while mapping fields", "router_address was empty in API response")
+ }
+ if instance.Network.InstanceAddress == nil {
+ return fmt.Errorf("creating network: no instance address returned")
+ }
+ networkValues = map[string]attr.Value{
+ "acl": aclList,
+ "access_scope": types.StringValue(string(*instance.Network.AccessScope)),
+ "instance_address": types.StringValue(*instance.Network.InstanceAddress),
+ "router_address": types.StringValue(routerAddress),
+ }
+ }
+ networkObject, diags := types.ObjectValue(networkTypes, networkValues)
+ if diags.HasError() {
+ return fmt.Errorf("creating network: %w", core.DiagsToError(diags))
+ }
+
+ simplifiedModelBackupSchedule := utils.SimplifyBackupSchedule(model.BackupSchedule.ValueString())
+ // If the value returned by the API is different from the one in the model after simplification,
+ // we update the model so that it causes an error in Terraform
+ if simplifiedModelBackupSchedule != types.StringPointerValue(instance.BackupSchedule).ValueString() {
+ model.BackupSchedule = types.StringPointerValue(instance.BackupSchedule)
+ }
+
+ if instance.Replicas == nil {
+ return fmt.Errorf("instance has no replicas set")
+ }
+
+ if instance.RetentionDays == nil {
+ return fmt.Errorf("instance has no retention days set")
+ }
+
+ if instance.Version == nil {
+ return fmt.Errorf("instance has no version set")
+ }
+
+ if instance.Edition == nil {
+ return fmt.Errorf("instance has no edition set")
+ }
+
+ if instance.Status == nil {
+ return fmt.Errorf("instance has no status set")
+ }
+
+ if instance.IsDeletable == nil {
+ return fmt.Errorf("instance has no IsDeletable set")
+ }
+
+ model.Id = utils.BuildInternalTerraformId(model.ProjectId.ValueString(), region, instanceId)
+ model.InstanceId = types.StringValue(instanceId)
+ model.Name = types.StringPointerValue(instance.Name)
+ model.Flavor = flavorObject
+ model.Replicas = types.Int64Value(int64(*instance.Replicas))
+ model.Storage = storageObject
+ model.Version = types.StringValue(string(*instance.Version))
+ model.Edition = types.StringValue(string(*instance.Edition))
+ model.Region = types.StringValue(region)
+ model.Encryption = encryptionObject
+ model.Network = networkObject
+ model.RetentionDays = types.Int64Value(*instance.RetentionDays)
+ model.Status = types.StringValue(string(*instance.Status))
+ model.IsDeletable = types.BoolValue(*instance.IsDeletable)
+ return nil
+}
+
+func toCreatePayload(model *Model, storage *storageModel, encryption *encryptionModel, network *networkModel) (*sqlserverflex.CreateInstanceRequestPayload, error) {
+ if model == nil {
+ return nil, fmt.Errorf("nil model")
+ }
+
+ if model.Flavor.IsNull() || model.Flavor.IsUnknown() {
+ return nil, fmt.Errorf("nil flavor")
+ }
+
+ storagePayload := &sqlserverflex.CreateInstanceRequestPayloadGetStorageArgType{}
+ if storage != nil {
+ storagePayload.Class = conversion.StringValueToPointer(storage.Class)
+ storagePayload.Size = conversion.Int64ValueToPointer(storage.Size)
+ }
+
+ encryptionPayload := &sqlserverflex.CreateInstanceRequestPayloadGetEncryptionArgType{}
+ if encryption != nil {
+ encryptionPayload.KekKeyId = conversion.StringValueToPointer(encryption.KeyId)
+ encryptionPayload.KekKeyVersion = conversion.StringValueToPointer(encryption.KeyVersion)
+ encryptionPayload.KekKeyRingId = conversion.StringValueToPointer(encryption.KeyRingId)
+ encryptionPayload.ServiceAccount = conversion.StringValueToPointer(encryption.ServiceAccount)
+ }
+
+ networkPayload := &sqlserverflex.CreateInstanceRequestPayloadGetNetworkArgType{}
+ if network != nil {
+ networkPayload.AccessScope = sqlserverflex.CreateInstanceRequestPayloadNetworkGetAccessScopeAttributeType(conversion.StringValueToPointer(network.AccessScope))
+ }
+
+ flavorId := ""
+ if !(model.Flavor.IsNull() || model.Flavor.IsUnknown()) {
+ modelValues := model.Flavor.Attributes()
+ if _, ok := modelValues["id"]; !ok {
+ return nil, fmt.Errorf("flavor has not yet been created")
+ }
+ flavorId = strings.Trim(modelValues["id"].String(), "\"")
+ }
+
+ var aclElements []string
+ if network != nil && !(network.ACL.IsNull() || network.ACL.IsUnknown()) {
+ aclElements = make([]string, 0, len(network.ACL.Elements()))
+ diags := network.ACL.ElementsAs(nil, &aclElements, false)
+ if diags.HasError() {
+ return nil, fmt.Errorf("creating network: %w", core.DiagsToError(diags))
+ }
+ }
+
+ return &sqlserverflex.CreateInstanceRequestPayload{
+ Acl: &aclElements,
+ BackupSchedule: conversion.StringValueToPointer(model.BackupSchedule),
+ FlavorId: &flavorId,
+ Name: conversion.StringValueToPointer(model.Name),
+ Storage: storagePayload,
+ Version: sqlserverflex.CreateInstanceRequestPayloadGetVersionAttributeType(conversion.StringValueToPointer(model.Version)),
+ Encryption: encryptionPayload,
+ RetentionDays: conversion.Int64ValueToPointer(model.RetentionDays),
+ Network: networkPayload,
+ }, nil
+}
+
+func toUpdatePayload(model *Model, storage *storageModel, network *networkModel) (*sqlserverflex.UpdateInstancePartiallyRequestPayload, error) {
+ if model == nil {
+ return nil, fmt.Errorf("nil model")
+ }
+ if model.Flavor.IsNull() || model.Flavor.IsUnknown() {
+ return nil, fmt.Errorf("nil flavor")
+ }
+ var flavorMdl flavorModel
+ diag := model.Flavor.As(context.Background(), &flavorMdl, basetypes.ObjectAsOptions{
+ UnhandledNullAsEmpty: true,
+ UnhandledUnknownAsEmpty: false,
+ })
+ if diag.HasError() {
+ return nil, fmt.Errorf("flavor conversion error: %v", diag.Errors())
+ }
+
+ storagePayload := &sqlserverflex.UpdateInstanceRequestPayloadGetStorageArgType{}
+ if storage != nil {
+ storagePayload.Size = conversion.Int64ValueToPointer(storage.Size)
+ }
+
+ var aclElements []string
+ if network != nil && !(network.ACL.IsNull() || network.ACL.IsUnknown()) {
+ aclElements = make([]string, 0, len(network.ACL.Elements()))
+ diags := network.ACL.ElementsAs(nil, &aclElements, false)
+ if diags.HasError() {
+ return nil, fmt.Errorf("creating network: %w", core.DiagsToError(diags))
+ }
+ }
+
+ // TODO - implement network.ACL as soon as it becomes available
+ replCount := int32(model.Replicas.ValueInt64())
+ flavorId := flavorMdl.Id.ValueString()
+ return &sqlserverflex.UpdateInstancePartiallyRequestPayload{
+ Acl: &aclElements,
+ BackupSchedule: conversion.StringValueToPointer(model.BackupSchedule),
+ FlavorId: &flavorId,
+ Name: conversion.StringValueToPointer(model.Name),
+ Replicas: sqlserverflex.UpdateInstancePartiallyRequestPayloadGetReplicasAttributeType(&replCount),
+ RetentionDays: conversion.Int64ValueToPointer(model.RetentionDays),
+ Storage: storagePayload,
+ Version: sqlserverflex.UpdateInstancePartiallyRequestPayloadGetVersionAttributeType(conversion.StringValueToPointer(model.Version)),
+ }, nil
+}
+
+func getAllFlavors(ctx context.Context, client sqlserverflexClient, projectId, region string) ([]sqlserverflex.ListFlavors, error) {
+ if projectId == "" || region == "" {
+ return nil, fmt.Errorf("listing sqlserverflex flavors: projectId and region are required")
+ }
+ var flavorList []sqlserverflex.ListFlavors
+
+ page := int64(1)
+ size := int64(10)
+ for {
+ res, err := client.GetFlavorsRequestExecute(ctx, projectId, region, &page, &size, sqlserverflex.FLAVORSORT_INDEX_ASC)
+ if err != nil {
+ return nil, fmt.Errorf("listing sqlserverflex flavors: %w", err)
+ }
+ if res.Flavors == nil {
+ return nil, fmt.Errorf("finding flavors for project %s", projectId)
+ }
+ pagination := res.GetPagination()
+ flavorList = append(flavorList, *res.Flavors...)
+
+ if *pagination.TotalRows == int64(len(flavorList)) {
+ break
+ }
+ page++
+ }
+ return flavorList, nil
+}
+
+func loadFlavorId(ctx context.Context, client sqlserverflexClient, model *Model, flavor *flavorModel, storage *storageModel) error {
+ if model == nil {
+ return fmt.Errorf("nil model")
+ }
+ if flavor == nil {
+ return fmt.Errorf("nil flavor")
+ }
+ cpu := conversion.Int64ValueToPointer(flavor.CPU)
+ if cpu == nil {
+ return fmt.Errorf("nil CPU")
+ }
+ ram := conversion.Int64ValueToPointer(flavor.RAM)
+ if ram == nil {
+ return fmt.Errorf("nil RAM")
+ }
+ nodeType := conversion.StringValueToPointer(flavor.NodeType)
+ if nodeType == nil {
+ return fmt.Errorf("nil NodeType")
+ }
+ storageClass := conversion.StringValueToPointer(storage.Class)
+ if storageClass == nil {
+ return fmt.Errorf("nil StorageClass")
+ }
+ storageSize := conversion.Int64ValueToPointer(storage.Size)
+ if storageSize == nil {
+ return fmt.Errorf("nil StorageSize")
+ }
+
+ projectId := model.ProjectId.ValueString()
+ region := model.Region.ValueString()
+
+ flavorList, err := getAllFlavors(ctx, client, projectId, region)
+ if err != nil {
+ return err
+ }
+
+ avl := ""
+ foundFlavorCount := 0
+ for _, f := range flavorList {
+ if f.Id == nil || f.Cpu == nil || f.Memory == nil {
+ continue
+ }
+ if strings.ToLower(*f.NodeType) != strings.ToLower(*nodeType) {
+ continue
+ }
+ if *f.Cpu == *cpu && *f.Memory == *ram {
+ var useSc *sqlserverflex.FlavorStorageClassesStorageClass
+ for _, sc := range *f.StorageClasses {
+ if *sc.Class != *storageClass {
+ continue
+ }
+ if *storageSize < *f.MinGB || *storageSize > *f.MaxGB {
+ return fmt.Errorf("storage size %d out of bounds (min: %d - max: %d)", *storageSize, *f.MinGB, *f.MaxGB)
+ }
+ useSc = &sc
+ }
+ if useSc == nil {
+ return fmt.Errorf("no storage class found for %s", *storageClass)
+ }
+
+ flavor.Id = types.StringValue(*f.Id)
+ flavor.Description = types.StringValue(*f.Description)
+ foundFlavorCount++
+ }
+ for _, cls := range *f.StorageClasses {
+ avl = fmt.Sprintf("%s\n- %d CPU, %d GB RAM, storage %s (min: %d - max: %d)", avl, *f.Cpu, *f.Memory, *cls.Class, *f.MinGB, *f.MaxGB)
+ }
+ }
+ if foundFlavorCount > 1 {
+ return fmt.Errorf("multiple flavors found: %d flavors", foundFlavorCount)
+ }
+ if flavor.Id.ValueString() == "" {
+ return fmt.Errorf("couldn't find flavor, available specs are:%s", avl)
+ }
+
+ return nil
+}
+
+func getFlavorModelById(ctx context.Context, client sqlserverflexClient, model *Model, flavor *flavorModel) error {
+ if model == nil {
+ return fmt.Errorf("nil model")
+ }
+ if flavor == nil {
+ return fmt.Errorf("nil flavor")
+ }
+ id := conversion.StringValueToPointer(flavor.Id)
+ if id == nil {
+ return fmt.Errorf("nil flavor ID")
+ }
+
+ flavor.Id = types.StringValue("")
+
+ projectId := model.ProjectId.ValueString()
+ region := model.Region.ValueString()
+
+ flavorList, err := getAllFlavors(ctx, client, projectId, region)
+ if err != nil {
+ return err
+ }
+
+ avl := ""
+ for _, f := range flavorList {
+ if f.Id == nil || f.Cpu == nil || f.Memory == nil {
+ continue
+ }
+ if *f.Id == *id {
+ flavor.Id = types.StringValue(*f.Id)
+ flavor.Description = types.StringValue(*f.Description)
+ flavor.CPU = types.Int64Value(*f.Cpu)
+ flavor.RAM = types.Int64Value(*f.Memory)
+ flavor.NodeType = types.StringValue(*f.NodeType)
+ break
+ }
+ avl = fmt.Sprintf("%s\n- %d CPU, %d GB RAM", avl, *f.Cpu, *f.Memory)
+ }
+ if flavor.Id.ValueString() == "" {
+ return fmt.Errorf("couldn't find flavor, available specs are: %s", avl)
+ }
+
+ return nil
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/instance/resource.go b/stackit/internal/services/sqlserverflexalpha/instance/resource.go
new file mode 100644
index 00000000..a57c3480
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/instance/resource.go
@@ -0,0 +1,916 @@
+package sqlserverflex
+
+import (
+ "context"
+ "fmt"
+ "net/http"
+ "regexp"
+ "strings"
+ "time"
+
+ "github.com/hashicorp/terraform-plugin-framework-validators/int64validator"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/boolplanmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/listplanmodifier"
+ sqlserverflexUtils "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/sqlserverflexalpha/utils"
+
+ "github.com/hashicorp/terraform-plugin-framework-validators/stringvalidator"
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/path"
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/conversion"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/validate"
+
+ "github.com/hashicorp/terraform-plugin-framework/resource"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/int64planmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/objectplanmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/planmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/stringplanmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/core/oapierror"
+ sqlserverflex "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+ "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha/wait"
+)
+
+// Ensure the implementation satisfies the expected interfaces.
+var (
+ _ resource.Resource = &instanceResource{}
+ _ resource.ResourceWithConfigure = &instanceResource{}
+ _ resource.ResourceWithImportState = &instanceResource{}
+ _ resource.ResourceWithModifyPlan = &instanceResource{}
+)
+
+var validNodeTypes []string = []string{
+ "Single",
+ "Replica",
+}
+
+type Model struct {
+ Id types.String `tfsdk:"id"` // needed by TF
+ InstanceId types.String `tfsdk:"instance_id"`
+ ProjectId types.String `tfsdk:"project_id"`
+ Name types.String `tfsdk:"name"`
+ BackupSchedule types.String `tfsdk:"backup_schedule"`
+ Flavor types.Object `tfsdk:"flavor"`
+ Encryption types.Object `tfsdk:"encryption"`
+ IsDeletable types.Bool `tfsdk:"is_deletable"`
+ Storage types.Object `tfsdk:"storage"`
+ Status types.String `tfsdk:"status"`
+ Version types.String `tfsdk:"version"`
+ Replicas types.Int64 `tfsdk:"replicas"`
+ Region types.String `tfsdk:"region"`
+ Network types.Object `tfsdk:"network"`
+ Edition types.String `tfsdk:"edition"`
+ RetentionDays types.Int64 `tfsdk:"retention_days"`
+}
+
+type encryptionModel struct {
+ KeyRingId types.String `tfsdk:"keyring_id"`
+ KeyId types.String `tfsdk:"key_id"`
+ KeyVersion types.String `tfsdk:"key_version"`
+ ServiceAccount types.String `tfsdk:"service_account"`
+}
+
+var encryptionTypes = map[string]attr.Type{
+ "keyring_id": basetypes.StringType{},
+ "key_id": basetypes.StringType{},
+ "key_version": basetypes.StringType{},
+ "service_account": basetypes.StringType{},
+}
+
+type networkModel struct {
+ ACL types.List `tfsdk:"acl"`
+ AccessScope types.String `tfsdk:"access_scope"`
+ InstanceAddress types.String `tfsdk:"instance_address"`
+ RouterAddress types.String `tfsdk:"router_address"`
+}
+
+var networkTypes = map[string]attr.Type{
+ "acl": basetypes.ListType{ElemType: types.StringType},
+ "access_scope": basetypes.StringType{},
+ "instance_address": basetypes.StringType{},
+ "router_address": basetypes.StringType{},
+}
+
+// Struct corresponding to Model.FlavorId
+type flavorModel struct {
+ Id types.String `tfsdk:"id"`
+ Description types.String `tfsdk:"description"`
+ CPU types.Int64 `tfsdk:"cpu"`
+ RAM types.Int64 `tfsdk:"ram"`
+ NodeType types.String `tfsdk:"node_type"`
+}
+
+// Types corresponding to flavorModel
+var flavorTypes = map[string]attr.Type{
+ "id": basetypes.StringType{},
+ "description": basetypes.StringType{},
+ "cpu": basetypes.Int64Type{},
+ "ram": basetypes.Int64Type{},
+ "node_type": basetypes.StringType{},
+}
+
+// Struct corresponding to Model.Storage
+type storageModel struct {
+ Class types.String `tfsdk:"class"`
+ Size types.Int64 `tfsdk:"size"`
+}
+
+// Types corresponding to storageModel
+var storageTypes = map[string]attr.Type{
+ "class": basetypes.StringType{},
+ "size": basetypes.Int64Type{},
+}
+
+// NewInstanceResource is a helper function to simplify the provider implementation.
+func NewInstanceResource() resource.Resource {
+ return &instanceResource{}
+}
+
+// instanceResource is the resource implementation.
+type instanceResource struct {
+ client *sqlserverflex.APIClient
+ providerData core.ProviderData
+}
+
+// Metadata returns the resource type name.
+func (r *instanceResource) Metadata(_ context.Context, req resource.MetadataRequest, resp *resource.MetadataResponse) {
+ resp.TypeName = req.ProviderTypeName + "_sqlserverflexalpha_instance"
+}
+
+// Configure adds the provider configured client to the resource.
+func (r *instanceResource) Configure(ctx context.Context, req resource.ConfigureRequest, resp *resource.ConfigureResponse) {
+ var ok bool
+ r.providerData, ok = conversion.ParseProviderData(ctx, req.ProviderData, &resp.Diagnostics)
+ if !ok {
+ return
+ }
+
+ apiClient := sqlserverflexUtils.ConfigureClient(ctx, &r.providerData, &resp.Diagnostics)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ r.client = apiClient
+ tflog.Info(ctx, "SQLServer Flex instance client configured")
+}
+
+// ModifyPlan implements resource.ResourceWithModifyPlan.
+// Use the modifier to set the effective region in the current plan.
+func (r *instanceResource) ModifyPlan(ctx context.Context, req resource.ModifyPlanRequest, resp *resource.ModifyPlanResponse) { // nolint:gocritic // function signature required by Terraform
+ var configModel Model
+ // skip initial empty configuration to avoid follow-up errors
+ if req.Config.Raw.IsNull() {
+ return
+ }
+ resp.Diagnostics.Append(req.Config.Get(ctx, &configModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ var planModel Model
+ resp.Diagnostics.Append(req.Plan.Get(ctx, &planModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ utils.AdaptRegion(ctx, configModel.Region, &planModel.Region, r.providerData.GetRegion(), resp)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ resp.Diagnostics.Append(resp.Plan.Set(ctx, planModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+}
+
+// Schema defines the schema for the resource.
+func (r *instanceResource) Schema(_ context.Context, _ resource.SchemaRequest, resp *resource.SchemaResponse) {
+ descriptions := map[string]string{
+ "main": "SQLServer Flex ALPHA instance resource schema. Must have a `region` specified in the provider configuration.",
+ "id": "Terraform's internal resource ID. It is structured as \"`project_id`,`region`,`instance_id`\".",
+ "instance_id": "ID of the SQLServer Flex instance.",
+ "project_id": "STACKIT project ID to which the instance is associated.",
+ "name": "Instance name.",
+ "access_scope": "The access scope of the instance. (e.g. SNA)",
+ "acl": "The Access Control List (ACL) for the SQLServer Flex instance.",
+ "backup_schedule": `The backup schedule. Should follow the cron scheduling system format (e.g. "0 0 * * *")`,
+ "region": "The resource region. If not defined, the provider region is used.",
+ "encryption": "The encryption block.",
+ "network": "The network block.",
+ "keyring_id": "STACKIT KMS - KeyRing ID of the encryption key to use.",
+ "key_id": "STACKIT KMS - Key ID of the encryption key to use.",
+ "key_version": "STACKIT KMS - Key version to use in the encryption key.",
+ "service:account": "STACKIT KMS - service account to use in the encryption key.",
+ "instance_address": "The returned instance IP address of the SQLServer Flex instance.",
+ "router_address": "The returned router IP address of the SQLServer Flex instance.",
+ }
+
+ resp.Schema = schema.Schema{
+ Description: descriptions["main"],
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Description: descriptions["id"],
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "instance_id": schema.StringAttribute{
+ Description: descriptions["instance_id"],
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "project_id": schema.StringAttribute{
+ Description: descriptions["project_id"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "name": schema.StringAttribute{
+ Description: descriptions["name"],
+ Required: true,
+ Validators: []validator.String{
+ stringvalidator.LengthAtLeast(1),
+ stringvalidator.RegexMatches(
+ regexp.MustCompile("^[a-z]([-a-z0-9]*[a-z0-9])?$"),
+ "must start with a letter, must have lower case letters, numbers or hyphens, and no hyphen at the end",
+ ),
+ },
+ },
+ "backup_schedule": schema.StringAttribute{
+ Description: descriptions["backup_schedule"],
+ Optional: true,
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "is_deletable": schema.BoolAttribute{
+ Description: descriptions["is_deletable"],
+ Optional: true,
+ Computed: true,
+ PlanModifiers: []planmodifier.Bool{
+ boolplanmodifier.UseStateForUnknown(),
+ },
+ },
+ // TODO - make it either flavor_id or ram, cpu and node_type
+ "flavor": schema.SingleNestedAttribute{
+ PlanModifiers: []planmodifier.Object{
+ objectplanmodifier.RequiresReplace(),
+ objectplanmodifier.UseStateForUnknown(),
+ },
+ Required: true,
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Optional: true,
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "description": schema.StringAttribute{
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "node_type": schema.StringAttribute{
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ stringvalidator.ConflictsWith([]path.Expression{
+ path.MatchRelative().AtParent().AtName("id"),
+ }...),
+ stringvalidator.OneOfCaseInsensitive(validNodeTypes...),
+ stringvalidator.AlsoRequires([]path.Expression{
+ path.MatchRelative().AtParent().AtName("cpu"),
+ path.MatchRelative().AtParent().AtName("ram"),
+ }...),
+ },
+ },
+ "cpu": schema.Int64Attribute{
+ Required: true,
+ PlanModifiers: []planmodifier.Int64{
+ int64planmodifier.RequiresReplace(),
+ int64planmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.Int64{
+ int64validator.ConflictsWith([]path.Expression{
+ path.MatchRelative().AtParent().AtName("id"),
+ }...),
+ int64validator.AlsoRequires([]path.Expression{
+ path.MatchRelative().AtParent().AtName("node_type"),
+ path.MatchRelative().AtParent().AtName("ram"),
+ }...),
+ },
+ },
+ "ram": schema.Int64Attribute{
+ Required: true,
+ PlanModifiers: []planmodifier.Int64{
+ int64planmodifier.RequiresReplace(),
+ int64planmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.Int64{
+ int64validator.ConflictsWith([]path.Expression{
+ path.MatchRelative().AtParent().AtName("id"),
+ }...),
+ int64validator.AlsoRequires([]path.Expression{
+ path.MatchRelative().AtParent().AtName("node_type"),
+ path.MatchRelative().AtParent().AtName("cpu"),
+ }...),
+ },
+ },
+ },
+ },
+ "replicas": schema.Int64Attribute{
+ Computed: true,
+ PlanModifiers: []planmodifier.Int64{
+ int64planmodifier.UseStateForUnknown(),
+ },
+ },
+ "storage": schema.SingleNestedAttribute{
+ Optional: true,
+ Computed: true,
+ PlanModifiers: []planmodifier.Object{
+ objectplanmodifier.UseStateForUnknown(),
+ },
+ Attributes: map[string]schema.Attribute{
+ "class": schema.StringAttribute{
+ Optional: true,
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "size": schema.Int64Attribute{
+ Optional: true,
+ Computed: true,
+ PlanModifiers: []planmodifier.Int64{
+ int64planmodifier.UseStateForUnknown(),
+ },
+ },
+ },
+ },
+ "version": schema.StringAttribute{
+ Optional: true,
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "edition": schema.StringAttribute{
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "retention_days": schema.Int64Attribute{
+ Optional: true,
+ Computed: true,
+ PlanModifiers: []planmodifier.Int64{
+ int64planmodifier.UseStateForUnknown(),
+ },
+ },
+ "region": schema.StringAttribute{
+ Optional: true,
+ // must be computed to allow for storing the override value from the provider
+ Computed: true,
+ Description: descriptions["region"],
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ },
+ "status": schema.StringAttribute{
+ Optional: true,
+ // must be computed to allow for storing the override value from the provider
+ Computed: true,
+ Description: descriptions["status"],
+ },
+ "encryption": schema.SingleNestedAttribute{
+ Required: true,
+ PlanModifiers: []planmodifier.Object{
+ objectplanmodifier.RequiresReplace(),
+ objectplanmodifier.UseStateForUnknown(),
+ },
+ Attributes: map[string]schema.Attribute{
+ "key_id": schema.StringAttribute{
+ Description: descriptions["key_id"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ "key_version": schema.StringAttribute{
+ Description: descriptions["key_version"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ "keyring_id": schema.StringAttribute{
+ Description: descriptions["key_ring_id"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ "service_account": schema.StringAttribute{
+ Description: descriptions["service_account"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ },
+ Description: descriptions["encryption"],
+ },
+ "network": schema.SingleNestedAttribute{
+ Required: true,
+ Attributes: map[string]schema.Attribute{
+ "access_scope": schema.StringAttribute{
+ Description: descriptions["access_scope"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ "acl": schema.ListAttribute{
+ Description: descriptions["acl"],
+ ElementType: types.StringType,
+ Required: true,
+ PlanModifiers: []planmodifier.List{
+ listplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "instance_address": schema.StringAttribute{
+ Description: descriptions["instance_address"],
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "router_address": schema.StringAttribute{
+ Description: descriptions["router_address"],
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ },
+ Description: descriptions["network"],
+ },
+ },
+ }
+}
+
+// Create creates the resource and sets the initial Terraform state.
+func (r *instanceResource) Create(ctx context.Context, req resource.CreateRequest, resp *resource.CreateResponse) { // nolint:gocritic // function signature required by Terraform
+ // Retrieve values from plan
+ var model Model
+ diags := req.Plan.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ region := model.Region.ValueString()
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ var storage = &storageModel{}
+ if !(model.Storage.IsNull() || model.Storage.IsUnknown()) {
+ diags = model.Storage.As(ctx, storage, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ var encryption = &encryptionModel{}
+ if !(model.Encryption.IsNull() || model.Encryption.IsUnknown()) {
+ diags = model.Encryption.As(ctx, encryption, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ var network = &networkModel{}
+ if !(model.Network.IsNull() || model.Network.IsUnknown()) {
+ diags = model.Network.As(ctx, network, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ flavor := &flavorModel{}
+ if !(model.Flavor.IsNull() || model.Flavor.IsUnknown()) {
+ diags = model.Flavor.As(ctx, flavor, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ if flavor.Id.IsNull() || flavor.Id.IsUnknown() {
+ err := loadFlavorId(ctx, r.client, &model, flavor, storage)
+ if err != nil {
+ resp.Diagnostics.AddError(err.Error(), err.Error())
+ return
+ }
+ flavorValues := map[string]attr.Value{
+ "id": flavor.Id,
+ "description": flavor.Description,
+ "cpu": flavor.CPU,
+ "ram": flavor.RAM,
+ "node_type": flavor.NodeType,
+ }
+ var flavorObject basetypes.ObjectValue
+ flavorObject, diags = types.ObjectValue(flavorTypes, flavorValues)
+ resp.Diagnostics.Append(diags...)
+ if diags.HasError() {
+ return
+ }
+ model.Flavor = flavorObject
+ }
+
+ // Generate API request body from model
+ payload, err := toCreatePayload(&model, storage, encryption, network)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating instance", fmt.Sprintf("Creating API payload: %v", err))
+ return
+ }
+ // Create new instance
+ createResp, err := r.client.CreateInstanceRequest(ctx, projectId, region).CreateInstanceRequestPayload(*payload).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating instance", fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ instanceId := *createResp.Id
+ utils.SetAndLogStateFields(ctx, &resp.Diagnostics, &resp.State, map[string]any{
+ "instance_id": instanceId,
+ })
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ // The creation waiter sometimes returns an error from the API: "instance with id xxx has unexpected status Failure"
+ // which can be avoided by sleeping before wait
+ waitResp, err := wait.CreateInstanceWaitHandler(ctx, r.client, projectId, instanceId, region).SetSleepBeforeWait(30 * time.Second).WaitWithContext(ctx)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating instance", fmt.Sprintf("Instance creation waiting: %v", err))
+ return
+ }
+
+ if waitResp.FlavorId == nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating instance", "Instance creation waiting: returned flavor id is nil")
+ return
+ }
+
+ if *waitResp.FlavorId != flavor.Id.ValueString() {
+ core.LogAndAddError(
+ ctx,
+ &resp.Diagnostics,
+ "Error creating instance",
+ fmt.Sprintf("Instance creation waiting: returned flavor id differs (expected: %s, current: %s)", flavor.Id.ValueString(), *waitResp.FlavorId),
+ )
+ return
+ }
+
+ if flavor.CPU.IsNull() || flavor.CPU.IsUnknown() {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating instance", "Instance creation waiting: flavor cpu is null or unknown")
+ }
+ if flavor.RAM.IsNull() || flavor.RAM.IsUnknown() {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating instance", "Instance creation waiting: flavor ram is null or unknown")
+ }
+ // flavorData := getFlavorModelById(ctx, r.client, &model, flavor)
+
+ // Map response body to schema
+ err = mapFields(ctx, waitResp, &model, flavor, storage, encryption, network, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating instance", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+ // Set state to fully populated data
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ // After the instance creation, database might not be ready to accept connections immediately.
+ // That is why we add a sleep
+ // TODO - can get removed?
+ time.Sleep(120 * time.Second)
+
+ tflog.Info(ctx, "SQLServer Flex instance created")
+}
+
+// Read refreshes the Terraform state with the latest data.
+func (r *instanceResource) Read(ctx context.Context, req resource.ReadRequest, resp *resource.ReadResponse) { // nolint:gocritic // function signature required by Terraform
+ var model Model
+ diags := req.State.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ region := r.providerData.GetRegionWithOverride(model.Region)
+
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ var flavor = &flavorModel{}
+ if !(model.Flavor.IsNull() || model.Flavor.IsUnknown()) {
+ diags = model.Flavor.As(ctx, flavor, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ err := getFlavorModelById(ctx, r.client, &model, flavor)
+ if err != nil {
+ resp.Diagnostics.AddError(err.Error(), err.Error())
+ return
+ }
+
+ diags = model.Flavor.As(ctx, flavor, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ var storage = &storageModel{}
+ if !(model.Storage.IsNull() || model.Storage.IsUnknown()) {
+ diags = model.Storage.As(ctx, storage, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ var encryption = &encryptionModel{}
+ if !(model.Encryption.IsNull() || model.Encryption.IsUnknown()) {
+ diags = model.Encryption.As(ctx, encryption, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ var network = &networkModel{}
+ if !(model.Network.IsNull() || model.Network.IsUnknown()) {
+ diags = model.Network.As(ctx, network, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ instanceResp, err := r.client.GetInstanceRequest(ctx, projectId, region, instanceId).Execute()
+ if err != nil {
+ oapiErr, ok := err.(*oapierror.GenericOpenAPIError) //nolint:errorlint //complaining that error.As should be used to catch wrapped errors, but this error should not be wrapped
+ if ok && oapiErr.StatusCode == http.StatusNotFound {
+ resp.State.RemoveResource(ctx)
+ return
+ }
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading instance", err.Error())
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ // Map response body to schema
+ err = mapFields(ctx, instanceResp, &model, flavor, storage, encryption, network, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading instance", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+ // Set refreshed state
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "SQLServer Flex instance read")
+}
+
+// Update updates the resource and sets the updated Terraform state on success.
+func (r *instanceResource) Update(ctx context.Context, req resource.UpdateRequest, resp *resource.UpdateResponse) { // nolint:gocritic // function signature required by Terraform
+ // Retrieve values from plan
+ var model Model
+ diags := req.Plan.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ region := model.Region.ValueString()
+
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ var storage = &storageModel{}
+ if !(model.Storage.IsNull() || model.Storage.IsUnknown()) {
+ diags = model.Storage.As(ctx, storage, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ var encryption = &encryptionModel{}
+ if !(model.Encryption.IsNull() || model.Encryption.IsUnknown()) {
+ diags = model.Encryption.As(ctx, encryption, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ var network = &networkModel{}
+ if !(model.Network.IsNull() || model.Network.IsUnknown()) {
+ diags = model.Network.As(ctx, network, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ flavor := &flavorModel{}
+ if !(model.Flavor.IsNull() || model.Flavor.IsUnknown()) {
+ diags = model.Flavor.As(ctx, flavor, basetypes.ObjectAsOptions{})
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ if flavor.Id.IsNull() || flavor.Id.IsUnknown() {
+ err := loadFlavorId(ctx, r.client, &model, flavor, storage)
+ if err != nil {
+ resp.Diagnostics.AddError(err.Error(), err.Error())
+ return
+ }
+ flavorValues := map[string]attr.Value{
+ "id": flavor.Id,
+ "description": flavor.Description,
+ "cpu": flavor.CPU,
+ "ram": flavor.RAM,
+ "node_type": flavor.NodeType,
+ }
+ var flavorObject basetypes.ObjectValue
+ flavorObject, diags = types.ObjectValue(flavorTypes, flavorValues)
+ resp.Diagnostics.Append(diags...)
+ if diags.HasError() {
+ return
+ }
+ model.Flavor = flavorObject
+ }
+
+ // Generate API request body from model
+ payload, err := toUpdatePayload(&model, storage, network)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating instance", fmt.Sprintf("Creating API payload: %v", err))
+ return
+ }
+ // Update existing instance
+ err = r.client.UpdateInstancePartiallyRequest(ctx, projectId, region, instanceId).UpdateInstancePartiallyRequestPayload(*payload).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating instance", err.Error())
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ waitResp, err := wait.UpdateInstanceWaitHandler(ctx, r.client, projectId, instanceId, region).WaitWithContext(ctx)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating instance", fmt.Sprintf("Instance update waiting: %v", err))
+ return
+ }
+
+ // Map response body to schema
+ err = mapFields(ctx, waitResp, &model, flavor, storage, encryption, network, region)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating instance", fmt.Sprintf("Processing API payload: %v", err))
+ return
+ }
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "SQLServer Flex instance updated")
+}
+
+// Delete deletes the resource and removes the Terraform state on success.
+func (r *instanceResource) Delete(ctx context.Context, req resource.DeleteRequest, resp *resource.DeleteResponse) { // nolint:gocritic // function signature required by Terraform
+ // Retrieve values from state
+ var model Model
+ diags := req.State.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ region := model.Region.ValueString()
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ // Delete existing instance
+ err := r.client.DeleteInstanceRequest(ctx, projectId, region, instanceId).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error deleting instance", fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ _, err = wait.DeleteInstanceWaitHandler(ctx, r.client, projectId, instanceId, region).WaitWithContext(ctx)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error deleting instance", fmt.Sprintf("Instance deletion waiting: %v", err))
+ return
+ }
+ tflog.Info(ctx, "SQLServer Flex instance deleted")
+}
+
+// ImportState imports a resource into the Terraform state on success.
+// The expected format of the resource import identifier is: project_id,instance_id
+func (r *instanceResource) ImportState(ctx context.Context, req resource.ImportStateRequest, resp *resource.ImportStateResponse) {
+ idParts := strings.Split(req.ID, core.Separator)
+
+ if len(idParts) != 3 || idParts[0] == "" || idParts[1] == "" || idParts[2] == "" {
+ core.LogAndAddError(ctx, &resp.Diagnostics,
+ "Error importing instance",
+ fmt.Sprintf("Expected import identifier with format: [project_id],[region],[instance_id] Got: %q", req.ID),
+ )
+ return
+ }
+
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("project_id"), idParts[0])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("region"), idParts[1])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("instance_id"), idParts[2])...)
+ tflog.Info(ctx, "SQLServer Flex instance state imported")
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/instance/resource_msh_test.go.bak b/stackit/internal/services/sqlserverflexalpha/instance/resource_msh_test.go.bak
new file mode 100644
index 00000000..2ad6eb7d
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/instance/resource_msh_test.go.bak
@@ -0,0 +1,282 @@
+// Copyright (c) STACKIT
+
+package sqlserverflex
+
+import (
+ "context"
+ "reflect"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-framework/resource"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+
+ sqlserverflex "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+)
+
+func TestNewInstanceResource(t *testing.T) {
+ tests := []struct {
+ name string
+ want resource.Resource
+ }{
+ // TODO: Add test cases.
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ if got := NewInstanceResource(); !reflect.DeepEqual(got, tt.want) {
+ t.Errorf("NewInstanceResource() = %v, want %v", got, tt.want)
+ }
+ })
+ }
+}
+
+func Test_instanceResource_Configure(t *testing.T) {
+ type fields struct {
+ client *sqlserverflex.APIClient
+ providerData core.ProviderData
+ }
+ type args struct {
+ ctx context.Context
+ req resource.ConfigureRequest
+ resp *resource.ConfigureResponse
+ }
+ tests := []struct {
+ name string
+ fields fields
+ args args
+ }{
+ // TODO: Add test cases.
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ r := &instanceResource{
+ client: tt.fields.client,
+ providerData: tt.fields.providerData,
+ }
+ r.Configure(tt.args.ctx, tt.args.req, tt.args.resp)
+ })
+ }
+}
+
+func Test_instanceResource_Create(t *testing.T) {
+ type fields struct {
+ client *sqlserverflex.APIClient
+ providerData core.ProviderData
+ }
+ type args struct {
+ ctx context.Context
+ req resource.CreateRequest
+ resp *resource.CreateResponse
+ }
+ tests := []struct {
+ name string
+ fields fields
+ args args
+ }{
+ // TODO: Add test cases.
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ r := &instanceResource{
+ client: tt.fields.client,
+ providerData: tt.fields.providerData,
+ }
+ r.Create(tt.args.ctx, tt.args.req, tt.args.resp)
+ })
+ }
+}
+
+func Test_instanceResource_Delete(t *testing.T) {
+ type fields struct {
+ client *sqlserverflex.APIClient
+ providerData core.ProviderData
+ }
+ type args struct {
+ ctx context.Context
+ req resource.DeleteRequest
+ resp *resource.DeleteResponse
+ }
+ tests := []struct {
+ name string
+ fields fields
+ args args
+ }{
+ // TODO: Add test cases.
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ r := &instanceResource{
+ client: tt.fields.client,
+ providerData: tt.fields.providerData,
+ }
+ r.Delete(tt.args.ctx, tt.args.req, tt.args.resp)
+ })
+ }
+}
+
+func Test_instanceResource_ImportState(t *testing.T) {
+ type fields struct {
+ client *sqlserverflex.APIClient
+ providerData core.ProviderData
+ }
+ type args struct {
+ ctx context.Context
+ req resource.ImportStateRequest
+ resp *resource.ImportStateResponse
+ }
+ tests := []struct {
+ name string
+ fields fields
+ args args
+ }{
+ // TODO: Add test cases.
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ r := &instanceResource{
+ client: tt.fields.client,
+ providerData: tt.fields.providerData,
+ }
+ r.ImportState(tt.args.ctx, tt.args.req, tt.args.resp)
+ })
+ }
+}
+
+func Test_instanceResource_Metadata(t *testing.T) {
+ type fields struct {
+ client *sqlserverflex.APIClient
+ providerData core.ProviderData
+ }
+ type args struct {
+ in0 context.Context
+ req resource.MetadataRequest
+ resp *resource.MetadataResponse
+ }
+ tests := []struct {
+ name string
+ fields fields
+ args args
+ }{
+ // TODO: Add test cases.
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ r := &instanceResource{
+ client: tt.fields.client,
+ providerData: tt.fields.providerData,
+ }
+ r.Metadata(tt.args.in0, tt.args.req, tt.args.resp)
+ })
+ }
+}
+
+func Test_instanceResource_ModifyPlan(t *testing.T) {
+ type fields struct {
+ client *sqlserverflex.APIClient
+ providerData core.ProviderData
+ }
+ type args struct {
+ ctx context.Context
+ req resource.ModifyPlanRequest
+ resp *resource.ModifyPlanResponse
+ }
+ tests := []struct {
+ name string
+ fields fields
+ args args
+ }{
+ // TODO: Add test cases.
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ r := &instanceResource{
+ client: tt.fields.client,
+ providerData: tt.fields.providerData,
+ }
+ r.ModifyPlan(tt.args.ctx, tt.args.req, tt.args.resp)
+ })
+ }
+}
+
+func Test_instanceResource_Read(t *testing.T) {
+ type fields struct {
+ client *sqlserverflex.APIClient
+ providerData core.ProviderData
+ }
+ type args struct {
+ ctx context.Context
+ req resource.ReadRequest
+ resp *resource.ReadResponse
+ }
+ tests := []struct {
+ name string
+ fields fields
+ args args
+ }{
+ // TODO: Add test cases.
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ r := &instanceResource{
+ client: tt.fields.client,
+ providerData: tt.fields.providerData,
+ }
+ r.Read(tt.args.ctx, tt.args.req, tt.args.resp)
+ })
+ }
+}
+
+func Test_instanceResource_Schema(t *testing.T) {
+ type fields struct {
+ client *sqlserverflex.APIClient
+ providerData core.ProviderData
+ }
+ type args struct {
+ in0 context.Context
+ in1 resource.SchemaRequest
+ resp *resource.SchemaResponse
+ }
+ tests := []struct {
+ name string
+ fields fields
+ args args
+ }{
+ // TODO: Add test cases.
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ r := &instanceResource{
+ client: tt.fields.client,
+ providerData: tt.fields.providerData,
+ }
+ r.Schema(tt.args.in0, tt.args.in1, tt.args.resp)
+ })
+ }
+}
+
+func Test_instanceResource_Update(t *testing.T) {
+ type fields struct {
+ client *sqlserverflex.APIClient
+ providerData core.ProviderData
+ }
+ type args struct {
+ ctx context.Context
+ req resource.UpdateRequest
+ resp *resource.UpdateResponse
+ }
+ tests := []struct {
+ name string
+ fields fields
+ args args
+ }{
+ // TODO: Add test cases.
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ r := &instanceResource{
+ client: tt.fields.client,
+ providerData: tt.fields.providerData,
+ }
+ r.Update(tt.args.ctx, tt.args.req, tt.args.resp)
+ })
+ }
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/instance/resource_test.go b/stackit/internal/services/sqlserverflexalpha/instance/resource_test.go
new file mode 100644
index 00000000..601af2fa
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/instance/resource_test.go
@@ -0,0 +1,862 @@
+package sqlserverflex
+
+import (
+ "context"
+ "fmt"
+ "testing"
+
+ "github.com/google/go-cmp/cmp"
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+ sqlserverflex "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+)
+
+type sqlserverflexClientMocked struct {
+ returnError bool
+ listFlavorsResp *sqlserverflex.GetFlavorsResponse
+}
+
+func (c *sqlserverflexClientMocked) GetFlavorsExecute(_ context.Context, _, _ string) (*sqlserverflex.GetFlavorsResponse, error) {
+ if c.returnError {
+ return nil, fmt.Errorf("get flavors failed")
+ }
+
+ return c.listFlavorsResp, nil
+}
+
+func TestMapFields(t *testing.T) {
+ const testRegion = "region"
+ tests := []struct {
+ description string
+ state Model
+ input *sqlserverflex.GetInstanceResponse
+ flavor *flavorModel
+ storage *storageModel
+ encryption *encryptionModel
+ network *networkModel
+ region string
+ expected Model
+ isValid bool
+ }{
+ {
+ "default_values",
+ Model{
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Replicas: types.Int64Value(1),
+ RetentionDays: types.Int64Value(1),
+ Version: types.StringValue("v1"),
+ Edition: types.StringValue("edition 1"),
+ Status: types.StringValue("status"),
+ IsDeletable: types.BoolValue(true),
+ Flavor: types.ObjectValueMust(flavorTypes, map[string]attr.Value{
+ "id": types.StringValue("flavor_id"),
+ "description": types.StringNull(),
+ "cpu": types.Int64Null(),
+ "ram": types.Int64Null(),
+ "node_type": types.StringNull(),
+ }),
+ },
+ &sqlserverflex.GetInstanceResponse{
+ FlavorId: utils.Ptr("flavor_id"),
+ Replicas: sqlserverflex.GetInstanceResponseGetReplicasAttributeType(utils.Ptr(int32(1))),
+ RetentionDays: utils.Ptr(int64(1)),
+ Version: sqlserverflex.GetInstanceResponseGetVersionAttributeType(utils.Ptr("v1")),
+ Edition: sqlserverflex.GetInstanceResponseGetEditionAttributeType(utils.Ptr("edition 1")),
+ Status: sqlserverflex.GetInstanceResponseGetStatusAttributeType(utils.Ptr("status")),
+ IsDeletable: utils.Ptr(true),
+ },
+ &flavorModel{
+ Id: types.StringValue("flavor_id"),
+ },
+ &storageModel{},
+ &encryptionModel{},
+ &networkModel{
+ ACL: types.ListNull(basetypes.StringType{}),
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Name: types.StringNull(),
+ BackupSchedule: types.StringNull(),
+ Flavor: types.ObjectValueMust(flavorTypes, map[string]attr.Value{
+ "id": types.StringValue("flavor_id"),
+ "description": types.StringNull(),
+ "cpu": types.Int64Null(),
+ "ram": types.Int64Null(),
+ "node_type": types.StringNull(),
+ }),
+ Replicas: types.Int64Value(1),
+ Storage: types.ObjectValueMust(storageTypes, map[string]attr.Value{
+ "class": types.StringNull(),
+ "size": types.Int64Null(),
+ }),
+ Encryption: types.ObjectValueMust(encryptionTypes, map[string]attr.Value{
+ "keyring_id": types.StringNull(),
+ "key_id": types.StringNull(),
+ "key_version": types.StringNull(),
+ "service_account": types.StringNull(),
+ }),
+ Network: types.ObjectValueMust(networkTypes, map[string]attr.Value{
+ "acl": types.ListNull(types.StringType),
+ "access_scope": types.StringNull(),
+ "instance_address": types.StringNull(),
+ "router_address": types.StringNull(),
+ }),
+ IsDeletable: types.BoolValue(true),
+ Edition: types.StringValue("edition 1"),
+ Status: types.StringValue("status"),
+ RetentionDays: types.Int64Value(1),
+ Version: types.StringValue("v1"),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "simple_values",
+ Model{
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ },
+ &sqlserverflex.GetInstanceResponse{
+ Acl: &[]string{
+ "ip1",
+ "ip2",
+ "",
+ },
+ BackupSchedule: utils.Ptr("schedule"),
+ FlavorId: utils.Ptr("flavor_id"),
+ Id: utils.Ptr("iid"),
+ Name: utils.Ptr("name"),
+ Replicas: sqlserverflex.GetInstanceResponseGetReplicasAttributeType(utils.Ptr(int32(56))),
+ Status: sqlserverflex.GetInstanceResponseGetStatusAttributeType(utils.Ptr("status")),
+ Storage: &sqlserverflex.Storage{
+ Class: utils.Ptr("class"),
+ Size: utils.Ptr(int64(78)),
+ },
+ Edition: sqlserverflex.GetInstanceResponseGetEditionAttributeType(utils.Ptr("edition")),
+ RetentionDays: utils.Ptr(int64(1)),
+ Version: sqlserverflex.GetInstanceResponseGetVersionAttributeType(utils.Ptr("version")),
+ IsDeletable: utils.Ptr(true),
+ Encryption: nil,
+ },
+ &flavorModel{
+ Id: basetypes.NewStringValue("flavor_id"),
+ Description: basetypes.NewStringValue("description"),
+ CPU: basetypes.NewInt64Value(12),
+ RAM: basetypes.NewInt64Value(34),
+ NodeType: basetypes.NewStringValue("node_type"),
+ },
+ &storageModel{},
+ &encryptionModel{},
+ &networkModel{
+ ACL: types.ListValueMust(basetypes.StringType{}, []attr.Value{
+ types.StringValue("ip1"),
+ types.StringValue("ip2"),
+ types.StringValue(""),
+ }),
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid"),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Name: types.StringValue("name"),
+ BackupSchedule: types.StringValue("schedule"),
+ Flavor: types.ObjectValueMust(flavorTypes, map[string]attr.Value{
+ "id": types.StringValue("flavor_id"),
+ "description": types.StringValue("description"),
+ "cpu": types.Int64Value(12),
+ "ram": types.Int64Value(34),
+ "node_type": types.StringValue("node_type"),
+ }),
+ Replicas: types.Int64Value(56),
+ Storage: types.ObjectValueMust(storageTypes, map[string]attr.Value{
+ "class": types.StringValue("class"),
+ "size": types.Int64Value(78),
+ }),
+ Network: types.ObjectValueMust(networkTypes, map[string]attr.Value{
+ "acl": types.ListValueMust(types.StringType, []attr.Value{
+ types.StringValue("ip1"),
+ types.StringValue("ip2"),
+ types.StringValue(""),
+ }),
+ "access_scope": types.StringNull(),
+ "instance_address": types.StringNull(),
+ "router_address": types.StringNull(),
+ }),
+ Edition: types.StringValue("edition"),
+ RetentionDays: types.Int64Value(1),
+ Version: types.StringValue("version"),
+ Region: types.StringValue(testRegion),
+ IsDeletable: types.BoolValue(true),
+ Encryption: types.ObjectValueMust(encryptionTypes, map[string]attr.Value{
+ "keyring_id": types.StringNull(),
+ "key_id": types.StringNull(),
+ "key_version": types.StringNull(),
+ "service_account": types.StringNull(),
+ }),
+ Status: types.StringValue("status"),
+ },
+ true,
+ },
+ //{
+ // "simple_values_no_flavor_and_storage",
+ // Model{
+ // InstanceId: types.StringValue("iid"),
+ // ProjectId: types.StringValue("pid"),
+ // },
+ // &sqlserverflex.GetInstanceResponse{
+ // Acl: &[]string{
+ // "ip1",
+ // "ip2",
+ // "",
+ // },
+ // BackupSchedule: utils.Ptr("schedule"),
+ // FlavorId: nil,
+ // Id: utils.Ptr("iid"),
+ // Name: utils.Ptr("name"),
+ // Replicas: sqlserverflex.GetInstanceResponseGetReplicasAttributeType(utils.Ptr(int32(56))),
+ // Status: sqlserverflex.GetInstanceResponseGetStatusAttributeType(utils.Ptr("status")),
+ // Storage: nil,
+ // Edition: sqlserverflex.GetInstanceResponseGetEditionAttributeType(utils.Ptr("edition")),
+ // RetentionDays: utils.Ptr(int64(1)),
+ // Version: sqlserverflex.GetInstanceResponseGetVersionAttributeType(utils.Ptr("version")),
+ // },
+ // &flavorModel{
+ // CPU: types.Int64Value(12),
+ // RAM: types.Int64Value(34),
+ // },
+ // &storageModel{
+ // Class: types.StringValue("class"),
+ // Size: types.Int64Value(78),
+ // },
+ // &optionsModel{
+ // Edition: types.StringValue("edition"),
+ // RetentionDays: types.Int64Value(1),
+ // },
+ // testRegion,
+ // Model{
+ // Id: types.StringValue("pid,region,iid"),
+ // InstanceId: types.StringValue("iid"),
+ // ProjectId: types.StringValue("pid"),
+ // Name: types.StringValue("name"),
+ // ACL: types.ListValueMust(types.StringType, []attr.Value{
+ // types.StringValue("ip1"),
+ // types.StringValue("ip2"),
+ // types.StringValue(""),
+ // }),
+ // BackupSchedule: types.StringValue("schedule"),
+ // Flavor: types.ObjectValueMust(flavorTypes, map[string]attr.Value{
+ // "id": types.StringNull(),
+ // "description": types.StringNull(),
+ // "cpu": types.Int64Value(12),
+ // "ram": types.Int64Value(34),
+ // }),
+ // Replicas: types.Int64Value(56),
+ // Storage: types.ObjectValueMust(storageTypes, map[string]attr.Value{
+ // "class": types.StringValue("class"),
+ // "size": types.Int64Value(78),
+ // }),
+ // Options: types.ObjectValueMust(optionsTypes, map[string]attr.Value{
+ // "edition": types.StringValue("edition"),
+ // "retention_days": types.Int64Value(1),
+ // }),
+ // Version: types.StringValue("version"),
+ // Region: types.StringValue(testRegion),
+ // },
+ // true,
+ //},
+ //{
+ // "acls_unordered",
+ // Model{
+ // InstanceId: types.StringValue("iid"),
+ // ProjectId: types.StringValue("pid"),
+ // ACL: types.ListValueMust(types.StringType, []attr.Value{
+ // types.StringValue("ip2"),
+ // types.StringValue(""),
+ // types.StringValue("ip1"),
+ // }),
+ // },
+ // &sqlserverflex.GetInstanceResponse{
+ // Acl: &[]string{
+ // "",
+ // "ip1",
+ // "ip2",
+ // },
+ // BackupSchedule: utils.Ptr("schedule"),
+ // FlavorId: nil,
+ // Id: utils.Ptr("iid"),
+ // Name: utils.Ptr("name"),
+ // Replicas: sqlserverflex.GetInstanceResponseGetReplicasAttributeType(utils.Ptr(int32(56))),
+ // Status: sqlserverflex.GetInstanceResponseGetStatusAttributeType(utils.Ptr("status")),
+ // Storage: nil,
+ // //Options: &map[string]string{
+ // // "edition": "edition",
+ // // "retentionDays": "1",
+ // //},
+ // Version: sqlserverflex.GetInstanceResponseGetVersionAttributeType(utils.Ptr("version")),
+ // },
+ // &flavorModel{
+ // CPU: types.Int64Value(12),
+ // RAM: types.Int64Value(34),
+ // },
+ // &storageModel{
+ // Class: types.StringValue("class"),
+ // Size: types.Int64Value(78),
+ // },
+ // &optionsModel{},
+ // testRegion,
+ // Model{
+ // Id: types.StringValue("pid,region,iid"),
+ // InstanceId: types.StringValue("iid"),
+ // ProjectId: types.StringValue("pid"),
+ // Name: types.StringValue("name"),
+ // ACL: types.ListValueMust(types.StringType, []attr.Value{
+ // types.StringValue("ip2"),
+ // types.StringValue(""),
+ // types.StringValue("ip1"),
+ // }),
+ // BackupSchedule: types.StringValue("schedule"),
+ // Flavor: types.ObjectValueMust(flavorTypes, map[string]attr.Value{
+ // "id": types.StringNull(),
+ // "description": types.StringNull(),
+ // "cpu": types.Int64Value(12),
+ // "ram": types.Int64Value(34),
+ // }),
+ // Replicas: types.Int64Value(56),
+ // Storage: types.ObjectValueMust(storageTypes, map[string]attr.Value{
+ // "class": types.StringValue("class"),
+ // "size": types.Int64Value(78),
+ // }),
+ // Options: types.ObjectValueMust(optionsTypes, map[string]attr.Value{
+ // "edition": types.StringValue("edition"),
+ // "retention_days": types.Int64Value(1),
+ // }),
+ // Version: types.StringValue("version"),
+ // Region: types.StringValue(testRegion),
+ // },
+ // true,
+ //},
+ //{
+ // "nil_response",
+ // Model{
+ // InstanceId: types.StringValue("iid"),
+ // ProjectId: types.StringValue("pid"),
+ // },
+ // nil,
+ // &flavorModel{},
+ // &storageModel{},
+ // &optionsModel{},
+ // testRegion,
+ // Model{},
+ // false,
+ //},
+ //{
+ // "no_resource_id",
+ // Model{
+ // InstanceId: types.StringValue("iid"),
+ // ProjectId: types.StringValue("pid"),
+ // },
+ // &sqlserverflex.GetInstanceResponse{},
+ // &flavorModel{},
+ // &storageModel{},
+ // &optionsModel{},
+ // testRegion,
+ // Model{},
+ // false,
+ //},
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ err := mapFields(context.Background(), tt.input, &tt.state, tt.flavor, tt.storage, tt.encryption, tt.network, tt.region)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(tt.state, tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ })
+ }
+}
+
+//func TestToCreatePayload(t *testing.T) {
+// tests := []struct {
+// description string
+// input *Model
+// inputAcl []string
+// inputFlavor *flavorModel
+// inputStorage *storageModel
+// inputOptions *optionsModel
+// expected *sqlserverflex.CreateInstanceRequestPayload
+// isValid bool
+// }{
+// {
+// "default_values",
+// &Model{},
+// []string{},
+// &flavorModel{},
+// &storageModel{},
+// &optionsModel{},
+// &sqlserverflex.CreateInstanceRequestPayload{
+// Acl: &sqlserverflex.CreateInstanceRequestPayloadGetAclArgType{},
+// Storage: &sqlserverflex.CreateInstanceRequestPayloadGetStorageArgType{},
+// },
+// true,
+// },
+// {
+// "simple_values",
+// &Model{
+// BackupSchedule: types.StringValue("schedule"),
+// Name: types.StringValue("name"),
+// Replicas: types.Int64Value(12),
+// Version: types.StringValue("version"),
+// },
+// []string{
+// "ip_1",
+// "ip_2",
+// },
+// &flavorModel{
+// Id: types.StringValue("flavor_id"),
+// },
+// &storageModel{
+// Class: types.StringValue("class"),
+// Size: types.Int64Value(34),
+// },
+// &optionsModel{
+// Edition: types.StringValue("edition"),
+// RetentionDays: types.Int64Value(1),
+// },
+// &sqlserverflex.CreateInstancePayload{
+// Acl: &sqlserverflex.CreateInstancePayloadAcl{
+// Items: &[]string{
+// "ip_1",
+// "ip_2",
+// },
+// },
+// BackupSchedule: utils.Ptr("schedule"),
+// FlavorId: utils.Ptr("flavor_id"),
+// Name: utils.Ptr("name"),
+// Storage: &sqlserverflex.CreateInstancePayloadStorage{
+// Class: utils.Ptr("class"),
+// Size: utils.Ptr(int64(34)),
+// },
+// Options: &sqlserverflex.CreateInstancePayloadOptions{
+// Edition: utils.Ptr("edition"),
+// RetentionDays: utils.Ptr("1"),
+// },
+// Version: utils.Ptr("version"),
+// },
+// true,
+// },
+// {
+// "null_fields_and_int_conversions",
+// &Model{
+// BackupSchedule: types.StringNull(),
+// Name: types.StringNull(),
+// Replicas: types.Int64Value(2123456789),
+// Version: types.StringNull(),
+// },
+// []string{
+// "",
+// },
+// &flavorModel{
+// Id: types.StringNull(),
+// },
+// &storageModel{
+// Class: types.StringNull(),
+// Size: types.Int64Null(),
+// },
+// &optionsModel{
+// Edition: types.StringNull(),
+// RetentionDays: types.Int64Null(),
+// },
+// &sqlserverflex.CreateInstancePayload{
+// Acl: &sqlserverflex.CreateInstancePayloadAcl{
+// Items: &[]string{
+// "",
+// },
+// },
+// BackupSchedule: nil,
+// FlavorId: nil,
+// Name: nil,
+// Storage: &sqlserverflex.CreateInstancePayloadStorage{
+// Class: nil,
+// Size: nil,
+// },
+// Options: &sqlserverflex.CreateInstancePayloadOptions{},
+// Version: nil,
+// },
+// true,
+// },
+// {
+// "nil_model",
+// nil,
+// []string{},
+// &flavorModel{},
+// &storageModel{},
+// &optionsModel{},
+// nil,
+// false,
+// },
+// {
+// "nil_acl",
+// &Model{},
+// nil,
+// &flavorModel{},
+// &storageModel{},
+// &optionsModel{},
+// &sqlserverflex.CreateInstancePayload{
+// Acl: &sqlserverflex.CreateInstancePayloadAcl{},
+// Storage: &sqlserverflex.CreateInstancePayloadStorage{},
+// Options: &sqlserverflex.CreateInstancePayloadOptions{},
+// },
+// true,
+// },
+// {
+// "nil_flavor",
+// &Model{},
+// []string{},
+// nil,
+// &storageModel{},
+// &optionsModel{},
+// nil,
+// false,
+// },
+// {
+// "nil_storage",
+// &Model{},
+// []string{},
+// &flavorModel{},
+// nil,
+// &optionsModel{},
+// &sqlserverflex.CreateInstancePayload{
+// Acl: &sqlserverflex.CreateInstancePayloadAcl{
+// Items: &[]string{},
+// },
+// Storage: &sqlserverflex.CreateInstancePayloadStorage{},
+// Options: &sqlserverflex.CreateInstancePayloadOptions{},
+// },
+// true,
+// },
+// {
+// "nil_options",
+// &Model{},
+// []string{},
+// &flavorModel{},
+// &storageModel{},
+// nil,
+// &sqlserverflex.CreateInstancePayload{
+// Acl: &sqlserverflex.CreateInstancePayloadAcl{
+// Items: &[]string{},
+// },
+// Storage: &sqlserverflex.CreateInstancePayloadStorage{},
+// Options: &sqlserverflex.CreateInstancePayloadOptions{},
+// },
+// true,
+// },
+// }
+// for _, tt := range tests {
+// t.Run(tt.description, func(t *testing.T) {
+// output, err := toCreatePayload(tt.input, tt.inputAcl, tt.inputFlavor, tt.inputStorage, tt.inputOptions)
+// if !tt.isValid && err == nil {
+// t.Fatalf("Should have failed")
+// }
+// if tt.isValid && err != nil {
+// t.Fatalf("Should not have failed: %v", err)
+// }
+// if tt.isValid {
+// diff := cmp.Diff(output, tt.expected)
+// if diff != "" {
+// t.Fatalf("Data does not match: %s", diff)
+// }
+// }
+// })
+// }
+//}
+//
+//func TestToUpdatePayload(t *testing.T) {
+// tests := []struct {
+// description string
+// input *Model
+// inputAcl []string
+// inputFlavor *flavorModel
+// expected *sqlserverflex.PartialUpdateInstancePayload
+// isValid bool
+// }{
+// {
+// "default_values",
+// &Model{},
+// []string{},
+// &flavorModel{},
+// &sqlserverflex.PartialUpdateInstancePayload{
+// Acl: &sqlserverflex.CreateInstancePayloadAcl{
+// Items: &[]string{},
+// },
+// },
+// true,
+// },
+// {
+// "simple_values",
+// &Model{
+// BackupSchedule: types.StringValue("schedule"),
+// Name: types.StringValue("name"),
+// Replicas: types.Int64Value(12),
+// Version: types.StringValue("version"),
+// },
+// []string{
+// "ip_1",
+// "ip_2",
+// },
+// &flavorModel{
+// Id: types.StringValue("flavor_id"),
+// },
+// &sqlserverflex.PartialUpdateInstancePayload{
+// Acl: &sqlserverflex.CreateInstancePayloadAcl{
+// Items: &[]string{
+// "ip_1",
+// "ip_2",
+// },
+// },
+// BackupSchedule: utils.Ptr("schedule"),
+// FlavorId: utils.Ptr("flavor_id"),
+// Name: utils.Ptr("name"),
+// Version: utils.Ptr("version"),
+// },
+// true,
+// },
+// {
+// "null_fields_and_int_conversions",
+// &Model{
+// BackupSchedule: types.StringNull(),
+// Name: types.StringNull(),
+// Replicas: types.Int64Value(2123456789),
+// Version: types.StringNull(),
+// },
+// []string{
+// "",
+// },
+// &flavorModel{
+// Id: types.StringNull(),
+// },
+// &sqlserverflex.PartialUpdateInstancePayload{
+// Acl: &sqlserverflex.CreateInstancePayloadAcl{
+// Items: &[]string{
+// "",
+// },
+// },
+// BackupSchedule: nil,
+// FlavorId: nil,
+// Name: nil,
+// Version: nil,
+// },
+// true,
+// },
+// {
+// "nil_model",
+// nil,
+// []string{},
+// &flavorModel{},
+// nil,
+// false,
+// },
+// {
+// "nil_acl",
+// &Model{},
+// nil,
+// &flavorModel{},
+// &sqlserverflex.PartialUpdateInstancePayload{
+// Acl: &sqlserverflex.CreateInstancePayloadAcl{},
+// },
+// true,
+// },
+// {
+// "nil_flavor",
+// &Model{},
+// []string{},
+// nil,
+// nil,
+// false,
+// },
+// }
+// for _, tt := range tests {
+// t.Run(tt.description, func(t *testing.T) {
+// output, err := toUpdatePayload(tt.input, tt.inputAcl, tt.inputFlavor)
+// if !tt.isValid && err == nil {
+// t.Fatalf("Should have failed")
+// }
+// if tt.isValid && err != nil {
+// t.Fatalf("Should not have failed: %v", err)
+// }
+// if tt.isValid {
+// diff := cmp.Diff(output, tt.expected)
+// if diff != "" {
+// t.Fatalf("Data does not match: %s", diff)
+// }
+// }
+// })
+// }
+//}
+//
+//func TestLoadFlavorId(t *testing.T) {
+// tests := []struct {
+// description string
+// inputFlavor *flavorModel
+// mockedResp *sqlserverflex.ListFlavorsResponse
+// expected *flavorModel
+// getFlavorsFails bool
+// isValid bool
+// }{
+// {
+// "ok_flavor",
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// &sqlserverflex.ListFlavorsResponse{
+// Flavors: &[]sqlserverflex.InstanceFlavorEntry{
+// {
+// Id: utils.Ptr("fid-1"),
+// Cpu: utils.Ptr(int64(2)),
+// Description: utils.Ptr("description"),
+// Memory: utils.Ptr(int64(8)),
+// },
+// },
+// },
+// &flavorModel{
+// Id: types.StringValue("fid-1"),
+// Description: types.StringValue("description"),
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// false,
+// true,
+// },
+// {
+// "ok_flavor_2",
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// &sqlserverflex.ListFlavorsResponse{
+// Flavors: &[]sqlserverflex.InstanceFlavorEntry{
+// {
+// Id: utils.Ptr("fid-1"),
+// Cpu: utils.Ptr(int64(2)),
+// Description: utils.Ptr("description"),
+// Memory: utils.Ptr(int64(8)),
+// },
+// {
+// Id: utils.Ptr("fid-2"),
+// Cpu: utils.Ptr(int64(1)),
+// Description: utils.Ptr("description"),
+// Memory: utils.Ptr(int64(4)),
+// },
+// },
+// },
+// &flavorModel{
+// Id: types.StringValue("fid-1"),
+// Description: types.StringValue("description"),
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// false,
+// true,
+// },
+// {
+// "no_matching_flavor",
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// &sqlserverflex.ListFlavorsResponse{
+// Flavors: &[]sqlserverflex.InstanceFlavorEntry{
+// {
+// Id: utils.Ptr("fid-1"),
+// Cpu: utils.Ptr(int64(1)),
+// Description: utils.Ptr("description"),
+// Memory: utils.Ptr(int64(8)),
+// },
+// {
+// Id: utils.Ptr("fid-2"),
+// Cpu: utils.Ptr(int64(1)),
+// Description: utils.Ptr("description"),
+// Memory: utils.Ptr(int64(4)),
+// },
+// },
+// },
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// false,
+// false,
+// },
+// {
+// "nil_response",
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// &sqlserverflex.ListFlavorsResponse{},
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// false,
+// false,
+// },
+// {
+// "error_response",
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// &sqlserverflex.ListFlavorsResponse{},
+// &flavorModel{
+// CPU: types.Int64Value(2),
+// RAM: types.Int64Value(8),
+// },
+// true,
+// false,
+// },
+// }
+// for _, tt := range tests {
+// t.Run(tt.description, func(t *testing.T) {
+// client := &sqlserverflexClientMocked{
+// returnError: tt.getFlavorsFails,
+// listFlavorsResp: tt.mockedResp,
+// }
+// model := &Model{
+// ProjectId: types.StringValue("pid"),
+// }
+// flavorModel := &flavorModel{
+// CPU: tt.inputFlavor.CPU,
+// RAM: tt.inputFlavor.RAM,
+// }
+// err := loadFlavorId(context.Background(), client, model, flavorModel)
+// if !tt.isValid && err == nil {
+// t.Fatalf("Should have failed")
+// }
+// if tt.isValid && err != nil {
+// t.Fatalf("Should not have failed: %v", err)
+// }
+// if tt.isValid {
+// diff := cmp.Diff(flavorModel, tt.expected)
+// if diff != "" {
+// t.Fatalf("Data does not match: %s", diff)
+// }
+// }
+// })
+// }
+//}
diff --git a/stackit/internal/services/sqlserverflexalpha/sqlserverflex_acc_test.go b/stackit/internal/services/sqlserverflexalpha/sqlserverflex_acc_test.go
new file mode 100644
index 00000000..e3b4fa2b
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/sqlserverflex_acc_test.go
@@ -0,0 +1,482 @@
+// Copyright (c) STACKIT
+
+package sqlserverflex_test
+
+import (
+ "context"
+ _ "embed"
+ "fmt"
+ "maps"
+ "strings"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-testing/config"
+ "github.com/hashicorp/terraform-plugin-testing/helper/acctest"
+ "github.com/hashicorp/terraform-plugin-testing/helper/resource"
+ "github.com/hashicorp/terraform-plugin-testing/terraform"
+ core_config "github.com/stackitcloud/stackit-sdk-go/core/config"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+ "github.com/stackitcloud/stackit-sdk-go/services/sqlserverflex"
+ "github.com/stackitcloud/stackit-sdk-go/services/sqlserverflex/wait"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/testutil"
+)
+
+var (
+ //go:embed testdata/resource-max.tf
+ resourceMaxConfig string
+ //go:embed testdata/resource-min.tf
+ resourceMinConfig string
+)
+var testConfigVarsMin = config.Variables{
+ "project_id": config.StringVariable(testutil.ProjectId),
+ "name": config.StringVariable(fmt.Sprintf("tf-acc-%s", acctest.RandStringFromCharSet(7, acctest.CharSetAlphaNum))),
+ "flavor_cpu": config.IntegerVariable(4),
+ "flavor_ram": config.IntegerVariable(16),
+ "flavor_description": config.StringVariable("SQLServer-Flex-4.16-Standard-EU01"),
+ "replicas": config.IntegerVariable(1),
+ "flavor_id": config.StringVariable("4.16-Single"),
+ "username": config.StringVariable(fmt.Sprintf("tf-acc-user-%s", acctest.RandStringFromCharSet(7, acctest.CharSetAlpha))),
+ "role": config.StringVariable("##STACKIT_LoginManager##"),
+}
+
+var testConfigVarsMax = config.Variables{
+ "project_id": config.StringVariable(testutil.ProjectId),
+ "name": config.StringVariable(fmt.Sprintf("tf-acc-%s", acctest.RandStringFromCharSet(7, acctest.CharSetAlphaNum))),
+ "acl1": config.StringVariable("192.168.0.0/16"),
+ "flavor_cpu": config.IntegerVariable(4),
+ "flavor_ram": config.IntegerVariable(16),
+ "flavor_description": config.StringVariable("SQLServer-Flex-4.16-Standard-EU01"),
+ "storage_class": config.StringVariable("premium-perf2-stackit"),
+ "storage_size": config.IntegerVariable(40),
+ "server_version": config.StringVariable("2022"),
+ "replicas": config.IntegerVariable(1),
+ "options_retention_days": config.IntegerVariable(64),
+ "flavor_id": config.StringVariable("4.16-Single"),
+ "backup_schedule": config.StringVariable("00 6 * * *"),
+ "username": config.StringVariable(fmt.Sprintf("tf-acc-user-%s", acctest.RandStringFromCharSet(7, acctest.CharSetAlpha))),
+ "role": config.StringVariable("##STACKIT_LoginManager##"),
+ "region": config.StringVariable(testutil.Region),
+}
+
+func configVarsMinUpdated() config.Variables {
+ temp := maps.Clone(testConfigVarsMax)
+ temp["name"] = config.StringVariable(testutil.ConvertConfigVariable(temp["name"]) + "changed")
+ return temp
+}
+
+func configVarsMaxUpdated() config.Variables {
+ temp := maps.Clone(testConfigVarsMax)
+ temp["backup_schedule"] = config.StringVariable("00 12 * * *")
+ return temp
+}
+
+func TestAccSQLServerFlexMinResource(t *testing.T) {
+ resource.Test(t, resource.TestCase{
+ ProtoV6ProviderFactories: testutil.TestAccProtoV6ProviderFactories,
+ CheckDestroy: testAccChecksqlserverflexDestroy,
+ Steps: []resource.TestStep{
+ // Creation
+ {
+ Config: testutil.SQLServerFlexProviderConfig() + "\n" + resourceMinConfig,
+ ConfigVariables: testConfigVarsMin,
+ Check: resource.ComposeAggregateTestCheckFunc(
+ // Instance
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "project_id", testutil.ConvertConfigVariable(testConfigVarsMin["project_id"])),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "instance_id"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "name", testutil.ConvertConfigVariable(testConfigVarsMin["name"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "acl.#", "1"),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "flavor.id"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.description", testutil.ConvertConfigVariable(testConfigVarsMin["flavor_description"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "replicas", testutil.ConvertConfigVariable(testConfigVarsMin["replicas"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.cpu", testutil.ConvertConfigVariable(testConfigVarsMin["flavor_cpu"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.ram", testutil.ConvertConfigVariable(testConfigVarsMin["flavor_ram"])),
+ // User
+ resource.TestCheckResourceAttrPair(
+ "stackit_sqlserverflex_user.user", "project_id",
+ "stackit_sqlserverflex_instance.instance", "project_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "stackit_sqlserverflex_user.user", "instance_id",
+ "stackit_sqlserverflex_instance.instance", "instance_id",
+ ),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_user.user", "user_id"),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_user.user", "password"),
+ ),
+ },
+ // Update
+ {
+ Config: testutil.SQLServerFlexProviderConfig() + "\n" + resourceMinConfig,
+ ConfigVariables: testConfigVarsMin,
+ Check: resource.ComposeAggregateTestCheckFunc(
+ // Instance
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "project_id", testutil.ConvertConfigVariable(testConfigVarsMin["project_id"])),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "instance_id"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "name", testutil.ConvertConfigVariable(testConfigVarsMin["name"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "acl.#", "1"),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "flavor.id"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.description", testutil.ConvertConfigVariable(testConfigVarsMin["flavor_description"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.cpu", testutil.ConvertConfigVariable(testConfigVarsMin["flavor_cpu"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.ram", testutil.ConvertConfigVariable(testConfigVarsMin["flavor_ram"])),
+ // User
+ resource.TestCheckResourceAttrPair(
+ "stackit_sqlserverflex_user.user", "project_id",
+ "stackit_sqlserverflex_instance.instance", "project_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "stackit_sqlserverflex_user.user", "instance_id",
+ "stackit_sqlserverflex_instance.instance", "instance_id",
+ ),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_user.user", "user_id"),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_user.user", "password"),
+ ),
+ },
+ // data source
+ {
+ Config: testutil.SQLServerFlexProviderConfig() + "\n" + resourceMinConfig,
+ ConfigVariables: testConfigVarsMin,
+ Check: resource.ComposeAggregateTestCheckFunc(
+ // Instance data
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "project_id", testutil.ConvertConfigVariable(testConfigVarsMin["project_id"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "name", testutil.ConvertConfigVariable(testConfigVarsMin["name"])),
+ resource.TestCheckResourceAttrPair(
+ "data.stackit_sqlserverflex_instance.instance", "project_id",
+ "stackit_sqlserverflex_instance.instance", "project_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "data.stackit_sqlserverflex_instance.instance", "instance_id",
+ "stackit_sqlserverflex_instance.instance", "instance_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "data.stackit_sqlserverflex_user.user", "instance_id",
+ "stackit_sqlserverflex_user.user", "instance_id",
+ ),
+
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "acl.#", "1"),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "flavor.id", testutil.ConvertConfigVariable(testConfigVarsMin["flavor_id"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "flavor.description", testutil.ConvertConfigVariable(testConfigVarsMin["flavor_description"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "flavor.cpu", testutil.ConvertConfigVariable(testConfigVarsMin["flavor_cpu"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "flavor.ram", testutil.ConvertConfigVariable(testConfigVarsMin["flavor_ram"])),
+
+ // User data
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_user.user", "project_id", testutil.ConvertConfigVariable(testConfigVarsMin["project_id"])),
+ resource.TestCheckResourceAttrSet("data.stackit_sqlserverflex_user.user", "user_id"),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_user.user", "username", testutil.ConvertConfigVariable(testConfigVarsMin["username"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_user.user", "roles.#", "1"),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_user.user", "roles.0", testutil.ConvertConfigVariable(testConfigVarsMax["role"])),
+ ),
+ },
+ // Import
+ {
+ ConfigVariables: testConfigVarsMin,
+ ResourceName: "stackit_sqlserverflex_instance.instance",
+ ImportStateIdFunc: func(s *terraform.State) (string, error) {
+ r, ok := s.RootModule().Resources["stackit_sqlserverflex_instance.instance"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find resource stackit_sqlserverflex_instance.instance")
+ }
+ instanceId, ok := r.Primary.Attributes["instance_id"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find attribute instance_id")
+ }
+
+ return fmt.Sprintf("%s,%s,%s", testutil.ProjectId, testutil.Region, instanceId), nil
+ },
+ ImportState: true,
+ ImportStateVerify: true,
+ ImportStateVerifyIgnore: []string{"backup_schedule"},
+ ImportStateCheck: func(s []*terraform.InstanceState) error {
+ if len(s) != 1 {
+ return fmt.Errorf("expected 1 state, got %d", len(s))
+ }
+ return nil
+ },
+ },
+ {
+ ResourceName: "stackit_sqlserverflex_user.user",
+ ConfigVariables: testConfigVarsMin,
+ ImportStateIdFunc: func(s *terraform.State) (string, error) {
+ r, ok := s.RootModule().Resources["stackit_sqlserverflex_user.user"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find resource stackit_sqlserverflex_user.user")
+ }
+ instanceId, ok := r.Primary.Attributes["instance_id"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find attribute instance_id")
+ }
+ userId, ok := r.Primary.Attributes["user_id"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find attribute user_id")
+ }
+
+ return fmt.Sprintf("%s,%s,%s,%s", testutil.ProjectId, testutil.Region, instanceId, userId), nil
+ },
+ ImportState: true,
+ ImportStateVerify: true,
+ ImportStateVerifyIgnore: []string{"password"},
+ },
+ // Update
+ {
+ Config: testutil.SQLServerFlexProviderConfig() + "\n" + resourceMinConfig,
+ ConfigVariables: configVarsMinUpdated(),
+ Check: resource.ComposeAggregateTestCheckFunc(
+ // Instance data
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "project_id", testutil.ConvertConfigVariable(configVarsMinUpdated()["project_id"])),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "instance_id"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "name", testutil.ConvertConfigVariable(configVarsMinUpdated()["name"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "acl.#", "1"),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "flavor.id"),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "flavor.description"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.cpu", testutil.ConvertConfigVariable(configVarsMinUpdated()["flavor_cpu"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.ram", testutil.ConvertConfigVariable(configVarsMinUpdated()["flavor_ram"])),
+ ),
+ },
+ // Deletion is done by the framework implicitly
+ },
+ })
+}
+
+func TestAccSQLServerFlexMaxResource(t *testing.T) {
+ resource.Test(t, resource.TestCase{
+ ProtoV6ProviderFactories: testutil.TestAccProtoV6ProviderFactories,
+ CheckDestroy: testAccChecksqlserverflexDestroy,
+ Steps: []resource.TestStep{
+ // Creation
+ {
+ Config: testutil.SQLServerFlexProviderConfig() + "\n" + resourceMaxConfig,
+ ConfigVariables: testConfigVarsMax,
+ Check: resource.ComposeAggregateTestCheckFunc(
+ // Instance
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "project_id", testutil.ConvertConfigVariable(testConfigVarsMax["project_id"])),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "instance_id"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "name", testutil.ConvertConfigVariable(testConfigVarsMax["name"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "acl.#", "1"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "acl.0", testutil.ConvertConfigVariable(testConfigVarsMax["acl1"])),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "flavor.id"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.description", testutil.ConvertConfigVariable(testConfigVarsMax["flavor_description"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "replicas", testutil.ConvertConfigVariable(testConfigVarsMax["replicas"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.cpu", testutil.ConvertConfigVariable(testConfigVarsMax["flavor_cpu"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.ram", testutil.ConvertConfigVariable(testConfigVarsMax["flavor_ram"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "storage.class", testutil.ConvertConfigVariable(testConfigVarsMax["storage_class"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "storage.size", testutil.ConvertConfigVariable(testConfigVarsMax["storage_size"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "version", testutil.ConvertConfigVariable(testConfigVarsMax["server_version"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "options.retention_days", testutil.ConvertConfigVariable(testConfigVarsMax["options_retention_days"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "backup_schedule", testutil.ConvertConfigVariable(testConfigVarsMax["backup_schedule"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "region", testutil.Region),
+ // User
+ resource.TestCheckResourceAttrPair(
+ "stackit_sqlserverflex_user.user", "project_id",
+ "stackit_sqlserverflex_instance.instance", "project_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "stackit_sqlserverflex_user.user", "instance_id",
+ "stackit_sqlserverflex_instance.instance", "instance_id",
+ ),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_user.user", "user_id"),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_user.user", "password"),
+ ),
+ },
+ // Update
+ {
+ Config: testutil.SQLServerFlexProviderConfig() + "\n" + resourceMaxConfig,
+ ConfigVariables: testConfigVarsMax,
+ Check: resource.ComposeAggregateTestCheckFunc(
+ // Instance
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "project_id", testutil.ConvertConfigVariable(testConfigVarsMax["project_id"])),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "instance_id"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "name", testutil.ConvertConfigVariable(testConfigVarsMax["name"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "acl.#", "1"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "acl.0", testutil.ConvertConfigVariable(testConfigVarsMax["acl1"])),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "flavor.id"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.description", testutil.ConvertConfigVariable(testConfigVarsMax["flavor_description"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "replicas", testutil.ConvertConfigVariable(testConfigVarsMax["replicas"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.cpu", testutil.ConvertConfigVariable(testConfigVarsMax["flavor_cpu"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.ram", testutil.ConvertConfigVariable(testConfigVarsMax["flavor_ram"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "storage.class", testutil.ConvertConfigVariable(testConfigVarsMax["storage_class"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "storage.size", testutil.ConvertConfigVariable(testConfigVarsMax["storage_size"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "version", testutil.ConvertConfigVariable(testConfigVarsMax["server_version"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "options.retention_days", testutil.ConvertConfigVariable(testConfigVarsMax["options_retention_days"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "backup_schedule", testutil.ConvertConfigVariable(testConfigVarsMax["backup_schedule"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "region", testutil.Region),
+ // User
+ resource.TestCheckResourceAttrPair(
+ "stackit_sqlserverflex_user.user", "project_id",
+ "stackit_sqlserverflex_instance.instance", "project_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "stackit_sqlserverflex_user.user", "instance_id",
+ "stackit_sqlserverflex_instance.instance", "instance_id",
+ ),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_user.user", "user_id"),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_user.user", "password"),
+ ),
+ },
+ // data source
+ {
+ Config: testutil.SQLServerFlexProviderConfig() + "\n" + resourceMaxConfig,
+ ConfigVariables: testConfigVarsMax,
+ Check: resource.ComposeAggregateTestCheckFunc(
+ // Instance data
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "project_id", testutil.ConvertConfigVariable(testConfigVarsMax["project_id"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "name", testutil.ConvertConfigVariable(testConfigVarsMax["name"])),
+ resource.TestCheckResourceAttrPair(
+ "data.stackit_sqlserverflex_instance.instance", "project_id",
+ "stackit_sqlserverflex_instance.instance", "project_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "data.stackit_sqlserverflex_instance.instance", "instance_id",
+ "stackit_sqlserverflex_instance.instance", "instance_id",
+ ),
+ resource.TestCheckResourceAttrPair(
+ "data.stackit_sqlserverflex_user.user", "instance_id",
+ "stackit_sqlserverflex_user.user", "instance_id",
+ ),
+
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "acl.#", "1"),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "acl.0", testutil.ConvertConfigVariable(testConfigVarsMax["acl1"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "flavor.id", testutil.ConvertConfigVariable(testConfigVarsMax["flavor_id"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "flavor.description", testutil.ConvertConfigVariable(testConfigVarsMax["flavor_description"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "flavor.cpu", testutil.ConvertConfigVariable(testConfigVarsMax["flavor_cpu"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "flavor.ram", testutil.ConvertConfigVariable(testConfigVarsMax["flavor_ram"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "replicas", testutil.ConvertConfigVariable(testConfigVarsMax["replicas"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "options.retention_days", testutil.ConvertConfigVariable(testConfigVarsMax["options_retention_days"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_instance.instance", "backup_schedule", testutil.ConvertConfigVariable(testConfigVarsMax["backup_schedule"])),
+
+ // User data
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_user.user", "project_id", testutil.ConvertConfigVariable(testConfigVarsMax["project_id"])),
+ resource.TestCheckResourceAttrSet("data.stackit_sqlserverflex_user.user", "user_id"),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_user.user", "username", testutil.ConvertConfigVariable(testConfigVarsMax["username"])),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_user.user", "roles.#", "1"),
+ resource.TestCheckResourceAttr("data.stackit_sqlserverflex_user.user", "roles.0", testutil.ConvertConfigVariable(testConfigVarsMax["role"])),
+ resource.TestCheckResourceAttrSet("data.stackit_sqlserverflex_user.user", "host"),
+ resource.TestCheckResourceAttrSet("data.stackit_sqlserverflex_user.user", "port"),
+ ),
+ },
+ // Import
+ {
+ ConfigVariables: testConfigVarsMax,
+ ResourceName: "stackit_sqlserverflex_instance.instance",
+ ImportStateIdFunc: func(s *terraform.State) (string, error) {
+ r, ok := s.RootModule().Resources["stackit_sqlserverflex_instance.instance"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find resource stackit_sqlserverflex_instance.instance")
+ }
+ instanceId, ok := r.Primary.Attributes["instance_id"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find attribute instance_id")
+ }
+
+ return fmt.Sprintf("%s,%s,%s", testutil.ProjectId, testutil.Region, instanceId), nil
+ },
+ ImportState: true,
+ ImportStateVerify: true,
+ ImportStateVerifyIgnore: []string{"backup_schedule"},
+ ImportStateCheck: func(s []*terraform.InstanceState) error {
+ if len(s) != 1 {
+ return fmt.Errorf("expected 1 state, got %d", len(s))
+ }
+ if s[0].Attributes["backup_schedule"] != testutil.ConvertConfigVariable(testConfigVarsMax["backup_schedule"]) {
+ return fmt.Errorf("expected backup_schedule %s, got %s", testConfigVarsMax["backup_schedule"], s[0].Attributes["backup_schedule"])
+ }
+ return nil
+ },
+ },
+ {
+ ResourceName: "stackit_sqlserverflex_user.user",
+ ConfigVariables: testConfigVarsMax,
+ ImportStateIdFunc: func(s *terraform.State) (string, error) {
+ r, ok := s.RootModule().Resources["stackit_sqlserverflex_user.user"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find resource stackit_sqlserverflex_user.user")
+ }
+ instanceId, ok := r.Primary.Attributes["instance_id"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find attribute instance_id")
+ }
+ userId, ok := r.Primary.Attributes["user_id"]
+ if !ok {
+ return "", fmt.Errorf("couldn't find attribute user_id")
+ }
+
+ return fmt.Sprintf("%s,%s,%s,%s", testutil.ProjectId, testutil.Region, instanceId, userId), nil
+ },
+ ImportState: true,
+ ImportStateVerify: true,
+ ImportStateVerifyIgnore: []string{"password"},
+ },
+ // Update
+ {
+ Config: testutil.SQLServerFlexProviderConfig() + "\n" + resourceMaxConfig,
+ ConfigVariables: configVarsMaxUpdated(),
+ Check: resource.ComposeAggregateTestCheckFunc(
+ // Instance data
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "project_id", testutil.ConvertConfigVariable(configVarsMaxUpdated()["project_id"])),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "instance_id"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "name", testutil.ConvertConfigVariable(configVarsMaxUpdated()["name"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "acl.#", "1"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "acl.0", testutil.ConvertConfigVariable(configVarsMaxUpdated()["acl1"])),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "flavor.id"),
+ resource.TestCheckResourceAttrSet("stackit_sqlserverflex_instance.instance", "flavor.description"),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.cpu", testutil.ConvertConfigVariable(configVarsMaxUpdated()["flavor_cpu"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "flavor.ram", testutil.ConvertConfigVariable(configVarsMaxUpdated()["flavor_ram"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "replicas", testutil.ConvertConfigVariable(configVarsMaxUpdated()["replicas"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "storage.class", testutil.ConvertConfigVariable(configVarsMaxUpdated()["storage_class"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "storage.size", testutil.ConvertConfigVariable(configVarsMaxUpdated()["storage_size"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "version", testutil.ConvertConfigVariable(configVarsMaxUpdated()["server_version"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "options.retention_days", testutil.ConvertConfigVariable(configVarsMaxUpdated()["options_retention_days"])),
+ resource.TestCheckResourceAttr("stackit_sqlserverflex_instance.instance", "backup_schedule", testutil.ConvertConfigVariable(configVarsMaxUpdated()["backup_schedule"])),
+ ),
+ },
+ // Deletion is done by the framework implicitly
+ },
+ })
+}
+
+func testAccChecksqlserverflexDestroy(s *terraform.State) error {
+ ctx := context.Background()
+ var client *sqlserverflex.APIClient
+ var err error
+ if testutil.SQLServerFlexCustomEndpoint == "" {
+ client, err = sqlserverflex.NewAPIClient()
+ } else {
+ client, err = sqlserverflex.NewAPIClient(
+ core_config.WithEndpoint(testutil.SQLServerFlexCustomEndpoint),
+ )
+ }
+ if err != nil {
+ return fmt.Errorf("creating client: %w", err)
+ }
+
+ instancesToDestroy := []string{}
+ for _, rs := range s.RootModule().Resources {
+ if rs.Type != "stackit_sqlserverflex_instance" {
+ continue
+ }
+ // instance terraform ID: = "[project_id],[region],[instance_id]"
+ instanceId := strings.Split(rs.Primary.ID, core.Separator)[2]
+ instancesToDestroy = append(instancesToDestroy, instanceId)
+ }
+
+ instancesResp, err := client.ListInstances(ctx, testutil.ProjectId, testutil.Region).Execute()
+ if err != nil {
+ return fmt.Errorf("getting instancesResp: %w", err)
+ }
+
+ items := *instancesResp.Items
+ for i := range items {
+ if items[i].Id == nil {
+ continue
+ }
+ if utils.Contains(instancesToDestroy, *items[i].Id) {
+ err := client.DeleteInstanceExecute(ctx, testutil.ProjectId, *items[i].Id, testutil.Region)
+ if err != nil {
+ return fmt.Errorf("destroying instance %s during CheckDestroy: %w", *items[i].Id, err)
+ }
+ _, err = wait.DeleteInstanceWaitHandler(ctx, client, testutil.ProjectId, *items[i].Id, testutil.Region).WaitWithContext(ctx)
+ if err != nil {
+ return fmt.Errorf("destroying instance %s during CheckDestroy: waiting for deletion %w", *items[i].Id, err)
+ }
+ }
+ }
+ return nil
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/testdata/resource-max.tf b/stackit/internal/services/sqlserverflexalpha/testdata/resource-max.tf
new file mode 100644
index 00000000..1c3cdd15
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/testdata/resource-max.tf
@@ -0,0 +1,53 @@
+# Copyright (c) STACKIT
+
+variable "project_id" {}
+variable "name" {}
+variable "acl1" {}
+variable "flavor_cpu" {}
+variable "flavor_ram" {}
+variable "storage_class" {}
+variable "storage_size" {}
+variable "options_retention_days" {}
+variable "backup_schedule" {}
+variable "username" {}
+variable "role" {}
+variable "server_version" {}
+variable "region" {}
+
+resource "stackit_sqlserverflex_instance" "instance" {
+ project_id = var.project_id
+ name = var.name
+ acl = [var.acl1]
+ flavor = {
+ cpu = var.flavor_cpu
+ ram = var.flavor_ram
+ }
+ storage = {
+ class = var.storage_class
+ size = var.storage_size
+ }
+ version = var.server_version
+ options = {
+ retention_days = var.options_retention_days
+ }
+ backup_schedule = var.backup_schedule
+ region = var.region
+}
+
+resource "stackit_sqlserverflex_user" "user" {
+ project_id = stackit_sqlserverflex_instance.instance.project_id
+ instance_id = stackit_sqlserverflex_instance.instance.instance_id
+ username = var.username
+ roles = [var.role]
+}
+
+data "stackit_sqlserverflex_instance" "instance" {
+ project_id = var.project_id
+ instance_id = stackit_sqlserverflex_instance.instance.instance_id
+}
+
+data "stackit_sqlserverflex_user" "user" {
+ project_id = var.project_id
+ instance_id = stackit_sqlserverflex_instance.instance.instance_id
+ user_id = stackit_sqlserverflex_user.user.user_id
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/testdata/resource-min.tf b/stackit/internal/services/sqlserverflexalpha/testdata/resource-min.tf
new file mode 100644
index 00000000..f53ef3e6
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/testdata/resource-min.tf
@@ -0,0 +1,35 @@
+# Copyright (c) STACKIT
+
+variable "project_id" {}
+variable "name" {}
+variable "flavor_cpu" {}
+variable "flavor_ram" {}
+variable "username" {}
+variable "role" {}
+
+resource "stackit_sqlserverflex_instance" "instance" {
+ project_id = var.project_id
+ name = var.name
+ flavor = {
+ cpu = var.flavor_cpu
+ ram = var.flavor_ram
+ }
+}
+
+resource "stackit_sqlserverflex_user" "user" {
+ project_id = stackit_sqlserverflex_instance.instance.project_id
+ instance_id = stackit_sqlserverflex_instance.instance.instance_id
+ username = var.username
+ roles = [var.role]
+}
+
+data "stackit_sqlserverflex_instance" "instance" {
+ project_id = var.project_id
+ instance_id = stackit_sqlserverflex_instance.instance.instance_id
+}
+
+data "stackit_sqlserverflex_user" "user" {
+ project_id = var.project_id
+ instance_id = stackit_sqlserverflex_instance.instance.instance_id
+ user_id = stackit_sqlserverflex_user.user.user_id
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/user/datasource.go b/stackit/internal/services/sqlserverflexalpha/user/datasource.go
new file mode 100644
index 00000000..71946c6c
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/user/datasource.go
@@ -0,0 +1,274 @@
+// Copyright (c) STACKIT
+
+package sqlserverflexalpha
+
+import (
+ "context"
+ "fmt"
+ "net/http"
+ "strconv"
+
+ "github.com/hashicorp/terraform-plugin-framework-validators/int64validator"
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/conversion"
+ sqlserverflexUtils "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/sqlserverflexalpha/utils"
+
+ "github.com/hashicorp/terraform-plugin-framework/datasource"
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/validate"
+
+ "github.com/hashicorp/terraform-plugin-framework/datasource/schema"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+)
+
+// Ensure the implementation satisfies the expected interfaces.
+var (
+ _ datasource.DataSource = &userDataSource{}
+)
+
+type DataSourceModel struct {
+ Id types.String `tfsdk:"id"` // needed by TF
+ UserId types.Int64 `tfsdk:"user_id"`
+ InstanceId types.String `tfsdk:"instance_id"`
+ ProjectId types.String `tfsdk:"project_id"`
+ Username types.String `tfsdk:"username"`
+ Roles types.Set `tfsdk:"roles"`
+ Host types.String `tfsdk:"host"`
+ Port types.Int64 `tfsdk:"port"`
+ Region types.String `tfsdk:"region"`
+ Status types.String `tfsdk:"status"`
+ DefaultDatabase types.String `tfsdk:"default_database"`
+}
+
+// NewUserDataSource is a helper function to simplify the provider implementation.
+func NewUserDataSource() datasource.DataSource {
+ return &userDataSource{}
+}
+
+// userDataSource is the data source implementation.
+type userDataSource struct {
+ client *sqlserverflexalpha.APIClient
+ providerData core.ProviderData
+}
+
+// Metadata returns the data source type name.
+func (r *userDataSource) Metadata(
+ _ context.Context,
+ req datasource.MetadataRequest,
+ resp *datasource.MetadataResponse,
+) {
+ resp.TypeName = req.ProviderTypeName + "_sqlserverflexalpha_user"
+}
+
+// Configure adds the provider configured client to the data source.
+func (r *userDataSource) Configure(
+ ctx context.Context,
+ req datasource.ConfigureRequest,
+ resp *datasource.ConfigureResponse,
+) {
+ var ok bool
+ r.providerData, ok = conversion.ParseProviderData(ctx, req.ProviderData, &resp.Diagnostics)
+ if !ok {
+ return
+ }
+
+ apiClient := sqlserverflexUtils.ConfigureClient(ctx, &r.providerData, &resp.Diagnostics)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ r.client = apiClient
+ tflog.Info(ctx, "SQLServer Flex user client configured")
+}
+
+// Schema defines the schema for the data source.
+func (r *userDataSource) Schema(_ context.Context, _ datasource.SchemaRequest, resp *datasource.SchemaResponse) {
+ descriptions := map[string]string{
+ "main": "SQLServer Flex user data source schema. Must have a `region` specified in the provider configuration.",
+ "id": "Terraform's internal data source. ID. It is structured as \"`project_id`,`region`,`instance_id`,`user_id`\".",
+ "user_id": "User ID.",
+ "instance_id": "ID of the SQLServer Flex instance.",
+ "project_id": "STACKIT project ID to which the instance is associated.",
+ "username": "Username of the SQLServer Flex instance.",
+ "roles": "Database access levels for the user.",
+ "password": "Password of the user account.",
+ "region": "The resource region. If not defined, the provider region is used.",
+ "status": "Status of the user.",
+ "default_database": "Default database of the user.",
+ }
+
+ resp.Schema = schema.Schema{
+ Description: descriptions["main"],
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Description: descriptions["id"],
+ Computed: true,
+ },
+ "user_id": schema.Int64Attribute{
+ Description: descriptions["user_id"],
+ Required: true,
+ Validators: []validator.Int64{
+ int64validator.AtLeast(1),
+ },
+ },
+ "instance_id": schema.StringAttribute{
+ Description: descriptions["instance_id"],
+ Required: true,
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "project_id": schema.StringAttribute{
+ Description: descriptions["project_id"],
+ Required: true,
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "username": schema.StringAttribute{
+ Description: descriptions["username"],
+ Computed: true,
+ },
+ "roles": schema.SetAttribute{
+ Description: descriptions["roles"],
+ ElementType: types.StringType,
+ Computed: true,
+ },
+ "host": schema.StringAttribute{
+ Computed: true,
+ },
+ "port": schema.Int64Attribute{
+ Computed: true,
+ },
+ "region": schema.StringAttribute{
+ // the region cannot be found automatically, so it has to be passed
+ Optional: true,
+ Description: descriptions["region"],
+ },
+ "status": schema.StringAttribute{
+ Computed: true,
+ },
+ "default_database": schema.StringAttribute{
+ Computed: true,
+ },
+ },
+ }
+}
+
+// Read refreshes the Terraform state with the latest data.
+func (r *userDataSource) Read(
+ ctx context.Context,
+ req datasource.ReadRequest,
+ resp *datasource.ReadResponse,
+) { // nolint:gocritic // function signature required by Terraform
+ var model DataSourceModel
+ diags := req.Config.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ userId := model.UserId.ValueInt64()
+ region := r.providerData.GetRegionWithOverride(model.Region)
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "user_id", userId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ recordSetResp, err := r.client.GetUserRequest(ctx, projectId, region, instanceId, userId).Execute()
+ if err != nil {
+ utils.LogError(
+ ctx,
+ &resp.Diagnostics,
+ err,
+ "Reading user",
+ fmt.Sprintf(
+ "User with ID %q or instance with ID %q does not exist in project %q.",
+ userId,
+ instanceId,
+ projectId,
+ ),
+ map[int]string{
+ http.StatusForbidden: fmt.Sprintf("Project with ID %q not found or forbidden access", projectId),
+ },
+ )
+ resp.State.RemoveResource(ctx)
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ // Map response body to schema and populate Computed attribute values
+ err = mapDataSourceFields(recordSetResp, &model, region)
+ if err != nil {
+ core.LogAndAddError(
+ ctx,
+ &resp.Diagnostics,
+ "Error reading user",
+ fmt.Sprintf("Processing API payload: %v", err),
+ )
+ return
+ }
+
+ // Set refreshed state
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "SQLServer Flex instance read")
+}
+
+func mapDataSourceFields(userResp *sqlserverflexalpha.GetUserResponse, model *DataSourceModel, region string) error {
+ if userResp == nil {
+ return fmt.Errorf("response is nil")
+ }
+ if model == nil {
+ return fmt.Errorf("model input is nil")
+ }
+ user := userResp
+
+ var userId int64
+ if model.UserId.ValueInt64() != 0 {
+ userId = model.UserId.ValueInt64()
+ } else if user.Id != nil {
+ userId = *user.Id
+ } else {
+ return fmt.Errorf("user id not present")
+ }
+ model.Id = utils.BuildInternalTerraformId(
+ model.ProjectId.ValueString(), region, model.InstanceId.ValueString(), strconv.FormatInt(userId, 10),
+ )
+ model.UserId = types.Int64Value(userId)
+ model.Username = types.StringPointerValue(user.Username)
+
+ if user.Roles == nil {
+ model.Roles = types.SetNull(types.StringType)
+ } else {
+ var roles []attr.Value
+ for _, role := range *user.Roles {
+ roles = append(roles, types.StringValue(string(role)))
+ }
+ rolesSet, diags := types.SetValue(types.StringType, roles)
+ if diags.HasError() {
+ return fmt.Errorf("failed to map roles: %w", core.DiagsToError(diags))
+ }
+ model.Roles = rolesSet
+ }
+ model.Host = types.StringPointerValue(user.Host)
+ model.Port = types.Int64PointerValue(user.Port)
+ model.Region = types.StringValue(region)
+ model.Status = types.StringPointerValue(user.Status)
+ model.DefaultDatabase = types.StringPointerValue(user.DefaultDatabase)
+
+ return nil
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/user/datasource_test.go b/stackit/internal/services/sqlserverflexalpha/user/datasource_test.go
new file mode 100644
index 00000000..5f99a8e5
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/user/datasource_test.go
@@ -0,0 +1,149 @@
+// Copyright (c) STACKIT
+
+package sqlserverflexalpha
+
+import (
+ "testing"
+
+ "github.com/google/go-cmp/cmp"
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+)
+
+func TestMapDataSourceFields(t *testing.T) {
+ const testRegion = "region"
+ tests := []struct {
+ description string
+ input *sqlserverflexalpha.GetUserResponse
+ region string
+ expected DataSourceModel
+ isValid bool
+ }{
+ {
+ "default_values",
+ &sqlserverflexalpha.GetUserResponse{},
+ testRegion,
+ DataSourceModel{
+ Id: types.StringValue("pid,region,iid,1"),
+ UserId: types.Int64Value(1),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringNull(),
+ Roles: types.SetNull(types.StringType),
+ Host: types.StringNull(),
+ Port: types.Int64Null(),
+ Region: types.StringValue(testRegion),
+ Status: types.StringNull(),
+ DefaultDatabase: types.StringNull(),
+ },
+ true,
+ },
+ {
+ "simple_values",
+ &sqlserverflexalpha.GetUserResponse{
+
+ Roles: &[]sqlserverflexalpha.UserRole{
+ "role_1",
+ "role_2",
+ "",
+ },
+ Username: utils.Ptr("username"),
+ Host: utils.Ptr("host"),
+ Port: utils.Ptr(int64(1234)),
+ Status: utils.Ptr("active"),
+ DefaultDatabase: utils.Ptr("default_db"),
+ },
+ testRegion,
+ DataSourceModel{
+ Id: types.StringValue("pid,region,iid,1"),
+ UserId: types.Int64Value(1),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringValue("username"),
+ Roles: types.SetValueMust(
+ types.StringType, []attr.Value{
+ types.StringValue("role_1"),
+ types.StringValue("role_2"),
+ types.StringValue(""),
+ },
+ ),
+ Host: types.StringValue("host"),
+ Port: types.Int64Value(1234),
+ Region: types.StringValue(testRegion),
+ Status: types.StringValue("active"),
+ DefaultDatabase: types.StringValue("default_db"),
+ },
+ true,
+ },
+ {
+ "null_fields_and_int_conversions",
+ &sqlserverflexalpha.GetUserResponse{
+ Id: utils.Ptr(int64(1)),
+ Roles: &[]sqlserverflexalpha.UserRole{},
+ Username: nil,
+ Host: nil,
+ Port: utils.Ptr(int64(2123456789)),
+ },
+ testRegion,
+ DataSourceModel{
+ Id: types.StringValue("pid,region,iid,1"),
+ UserId: types.Int64Value(1),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringNull(),
+ Roles: types.SetValueMust(types.StringType, []attr.Value{}),
+ Host: types.StringNull(),
+ Port: types.Int64Value(2123456789),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "nil_response",
+ nil,
+ testRegion,
+ DataSourceModel{},
+ false,
+ },
+ {
+ "nil_response_2",
+ &sqlserverflexalpha.GetUserResponse{},
+ testRegion,
+ DataSourceModel{},
+ false,
+ },
+ {
+ "no_resource_id",
+ &sqlserverflexalpha.GetUserResponse{},
+ testRegion,
+ DataSourceModel{},
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(
+ tt.description, func(t *testing.T) {
+ state := &DataSourceModel{
+ ProjectId: tt.expected.ProjectId,
+ InstanceId: tt.expected.InstanceId,
+ UserId: tt.expected.UserId,
+ }
+ err := mapDataSourceFields(tt.input, state, tt.region)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(state, &tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ },
+ )
+ }
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/user/resource.go b/stackit/internal/services/sqlserverflexalpha/user/resource.go
new file mode 100644
index 00000000..f52d990b
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/user/resource.go
@@ -0,0 +1,568 @@
+// Copyright (c) STACKIT
+
+package sqlserverflexalpha
+
+import (
+ "context"
+ "errors"
+ "fmt"
+ "net/http"
+ "strconv"
+ "strings"
+
+ "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+ sqlserverflexalphaUtils "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/sqlserverflexalpha/utils"
+
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/conversion"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/validate"
+
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/path"
+ "github.com/hashicorp/terraform-plugin-framework/resource"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/planmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/setplanmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/stringplanmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/core/oapierror"
+)
+
+// Ensure the implementation satisfies the expected interfaces.
+var (
+ _ resource.Resource = &userResource{}
+ _ resource.ResourceWithConfigure = &userResource{}
+ _ resource.ResourceWithImportState = &userResource{}
+ _ resource.ResourceWithModifyPlan = &userResource{}
+)
+
+type Model struct {
+ Id types.String `tfsdk:"id"` // needed by TF
+ UserId types.Int64 `tfsdk:"user_id"`
+ InstanceId types.String `tfsdk:"instance_id"`
+ ProjectId types.String `tfsdk:"project_id"`
+ Username types.String `tfsdk:"username"`
+ Roles types.Set `tfsdk:"roles"`
+ Password types.String `tfsdk:"password"`
+ Host types.String `tfsdk:"host"`
+ Port types.Int64 `tfsdk:"port"`
+ Region types.String `tfsdk:"region"`
+ Status types.String `tfsdk:"status"`
+ DefaultDatabase types.String `tfsdk:"default_database"`
+}
+
+// NewUserResource is a helper function to simplify the provider implementation.
+func NewUserResource() resource.Resource {
+ return &userResource{}
+}
+
+// userResource is the resource implementation.
+type userResource struct {
+ client *sqlserverflexalpha.APIClient
+ providerData core.ProviderData
+}
+
+// Metadata returns the resource type name.
+func (r *userResource) Metadata(_ context.Context, req resource.MetadataRequest, resp *resource.MetadataResponse) {
+ resp.TypeName = req.ProviderTypeName + "_sqlserverflexalpha_user"
+}
+
+// Configure adds the provider configured client to the resource.
+func (r *userResource) Configure(ctx context.Context, req resource.ConfigureRequest, resp *resource.ConfigureResponse) {
+ var ok bool
+ r.providerData, ok = conversion.ParseProviderData(ctx, req.ProviderData, &resp.Diagnostics)
+ if !ok {
+ return
+ }
+
+ apiClient := sqlserverflexalphaUtils.ConfigureClient(ctx, &r.providerData, &resp.Diagnostics)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ r.client = apiClient
+ tflog.Info(ctx, "SQLServer Alpha Flex user client configured")
+}
+
+// ModifyPlan implements resource.ResourceWithModifyPlan.
+// Use the modifier to set the effective region in the current plan.
+func (r *userResource) ModifyPlan(
+ ctx context.Context,
+ req resource.ModifyPlanRequest,
+ resp *resource.ModifyPlanResponse,
+) { // nolint:gocritic // function signature required by Terraform
+ var configModel Model
+ // skip initial empty configuration to avoid follow-up errors
+ if req.Config.Raw.IsNull() {
+ return
+ }
+ resp.Diagnostics.Append(req.Config.Get(ctx, &configModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ var planModel Model
+ resp.Diagnostics.Append(req.Plan.Get(ctx, &planModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ utils.AdaptRegion(ctx, configModel.Region, &planModel.Region, r.providerData.GetRegion(), resp)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ resp.Diagnostics.Append(resp.Plan.Set(ctx, planModel)...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+}
+
+// Schema defines the schema for the resource.
+func (r *userResource) Schema(_ context.Context, _ resource.SchemaRequest, resp *resource.SchemaResponse) {
+ descriptions := map[string]string{
+ "main": "SQLServer Flex user resource schema. Must have a `region` specified in the provider configuration.",
+ "id": "Terraform's internal resource ID. It is structured as \"`project_id`,`region`,`instance_id`,`user_id`\".",
+ "user_id": "User ID.",
+ "instance_id": "ID of the SQLServer Flex instance.",
+ "project_id": "STACKIT project ID to which the instance is associated.",
+ "username": "Username of the SQLServer Flex instance.",
+ "roles": "Database access levels for the user. The values for the default roles are: `##STACKIT_DatabaseManager##`, `##STACKIT_LoginManager##`, `##STACKIT_ProcessManager##`, `##STACKIT_ServerManager##`, `##STACKIT_SQLAgentManager##`, `##STACKIT_SQLAgentUser##`",
+ "password": "Password of the user account.",
+ "status": "Status of the user.",
+ "default_database": "Default database of the user.",
+ }
+
+ resp.Schema = schema.Schema{
+ Description: descriptions["main"],
+ Attributes: map[string]schema.Attribute{
+ "id": schema.StringAttribute{
+ Description: descriptions["id"],
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "user_id": schema.StringAttribute{
+ Description: descriptions["user_id"],
+ Computed: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.NoSeparator(),
+ },
+ },
+ "instance_id": schema.StringAttribute{
+ Description: descriptions["instance_id"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "project_id": schema.StringAttribute{
+ Description: descriptions["project_id"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ Validators: []validator.String{
+ validate.UUID(),
+ validate.NoSeparator(),
+ },
+ },
+ "username": schema.StringAttribute{
+ Description: descriptions["username"],
+ Required: true,
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ stringplanmodifier.UseStateForUnknown(),
+ },
+ },
+ "roles": schema.SetAttribute{
+ Description: descriptions["roles"],
+ ElementType: types.StringType,
+ Required: true,
+ PlanModifiers: []planmodifier.Set{
+ setplanmodifier.RequiresReplace(),
+ },
+ },
+ "password": schema.StringAttribute{
+ Description: descriptions["password"],
+ Computed: true,
+ Sensitive: true,
+ },
+ "host": schema.StringAttribute{
+ Computed: true,
+ },
+ "port": schema.Int64Attribute{
+ Computed: true,
+ },
+ "region": schema.StringAttribute{
+ Optional: true,
+ // must be computed to allow for storing the override value from the provider
+ Computed: true,
+ Description: descriptions["region"],
+ PlanModifiers: []planmodifier.String{
+ stringplanmodifier.RequiresReplace(),
+ },
+ },
+ "status": schema.StringAttribute{
+ Computed: true,
+ },
+ "default_database": schema.StringAttribute{
+ Computed: true,
+ },
+ },
+ }
+}
+
+// Create creates the resource and sets the initial Terraform state.
+func (r *userResource) Create(
+ ctx context.Context,
+ req resource.CreateRequest,
+ resp *resource.CreateResponse,
+) { // nolint:gocritic // function signature required by Terraform
+ var model Model
+ diags := req.Plan.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ region := model.Region.ValueString()
+
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ var roles []sqlserverflexalpha.UserRole
+ if !(model.Roles.IsNull() || model.Roles.IsUnknown()) {
+ diags = model.Roles.ElementsAs(ctx, &roles, false)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ }
+
+ // Generate API request body from model
+ payload, err := toCreatePayload(&model, roles)
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating user", fmt.Sprintf("Creating API payload: %v", err))
+ return
+ }
+ // Create new user
+ userResp, err := r.client.CreateUserRequest(
+ ctx,
+ projectId,
+ region,
+ instanceId,
+ ).CreateUserRequestPayload(*payload).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error creating user", fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ if userResp == nil || userResp.Id == nil || *userResp.Id == 0 {
+ core.LogAndAddError(
+ ctx,
+ &resp.Diagnostics,
+ "Error creating user",
+ "API didn't return user Id. A user might have been created",
+ )
+ return
+ }
+ userId := *userResp.Id
+ ctx = tflog.SetField(ctx, "user_id", userId)
+
+ // Map response body to schema
+ err = mapFieldsCreate(userResp, &model, region)
+ if err != nil {
+ core.LogAndAddError(
+ ctx,
+ &resp.Diagnostics,
+ "Error creating user",
+ fmt.Sprintf("Processing API payload: %v", err),
+ )
+ return
+ }
+ // Set state to fully populated data
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "SQLServer Flex user created")
+}
+
+// Read refreshes the Terraform state with the latest data.
+func (r *userResource) Read(
+ ctx context.Context,
+ req resource.ReadRequest,
+ resp *resource.ReadResponse,
+) { // nolint:gocritic // function signature required by Terraform
+ var model Model
+ diags := req.State.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ userId := model.UserId.ValueInt64()
+ region := r.providerData.GetRegionWithOverride(model.Region)
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "user_id", userId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ recordSetResp, err := r.client.GetUserRequest(ctx, projectId, region, instanceId, userId).Execute()
+ if err != nil {
+ var oapiErr *oapierror.GenericOpenAPIError
+ ok := errors.As(
+ err,
+ &oapiErr,
+ )
+ //nolint:errorlint //complaining that error.As should be used to catch wrapped errors, but this error should not be wrapped
+ if ok && oapiErr.StatusCode == http.StatusNotFound {
+ resp.State.RemoveResource(ctx)
+ return
+ }
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error reading user", fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ // Map response body to schema
+ err = mapFields(recordSetResp, &model, region)
+ if err != nil {
+ core.LogAndAddError(
+ ctx,
+ &resp.Diagnostics,
+ "Error reading user",
+ fmt.Sprintf("Processing API payload: %v", err),
+ )
+ return
+ }
+
+ // Set refreshed state
+ diags = resp.State.Set(ctx, model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+ tflog.Info(ctx, "SQLServer Flex user read")
+}
+
+// Update updates the resource and sets the updated Terraform state on success.
+func (r *userResource) Update(
+ ctx context.Context,
+ _ resource.UpdateRequest,
+ resp *resource.UpdateResponse,
+) { // nolint:gocritic // function signature required by Terraform
+ // Update shouldn't be called
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error updating user", "User can't be updated")
+}
+
+// Delete deletes the resource and removes the Terraform state on success.
+func (r *userResource) Delete(
+ ctx context.Context,
+ req resource.DeleteRequest,
+ resp *resource.DeleteResponse,
+) { // nolint:gocritic // function signature required by Terraform
+ // Retrieve values from plan
+ var model Model
+ diags := req.State.Get(ctx, &model)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ ctx = core.InitProviderContext(ctx)
+
+ projectId := model.ProjectId.ValueString()
+ instanceId := model.InstanceId.ValueString()
+ userId := model.UserId.ValueInt64()
+ region := model.Region.ValueString()
+ ctx = tflog.SetField(ctx, "project_id", projectId)
+ ctx = tflog.SetField(ctx, "instance_id", instanceId)
+ ctx = tflog.SetField(ctx, "user_id", userId)
+ ctx = tflog.SetField(ctx, "region", region)
+
+ // Delete existing record set
+ err := r.client.DeleteUserRequest(ctx, projectId, region, instanceId, userId).Execute()
+ if err != nil {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "Error deleting user", fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ ctx = core.LogResponse(ctx)
+
+ tflog.Info(ctx, "SQLServer Flex user deleted")
+}
+
+// ImportState imports a resource into the Terraform state on success.
+// The expected format of the resource import identifier is: project_id,zone_id,record_set_id
+func (r *userResource) ImportState(
+ ctx context.Context,
+ req resource.ImportStateRequest,
+ resp *resource.ImportStateResponse,
+) {
+ idParts := strings.Split(req.ID, core.Separator)
+ if len(idParts) != 4 || idParts[0] == "" || idParts[1] == "" || idParts[2] == "" || idParts[3] == "" {
+ core.LogAndAddError(
+ ctx, &resp.Diagnostics,
+ "Error importing user",
+ fmt.Sprintf(
+ "Expected import identifier with format [project_id],[region],[instance_id],[user_id], got %q",
+ req.ID,
+ ),
+ )
+ return
+ }
+
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("project_id"), idParts[0])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("region"), idParts[1])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("instance_id"), idParts[2])...)
+ resp.Diagnostics.Append(resp.State.SetAttribute(ctx, path.Root("user_id"), idParts[3])...)
+ core.LogAndAddWarning(
+ ctx,
+ &resp.Diagnostics,
+ "SQLServer Flex user imported with empty password",
+ "The user password is not imported as it is only available upon creation of a new user. The password field will be empty.",
+ )
+ tflog.Info(ctx, "SQLServer Flex user state imported")
+}
+
+func mapFieldsCreate(userResp *sqlserverflexalpha.CreateUserResponse, model *Model, region string) error {
+ if userResp == nil {
+ return fmt.Errorf("response is nil")
+ }
+ if model == nil {
+ return fmt.Errorf("model input is nil")
+ }
+ user := userResp
+
+ if user.Id == nil {
+ return fmt.Errorf("user id not present")
+ }
+ userId := *user.Id
+ model.Id = utils.BuildInternalTerraformId(
+ model.ProjectId.ValueString(),
+ region,
+ model.InstanceId.ValueString(),
+ strconv.FormatInt(userId, 10),
+ )
+ model.UserId = types.Int64Value(userId)
+ model.Username = types.StringPointerValue(user.Username)
+
+ if user.Password == nil {
+ return fmt.Errorf("user password not present")
+ }
+ model.Password = types.StringValue(*user.Password)
+
+ if user.Roles != nil {
+ var roles []attr.Value
+ for _, role := range *user.Roles {
+ roles = append(roles, types.StringValue(string(role)))
+ }
+ rolesSet, diags := types.SetValue(types.StringType, roles)
+ if diags.HasError() {
+ return fmt.Errorf("failed to map roles: %w", core.DiagsToError(diags))
+ }
+ model.Roles = rolesSet
+ }
+
+ if model.Roles.IsNull() || model.Roles.IsUnknown() {
+ model.Roles = types.SetNull(types.StringType)
+ }
+
+ model.Host = types.StringPointerValue(user.Host)
+ model.Port = types.Int64PointerValue(user.Port)
+ model.Region = types.StringValue(region)
+ model.Status = types.StringPointerValue(user.Status)
+ model.DefaultDatabase = types.StringPointerValue(user.DefaultDatabase)
+
+ return nil
+}
+
+func mapFields(userResp *sqlserverflexalpha.GetUserResponse, model *Model, region string) error {
+ if userResp == nil {
+ return fmt.Errorf("response is nil")
+ }
+ if model == nil {
+ return fmt.Errorf("model input is nil")
+ }
+ user := userResp
+
+ var userId int64
+ if model.UserId.ValueInt64() != 0 {
+ userId = model.UserId.ValueInt64()
+ } else if user.Id != nil {
+ userId = *user.Id
+ } else {
+ return fmt.Errorf("user id not present")
+ }
+ model.Id = utils.BuildInternalTerraformId(
+ model.ProjectId.ValueString(),
+ region,
+ model.InstanceId.ValueString(),
+ strconv.FormatInt(userId, 10),
+ )
+ model.UserId = types.Int64Value(userId)
+ model.Username = types.StringPointerValue(user.Username)
+
+ if user.Roles != nil {
+ var roles []attr.Value
+ for _, role := range *user.Roles {
+ roles = append(roles, types.StringValue(string(role)))
+ }
+ rolesSet, diags := types.SetValue(types.StringType, roles)
+ if diags.HasError() {
+ return fmt.Errorf("failed to map roles: %w", core.DiagsToError(diags))
+ }
+ model.Roles = rolesSet
+ }
+
+ if model.Roles.IsNull() || model.Roles.IsUnknown() {
+ model.Roles = types.SetNull(types.StringType)
+ }
+
+ model.Host = types.StringPointerValue(user.Host)
+ model.Port = types.Int64PointerValue(user.Port)
+ model.Region = types.StringValue(region)
+ return nil
+}
+
+func toCreatePayload(
+ model *Model,
+ roles []sqlserverflexalpha.UserRole,
+) (*sqlserverflexalpha.CreateUserRequestPayload, error) {
+ if model == nil {
+ return nil, fmt.Errorf("nil model")
+ }
+
+ return &sqlserverflexalpha.CreateUserRequestPayload{
+ Username: conversion.StringValueToPointer(model.Username),
+ DefaultDatabase: conversion.StringValueToPointer(model.DefaultDatabase),
+ Roles: &roles,
+ }, nil
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/user/resource_test.go b/stackit/internal/services/sqlserverflexalpha/user/resource_test.go
new file mode 100644
index 00000000..8277203a
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/user/resource_test.go
@@ -0,0 +1,387 @@
+// Copyright (c) STACKIT
+
+package sqlserverflexalpha
+
+import (
+ "testing"
+
+ "github.com/google/go-cmp/cmp"
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+)
+
+func TestMapFieldsCreate(t *testing.T) {
+ const testRegion = "region"
+ tests := []struct {
+ description string
+ input *sqlserverflexalpha.CreateUserResponse
+ region string
+ expected Model
+ isValid bool
+ }{
+ {
+ "default_values",
+ &sqlserverflexalpha.CreateUserResponse{
+ Id: utils.Ptr(int64(1)),
+ Password: utils.Ptr(""),
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,1"),
+ UserId: types.Int64Value(1),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringNull(),
+ Roles: types.SetNull(types.StringType),
+ Password: types.StringValue(""),
+ Host: types.StringNull(),
+ Port: types.Int64Null(),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "simple_values",
+ &sqlserverflexalpha.CreateUserResponse{
+ Id: utils.Ptr(int64(2)),
+ Roles: &[]sqlserverflexalpha.UserRole{
+ "role_1",
+ "role_2",
+ "",
+ },
+ Username: utils.Ptr("username"),
+ Password: utils.Ptr("password"),
+ Host: utils.Ptr("host"),
+ Port: utils.Ptr(int64(1234)),
+ Status: utils.Ptr("status"),
+ DefaultDatabase: utils.Ptr("default_db"),
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,2"),
+ UserId: types.Int64Value(2),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringValue("username"),
+ Roles: types.SetValueMust(
+ types.StringType, []attr.Value{
+ types.StringValue("role_1"),
+ types.StringValue("role_2"),
+ types.StringValue(""),
+ },
+ ),
+ Password: types.StringValue("password"),
+ Host: types.StringValue("host"),
+ Port: types.Int64Value(1234),
+ Region: types.StringValue(testRegion),
+ Status: types.StringValue("status"),
+ DefaultDatabase: types.StringValue("default_db"),
+ },
+ true,
+ },
+ {
+ "null_fields_and_int_conversions",
+ &sqlserverflexalpha.CreateUserResponse{
+ Id: utils.Ptr(int64(3)),
+ Roles: &[]sqlserverflexalpha.UserRole{},
+ Username: nil,
+ Password: utils.Ptr(""),
+ Host: nil,
+ Port: utils.Ptr(int64(2123456789)),
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,3"),
+ UserId: types.Int64Value(3),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringNull(),
+ Roles: types.SetValueMust(types.StringType, []attr.Value{}),
+ Password: types.StringValue(""),
+ Host: types.StringNull(),
+ Port: types.Int64Value(2123456789),
+ Region: types.StringValue(testRegion),
+ DefaultDatabase: types.StringNull(),
+ Status: types.StringNull(),
+ },
+ true,
+ },
+ {
+ "nil_response",
+ nil,
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "nil_response_2",
+ &sqlserverflexalpha.CreateUserResponse{},
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "no_resource_id",
+ &sqlserverflexalpha.CreateUserResponse{},
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "no_password",
+ &sqlserverflexalpha.CreateUserResponse{
+ Id: utils.Ptr(int64(1)),
+ },
+ testRegion,
+ Model{},
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(
+ tt.description, func(t *testing.T) {
+ state := &Model{
+ ProjectId: tt.expected.ProjectId,
+ InstanceId: tt.expected.InstanceId,
+ }
+ err := mapFieldsCreate(tt.input, state, tt.region)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(state, &tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ },
+ )
+ }
+}
+
+func TestMapFields(t *testing.T) {
+ const testRegion = "region"
+ tests := []struct {
+ description string
+ input *sqlserverflexalpha.GetUserResponse
+ region string
+ expected Model
+ isValid bool
+ }{
+ {
+ "default_values",
+ &sqlserverflexalpha.GetUserResponse{},
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,1"),
+ UserId: types.Int64Value(1),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringNull(),
+ Roles: types.SetNull(types.StringType),
+ Host: types.StringNull(),
+ Port: types.Int64Null(),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "simple_values",
+ &sqlserverflexalpha.GetUserResponse{
+ Roles: &[]sqlserverflexalpha.UserRole{
+ "role_1",
+ "role_2",
+ "",
+ },
+ Username: utils.Ptr("username"),
+ Host: utils.Ptr("host"),
+ Port: utils.Ptr(int64(1234)),
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,2"),
+ UserId: types.Int64Value(2),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringValue("username"),
+ Roles: types.SetValueMust(
+ types.StringType, []attr.Value{
+ types.StringValue("role_1"),
+ types.StringValue("role_2"),
+ types.StringValue(""),
+ },
+ ),
+ Host: types.StringValue("host"),
+ Port: types.Int64Value(1234),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "null_fields_and_int_conversions",
+ &sqlserverflexalpha.GetUserResponse{
+ Id: utils.Ptr(int64(1)),
+ Roles: &[]sqlserverflexalpha.UserRole{},
+ Username: nil,
+ Host: nil,
+ Port: utils.Ptr(int64(2123456789)),
+ },
+ testRegion,
+ Model{
+ Id: types.StringValue("pid,region,iid,1"),
+ UserId: types.Int64Value(1),
+ InstanceId: types.StringValue("iid"),
+ ProjectId: types.StringValue("pid"),
+ Username: types.StringNull(),
+ Roles: types.SetValueMust(types.StringType, []attr.Value{}),
+ Host: types.StringNull(),
+ Port: types.Int64Value(2123456789),
+ Region: types.StringValue(testRegion),
+ },
+ true,
+ },
+ {
+ "nil_response",
+ nil,
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "nil_response_2",
+ &sqlserverflexalpha.GetUserResponse{},
+ testRegion,
+ Model{},
+ false,
+ },
+ {
+ "no_resource_id",
+ &sqlserverflexalpha.GetUserResponse{},
+ testRegion,
+ Model{},
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(
+ tt.description, func(t *testing.T) {
+ state := &Model{
+ ProjectId: tt.expected.ProjectId,
+ InstanceId: tt.expected.InstanceId,
+ UserId: tt.expected.UserId,
+ }
+ err := mapFields(tt.input, state, tt.region)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(state, &tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ },
+ )
+ }
+}
+
+func TestToCreatePayload(t *testing.T) {
+ tests := []struct {
+ description string
+ input *Model
+ inputRoles []sqlserverflexalpha.UserRole
+ expected *sqlserverflexalpha.CreateUserRequestPayload
+ isValid bool
+ }{
+ {
+ "default_values",
+ &Model{},
+ []sqlserverflexalpha.UserRole{},
+ &sqlserverflexalpha.CreateUserRequestPayload{
+ Roles: &[]sqlserverflexalpha.UserRole{},
+ Username: nil,
+ },
+ true,
+ },
+ {
+ "default_values",
+ &Model{
+ Username: types.StringValue("username"),
+ },
+ []sqlserverflexalpha.UserRole{
+ "role_1",
+ "role_2",
+ },
+ &sqlserverflexalpha.CreateUserRequestPayload{
+ Roles: &[]sqlserverflexalpha.UserRole{
+ "role_1",
+ "role_2",
+ },
+ Username: utils.Ptr("username"),
+ },
+ true,
+ },
+ {
+ "null_fields_and_int_conversions",
+ &Model{
+ Username: types.StringNull(),
+ },
+ []sqlserverflexalpha.UserRole{
+ "",
+ },
+ &sqlserverflexalpha.CreateUserRequestPayload{
+ Roles: &[]sqlserverflexalpha.UserRole{
+ "",
+ },
+ Username: nil,
+ },
+ true,
+ },
+ {
+ "nil_model",
+ nil,
+ []sqlserverflexalpha.UserRole{},
+ nil,
+ false,
+ },
+ {
+ "nil_roles",
+ &Model{
+ Username: types.StringValue("username"),
+ },
+ []sqlserverflexalpha.UserRole{},
+ &sqlserverflexalpha.CreateUserRequestPayload{
+ Roles: &[]sqlserverflexalpha.UserRole{},
+ Username: utils.Ptr("username"),
+ },
+ true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(
+ tt.description, func(t *testing.T) {
+ output, err := toCreatePayload(tt.input, tt.inputRoles)
+ if !tt.isValid && err == nil {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && err != nil {
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if tt.isValid {
+ diff := cmp.Diff(output, tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ }
+ },
+ )
+ }
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/utils/util.go b/stackit/internal/services/sqlserverflexalpha/utils/util.go
new file mode 100644
index 00000000..3c49e1b9
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/utils/util.go
@@ -0,0 +1,49 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "context"
+ "fmt"
+
+ sqlserverflex "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+)
+
+func ConfigureClient(
+ ctx context.Context,
+ providerData *core.ProviderData,
+ diags *diag.Diagnostics,
+) *sqlserverflex.APIClient {
+ apiClientConfigOptions := []config.ConfigurationOption{
+ config.WithCustomAuth(providerData.RoundTripper),
+ utils.UserAgentConfigOption(providerData.Version),
+ }
+ if providerData.SQLServerFlexCustomEndpoint != "" {
+ apiClientConfigOptions = append(
+ apiClientConfigOptions,
+ config.WithEndpoint(providerData.SQLServerFlexCustomEndpoint),
+ )
+ } else {
+ apiClientConfigOptions = append(apiClientConfigOptions, config.WithRegion(providerData.GetRegion()))
+ }
+ apiClient, err := sqlserverflex.NewAPIClient(apiClientConfigOptions...)
+ if err != nil {
+ core.LogAndAddError(
+ ctx,
+ diags,
+ "Error configuring API client",
+ fmt.Sprintf(
+ "Configuring client: %v. This is an error related to the provider configuration, not to the resource configuration",
+ err,
+ ),
+ )
+ return nil
+ }
+
+ return apiClient
+}
diff --git a/stackit/internal/services/sqlserverflexalpha/utils/util_test.go b/stackit/internal/services/sqlserverflexalpha/utils/util_test.go
new file mode 100644
index 00000000..cfa3f198
--- /dev/null
+++ b/stackit/internal/services/sqlserverflexalpha/utils/util_test.go
@@ -0,0 +1,99 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "context"
+ "os"
+ "reflect"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ sdkClients "github.com/stackitcloud/stackit-sdk-go/core/clients"
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+ "github.com/stackitcloud/terraform-provider-stackit/pkg/sqlserverflexalpha"
+
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+)
+
+const (
+ testVersion = "1.2.3"
+ testCustomEndpoint = "https://sqlserverflex-custom-endpoint.api.stackit.cloud"
+)
+
+func TestConfigureClient(t *testing.T) {
+ /* mock authentication by setting service account token env variable */
+ os.Clearenv()
+ err := os.Setenv(sdkClients.ServiceAccountToken, "mock-val")
+ if err != nil {
+ t.Errorf("error setting env variable: %v", err)
+ }
+
+ type args struct {
+ providerData *core.ProviderData
+ }
+ tests := []struct {
+ name string
+ args args
+ wantErr bool
+ expected *sqlserverflexalpha.APIClient
+ }{
+ {
+ name: "default endpoint",
+ args: args{
+ providerData: &core.ProviderData{
+ Version: testVersion,
+ },
+ },
+ expected: func() *sqlserverflexalpha.APIClient {
+ apiClient, err := sqlserverflexalpha.NewAPIClient(
+ config.WithRegion("eu01"),
+ utils.UserAgentConfigOption(testVersion),
+ )
+ if err != nil {
+ t.Errorf("error configuring client: %v", err)
+ }
+ return apiClient
+ }(),
+ wantErr: false,
+ },
+ {
+ name: "custom endpoint",
+ args: args{
+ providerData: &core.ProviderData{
+ Version: testVersion,
+ SQLServerFlexCustomEndpoint: testCustomEndpoint,
+ },
+ },
+ expected: func() *sqlserverflexalpha.APIClient {
+ apiClient, err := sqlserverflexalpha.NewAPIClient(
+ utils.UserAgentConfigOption(testVersion),
+ config.WithEndpoint(testCustomEndpoint),
+ )
+ if err != nil {
+ t.Errorf("error configuring client: %v", err)
+ }
+ return apiClient
+ }(),
+ wantErr: false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(
+ tt.name, func(t *testing.T) {
+ ctx := context.Background()
+ diags := diag.Diagnostics{}
+
+ actual := ConfigureClient(ctx, tt.args.providerData, &diags)
+ if diags.HasError() != tt.wantErr {
+ t.Errorf("ConfigureClient() error = %v, want %v", diags.HasError(), tt.wantErr)
+ }
+
+ if !reflect.DeepEqual(actual, tt.expected) {
+ t.Errorf("ConfigureClient() = %v, want %v", actual, tt.expected)
+ }
+ },
+ )
+ }
+}
diff --git a/stackit/internal/testutil/testutil.go b/stackit/internal/testutil/testutil.go
new file mode 100644
index 00000000..fd7d95ff
--- /dev/null
+++ b/stackit/internal/testutil/testutil.go
@@ -0,0 +1,610 @@
+// Copyright (c) STACKIT
+
+package testutil
+
+import (
+ "encoding/json"
+ "fmt"
+ "os"
+ "path/filepath"
+ "strings"
+ "time"
+
+ "github.com/hashicorp/terraform-plugin-framework/providerserver"
+ "github.com/hashicorp/terraform-plugin-go/tfprotov6"
+ "github.com/hashicorp/terraform-plugin-testing/config"
+ "github.com/hashicorp/terraform-plugin-testing/echoprovider"
+
+ "github.com/stackitcloud/terraform-provider-stackit/stackit"
+)
+
+const (
+ // Default location of credentials JSON
+ credentialsFilePath = ".stackit/credentials.json" //nolint:gosec // linter false positive
+)
+
+var (
+ // TestAccProtoV6ProviderFactories is used to instantiate a provider during
+ // acceptance testing. The factory function will be invoked for every Terraform
+ // CLI command executed to create a provider server to which the CLI can
+ // reattach.
+ TestAccProtoV6ProviderFactories = map[string]func() (tfprotov6.ProviderServer, error){
+ "stackit": providerserver.NewProtocol6WithError(stackit.New("test-version")()),
+ }
+
+ // TestEphemeralAccProtoV6ProviderFactories is used to instantiate a provider during
+ // acceptance testing. The factory function will be invoked for every Terraform
+ // CLI command executed to create a provider server to which the CLI can
+ // reattach.
+ //
+ // See the Terraform acceptance test documentation on ephemeral resources for more information:
+ // https://developer.hashicorp.com/terraform/plugin/testing/acceptance-tests/ephemeral-resources
+ TestEphemeralAccProtoV6ProviderFactories = map[string]func() (tfprotov6.ProviderServer, error){
+ "stackit": providerserver.NewProtocol6WithError(stackit.New("test-version")()),
+ "echo": echoprovider.NewProviderServer(),
+ }
+
+ // E2ETestsEnabled checks if end-to-end tests should be run.
+ // It is enabled when the TF_ACC environment variable is set to "1".
+ E2ETestsEnabled = os.Getenv("TF_ACC") == "1"
+ // OrganizationId is the id of organization used for tests
+ OrganizationId = os.Getenv("TF_ACC_ORGANIZATION_ID")
+ // ProjectId is the id of project used for tests
+ ProjectId = os.Getenv("TF_ACC_PROJECT_ID")
+ Region = os.Getenv("TF_ACC_REGION")
+ // ServerId is the id of a server used for some tests
+ ServerId = getenv("TF_ACC_SERVER_ID", "")
+ // TestProjectParentContainerID is the container id of the parent resource under which projects are created as part of the resource-manager acceptance tests
+ TestProjectParentContainerID = os.Getenv("TF_ACC_TEST_PROJECT_PARENT_CONTAINER_ID")
+ // TestProjectParentUUID is the uuid of the parent resource under which projects are created as part of the resource-manager acceptance tests
+ TestProjectParentUUID = os.Getenv("TF_ACC_TEST_PROJECT_PARENT_UUID")
+ // TestProjectServiceAccountEmail is the e-mail of a service account with admin permissions on the organization under which projects are created as part of the resource-manager acceptance tests
+ TestProjectServiceAccountEmail = os.Getenv("TF_ACC_TEST_PROJECT_SERVICE_ACCOUNT_EMAIL")
+ // TestProjectUserEmail is the e-mail of a user for the project created as part of the resource-manager acceptance tests
+ // Default email: acc-test@sa.stackit.cloud
+ TestProjectUserEmail = getenv("TF_ACC_TEST_PROJECT_USER_EMAIL", "acc-test@sa.stackit.cloud")
+ // TestImageLocalFilePath is the local path to an image file used for image acceptance tests
+ TestImageLocalFilePath = getenv("TF_ACC_TEST_IMAGE_LOCAL_FILE_PATH", "default")
+
+ CdnCustomEndpoint = os.Getenv("TF_ACC_CDN_CUSTOM_ENDPOINT")
+ DnsCustomEndpoint = os.Getenv("TF_ACC_DNS_CUSTOM_ENDPOINT")
+ GitCustomEndpoint = os.Getenv("TF_ACC_GIT_CUSTOM_ENDPOINT")
+ IaaSCustomEndpoint = os.Getenv("TF_ACC_IAAS_CUSTOM_ENDPOINT")
+ KMSCustomEndpoint = os.Getenv("TF_ACC_KMS_CUSTOM_ENDPOINT")
+ LoadBalancerCustomEndpoint = os.Getenv("TF_ACC_LOADBALANCER_CUSTOM_ENDPOINT")
+ LogMeCustomEndpoint = os.Getenv("TF_ACC_LOGME_CUSTOM_ENDPOINT")
+ MariaDBCustomEndpoint = os.Getenv("TF_ACC_MARIADB_CUSTOM_ENDPOINT")
+ ModelServingCustomEndpoint = os.Getenv("TF_ACC_MODELSERVING_CUSTOM_ENDPOINT")
+ AuthorizationCustomEndpoint = os.Getenv("TF_ACC_authorization_custom_endpoint")
+ MongoDBFlexCustomEndpoint = os.Getenv("TF_ACC_MONGODBFLEX_CUSTOM_ENDPOINT")
+ OpenSearchCustomEndpoint = os.Getenv("TF_ACC_OPENSEARCH_CUSTOM_ENDPOINT")
+ ObservabilityCustomEndpoint = os.Getenv("TF_ACC_OBSERVABILITY_CUSTOM_ENDPOINT")
+ ObjectStorageCustomEndpoint = os.Getenv("TF_ACC_OBJECTSTORAGE_CUSTOM_ENDPOINT")
+ PostgresFlexCustomEndpoint = os.Getenv("TF_ACC_POSTGRESFLEX_CUSTOM_ENDPOINT")
+ RabbitMQCustomEndpoint = os.Getenv("TF_ACC_RABBITMQ_CUSTOM_ENDPOINT")
+ RedisCustomEndpoint = os.Getenv("TF_ACC_REDIS_CUSTOM_ENDPOINT")
+ ResourceManagerCustomEndpoint = os.Getenv("TF_ACC_RESOURCEMANAGER_CUSTOM_ENDPOINT")
+ ScfCustomEndpoint = os.Getenv("TF_ACC_SCF_CUSTOM_ENDPOINT")
+ SecretsManagerCustomEndpoint = os.Getenv("TF_ACC_SECRETSMANAGER_CUSTOM_ENDPOINT")
+ SQLServerFlexCustomEndpoint = os.Getenv("TF_ACC_SQLSERVERFLEX_CUSTOM_ENDPOINT")
+ ServerBackupCustomEndpoint = os.Getenv("TF_ACC_SERVER_BACKUP_CUSTOM_ENDPOINT")
+ ServerUpdateCustomEndpoint = os.Getenv("TF_ACC_SERVER_UPDATE_CUSTOM_ENDPOINT")
+ ServiceAccountCustomEndpoint = os.Getenv("TF_ACC_SERVICE_ACCOUNT_CUSTOM_ENDPOINT")
+ SKECustomEndpoint = os.Getenv("TF_ACC_SKE_CUSTOM_ENDPOINT")
+)
+
+// Provider config helper functions
+
+func ObservabilityProviderConfig() string {
+ if ObservabilityCustomEndpoint == "" {
+ return `provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ observability_custom_endpoint = "%s"
+ }`,
+ ObservabilityCustomEndpoint,
+ )
+}
+func CdnProviderConfig() string {
+ if CdnCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ enable_beta_resources = true
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ cdn_custom_endpoint = "%s"
+ enable_beta_resources = true
+ }`,
+ CdnCustomEndpoint,
+ )
+}
+
+func DnsProviderConfig() string {
+ if DnsCustomEndpoint == "" {
+ return `provider "stackit" {}`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ dns_custom_endpoint = "%s"
+ }`,
+ DnsCustomEndpoint,
+ )
+}
+
+func IaaSProviderConfig() string {
+ if IaaSCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ iaas_custom_endpoint = "%s"
+ }`,
+ IaaSCustomEndpoint,
+ )
+}
+
+func IaaSProviderConfigWithBetaResourcesEnabled() string {
+ if IaaSCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ enable_beta_resources = true
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ enable_beta_resources = true
+ iaas_custom_endpoint = "%s"
+ }`,
+ IaaSCustomEndpoint,
+ )
+}
+
+func IaaSProviderConfigWithExperiments() string {
+ if IaaSCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ experiments = [ "routing-tables", "network" ]
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ iaas_custom_endpoint = "%s"
+ experiments = [ "routing-tables", "network" ]
+ }`,
+ IaaSCustomEndpoint,
+ )
+}
+
+func KMSProviderConfig() string {
+ if KMSCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ kms_custom_endpoint = "%s"
+ }`,
+ KMSCustomEndpoint,
+ )
+}
+
+func LoadBalancerProviderConfig() string {
+ if LoadBalancerCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ loadbalancer_custom_endpoint = "%s"
+ }`,
+ LoadBalancerCustomEndpoint,
+ )
+}
+
+func LogMeProviderConfig() string {
+ if LogMeCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ logme_custom_endpoint = "%s"
+ }`,
+ LogMeCustomEndpoint,
+ )
+}
+
+func MariaDBProviderConfig() string {
+ if MariaDBCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ mariadb_custom_endpoint = "%s"
+ }`,
+ MariaDBCustomEndpoint,
+ )
+}
+
+func ModelServingProviderConfig() string {
+ if ModelServingCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }
+ `
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ modelserving_custom_endpoint = "%s"
+ }`,
+ ModelServingCustomEndpoint,
+ )
+}
+
+func MongoDBFlexProviderConfig() string {
+ if MongoDBFlexCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ mongodbflex_custom_endpoint = "%s"
+ }`,
+ MongoDBFlexCustomEndpoint,
+ )
+}
+
+func ObjectStorageProviderConfig() string {
+ if ObjectStorageCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ objectstorage_custom_endpoint = "%s"
+ }`,
+ ObjectStorageCustomEndpoint,
+ )
+}
+
+func OpenSearchProviderConfig() string {
+ if OpenSearchCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ opensearch_custom_endpoint = "%s"
+ }`,
+ OpenSearchCustomEndpoint,
+ )
+}
+
+func PostgresFlexProviderConfig() string {
+ if PostgresFlexCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ postgresflex_custom_endpoint = "%s"
+ }`,
+ PostgresFlexCustomEndpoint,
+ )
+}
+
+func RabbitMQProviderConfig() string {
+ if RabbitMQCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ rabbitmq_custom_endpoint = "%s"
+ }`,
+ RabbitMQCustomEndpoint,
+ )
+}
+
+func RedisProviderConfig() string {
+ if RedisCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ redis_custom_endpoint = "%s"
+ }`,
+ RedisCustomEndpoint,
+ )
+}
+
+func ResourceManagerProviderConfig() string {
+ token := GetTestProjectServiceAccountToken("")
+ if ResourceManagerCustomEndpoint == "" || AuthorizationCustomEndpoint == "" {
+ return fmt.Sprintf(`
+ provider "stackit" {
+ service_account_token = "%s"
+ }`,
+ token,
+ )
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ resourcemanager_custom_endpoint = "%s"
+ authorization_custom_endpoint = "%s"
+ service_account_token = "%s"
+ }`,
+ ResourceManagerCustomEndpoint,
+ AuthorizationCustomEndpoint,
+ token,
+ )
+}
+
+func SecretsManagerProviderConfig() string {
+ if SecretsManagerCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ secretsmanager_custom_endpoint = "%s"
+ }`,
+ SecretsManagerCustomEndpoint,
+ )
+}
+
+func SQLServerFlexProviderConfig() string {
+ if SQLServerFlexCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ sqlserverflex_custom_endpoint = "%s"
+ }`,
+ SQLServerFlexCustomEndpoint,
+ )
+}
+
+func ServerBackupProviderConfig() string {
+ if ServerBackupCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ enable_beta_resources = true
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ server_backup_custom_endpoint = "%s"
+ enable_beta_resources = true
+ }`,
+ ServerBackupCustomEndpoint,
+ )
+}
+
+func ServerUpdateProviderConfig() string {
+ if ServerUpdateCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ enable_beta_resources = true
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ server_update_custom_endpoint = "%s"
+ enable_beta_resources = true
+ }`,
+ ServerUpdateCustomEndpoint,
+ )
+}
+
+func SKEProviderConfig() string {
+ if SKECustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ ske_custom_endpoint = "%s"
+ }`,
+ SKECustomEndpoint,
+ )
+}
+
+func AuthorizationProviderConfig() string {
+ if AuthorizationCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ experiments = ["iam"]
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ authorization_custom_endpoint = "%s"
+ experiments = ["iam"]
+ }`,
+ AuthorizationCustomEndpoint,
+ )
+}
+
+func ServiceAccountProviderConfig() string {
+ if ServiceAccountCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ enable_beta_resources = true
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ service_account_custom_endpoint = "%s"
+ enable_beta_resources = true
+ }`,
+ ServiceAccountCustomEndpoint,
+ )
+}
+
+func GitProviderConfig() string {
+ if GitCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ enable_beta_resources = true
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ git_custom_endpoint = "%s"
+ enable_beta_resources = true
+ }`,
+ GitCustomEndpoint,
+ )
+}
+
+func ScfProviderConfig() string {
+ if ScfCustomEndpoint == "" {
+ return `
+ provider "stackit" {
+ default_region = "eu01"
+ }`
+ }
+ return fmt.Sprintf(`
+ provider "stackit" {
+ default_region = "eu01"
+ scf_custom_endpoint = "%s"
+ }`,
+ ScfCustomEndpoint,
+ )
+}
+
+func ResourceNameWithDateTime(name string) string {
+ dateTime := time.Now().Format(time.RFC3339)
+ // Remove timezone to have a smaller datetime
+ dateTimeTrimmed, _, _ := strings.Cut(dateTime, "+")
+ return fmt.Sprintf("tf-acc-%s-%s", name, dateTimeTrimmed)
+}
+
+func GetTestProjectServiceAccountToken(path string) string {
+ var err error
+ token, tokenSet := os.LookupEnv("TF_ACC_TEST_PROJECT_SERVICE_ACCOUNT_TOKEN")
+ if !tokenSet || token == "" {
+ token, err = readTestTokenFromCredentialsFile(path)
+ if err != nil {
+ return ""
+ }
+ }
+ return token
+}
+
+func readTestTokenFromCredentialsFile(path string) (string, error) {
+ if path == "" {
+ customPath, customPathSet := os.LookupEnv("STACKIT_CREDENTIALS_PATH")
+ if !customPathSet || customPath == "" {
+ path = credentialsFilePath
+ home, err := os.UserHomeDir()
+ if err != nil {
+ return "", fmt.Errorf("getting home directory: %w", err)
+ }
+ path = filepath.Join(home, path)
+ } else {
+ path = customPath
+ }
+ }
+
+ credentialsRaw, err := os.ReadFile(path)
+ if err != nil {
+ return "", fmt.Errorf("opening file: %w", err)
+ }
+
+ var credentials struct {
+ TF_ACC_TEST_PROJECT_SERVICE_ACCOUNT_TOKEN string `json:"TF_ACC_TEST_PROJECT_SERVICE_ACCOUNT_TOKEN"`
+ }
+ err = json.Unmarshal(credentialsRaw, &credentials)
+ if err != nil {
+ return "", fmt.Errorf("unmarshalling credentials: %w", err)
+ }
+ return credentials.TF_ACC_TEST_PROJECT_SERVICE_ACCOUNT_TOKEN, nil
+}
+
+func getenv(key, defaultValue string) string {
+ val := os.Getenv(key)
+ if val == "" {
+ return defaultValue
+ }
+ return val
+}
+
+// CreateDefaultLocalFile is a helper for local_file_path. No real data is created
+func CreateDefaultLocalFile() os.File {
+ // Define the file name and size
+ fileName := "test-512k.img"
+ size := 512 * 1024 // 512 KB
+
+ // Create the file
+ file, err := os.Create(fileName)
+ if err != nil {
+ panic(err)
+ }
+
+ // Seek to the desired position (512 KB)
+ _, err = file.Seek(int64(size), 0)
+ if err != nil {
+ panic(err)
+ }
+
+ return *file
+}
+
+func ConvertConfigVariable(variable config.Variable) string {
+ tmpByteArray, _ := variable.MarshalJSON()
+ // In case the variable is a string, the quotes should be removed
+ if tmpByteArray[0] == '"' && tmpByteArray[len(tmpByteArray)-1] == '"' {
+ result := string(tmpByteArray[1 : len(tmpByteArray)-1])
+ // Replace escaped quotes which where added MarshalJSON
+ rawString := strings.ReplaceAll(result, `\"`, `"`)
+ return rawString
+ }
+ return string(tmpByteArray)
+}
diff --git a/stackit/internal/testutil/testutil_test.go b/stackit/internal/testutil/testutil_test.go
new file mode 100644
index 00000000..f74ca81c
--- /dev/null
+++ b/stackit/internal/testutil/testutil_test.go
@@ -0,0 +1,50 @@
+// Copyright (c) STACKIT
+
+package testutil
+
+import (
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-testing/config"
+)
+
+func TestConvertConfigVariable(t *testing.T) {
+ tests := []struct {
+ name string
+ variable config.Variable
+ want string
+ }{
+ {
+ name: "string",
+ variable: config.StringVariable("test"),
+ want: "test",
+ },
+ {
+ name: "bool: true",
+ variable: config.BoolVariable(true),
+ want: "true",
+ },
+ {
+ name: "bool: false",
+ variable: config.BoolVariable(false),
+ want: "false",
+ },
+ {
+ name: "integer",
+ variable: config.IntegerVariable(10),
+ want: "10",
+ },
+ {
+ name: "quoted string",
+ variable: config.StringVariable(`instance =~ ".*"`),
+ want: `instance =~ ".*"`,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ if got := ConvertConfigVariable(tt.variable); got != tt.want {
+ t.Errorf("ConvertConfigVariable() = %v, want %v", got, tt.want)
+ }
+ })
+ }
+}
diff --git a/stackit/internal/utils/attributes.go b/stackit/internal/utils/attributes.go
new file mode 100644
index 00000000..4572960f
--- /dev/null
+++ b/stackit/internal/utils/attributes.go
@@ -0,0 +1,48 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "context"
+ "fmt"
+ "time"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/hashicorp/terraform-plugin-framework/path"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+)
+
+type attributeGetter interface {
+ GetAttribute(ctx context.Context, attributePath path.Path, target interface{}) diag.Diagnostics
+}
+
+func ToTime(ctx context.Context, format string, val types.String, target *time.Time) (diags diag.Diagnostics) {
+ var err error
+ text := val.ValueString()
+ *target, err = time.Parse(format, text)
+ if err != nil {
+ core.LogAndAddError(ctx, &diags, "cannot parse date", fmt.Sprintf("cannot parse date %q with format %q: %v", text, format, err))
+ return diags
+ }
+ return diags
+}
+
+// GetTimeFromStringAttribute retrieves a string attribute from e.g. a [plan.Plan], [tfsdk.Config] or a [tfsdk.State] and
+// converts it to a [time.Time] object with a given format, if possible.
+func GetTimeFromStringAttribute(ctx context.Context, attributePath path.Path, source attributeGetter, dateFormat string, target *time.Time) (diags diag.Diagnostics) {
+ var date types.String
+ diags.Append(source.GetAttribute(ctx, attributePath, &date)...)
+ if diags.HasError() {
+ return diags
+ }
+ if date.IsNull() || date.IsUnknown() {
+ return diags
+ }
+ diags.Append(ToTime(ctx, dateFormat, date, target)...)
+ if diags.HasError() {
+ return diags
+ }
+
+ return diags
+}
diff --git a/stackit/internal/utils/attributes_test.go b/stackit/internal/utils/attributes_test.go
new file mode 100644
index 00000000..cddaceb5
--- /dev/null
+++ b/stackit/internal/utils/attributes_test.go
@@ -0,0 +1,90 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "context"
+ "log"
+ "testing"
+ "time"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/hashicorp/terraform-plugin-framework/path"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+)
+
+type attributeGetterFunc func(ctx context.Context, attributePath path.Path, target interface{}) diag.Diagnostics
+
+func (a attributeGetterFunc) GetAttribute(ctx context.Context, attributePath path.Path, target interface{}) diag.Diagnostics {
+ return a(ctx, attributePath, target)
+}
+
+func mustLocation(name string) *time.Location {
+ loc, err := time.LoadLocation(name)
+ if err != nil {
+ log.Panicf("cannot load location %s: %v", name, err)
+ }
+ return loc
+}
+
+func TestGetTimeFromString(t *testing.T) {
+ type args struct {
+ path path.Path
+ source attributeGetterFunc
+ dateFormat string
+ }
+ tests := []struct {
+ name string
+ args args
+ wantErr bool
+ want time.Time
+ }{
+ {
+ name: "simple string",
+ args: args{
+ path: path.Root("foo"),
+ source: func(_ context.Context, _ path.Path, target interface{}) diag.Diagnostics {
+ t, ok := target.(*types.String)
+ if !ok {
+ log.Panicf("wrong type %T", target)
+ }
+ *t = types.StringValue("2025-02-06T09:41:00+01:00")
+ return nil
+ },
+ dateFormat: time.RFC3339,
+ },
+ want: time.Date(2025, 2, 6, 9, 41, 0, 0, mustLocation("Europe/Berlin")),
+ },
+ {
+ name: "invalid type",
+ args: args{
+ path: path.Root("foo"),
+ source: func(_ context.Context, p path.Path, _ interface{}) (diags diag.Diagnostics) {
+ diags.AddAttributeError(p, "kapow", "kapow")
+ return diags
+ },
+ dateFormat: time.RFC3339,
+ },
+ wantErr: true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ var target time.Time
+ gotDiags := GetTimeFromStringAttribute(context.Background(), tt.args.path, tt.args.source, tt.args.dateFormat, &target)
+ if tt.wantErr {
+ if !gotDiags.HasError() {
+ t.Errorf("expected error")
+ }
+ } else {
+ if gotDiags.HasError() {
+ t.Errorf("expected no errors, but got %v", gotDiags)
+ } else {
+ if want, got := tt.want, target; !want.Equal(got) {
+ t.Errorf("got wrong date, want %s but got %s", want, got)
+ }
+ }
+ }
+ })
+ }
+}
diff --git a/stackit/internal/utils/headers.go b/stackit/internal/utils/headers.go
new file mode 100644
index 00000000..bd51f2f3
--- /dev/null
+++ b/stackit/internal/utils/headers.go
@@ -0,0 +1,13 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "fmt"
+
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+)
+
+func UserAgentConfigOption(providerVersion string) config.ConfigurationOption {
+ return config.WithUserAgent(fmt.Sprintf("stackit-terraform-provider/%s", providerVersion))
+}
diff --git a/stackit/internal/utils/headers_test.go b/stackit/internal/utils/headers_test.go
new file mode 100644
index 00000000..03880034
--- /dev/null
+++ b/stackit/internal/utils/headers_test.go
@@ -0,0 +1,48 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "reflect"
+ "testing"
+
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+)
+
+func TestUserAgentConfigOption(t *testing.T) {
+ type args struct {
+ providerVersion string
+ }
+ tests := []struct {
+ name string
+ args args
+ want config.ConfigurationOption
+ }{
+ {
+ name: "TestUserAgentConfigOption",
+ args: args{
+ providerVersion: "1.0.0",
+ },
+ want: config.WithUserAgent("stackit-terraform-provider/1.0.0"),
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ clientConfigActual := config.Configuration{}
+ err := tt.want(&clientConfigActual)
+ if err != nil {
+ t.Errorf("error applying configuration: %v", err)
+ }
+
+ clientConfigExpected := config.Configuration{}
+ err = UserAgentConfigOption(tt.args.providerVersion)(&clientConfigExpected)
+ if err != nil {
+ t.Errorf("error applying configuration: %v", err)
+ }
+
+ if !reflect.DeepEqual(clientConfigActual, clientConfigExpected) {
+ t.Errorf("UserAgentConfigOption() = %v, want %v", clientConfigActual, clientConfigExpected)
+ }
+ })
+ }
+}
diff --git a/stackit/internal/utils/regions.go b/stackit/internal/utils/regions.go
new file mode 100644
index 00000000..1b7cec36
--- /dev/null
+++ b/stackit/internal/utils/regions.go
@@ -0,0 +1,38 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "context"
+
+ "github.com/hashicorp/terraform-plugin-framework/path"
+ "github.com/hashicorp/terraform-plugin-framework/resource"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+)
+
+// AdaptRegion rewrites the region of a terraform plan
+func AdaptRegion(ctx context.Context, configRegion types.String, planRegion *types.String, defaultRegion string, resp *resource.ModifyPlanResponse) {
+ // Get the intended region. This is either set directly set in the individual
+ // config or the provider region has to be used
+ var intendedRegion types.String
+ if configRegion.IsNull() {
+ if defaultRegion == "" {
+ core.LogAndAddError(ctx, &resp.Diagnostics, "set region", "no region defined in config or provider")
+ return
+ }
+ intendedRegion = types.StringValue(defaultRegion)
+ } else {
+ intendedRegion = configRegion
+ }
+
+ // check if the currently configured region corresponds to the planned region
+ // on mismatch override the planned region with the intended region
+ // and force a replacement of the resource
+ p := path.Root("region")
+ if !intendedRegion.Equal(*planRegion) {
+ resp.RequiresReplace.Append(p)
+ *planRegion = intendedRegion
+ }
+ resp.Diagnostics.Append(resp.Plan.SetAttribute(ctx, p, *planRegion)...)
+}
diff --git a/stackit/internal/utils/regions_test.go b/stackit/internal/utils/regions_test.go
new file mode 100644
index 00000000..242a340f
--- /dev/null
+++ b/stackit/internal/utils/regions_test.go
@@ -0,0 +1,89 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "context"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-framework/provider/schema"
+ "github.com/hashicorp/terraform-plugin-framework/resource"
+ "github.com/hashicorp/terraform-plugin-framework/tfsdk"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+)
+
+func TestAdaptRegion(t *testing.T) {
+ type model struct {
+ Region types.String `tfsdk:"region"`
+ }
+ type args struct {
+ configRegion types.String
+ defaultRegion string
+ }
+ testcases := []struct {
+ name string
+ args args
+ wantErr bool
+ wantRegion types.String
+ }{
+ {
+ "no configured region, use provider region",
+ args{
+ types.StringNull(),
+ "eu01",
+ },
+ false,
+ types.StringValue("eu01"),
+ },
+ {
+ "no configured region, no provider region => want error",
+ args{
+ types.StringNull(),
+ "",
+ },
+ true,
+ types.StringNull(),
+ },
+ {
+ "configuration region overrides provider region",
+ args{
+ types.StringValue("eu01-m"),
+ "eu01",
+ },
+ false,
+ types.StringValue("eu01-m"),
+ },
+ }
+ for _, tc := range testcases {
+ t.Run(tc.name, func(t *testing.T) {
+ plan := tfsdk.Plan{
+ Schema: schema.Schema{
+ Attributes: map[string]schema.Attribute{
+ "region": schema.StringAttribute{
+ Required: true,
+ },
+ },
+ },
+ }
+
+ if diags := plan.Set(context.Background(), model{types.StringValue("unknown")}); diags.HasError() {
+ t.Fatalf("cannot create test model: %v", diags)
+ }
+ resp := resource.ModifyPlanResponse{
+ Plan: plan,
+ }
+
+ configModel := model{
+ Region: tc.args.configRegion,
+ }
+ planModel := model{}
+ AdaptRegion(context.Background(), configModel.Region, &planModel.Region, tc.args.defaultRegion, &resp)
+ if diags := resp.Diagnostics; tc.wantErr != diags.HasError() {
+ t.Errorf("unexpected diagnostics: want err: %v, actual %v", tc.wantErr, diags.Errors())
+ }
+ if expected, actual := tc.wantRegion, planModel.Region; !expected.Equal(actual) {
+ t.Errorf("wrong result region. expect %s but got %s", expected, actual)
+ }
+ })
+ }
+}
diff --git a/stackit/internal/utils/use_state_for_unknown_if.go b/stackit/internal/utils/use_state_for_unknown_if.go
new file mode 100644
index 00000000..76db6bca
--- /dev/null
+++ b/stackit/internal/utils/use_state_for_unknown_if.go
@@ -0,0 +1,71 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "context"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/planmodifier"
+)
+
+type UseStateForUnknownFuncResponse struct {
+ UseStateForUnknown bool
+ Diagnostics diag.Diagnostics
+}
+
+// UseStateForUnknownIfFunc is a conditional function used in UseStateForUnknownIf
+type UseStateForUnknownIfFunc func(context.Context, planmodifier.StringRequest, *UseStateForUnknownFuncResponse)
+
+type useStateForUnknownIf struct {
+ ifFunc UseStateForUnknownIfFunc
+ description string
+}
+
+// UseStateForUnknownIf returns a plan modifier similar to UseStateForUnknown with a conditional
+func UseStateForUnknownIf(f UseStateForUnknownIfFunc, description string) planmodifier.String {
+ return useStateForUnknownIf{
+ ifFunc: f,
+ description: description,
+ }
+}
+
+func (m useStateForUnknownIf) Description(context.Context) string {
+ return m.description
+}
+
+func (m useStateForUnknownIf) MarkdownDescription(ctx context.Context) string {
+ return m.Description(ctx)
+}
+
+func (m useStateForUnknownIf) PlanModifyString(ctx context.Context, req planmodifier.StringRequest, resp *planmodifier.StringResponse) { // nolint:gocritic // function signature required by Terraform
+ // Do nothing if there is no state value.
+ if req.StateValue.IsNull() {
+ return
+ }
+
+ // Do nothing if there is a known planned value.
+ if !req.PlanValue.IsUnknown() {
+ return
+ }
+
+ // Do nothing if there is an unknown configuration value, otherwise interpolation gets messed up.
+ if req.ConfigValue.IsUnknown() {
+ return
+ }
+
+ // The above checks are taken from the UseStateForUnknown plan modifier implementation
+ // (https://github.com/hashicorp/terraform-plugin-framework/blob/44348af3923c82a93c64ae7dca906d9850ba956b/resource/schema/stringplanmodifier/use_state_for_unknown.go#L38)
+
+ funcResponse := &UseStateForUnknownFuncResponse{}
+ m.ifFunc(ctx, req, funcResponse)
+
+ resp.Diagnostics.Append(funcResponse.Diagnostics...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ if funcResponse.UseStateForUnknown {
+ resp.PlanValue = req.StateValue
+ }
+}
diff --git a/stackit/internal/utils/use_state_for_unknown_if_test.go b/stackit/internal/utils/use_state_for_unknown_if_test.go
new file mode 100644
index 00000000..01817fb0
--- /dev/null
+++ b/stackit/internal/utils/use_state_for_unknown_if_test.go
@@ -0,0 +1,130 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "context"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema/planmodifier"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+)
+
+func TestUseStateForUnknownIf_PlanModifyString(t *testing.T) {
+ ctx := context.Background()
+
+ tests := []struct {
+ name string
+ stateValue types.String
+ planValue types.String
+ configValue types.String
+ ifFunc UseStateForUnknownIfFunc
+ expectedPlanValue types.String
+ expectedError bool
+ }{
+ {
+ name: "State is Null (Creation)",
+ stateValue: types.StringNull(),
+ planValue: types.StringUnknown(),
+ configValue: types.StringValue("some-config"),
+ ifFunc: func(_ context.Context, _ planmodifier.StringRequest, resp *UseStateForUnknownFuncResponse) {
+ // This should not be reached because the state is null
+ resp.UseStateForUnknown = true
+ },
+ expectedPlanValue: types.StringUnknown(),
+ },
+ {
+ name: "Plan is already known - (User updated the value)",
+ stateValue: types.StringValue("old-state"),
+ planValue: types.StringValue("new-plan"),
+ configValue: types.StringValue("new-plan"),
+ ifFunc: func(_ context.Context, _ planmodifier.StringRequest, resp *UseStateForUnknownFuncResponse) {
+ // This should not be reached because the plan is known
+ resp.UseStateForUnknown = true
+ },
+ expectedPlanValue: types.StringValue("new-plan"),
+ },
+ {
+ name: "Config is Unknown (Interpolation)",
+ stateValue: types.StringValue("old-state"),
+ planValue: types.StringUnknown(),
+ configValue: types.StringUnknown(),
+ ifFunc: func(_ context.Context, _ planmodifier.StringRequest, resp *UseStateForUnknownFuncResponse) {
+ // This should not be reached
+ resp.UseStateForUnknown = true
+ },
+ expectedPlanValue: types.StringUnknown(),
+ },
+ {
+ name: "Condition returns False (Do not use state)",
+ stateValue: types.StringValue("old-state"),
+ planValue: types.StringUnknown(),
+ configValue: types.StringNull(), // Simulating computed only
+ ifFunc: func(_ context.Context, _ planmodifier.StringRequest, resp *UseStateForUnknownFuncResponse) {
+ resp.UseStateForUnknown = false
+ },
+ expectedPlanValue: types.StringUnknown(),
+ },
+ {
+ name: "Condition returns True (Use state)",
+ stateValue: types.StringValue("old-state"),
+ planValue: types.StringUnknown(),
+ configValue: types.StringNull(),
+ ifFunc: func(_ context.Context, _ planmodifier.StringRequest, resp *UseStateForUnknownFuncResponse) {
+ resp.UseStateForUnknown = true
+ },
+ expectedPlanValue: types.StringValue("old-state"),
+ },
+ {
+ name: "Func returns Error",
+ stateValue: types.StringValue("old-state"),
+ planValue: types.StringUnknown(),
+ configValue: types.StringNull(),
+ ifFunc: func(_ context.Context, _ planmodifier.StringRequest, resp *UseStateForUnknownFuncResponse) {
+ resp.Diagnostics.AddError("Test Error", "Something went wrong")
+ },
+ expectedPlanValue: types.StringUnknown(),
+ expectedError: true,
+ },
+ }
+
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ // Initialize the modifier
+ modifier := UseStateForUnknownIf(tt.ifFunc, "test description")
+
+ // Construct request
+ req := planmodifier.StringRequest{
+ StateValue: tt.stateValue,
+ PlanValue: tt.planValue,
+ ConfigValue: tt.configValue,
+ }
+
+ // Construct response
+ // Note: In the framework, resp.PlanValue is initialized to req.PlanValue
+ // before the modifier is called. We must simulate this.
+ resp := &planmodifier.StringResponse{
+ PlanValue: tt.planValue,
+ }
+
+ // Run the modifier
+ modifier.PlanModifyString(ctx, req, resp)
+
+ // Check Errors
+ if tt.expectedError {
+ if !resp.Diagnostics.HasError() {
+ t.Error("Expected error, got none")
+ }
+ } else {
+ if resp.Diagnostics.HasError() {
+ t.Errorf("Unexpected error: %s", resp.Diagnostics)
+ }
+ }
+
+ // Check Plan Value
+ if !resp.PlanValue.Equal(tt.expectedPlanValue) {
+ t.Errorf("PlanValue mismatch.\nExpected: %s\nGot: %s", tt.expectedPlanValue, resp.PlanValue)
+ }
+ })
+ }
+}
diff --git a/stackit/internal/utils/utils.go b/stackit/internal/utils/utils.go
new file mode 100644
index 00000000..962799ea
--- /dev/null
+++ b/stackit/internal/utils/utils.go
@@ -0,0 +1,186 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "context"
+ "errors"
+ "fmt"
+ "regexp"
+ "strings"
+
+ "github.com/hashicorp/terraform-plugin-framework/tfsdk"
+
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/hashicorp/terraform-plugin-framework/path"
+ "github.com/hashicorp/terraform-plugin-framework/resource"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+ "github.com/hashicorp/terraform-plugin-log/tflog"
+ "github.com/stackitcloud/stackit-sdk-go/core/oapierror"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+)
+
+const (
+ SKEServiceId = "cloud.stackit.ske"
+ ModelServingServiceId = "cloud.stackit.model-serving"
+)
+
+var (
+ LegacyProjectRoles = []string{"project.admin", "project.auditor", "project.member", "project.owner"}
+)
+
+// ReconcileStringSlices reconciles two string lists by removing elements from the
+// first list that are not in the second list and appending elements from the
+// second list that are not in the first list.
+// This preserves the order of the elements in the first list that are also in
+// the second list, which is useful when using ListAttributes in Terraform.
+// The source of truth for the order is the first list and the source of truth for the content is the second list.
+func ReconcileStringSlices(list1, list2 []string) []string {
+ // Create a copy of list1 to avoid modifying the original list
+ list1Copy := append([]string{}, list1...)
+
+ // Create a map to quickly check if an element is in list2
+ inList2 := make(map[string]bool)
+ for _, elem := range list2 {
+ inList2[elem] = true
+ }
+
+ // Remove elements from list1Copy that are not in list2
+ i := 0
+ for _, elem := range list1Copy {
+ if inList2[elem] {
+ list1Copy[i] = elem
+ i++
+ }
+ }
+ list1Copy = list1Copy[:i]
+
+ // Append elements to list1Copy that are in list2 but not in list1Copy
+ inList1 := make(map[string]bool)
+ for _, elem := range list1Copy {
+ inList1[elem] = true
+ }
+ for _, elem := range list2 {
+ if !inList1[elem] {
+ list1Copy = append(list1Copy, elem)
+ }
+ }
+
+ return list1Copy
+}
+
+func ListValuetoStringSlice(list basetypes.ListValue) ([]string, error) {
+ result := []string{}
+ for _, el := range list.Elements() {
+ elStr, ok := el.(types.String)
+ if !ok {
+ return result, fmt.Errorf("expected record to be of type %T, got %T", types.String{}, elStr)
+ }
+ result = append(result, elStr.ValueString())
+ }
+
+ return result, nil
+}
+
+// SimplifyBackupSchedule removes leading 0s from backup schedule numbers (e.g. "00 00 * * *" becomes "0 0 * * *")
+// Needed as the API does it internally and would otherwise cause inconsistent result in Terraform
+func SimplifyBackupSchedule(schedule string) string {
+ regex := regexp.MustCompile(`0+\d+`) // Matches series of one or more zeros followed by a series of one or more digits
+ simplifiedSchedule := regex.ReplaceAllStringFunc(schedule, func(match string) string {
+ simplified := strings.TrimLeft(match, "0")
+ if simplified == "" {
+ simplified = "0"
+ }
+ return simplified
+ })
+ return simplifiedSchedule
+}
+
+// ConvertPointerSliceToStringSlice safely converts a slice of string pointers to a slice of strings.
+func ConvertPointerSliceToStringSlice(pointerSlice []*string) []string {
+ if pointerSlice == nil {
+ return []string{}
+ }
+ stringSlice := make([]string, 0, len(pointerSlice))
+ for _, strPtr := range pointerSlice {
+ if strPtr != nil { // Safely skip any nil pointers in the list
+ stringSlice = append(stringSlice, *strPtr)
+ }
+ }
+ return stringSlice
+}
+
+func IsLegacyProjectRole(role string) bool {
+ return utils.Contains(LegacyProjectRoles, role)
+}
+
+type value interface {
+ IsUnknown() bool
+ IsNull() bool
+}
+
+// IsUndefined checks if a passed value is unknown or null
+func IsUndefined(val value) bool {
+ return val.IsUnknown() || val.IsNull()
+}
+
+// LogError logs errors. In descriptions different messages for http status codes can be passed. When no one matches the defaultDescription will be used
+func LogError(ctx context.Context, inputDiags *diag.Diagnostics, err error, summary, defaultDescription string, descriptions map[int]string) {
+ if err == nil {
+ return
+ }
+ tflog.Error(ctx, fmt.Sprintf("%s. Err: %v", summary, err))
+
+ var oapiErr *oapierror.GenericOpenAPIError
+ ok := errors.As(err, &oapiErr)
+ if !ok {
+ core.LogAndAddError(ctx, inputDiags, summary, fmt.Sprintf("Calling API: %v", err))
+ return
+ }
+
+ var description string
+ if len(descriptions) != 0 {
+ description, ok = descriptions[oapiErr.StatusCode]
+ }
+ if !ok || description == "" {
+ description = defaultDescription
+ }
+ core.LogAndAddError(ctx, inputDiags, summary, description)
+}
+
+// FormatPossibleValues formats a slice into a comma-separated-list for usage in the provider docs
+func FormatPossibleValues(values ...string) string {
+ var formattedValues []string
+ for _, value := range values {
+ formattedValues = append(formattedValues, fmt.Sprintf("`%v`", value))
+ }
+ return fmt.Sprintf("Possible values are: %s.", strings.Join(formattedValues, ", "))
+}
+
+func BuildInternalTerraformId(idParts ...string) types.String {
+ return types.StringValue(strings.Join(idParts, core.Separator))
+}
+
+// If a List was completely removed from the terraform config this is not recognized by terraform.
+// This helper function checks if that is the case and adjusts the plan accordingly.
+func CheckListRemoval(ctx context.Context, configModelList, planModelList types.List, destination path.Path, listType attr.Type, createEmptyList bool, resp *resource.ModifyPlanResponse) {
+ if configModelList.IsNull() && !planModelList.IsNull() {
+ if createEmptyList {
+ emptyList, _ := types.ListValueFrom(ctx, listType, []string{})
+ resp.Diagnostics.Append(resp.Plan.SetAttribute(ctx, destination, emptyList)...)
+ } else {
+ resp.Diagnostics.Append(resp.Plan.SetAttribute(ctx, destination, types.ListNull(listType))...)
+ }
+ }
+}
+
+// SetAndLogStateFields writes the given map of key-value pairs to the state
+func SetAndLogStateFields(ctx context.Context, diags *diag.Diagnostics, state *tfsdk.State, values map[string]any) {
+ for key, val := range values {
+ ctx = tflog.SetField(ctx, key, val)
+ diags.Append(state.SetAttribute(ctx, path.Root(key), val)...)
+ }
+}
diff --git a/stackit/internal/utils/utils_test.go b/stackit/internal/utils/utils_test.go
new file mode 100644
index 00000000..00e9f77c
--- /dev/null
+++ b/stackit/internal/utils/utils_test.go
@@ -0,0 +1,614 @@
+// Copyright (c) STACKIT
+
+package utils
+
+import (
+ "context"
+ "fmt"
+ "reflect"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-framework/diag"
+ "github.com/hashicorp/terraform-plugin-go/tftypes"
+
+ "github.com/google/go-cmp/cmp"
+ "github.com/hashicorp/terraform-plugin-framework/attr"
+ "github.com/hashicorp/terraform-plugin-framework/datasource/schema"
+ "github.com/hashicorp/terraform-plugin-framework/path"
+ "github.com/hashicorp/terraform-plugin-framework/resource"
+ "github.com/hashicorp/terraform-plugin-framework/tfsdk"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+ "github.com/stackitcloud/stackit-sdk-go/core/utils"
+)
+
+func TestReconcileStrLists(t *testing.T) {
+ tests := []struct {
+ description string
+ list1 []string
+ list2 []string
+ expected []string
+ }{
+ {
+ "empty lists",
+ []string{},
+ []string{},
+ []string{},
+ },
+ {
+ "list1 empty",
+ []string{},
+ []string{"a", "b", "c"},
+ []string{"a", "b", "c"},
+ },
+ {
+ "list2 empty",
+ []string{"a", "b", "c"},
+ []string{},
+ []string{},
+ },
+ {
+ "no common elements",
+ []string{"a", "b", "c"},
+ []string{"d", "e", "f"},
+ []string{"d", "e", "f"},
+ },
+ {
+ "common elements",
+ []string{"d", "a", "c"},
+ []string{"b", "c", "d", "e"},
+ []string{"d", "c", "b", "e"},
+ },
+ {
+ "common elements with empty string",
+ []string{"d", "", "c"},
+ []string{"", "c", "d"},
+ []string{"d", "", "c"},
+ },
+ {
+ "common elements with duplicates",
+ []string{"a", "b", "c", "c"},
+ []string{"b", "c", "d", "e"},
+ []string{"b", "c", "c", "d", "e"},
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ output := ReconcileStringSlices(tt.list1, tt.list2)
+ diff := cmp.Diff(output, tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ })
+ }
+}
+
+func TestListValuetoStrSlice(t *testing.T) {
+ tests := []struct {
+ description string
+ input basetypes.ListValue
+ expected []string
+ isValid bool
+ }{
+ {
+ description: "empty list",
+ input: types.ListValueMust(types.StringType, []attr.Value{}),
+ expected: []string{},
+ isValid: true,
+ },
+ {
+ description: "values ok",
+ input: types.ListValueMust(types.StringType, []attr.Value{
+ types.StringValue("a"),
+ types.StringValue("b"),
+ types.StringValue("c"),
+ }),
+ expected: []string{"a", "b", "c"},
+ isValid: true,
+ },
+ {
+ description: "different type",
+ input: types.ListValueMust(types.Int64Type, []attr.Value{
+ types.Int64Value(12),
+ }),
+ isValid: false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ output, err := ListValuetoStringSlice(tt.input)
+ if err != nil {
+ if !tt.isValid {
+ return
+ }
+ t.Fatalf("Should not have failed: %v", err)
+ }
+ if !tt.isValid {
+ t.Fatalf("Should have failed")
+ }
+ diff := cmp.Diff(output, tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ })
+ }
+}
+
+func TestConvertPointerSliceToStringSlice(t *testing.T) {
+ tests := []struct {
+ description string
+ input []*string
+ expected []string
+ }{
+ {
+ description: "nil slice",
+ input: nil,
+ expected: []string{},
+ },
+ {
+ description: "empty slice",
+ input: []*string{},
+ expected: []string{},
+ },
+ {
+ description: "slice with valid pointers",
+ input: []*string{utils.Ptr("apple"), utils.Ptr("banana"), utils.Ptr("cherry")},
+ expected: []string{"apple", "banana", "cherry"},
+ },
+ {
+ description: "slice with some nil pointers",
+ input: []*string{utils.Ptr("apple"), nil, utils.Ptr("cherry"), nil},
+ expected: []string{"apple", "cherry"},
+ },
+ {
+ description: "slice with all nil pointers",
+ input: []*string{nil, nil, nil},
+ expected: []string{},
+ },
+ {
+ description: "slice with a pointer to an empty string",
+ input: []*string{utils.Ptr("apple"), utils.Ptr(""), utils.Ptr("cherry")},
+ expected: []string{"apple", "", "cherry"},
+ },
+ }
+
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ output := ConvertPointerSliceToStringSlice(tt.input)
+ diff := cmp.Diff(output, tt.expected)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ })
+ }
+}
+
+func TestSimplifyBackupSchedule(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ expected string
+ }{
+ {
+ "simple schedule",
+ "0 0 * * *",
+ "0 0 * * *",
+ },
+ {
+ "schedule with leading zeros",
+ "00 00 * * *",
+ "0 0 * * *",
+ },
+ {
+ "schedule with leading zeros 2",
+ "00 001 * * *",
+ "0 1 * * *",
+ },
+ {
+ "schedule with leading zeros 3",
+ "00 0010 * * *",
+ "0 10 * * *",
+ },
+ {
+ "simple schedule with slash",
+ "0 0/6 * * *",
+ "0 0/6 * * *",
+ },
+ {
+ "schedule with leading zeros and slash",
+ "00 00/6 * * *",
+ "0 0/6 * * *",
+ },
+ {
+ "schedule with leading zeros and slash 2",
+ "00 001/06 * * *",
+ "0 1/6 * * *",
+ },
+ {
+ "simple schedule with comma",
+ "0 10,15 * * *",
+ "0 10,15 * * *",
+ },
+ {
+ "schedule with leading zeros and comma",
+ "0 010,0015 * * *",
+ "0 10,15 * * *",
+ },
+ {
+ "simple schedule with comma and slash",
+ "0 0-11/10 * * *",
+ "0 0-11/10 * * *",
+ },
+ {
+ "schedule with leading zeros, comma, and slash",
+ "00 000-011/010 * * *",
+ "0 0-11/10 * * *",
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ output := SimplifyBackupSchedule(tt.input)
+ if output != tt.expected {
+ t.Fatalf("Data does not match: %s", output)
+ }
+ })
+ }
+}
+
+func TestIsLegacyProjectRole(t *testing.T) {
+ tests := []struct {
+ description string
+ role string
+ expected bool
+ }{
+ {
+ "non legacy role",
+ "owner",
+ false,
+ },
+ {
+ "leagcy role",
+ "project.owner",
+ true,
+ },
+ {
+ "leagcy role 2",
+ "project.admin",
+ true,
+ },
+ {
+ "leagcy role 3",
+ "project.member",
+ true,
+ },
+ {
+ "leagcy role 4",
+ "project.auditor",
+ true,
+ },
+ }
+
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ output := IsLegacyProjectRole(tt.role)
+ if output != tt.expected {
+ t.Fatalf("Data does not match: %v", output)
+ }
+ })
+ }
+}
+
+func TestFormatPossibleValues(t *testing.T) {
+ gotPrefix := "Possible values are:"
+
+ type args struct {
+ values []string
+ }
+ tests := []struct {
+ name string
+ args args
+ want string
+ }{
+ {
+ name: "single string value",
+ args: args{
+ values: []string{"foo"},
+ },
+ want: fmt.Sprintf("%s `foo`.", gotPrefix),
+ },
+ {
+ name: "multiple string value",
+ args: args{
+ values: []string{"foo", "bar", "trololol"},
+ },
+ want: fmt.Sprintf("%s `foo`, `bar`, `trololol`.", gotPrefix),
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ if got := FormatPossibleValues(tt.args.values...); got != tt.want {
+ t.Errorf("FormatPossibleValues() = %v, want %v", got, tt.want)
+ }
+ })
+ }
+}
+
+func TestIsUndefined(t *testing.T) {
+ type args struct {
+ val value
+ }
+ tests := []struct {
+ name string
+ args args
+ want bool
+ }{
+ {
+ name: "undefined value",
+ args: args{
+ val: types.StringNull(),
+ },
+ want: true,
+ },
+ {
+ name: "unknown value",
+ args: args{
+ val: types.StringUnknown(),
+ },
+ want: true,
+ },
+ {
+ name: "string value",
+ args: args{
+ val: types.StringValue(""),
+ },
+ want: false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ if got := IsUndefined(tt.args.val); got != tt.want {
+ t.Errorf("IsUndefined() = %v, want %v", got, tt.want)
+ }
+ })
+ }
+}
+
+func TestBuildInternalTerraformId(t *testing.T) {
+ type args struct {
+ idParts []string
+ }
+ tests := []struct {
+ name string
+ args args
+ want types.String
+ }{
+ {
+ name: "no id parts",
+ args: args{
+ idParts: []string{},
+ },
+ want: types.StringValue(""),
+ },
+ {
+ name: "multiple id parts",
+ args: args{
+ idParts: []string{"abc", "foo", "bar", "xyz"},
+ },
+ want: types.StringValue("abc,foo,bar,xyz"),
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ if got := BuildInternalTerraformId(tt.args.idParts...); !reflect.DeepEqual(got, tt.want) {
+ t.Errorf("BuildInternalTerraformId() = %v, want %v", got, tt.want)
+ }
+ })
+ }
+}
+
+func TestCheckListRemoval(t *testing.T) {
+ type model struct {
+ AllowedAddresses types.List `tfsdk:"allowed_addresses"`
+ }
+ tests := []struct {
+ description string
+ configModelList types.List
+ planModelList types.List
+ path path.Path
+ listType attr.Type
+ createEmptyList bool
+ expectedAdjustedResp bool
+ }{
+ {
+ "config and plan are the same - no change",
+ types.ListValueMust(types.StringType, []attr.Value{
+ types.StringValue("value1"),
+ }),
+ types.ListValueMust(types.StringType, []attr.Value{
+ types.StringValue("value1"),
+ }),
+ path.Root("allowed_addresses"),
+ types.StringType,
+ false,
+ false,
+ },
+ {
+ "list was removed from config",
+ types.ListNull(types.StringType),
+ types.ListValueMust(types.StringType, []attr.Value{
+ types.StringValue("value1"),
+ }),
+ path.Root("allowed_addresses"),
+ types.StringType,
+ false,
+ true,
+ },
+ {
+ "list was added to config",
+ types.ListValueMust(types.StringType, []attr.Value{
+ types.StringValue("value1"),
+ }),
+ types.ListNull(types.StringType),
+ path.Root("allowed_addresses"),
+ types.StringType,
+ false,
+ false,
+ },
+ {
+ "no list provided at all",
+ types.ListNull(types.StringType),
+ types.ListNull(types.StringType),
+ path.Root("allowed_addresses"),
+ types.StringType,
+ false,
+ false,
+ },
+ {
+ "create empty list test - list was removed from config",
+ types.ListNull(types.StringType),
+ types.ListValueMust(types.StringType, []attr.Value{
+ types.StringValue("value1"),
+ }),
+ path.Root("allowed_addresses"),
+ types.StringType,
+ true,
+ true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ // create resp
+ plan := tfsdk.Plan{
+ Schema: schema.Schema{
+ Attributes: map[string]schema.Attribute{
+ "allowed_addresses": schema.ListAttribute{
+ ElementType: basetypes.StringType{},
+ },
+ },
+ },
+ }
+
+ // set input planModelList to plan
+ if diags := plan.Set(context.Background(), model{tt.planModelList}); diags.HasError() {
+ t.Fatalf("cannot create test model: %v", diags)
+ }
+ resp := resource.ModifyPlanResponse{
+ Plan: plan,
+ }
+
+ CheckListRemoval(context.Background(), tt.configModelList, tt.planModelList, tt.path, tt.listType, tt.createEmptyList, &resp)
+ // check targetList
+ var respList types.List
+ resp.Plan.GetAttribute(context.Background(), tt.path, &respList)
+
+ if tt.createEmptyList {
+ emptyList, _ := types.ListValueFrom(context.Background(), tt.listType, []string{})
+ diffEmptyList := cmp.Diff(emptyList, respList)
+ if diffEmptyList != "" {
+ t.Fatalf("an empty list should have been created but was not: %s", diffEmptyList)
+ }
+ }
+
+ // compare planModelList and resp list
+ diff := cmp.Diff(tt.planModelList, respList)
+ if tt.expectedAdjustedResp {
+ if diff == "" {
+ t.Fatalf("plan should be adjusted but was not")
+ }
+ } else {
+ if diff != "" {
+ t.Fatalf("plan should not be adjusted but diff is: %s", diff)
+ }
+ }
+ })
+ }
+}
+
+func TestSetAndLogStateFields(t *testing.T) {
+ testSchema := schema.Schema{
+ Attributes: map[string]schema.Attribute{
+ "project_id": schema.StringAttribute{},
+ "instance_id": schema.StringAttribute{},
+ },
+ }
+
+ type args struct {
+ diags *diag.Diagnostics
+ state *tfsdk.State
+ values map[string]interface{}
+ }
+ type want struct {
+ hasError bool
+ state *tfsdk.State
+ }
+ tests := []struct {
+ name string
+ args args
+ want want
+ }{
+ {
+ name: "empty map",
+ args: args{
+ diags: &diag.Diagnostics{},
+ state: &tfsdk.State{},
+ values: map[string]interface{}{},
+ },
+ want: want{
+ hasError: false,
+ state: &tfsdk.State{},
+ },
+ },
+ {
+ name: "base",
+ args: args{
+ diags: &diag.Diagnostics{},
+ state: func() *tfsdk.State {
+ ctx := context.Background()
+ state := tfsdk.State{
+ Raw: tftypes.NewValue(testSchema.Type().TerraformType(ctx), map[string]tftypes.Value{
+ "project_id": tftypes.NewValue(tftypes.String, "9b15d120-86f8-45f5-81d8-a554f09c7582"),
+ "instance_id": tftypes.NewValue(tftypes.String, nil),
+ }),
+ Schema: testSchema,
+ }
+ return &state
+ }(),
+ values: map[string]interface{}{
+ "project_id": "a414f971-3f7a-4e9a-8671-51a8acb7bcc8",
+ "instance_id": "97073250-8cad-46c3-8424-6258ac0b3731",
+ },
+ },
+ want: want{
+ hasError: false,
+ state: func() *tfsdk.State {
+ ctx := context.Background()
+ state := tfsdk.State{
+ Raw: tftypes.NewValue(testSchema.Type().TerraformType(ctx), map[string]tftypes.Value{
+ "project_id": tftypes.NewValue(tftypes.String, nil),
+ "instance_id": tftypes.NewValue(tftypes.String, nil),
+ }),
+ Schema: testSchema,
+ }
+ state.SetAttribute(ctx, path.Root("project_id"), "a414f971-3f7a-4e9a-8671-51a8acb7bcc8")
+ state.SetAttribute(ctx, path.Root("instance_id"), "97073250-8cad-46c3-8424-6258ac0b3731")
+ return &state
+ }(),
+ },
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ ctx := context.Background()
+ SetAndLogStateFields(ctx, tt.args.diags, tt.args.state, tt.args.values)
+
+ if tt.args.diags.HasError() != tt.want.hasError {
+ t.Errorf("TestSetAndLogStateFields() error count = %v, hasErr %v", tt.args.diags.ErrorsCount(), tt.want.hasError)
+ }
+
+ diff := cmp.Diff(tt.args.state, tt.want.state)
+ if diff != "" {
+ t.Fatalf("Data does not match: %s", diff)
+ }
+ })
+ }
+}
diff --git a/stackit/internal/validate/validate.go b/stackit/internal/validate/validate.go
new file mode 100644
index 00000000..9675bec0
--- /dev/null
+++ b/stackit/internal/validate/validate.go
@@ -0,0 +1,373 @@
+// Copyright (c) STACKIT
+
+package validate
+
+import (
+ "context"
+ "fmt"
+ "net"
+ "os"
+ "regexp"
+ "strings"
+ "time"
+ _ "time/tzdata"
+
+ "github.com/google/uuid"
+ "github.com/hashicorp/terraform-plugin-framework-validators/helpers/validatordiag"
+ "github.com/hashicorp/terraform-plugin-framework/path"
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/utils"
+ "github.com/teambition/rrule-go"
+)
+
+const (
+ MajorMinorVersionRegex = `^\d+\.\d+?$`
+ FullVersionRegex = `^\d+\.\d+.\d+?$`
+)
+
+type Validator struct {
+ description string
+ markdownDescription string
+ validate ValidationFn
+}
+
+type ValidationFn func(context.Context, validator.StringRequest, *validator.StringResponse)
+
+var _ = validator.String(&Validator{})
+
+func (v *Validator) Description(_ context.Context) string {
+ return v.description
+}
+
+func (v *Validator) MarkdownDescription(_ context.Context) string {
+ return v.markdownDescription
+}
+
+func (v *Validator) ValidateString(ctx context.Context, req validator.StringRequest, resp *validator.StringResponse) { // nolint:gocritic // function signature required by Terraform
+ if req.ConfigValue.IsUnknown() || req.ConfigValue.IsNull() {
+ return
+ }
+ v.validate(ctx, req, resp)
+}
+
+func UUID() *Validator {
+ description := "value must be an UUID"
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ if _, err := uuid.Parse(req.ConfigValue.ValueString()); err != nil {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ },
+ }
+}
+
+func NoUUID() *Validator {
+ description := "value must not be an UUID"
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ if _, err := uuid.Parse(req.ConfigValue.ValueString()); err == nil {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ },
+ }
+}
+
+// IP returns a validator that checks, if the given string is a valid IP address.
+// The allowZeroAddress parameter defines, if 0.0.0.0, resp. [::] should be considered valid.
+func IP(allowZeroAddress bool) *Validator {
+ description := "value must be an IP address"
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ ip := net.ParseIP(req.ConfigValue.ValueString())
+ invalidZeroAddress := !allowZeroAddress && (net.IPv4zero.Equal(ip) || net.IPv6zero.Equal(ip))
+ if ip == nil || invalidZeroAddress {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ },
+ }
+}
+
+func RecordSet() *Validator {
+ const typePath = "type"
+ return &Validator{
+ description: "value must be a valid record set",
+ validate: func(ctx context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ recordType := basetypes.StringValue{}
+ req.Config.GetAttribute(ctx, path.Root(typePath), &recordType)
+ switch recordType.ValueString() {
+ case "A":
+ ip := net.ParseIP(req.ConfigValue.ValueString())
+ if ip == nil || ip.To4() == nil {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ "value must be an IPv4 address",
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ case "AAAA":
+ ip := net.ParseIP(req.ConfigValue.ValueString())
+ if ip == nil || ip.To4() != nil || ip.To16() == nil {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ "value must be an IPv6 address",
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ case "CNAME":
+ name := req.ConfigValue.ValueString()
+ if name == "" || name[len(name)-1] != '.' {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ "value must be a Fully Qualified Domain Name (FQDN) and end with dot '.'",
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ case "NS":
+ case "MX":
+ case "TXT":
+ case "ALIAS":
+ case "DNAME":
+ case "CAA":
+ default:
+ }
+ },
+ }
+}
+
+func NoSeparator() *Validator {
+ description := fmt.Sprintf("value must not contain identifier separator '%s'", core.Separator)
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ if strings.Contains(req.ConfigValue.ValueString(), core.Separator) {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ },
+ }
+}
+
+func NonLegacyProjectRole() *Validator {
+ description := "legacy roles are not supported"
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ if utils.IsLegacyProjectRole(req.ConfigValue.ValueString()) {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ },
+ }
+}
+
+func MinorVersionNumber() *Validator {
+ description := "value must be a minor version number, without a leading 'v': '[MAJOR].[MINOR]'"
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ exp := MajorMinorVersionRegex
+ r := regexp.MustCompile(exp)
+ version := req.ConfigValue.ValueString()
+ if !r.MatchString(version) {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ },
+ }
+}
+
+func VersionNumber() *Validator {
+ description := "value must be a version number, without a leading 'v': '[MAJOR].[MINOR]' or '[MAJOR].[MINOR].[PATCH]'"
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ minorVersionExp := MajorMinorVersionRegex
+ minorVersionRegex := regexp.MustCompile(minorVersionExp)
+
+ versionExp := FullVersionRegex
+ versionRegex := regexp.MustCompile(versionExp)
+
+ version := req.ConfigValue.ValueString()
+ if !minorVersionRegex.MatchString(version) && !versionRegex.MatchString(version) {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ },
+ }
+}
+
+func RFC3339SecondsOnly() *Validator {
+ description := "value must be in RFC339 format (seconds only)"
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ t, err := time.Parse(time.RFC3339, req.ConfigValue.ValueString())
+ if err != nil {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ req.ConfigValue.ValueString(),
+ ))
+ return
+ }
+
+ // Check if it failed because it has nanoseconds
+ if t.Nanosecond() != 0 {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ "value can't have fractional seconds",
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ },
+ }
+}
+
+func CIDR() *Validator {
+ description := "value must be in CIDR notation"
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ _, _, err := net.ParseCIDR(req.ConfigValue.ValueString())
+ if err != nil {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ "parsing value in CIDR notation: invalid CIDR address",
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ },
+ }
+}
+
+func Rrule() *Validator {
+ description := "value must be in a valid RRULE format"
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ // The go library rrule-go expects \n before RRULE (to be a newline and not a space)
+ // for example: "DTSTART;TZID=America/New_York:19970902T090000\nRRULE:FREQ=DAILY;COUNT=10"
+ // whereas a valid rrule according to the API docs is:
+ // for example: "DTSTART;TZID=America/New_York:19970902T090000 RRULE:FREQ=DAILY;COUNT=10"
+ //
+ // So we will accept a ' ' (which is valid per API docs),
+ // but replace it with a '\n' for the rrule-go validations
+ value := req.ConfigValue.ValueString()
+ value = strings.ReplaceAll(value, " ", "\n")
+
+ if _, err := rrule.StrToRRuleSet(value); err != nil {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ },
+ }
+}
+
+func FileExists() *Validator {
+ description := "file must exist"
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ _, err := os.Stat(req.ConfigValue.ValueString())
+ if err != nil {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ },
+ }
+}
+
+func ValidDurationString() *Validator {
+ description := "value must be in a valid duration string. Such as \"300ms\", \"-1.5h\" or \"2h45m\".\nValid time units are \"ns\", \"us\" (or \"µs\"), \"ms\", \"s\", \"m\", \"h\"."
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ _, err := time.ParseDuration(req.ConfigValue.ValueString())
+ if err != nil {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ req.ConfigValue.ValueString(),
+ ))
+ }
+ },
+ }
+}
+
+// ValidNoTrailingNewline returns a Validator that checks if the input string has no trailing newline
+// character ("\n" or "\r\n"). If a trailing newline is present, a diagnostic error will be appended.
+func ValidNoTrailingNewline() *Validator {
+ description := `The value must not have a trailing newline character ("\n" or "\r\n"). You can remove a trailing newline by using Terraform's built-in chomp() function.`
+
+ return &Validator{
+ description: description,
+ validate: func(_ context.Context, req validator.StringRequest, resp *validator.StringResponse) {
+ val := req.ConfigValue.ValueString()
+ if val == "" {
+ return
+ }
+ if len(val) >= 2 && val[len(val)-2:] == "\r\n" {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ val,
+ ))
+ return
+ }
+ if val[len(val)-1] == '\n' {
+ resp.Diagnostics.Append(validatordiag.InvalidAttributeValueDiagnostic(
+ req.Path,
+ description,
+ val,
+ ))
+ }
+ },
+ }
+}
diff --git a/stackit/internal/validate/validate_test.go b/stackit/internal/validate/validate_test.go
new file mode 100644
index 00000000..210a5ca9
--- /dev/null
+++ b/stackit/internal/validate/validate_test.go
@@ -0,0 +1,970 @@
+// Copyright (c) STACKIT
+
+package validate
+
+import (
+ "context"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-framework/resource/schema"
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-framework/tfsdk"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/hashicorp/terraform-plugin-go/tftypes"
+)
+
+func TestUUID(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ isValid bool
+ }{
+ {
+ "ok",
+ "cae27bba-c43d-498a-861e-d11d241c4ff8",
+ true,
+ },
+ {
+ "too short",
+ "a-b-c-d",
+ false,
+ },
+ {
+ "Empty",
+ "",
+ false,
+ },
+ {
+ "not UUID",
+ "www-541-%",
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ UUID().ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Should not have failed: %v", r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestNoUUID(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ isValid bool
+ }{
+ {
+ "UUID",
+ "cae27bba-c43d-498a-861e-d11d241c4ff8",
+ false,
+ },
+ {
+ "no UUID",
+ "a-b-c-d",
+ true,
+ },
+ {
+ "Empty",
+ "",
+ true,
+ },
+ {
+ "domain name",
+ "www.test.de",
+ true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ NoUUID().ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Should not have failed: %v", r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestIP(t *testing.T) {
+ tests := []struct {
+ description string
+ invalidZero bool
+ input string
+ isValid bool
+ }{
+ {
+ "ok IP4",
+ false,
+ "111.222.111.222",
+ true,
+ },
+ {
+ "ok IP6",
+ false,
+ "2001:0db8:85a3:08d3::0370:7344",
+ true,
+ },
+ {
+ "too short",
+ false,
+ "0.1.2",
+ false,
+ },
+ {
+ "Empty",
+ false,
+ "",
+ false,
+ },
+ {
+ "Not an IP",
+ false,
+ "for-sure-not-an-IP",
+ false,
+ },
+ {
+ "valid ipv4 zero",
+ true,
+ "0.0.0.0",
+ true,
+ },
+ {
+ "invalid ipv4 zero",
+ false,
+ "0.0.0.0",
+ false,
+ },
+ {
+ "valid ipv6 zero",
+ true,
+ "::",
+ true,
+ },
+ {
+ "valid ipv6 zero short notation",
+ true,
+ "::0",
+ true,
+ },
+ {
+ "valid ipv6 zero long notation",
+ true,
+ "0000:0000:0000:0000:0000:0000:0000:0000",
+ true,
+ },
+ {
+ "invalid ipv6 zero short notation",
+ false,
+ "::",
+ false,
+ },
+ {
+ "invalid ipv6 zero long notation",
+ false,
+ "0000:0000:0000:0000:0000:0000:0000:0000",
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ IP(tt.invalidZero).ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Should not have failed: %v", r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestRecordSet(t *testing.T) {
+ tests := []struct {
+ description string
+ record string
+ recordType string
+ isValid bool
+ }{
+ {
+ "A record ok IP4",
+ "111.222.111.222",
+ "A",
+ true,
+ },
+ {
+ "A record fail IP6",
+ "2001:0db8:85a3:08d3::0370:7344",
+ "A",
+ false,
+ },
+ {
+ "A record too short",
+ "0.1.2",
+ "A",
+ false,
+ },
+ {
+ "A record Empty",
+ "",
+ "A",
+ false,
+ },
+ {
+ "A record Not an IP",
+ "for-sure-not-an-IP",
+ "A",
+ false,
+ },
+ {
+ "AAAA record fail IP4",
+ "111.222.111.222",
+ "AAAA",
+ false,
+ },
+ {
+ "AAAA record ok IP6",
+ "2001:0db8:85a3:08d3::0370:7344",
+ "AAAA",
+ true,
+ },
+ {
+ "AAAA record too short",
+ "0.1.2",
+ "AAAA",
+ false,
+ },
+ {
+ "AAAA record Empty",
+ "",
+ "AAAA",
+ false,
+ },
+ {
+ "AAAA record Not an IP",
+ "for-sure-not-an-IP",
+ "AAAA",
+ false,
+ },
+ {
+ "CNAME record Not a Fully Qualified Domain Name",
+ "stackit.de",
+ "CNAME",
+ false,
+ },
+ {
+ "CNAME record ok Fully Qualified Domain Name",
+ "stackit.de.",
+ "CNAME",
+ true,
+ },
+ {
+ "NS record",
+ "some-record",
+ "NS",
+ true,
+ },
+ {
+ "MX record",
+ "some-record",
+ "MX",
+ true,
+ },
+ {
+ "TXT record",
+ "some-record",
+ "TXT",
+ true,
+ },
+ {
+ "ALIAS record",
+ "some-record",
+ "ALIAS",
+ true,
+ },
+ {
+ "DNAME record",
+ "some-record",
+ "DNAME",
+ true,
+ },
+ {
+ "CAA record",
+ "some-record",
+ "CAA",
+ true,
+ },
+ {
+ "random record",
+ "some-record",
+ "random",
+ true,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ scheme := tftypes.Object{
+ AttributeTypes: map[string]tftypes.Type{
+ "type": tftypes.String,
+ },
+ }
+ value := map[string]tftypes.Value{
+ "type": tftypes.NewValue(tftypes.String, tt.recordType),
+ }
+ record := tftypes.NewValue(scheme, value)
+
+ RecordSet().ValidateString(context.Background(), validator.StringRequest{
+ Config: tfsdk.Config{
+ Schema: schema.Schema{
+ Attributes: map[string]schema.Attribute{
+ "type": schema.StringAttribute{},
+ },
+ },
+ Raw: record,
+ },
+ ConfigValue: types.StringValue(tt.record),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Should not have failed: %v", r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestNoSeparator(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ isValid bool
+ }{
+ {
+ "ok",
+ "ABCD",
+ true,
+ },
+ {
+ "ok-2",
+ "#$%&/()=.;-",
+ true,
+ },
+ {
+ "Empty",
+ "",
+ true,
+ },
+ {
+ "not ok",
+ "ab,",
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ NoSeparator().ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Should not have failed: %v", r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestNonLegacyProjectRole(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ isValid bool
+ }{
+ {
+ "ok",
+ "owner",
+ true,
+ },
+ {
+ "ok-2",
+ "reader",
+ true,
+ },
+ {
+ "leagcy-role",
+ "project.owner",
+ false,
+ },
+ {
+ "leagcy-role-2",
+ "project.admin",
+ false,
+ },
+ {
+ "leagcy-role-3",
+ "project.member",
+ false,
+ },
+ {
+ "leagcy-role-4",
+ "project.auditor",
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ NonLegacyProjectRole().ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Should not have failed: %v", r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestMinorVersionNumber(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ isValid bool
+ }{
+ {
+ "ok",
+ "1.20",
+ true,
+ },
+ {
+ "ok-2",
+ "1.3",
+ true,
+ },
+ {
+ "ok-3",
+ "10.1",
+ true,
+ },
+ {
+ "Empty",
+ "",
+ false,
+ },
+ {
+ "not ok",
+ "afssfdfs",
+ false,
+ },
+ {
+ "not ok-major-version",
+ "1",
+ false,
+ },
+ {
+ "not ok-patch-version",
+ "1.20.1",
+ false,
+ },
+ {
+ "not ok-version",
+ "v1.20.1",
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ MinorVersionNumber().ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Should not have failed: %v", r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestVersionNumber(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ isValid bool
+ }{
+ {
+ "ok",
+ "1.20",
+ true,
+ },
+ {
+ "ok-2",
+ "1.3",
+ true,
+ },
+ {
+ "ok-3",
+ "10.1",
+ true,
+ },
+ {
+ "ok-patch-version",
+ "1.20.1",
+ true,
+ },
+ {
+ "ok-patch-version-2",
+ "1.20.10",
+ true,
+ },
+ {
+ "ok-patch-version-3",
+ "10.20.10",
+ true,
+ },
+ {
+ "Empty",
+ "",
+ false,
+ },
+ {
+ "not ok",
+ "afssfdfs",
+ false,
+ },
+ {
+ "not ok-major-version",
+ "1",
+ false,
+ },
+ {
+ "not ok-version",
+ "v1.20.1",
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ VersionNumber().ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Should not have failed: %v", r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestRFC3339SecondsOnly(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ isValid bool
+ }{
+ {
+ "ok",
+ "9999-01-02T03:04:05Z",
+ true,
+ },
+ {
+ "ok_2",
+ "9999-01-02T03:04:05+06:00",
+ true,
+ },
+ {
+ "empty",
+ "",
+ false,
+ },
+ {
+ "not_ok",
+ "foo-bar",
+ false,
+ },
+ {
+ "with_sub_seconds",
+ "9999-01-02T03:04:05.678Z",
+ false,
+ },
+ {
+ "with_sub_seconds_2",
+ "9999-01-02T03:04:05.678+06:00",
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ RFC3339SecondsOnly().ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Should not have failed: %v", r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestCIDR(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ isValid bool
+ }{
+ {
+ "IPv4_block",
+ "198.51.100.14/24",
+ true,
+ },
+ {
+ "IPv4_block_2",
+ "111.222.111.222/22",
+ true,
+ },
+ {
+ "IPv4_single",
+ "198.51.100.14/32",
+ true,
+ },
+ {
+ "IPv4_entire_internet",
+ "0.0.0.0/0",
+ true,
+ },
+ {
+ "IPv4_block_invalid",
+ "198.51.100.14/33",
+ false,
+ },
+ {
+ "IPv4_no_block",
+ "111.222.111.222",
+ false,
+ },
+ {
+ "IPv6_block",
+ "2001:db8::/48",
+ true,
+ },
+ {
+ "IPv6_single",
+ "2001:0db8:85a3:08d3::0370:7344/128",
+ true,
+ },
+ {
+ "IPv6_all",
+ "::/0",
+ true,
+ },
+ {
+ "IPv6_block_invalid",
+ "2001:0db8:85a3:08d3::0370:7344/129",
+ false,
+ },
+ {
+ "IPv6_no_block",
+ "2001:0db8:85a3:08d3::0370:7344",
+ false,
+ },
+ {
+ "empty",
+ "",
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ CIDR().ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Should not have failed: %v", r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestRrule(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ isValid bool
+ }{
+ {
+ "ok",
+ "DTSTART;TZID=Europe/Sofia:20200803T023000 RRULE:FREQ=DAILY;INTERVAL=1",
+ true,
+ },
+ {
+ "ok-2",
+ "DTSTART;TZID=Europe/Sofia:20200803T023000\nRULE:FREQ=DAILY;INTERVAL=1",
+ true,
+ },
+ {
+ "Empty",
+ "",
+ false,
+ },
+ {
+ "not ok",
+ "afssfdfs",
+ false,
+ },
+ {
+ "not ok-missing-space-before-rrule",
+ "DTSTART;TZID=Europe/Sofia:20200803T023000RRULE:FREQ=DAILY;INTERVAL=1",
+ false,
+ },
+ {
+ "not ok-missing-interval",
+ "DTSTART;TZID=Europe/Sofia:20200803T023000 RRULE:FREQ=DAILY;INTERVAL=",
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ Rrule().ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Should not have failed: %v", r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestFileExists(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ isValid bool
+ }{
+ {
+ "ok",
+ "testdata/file.txt",
+ true,
+ },
+ {
+ "not ok",
+ "testdata/non-existing-file.txt",
+ false,
+ },
+ {
+ "empty",
+ "",
+ false,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ FileExists().ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Should have failed")
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Should not have failed: %v", r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestValidTtlDuration(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ isValid bool
+ }{
+ {
+ "valid duration with hours, minutes, and seconds",
+ "5h30m40s",
+ true,
+ },
+ {
+ "valid duration with hours only",
+ "5h",
+ true,
+ },
+ {
+ "valid duration with hours and minutes",
+ "5h30m",
+ true,
+ },
+ {
+ "valid duration with minutes only",
+ "30m",
+ true,
+ },
+ {
+ "valid duration with seconds only",
+ "30s",
+ true,
+ },
+ {
+ "invalid duration with incorrect unit",
+ "30o",
+ false,
+ },
+ {
+ "invalid duration without unit",
+ "30",
+ false,
+ },
+ {
+ "invalid duration with invalid letters",
+ "30e",
+ false,
+ },
+ {
+ "invalid duration with letters in middle",
+ "1h30x",
+ false,
+ },
+ {
+ "empty string",
+ "",
+ false,
+ },
+ }
+
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ va := ValidDurationString()
+ va.ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Expected validation to fail for input: %v", tt.input)
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Expected validation to succeed for input: %v, but got errors: %v", tt.input, r.Diagnostics.Errors())
+ }
+ })
+ }
+}
+
+func TestValidNoTrailingNewline(t *testing.T) {
+ tests := []struct {
+ description string
+ input string
+ isValid bool
+ }{
+ {
+ "string with no trailing newline",
+ "abc",
+ true,
+ },
+ {
+ "string with trailing \\n",
+ "abc\n",
+ false,
+ },
+ {
+ "string with trailing \\r\\n",
+ "abc\r\n",
+ false,
+ },
+ {
+ "string with internal newlines but not trailing",
+ "abc\ndef\nghi",
+ true,
+ },
+ {
+ "empty string",
+ "",
+ true,
+ },
+ {
+ "string that is just \\n",
+ "\n",
+ false,
+ },
+ {
+ "string that is just \\r\\n",
+ "\r\n",
+ false,
+ },
+ {
+ "string with multiple newlines, trailing",
+ "abc\n\n",
+ false,
+ },
+ {
+ "string with newlines but ends with character",
+ "abc\ndef\n",
+ false,
+ },
+ }
+
+ for _, tt := range tests {
+ t.Run(tt.description, func(t *testing.T) {
+ r := validator.StringResponse{}
+ va := ValidNoTrailingNewline()
+ va.ValidateString(context.Background(), validator.StringRequest{
+ ConfigValue: types.StringValue(tt.input),
+ }, &r)
+
+ if !tt.isValid && !r.Diagnostics.HasError() {
+ t.Fatalf("Expected validation to fail for input: %q", tt.input)
+ }
+ if tt.isValid && r.Diagnostics.HasError() {
+ t.Fatalf("Expected validation to succeed for input: %q, but got errors: %v", tt.input, r.Diagnostics.Errors())
+ }
+ })
+ }
+}
diff --git a/stackit/provider.go b/stackit/provider.go
new file mode 100644
index 00000000..c9c54a7f
--- /dev/null
+++ b/stackit/provider.go
@@ -0,0 +1,502 @@
+// Copyright (c) STACKIT
+
+package stackit
+
+import (
+ "context"
+ "fmt"
+ "strings"
+
+ "github.com/hashicorp/terraform-plugin-framework-validators/stringvalidator"
+ "github.com/hashicorp/terraform-plugin-framework/datasource"
+ "github.com/hashicorp/terraform-plugin-framework/path"
+ "github.com/hashicorp/terraform-plugin-framework/provider"
+ "github.com/hashicorp/terraform-plugin-framework/provider/schema"
+ "github.com/hashicorp/terraform-plugin-framework/resource"
+ "github.com/hashicorp/terraform-plugin-framework/schema/validator"
+ "github.com/hashicorp/terraform-plugin-framework/types"
+ "github.com/hashicorp/terraform-plugin-framework/types/basetypes"
+ sdkauth "github.com/stackitcloud/stackit-sdk-go/core/auth"
+ "github.com/stackitcloud/stackit-sdk-go/core/config"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/core"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/features"
+ postgresFlexAlphaInstance "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/postgresflexalpha/instance"
+ sqlServerFlexAlphaInstance "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/sqlserverflexalpha/instance"
+ sqlServerFlexAlpaUser "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/services/sqlserverflexalpha/user"
+)
+
+// Ensure the implementation satisfies the expected interfaces
+var (
+ _ provider.Provider = &Provider{}
+)
+
+// Provider is the provider implementation.
+type Provider struct {
+ version string
+}
+
+// New is a helper function to simplify provider server and testing implementation.
+func New(version string) func() provider.Provider {
+ return func() provider.Provider {
+ return &Provider{
+ version: version,
+ }
+ }
+}
+
+func (p *Provider) Metadata(_ context.Context, _ provider.MetadataRequest, resp *provider.MetadataResponse) {
+ resp.TypeName = "stackitprivatepreview"
+ resp.Version = p.version
+}
+
+type providerModel struct {
+ CredentialsFilePath types.String `tfsdk:"credentials_path"`
+ ServiceAccountEmail types.String `tfsdk:"service_account_email"` // Deprecated: ServiceAccountEmail is not required and will be removed after 12th June 2025
+ ServiceAccountKey types.String `tfsdk:"service_account_key"`
+ ServiceAccountKeyPath types.String `tfsdk:"service_account_key_path"`
+ PrivateKey types.String `tfsdk:"private_key"`
+ PrivateKeyPath types.String `tfsdk:"private_key_path"`
+ Token types.String `tfsdk:"service_account_token"`
+ // Deprecated: Use DefaultRegion instead
+ Region types.String `tfsdk:"region"`
+ DefaultRegion types.String `tfsdk:"default_region"`
+
+ // Custom endpoints
+ AuthorizationCustomEndpoint types.String `tfsdk:"authorization_custom_endpoint"`
+ CdnCustomEndpoint types.String `tfsdk:"cdn_custom_endpoint"`
+ DnsCustomEndpoint types.String `tfsdk:"dns_custom_endpoint"`
+ GitCustomEndpoint types.String `tfsdk:"git_custom_endpoint"`
+ IaaSCustomEndpoint types.String `tfsdk:"iaas_custom_endpoint"`
+ KmsCustomEndpoint types.String `tfsdk:"kms_custom_endpoint"`
+ LoadBalancerCustomEndpoint types.String `tfsdk:"loadbalancer_custom_endpoint"`
+ LogMeCustomEndpoint types.String `tfsdk:"logme_custom_endpoint"`
+ MariaDBCustomEndpoint types.String `tfsdk:"mariadb_custom_endpoint"`
+ ModelServingCustomEndpoint types.String `tfsdk:"modelserving_custom_endpoint"`
+ MongoDBFlexCustomEndpoint types.String `tfsdk:"mongodbflex_custom_endpoint"`
+ ObjectStorageCustomEndpoint types.String `tfsdk:"objectstorage_custom_endpoint"`
+ ObservabilityCustomEndpoint types.String `tfsdk:"observability_custom_endpoint"`
+ OpenSearchCustomEndpoint types.String `tfsdk:"opensearch_custom_endpoint"`
+ PostgresFlexCustomEndpoint types.String `tfsdk:"postgresflex_custom_endpoint"`
+ RabbitMQCustomEndpoint types.String `tfsdk:"rabbitmq_custom_endpoint"`
+ RedisCustomEndpoint types.String `tfsdk:"redis_custom_endpoint"`
+ ResourceManagerCustomEndpoint types.String `tfsdk:"resourcemanager_custom_endpoint"`
+ ScfCustomEndpoint types.String `tfsdk:"scf_custom_endpoint"`
+ SecretsManagerCustomEndpoint types.String `tfsdk:"secretsmanager_custom_endpoint"`
+ ServerBackupCustomEndpoint types.String `tfsdk:"server_backup_custom_endpoint"`
+ ServerUpdateCustomEndpoint types.String `tfsdk:"server_update_custom_endpoint"`
+ ServiceAccountCustomEndpoint types.String `tfsdk:"service_account_custom_endpoint"`
+ ServiceEnablementCustomEndpoint types.String `tfsdk:"service_enablement_custom_endpoint"`
+ SkeCustomEndpoint types.String `tfsdk:"ske_custom_endpoint"`
+ SqlServerFlexCustomEndpoint types.String `tfsdk:"sqlserverflex_custom_endpoint"`
+ TokenCustomEndpoint types.String `tfsdk:"token_custom_endpoint"`
+
+ EnableBetaResources types.Bool `tfsdk:"enable_beta_resources"`
+ Experiments types.List `tfsdk:"experiments"`
+}
+
+// Schema defines the provider-level schema for configuration data.
+func (p *Provider) Schema(_ context.Context, _ provider.SchemaRequest, resp *provider.SchemaResponse) {
+ descriptions := map[string]string{
+ "credentials_path": "Path of JSON from where the credentials are read. Takes precedence over the env var `STACKIT_CREDENTIALS_PATH`. Default value is `~/.stackit/credentials.json`.",
+ "service_account_token": "Token used for authentication. If set, the token flow will be used to authenticate all operations.",
+ "service_account_key_path": "Path for the service account key used for authentication. If set, the key flow will be used to authenticate all operations.",
+ "service_account_key": "Service account key used for authentication. If set, the key flow will be used to authenticate all operations.",
+ "private_key_path": "Path for the private RSA key used for authentication, relevant for the key flow. It takes precedence over the private key that is included in the service account key.",
+ "private_key": "Private RSA key used for authentication, relevant for the key flow. It takes precedence over the private key that is included in the service account key.",
+ "service_account_email": "Service account email. It can also be set using the environment variable STACKIT_SERVICE_ACCOUNT_EMAIL. It is required if you want to use the resource manager project resource.",
+ "region": "Region will be used as the default location for regional services. Not all services require a region, some are global",
+ "default_region": "Region will be used as the default location for regional services. Not all services require a region, some are global",
+ "cdn_custom_endpoint": "Custom endpoint for the CDN service",
+ "dns_custom_endpoint": "Custom endpoint for the DNS service",
+ "git_custom_endpoint": "Custom endpoint for the Git service",
+ "iaas_custom_endpoint": "Custom endpoint for the IaaS service",
+ "kms_custom_endpoint": "Custom endpoint for the KMS service",
+ "mongodbflex_custom_endpoint": "Custom endpoint for the MongoDB Flex service",
+ "modelserving_custom_endpoint": "Custom endpoint for the AI Model Serving service",
+ "loadbalancer_custom_endpoint": "Custom endpoint for the Load Balancer service",
+ "logme_custom_endpoint": "Custom endpoint for the LogMe service",
+ "rabbitmq_custom_endpoint": "Custom endpoint for the RabbitMQ service",
+ "mariadb_custom_endpoint": "Custom endpoint for the MariaDB service",
+ "authorization_custom_endpoint": "Custom endpoint for the Membership service",
+ "objectstorage_custom_endpoint": "Custom endpoint for the Object Storage service",
+ "observability_custom_endpoint": "Custom endpoint for the Observability service",
+ "opensearch_custom_endpoint": "Custom endpoint for the OpenSearch service",
+ "postgresflex_custom_endpoint": "Custom endpoint for the PostgresFlex service",
+ "redis_custom_endpoint": "Custom endpoint for the Redis service",
+ "server_backup_custom_endpoint": "Custom endpoint for the Server Backup service",
+ "server_update_custom_endpoint": "Custom endpoint for the Server Update service",
+ "service_account_custom_endpoint": "Custom endpoint for the Service Account service",
+ "resourcemanager_custom_endpoint": "Custom endpoint for the Resource Manager service",
+ "scf_custom_endpoint": "Custom endpoint for the Cloud Foundry (SCF) service",
+ "secretsmanager_custom_endpoint": "Custom endpoint for the Secrets Manager service",
+ "sqlserverflex_custom_endpoint": "Custom endpoint for the SQL Server Flex service",
+ "ske_custom_endpoint": "Custom endpoint for the Kubernetes Engine (SKE) service",
+ "service_enablement_custom_endpoint": "Custom endpoint for the Service Enablement API",
+ "token_custom_endpoint": "Custom endpoint for the token API, which is used to request access tokens when using the key flow",
+ "enable_beta_resources": "Enable beta resources. Default is false.",
+ "experiments": fmt.Sprintf(
+ "Enables experiments. These are unstable features without official support. More information can be found in the README. Available Experiments: %v",
+ strings.Join(features.AvailableExperiments, ", "),
+ ),
+ }
+
+ resp.Schema = schema.Schema{
+ Attributes: map[string]schema.Attribute{
+ "credentials_path": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["credentials_path"],
+ },
+ "service_account_email": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["service_account_email"],
+ DeprecationMessage: "The `service_account_email` field has been deprecated because it is not required. Will be removed after June 12th 2025.",
+ },
+ "service_account_token": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["service_account_token"],
+ DeprecationMessage: "Authentication via Service Account Token is deprecated and will be removed on December 17, 2025. " +
+ "Please use `service_account_key` or `service_account_key_path` instead. " +
+ "For a smooth transition, refer to our migration guide: https://docs.stackit.cloud/platform/access-and-identity/service-accounts/migrate-flows/",
+ },
+ "service_account_key_path": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["service_account_key_path"],
+ },
+ "service_account_key": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["service_account_key"],
+ },
+ "private_key": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["private_key"],
+ },
+ "private_key_path": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["private_key_path"],
+ },
+ "region": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["region"],
+ DeprecationMessage: "This attribute is deprecated. Use 'default_region' instead",
+ Validators: []validator.String{
+ stringvalidator.ConflictsWith(path.MatchRoot("default_region")),
+ },
+ },
+ "default_region": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["default_region"],
+ Validators: []validator.String{
+ stringvalidator.ConflictsWith(path.MatchRoot("region")),
+ },
+ },
+ "enable_beta_resources": schema.BoolAttribute{
+ Optional: true,
+ Description: descriptions["enable_beta_resources"],
+ },
+ "experiments": schema.ListAttribute{
+ ElementType: types.StringType,
+ Optional: true,
+ Description: descriptions["experiments"],
+ },
+ // Custom endpoints
+ "cdn_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["cdn_custom_endpoint"],
+ },
+ "dns_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["dns_custom_endpoint"],
+ },
+ "git_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["git_custom_endpoint"],
+ },
+ "iaas_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["iaas_custom_endpoint"],
+ },
+ "kms_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["kms_custom_endpoint"],
+ },
+ "postgresflex_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["postgresflex_custom_endpoint"],
+ },
+ "mariadb_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["mariadb_custom_endpoint"],
+ },
+ "modelserving_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["modelserving_custom_endpoint"],
+ },
+ "authorization_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["authorization_custom_endpoint"],
+ },
+ "mongodbflex_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["mongodbflex_custom_endpoint"],
+ },
+ "loadbalancer_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["loadbalancer_custom_endpoint"],
+ },
+ "logme_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["logme_custom_endpoint"],
+ },
+ "rabbitmq_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["rabbitmq_custom_endpoint"],
+ },
+ "objectstorage_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["objectstorage_custom_endpoint"],
+ },
+ "observability_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["observability_custom_endpoint"],
+ },
+ "opensearch_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["opensearch_custom_endpoint"],
+ },
+ "redis_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["redis_custom_endpoint"],
+ },
+ "scf_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["scf_custom_endpoint"],
+ },
+ "resourcemanager_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["resourcemanager_custom_endpoint"],
+ },
+ "secretsmanager_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["secretsmanager_custom_endpoint"],
+ },
+ "sqlserverflex_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["sqlserverflex_custom_endpoint"],
+ },
+ "ske_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["ske_custom_endpoint"],
+ },
+ "server_backup_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["server_backup_custom_endpoint"],
+ },
+ "server_update_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["server_update_custom_endpoint"],
+ },
+ "service_account_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["service_account_custom_endpoint"],
+ },
+ "service_enablement_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["service_enablement_custom_endpoint"],
+ },
+ "token_custom_endpoint": schema.StringAttribute{
+ Optional: true,
+ Description: descriptions["token_custom_endpoint"],
+ },
+ },
+ }
+}
+
+// Configure prepares a stackit API client for data sources and resources.
+func (p *Provider) Configure(ctx context.Context, req provider.ConfigureRequest, resp *provider.ConfigureResponse) {
+ // Retrieve provider data and configuration
+ var providerConfig providerModel
+ diags := req.Config.Get(ctx, &providerConfig)
+ resp.Diagnostics.Append(diags...)
+ if resp.Diagnostics.HasError() {
+ return
+ }
+
+ // Configure SDK client
+ sdkConfig := &config.Configuration{}
+ var providerData core.ProviderData
+
+ // Helper function to set a string field if it's known and not null
+ setStringField := func(v basetypes.StringValue, setter func(string)) {
+ if !v.IsUnknown() && !v.IsNull() {
+ setter(v.ValueString())
+ }
+ }
+
+ // Helper function to set a boolean field if it's known and not null
+ setBoolField := func(v basetypes.BoolValuable, setter func(bool)) {
+ if !v.IsUnknown() && !v.IsNull() {
+ val, err := v.ToBoolValue(ctx)
+ if err != nil {
+ core.LogAndAddError(
+ ctx,
+ &resp.Diagnostics,
+ "Error configuring provider",
+ fmt.Sprintf("Setting up bool value: %v", diags.Errors()),
+ )
+ }
+ setter(val.ValueBool())
+ }
+ }
+
+ // Configure SDK client
+ setStringField(providerConfig.CredentialsFilePath, func(v string) { sdkConfig.CredentialsFilePath = v })
+ setStringField(providerConfig.ServiceAccountKey, func(v string) { sdkConfig.ServiceAccountKey = v })
+ setStringField(providerConfig.ServiceAccountKeyPath, func(v string) { sdkConfig.ServiceAccountKeyPath = v })
+ setStringField(providerConfig.PrivateKey, func(v string) { sdkConfig.PrivateKey = v })
+ setStringField(providerConfig.PrivateKeyPath, func(v string) { sdkConfig.PrivateKeyPath = v })
+ setStringField(providerConfig.Token, func(v string) { sdkConfig.Token = v })
+ setStringField(providerConfig.TokenCustomEndpoint, func(v string) { sdkConfig.TokenCustomUrl = v })
+
+ setStringField(providerConfig.DefaultRegion, func(v string) { providerData.DefaultRegion = v })
+ setStringField(
+ providerConfig.Region,
+ func(v string) { providerData.Region = v },
+ ) // nolint:staticcheck // preliminary handling of deprecated attribute
+ setBoolField(providerConfig.EnableBetaResources, func(v bool) { providerData.EnableBetaResources = v })
+
+ setStringField(
+ providerConfig.AuthorizationCustomEndpoint,
+ func(v string) { providerData.AuthorizationCustomEndpoint = v },
+ )
+ setStringField(providerConfig.CdnCustomEndpoint, func(v string) { providerData.CdnCustomEndpoint = v })
+ setStringField(providerConfig.DnsCustomEndpoint, func(v string) { providerData.DnsCustomEndpoint = v })
+ setStringField(providerConfig.GitCustomEndpoint, func(v string) { providerData.GitCustomEndpoint = v })
+ setStringField(providerConfig.IaaSCustomEndpoint, func(v string) { providerData.IaaSCustomEndpoint = v })
+ setStringField(providerConfig.KmsCustomEndpoint, func(v string) { providerData.KMSCustomEndpoint = v })
+ setStringField(
+ providerConfig.LoadBalancerCustomEndpoint,
+ func(v string) { providerData.LoadBalancerCustomEndpoint = v },
+ )
+ setStringField(providerConfig.LogMeCustomEndpoint, func(v string) { providerData.LogMeCustomEndpoint = v })
+ setStringField(providerConfig.MariaDBCustomEndpoint, func(v string) { providerData.MariaDBCustomEndpoint = v })
+ setStringField(
+ providerConfig.ModelServingCustomEndpoint,
+ func(v string) { providerData.ModelServingCustomEndpoint = v },
+ )
+ setStringField(
+ providerConfig.MongoDBFlexCustomEndpoint,
+ func(v string) { providerData.MongoDBFlexCustomEndpoint = v },
+ )
+ setStringField(
+ providerConfig.ObjectStorageCustomEndpoint,
+ func(v string) { providerData.ObjectStorageCustomEndpoint = v },
+ )
+ setStringField(
+ providerConfig.ObservabilityCustomEndpoint,
+ func(v string) { providerData.ObservabilityCustomEndpoint = v },
+ )
+ setStringField(
+ providerConfig.OpenSearchCustomEndpoint,
+ func(v string) { providerData.OpenSearchCustomEndpoint = v },
+ )
+ setStringField(
+ providerConfig.PostgresFlexCustomEndpoint,
+ func(v string) { providerData.PostgresFlexCustomEndpoint = v },
+ )
+ setStringField(providerConfig.RabbitMQCustomEndpoint, func(v string) { providerData.RabbitMQCustomEndpoint = v })
+ setStringField(providerConfig.RedisCustomEndpoint, func(v string) { providerData.RedisCustomEndpoint = v })
+ setStringField(
+ providerConfig.ResourceManagerCustomEndpoint,
+ func(v string) { providerData.ResourceManagerCustomEndpoint = v },
+ )
+ setStringField(providerConfig.ScfCustomEndpoint, func(v string) { providerData.ScfCustomEndpoint = v })
+ setStringField(
+ providerConfig.SecretsManagerCustomEndpoint,
+ func(v string) { providerData.SecretsManagerCustomEndpoint = v },
+ )
+ setStringField(
+ providerConfig.ServerBackupCustomEndpoint,
+ func(v string) { providerData.ServerBackupCustomEndpoint = v },
+ )
+ setStringField(
+ providerConfig.ServerUpdateCustomEndpoint,
+ func(v string) { providerData.ServerUpdateCustomEndpoint = v },
+ )
+ setStringField(
+ providerConfig.ServiceAccountCustomEndpoint,
+ func(v string) { providerData.ServiceAccountCustomEndpoint = v },
+ )
+ setStringField(
+ providerConfig.ServiceEnablementCustomEndpoint,
+ func(v string) { providerData.ServiceEnablementCustomEndpoint = v },
+ )
+ setStringField(providerConfig.SkeCustomEndpoint, func(v string) { providerData.SKECustomEndpoint = v })
+ setStringField(
+ providerConfig.SqlServerFlexCustomEndpoint,
+ func(v string) { providerData.SQLServerFlexCustomEndpoint = v },
+ )
+
+ if !(providerConfig.Experiments.IsUnknown() || providerConfig.Experiments.IsNull()) {
+ var experimentValues []string
+ diags := providerConfig.Experiments.ElementsAs(ctx, &experimentValues, false)
+ if diags.HasError() {
+ core.LogAndAddError(
+ ctx,
+ &resp.Diagnostics,
+ "Error configuring provider",
+ fmt.Sprintf("Setting up experiments: %v", diags.Errors()),
+ )
+ }
+ providerData.Experiments = experimentValues
+ }
+
+ roundTripper, err := sdkauth.SetupAuth(sdkConfig)
+ if err != nil {
+ core.LogAndAddError(
+ ctx,
+ &resp.Diagnostics,
+ "Error configuring provider",
+ fmt.Sprintf("Setting up authentication: %v", err),
+ )
+ return
+ }
+
+ // Make round tripper and custom endpoints available during DataSource and Resource
+ // type Configure methods.
+ providerData.RoundTripper = roundTripper
+ resp.DataSourceData = providerData
+ resp.ResourceData = providerData
+
+ // Copy service account, private key credentials and custom-token endpoint to support ephemeral access token generation
+ var ephemeralProviderData core.EphemeralProviderData
+ ephemeralProviderData.ProviderData = providerData
+ setStringField(providerConfig.ServiceAccountKey, func(v string) { ephemeralProviderData.ServiceAccountKey = v })
+ setStringField(
+ providerConfig.ServiceAccountKeyPath,
+ func(v string) { ephemeralProviderData.ServiceAccountKeyPath = v },
+ )
+ setStringField(providerConfig.PrivateKey, func(v string) { ephemeralProviderData.PrivateKey = v })
+ setStringField(providerConfig.PrivateKeyPath, func(v string) { ephemeralProviderData.PrivateKeyPath = v })
+ setStringField(providerConfig.TokenCustomEndpoint, func(v string) { ephemeralProviderData.TokenCustomEndpoint = v })
+ resp.EphemeralResourceData = ephemeralProviderData
+
+ providerData.Version = p.version
+}
+
+// DataSources defines the data sources implemented in the provider.
+func (p *Provider) DataSources(_ context.Context) []func() datasource.DataSource {
+ return []func() datasource.DataSource{
+ sqlServerFlexAlphaInstance.NewInstanceDataSource,
+ sqlServerFlexAlpaUser.NewUserDataSource,
+ }
+}
+
+// Resources defines the resources implemented in the provider.
+func (p *Provider) Resources(_ context.Context) []func() resource.Resource {
+ resources := []func() resource.Resource{
+ postgresFlexAlphaInstance.NewInstanceResource,
+ sqlServerFlexAlphaInstance.NewInstanceResource,
+ sqlServerFlexAlpaUser.NewUserResource,
+ }
+ return resources
+}
diff --git a/stackit/provider_acc_test.go b/stackit/provider_acc_test.go
new file mode 100644
index 00000000..557d3c61
--- /dev/null
+++ b/stackit/provider_acc_test.go
@@ -0,0 +1,261 @@
+// Copyright (c) STACKIT
+
+package stackit_test
+
+import (
+ _ "embed"
+ "fmt"
+ "os"
+ "path"
+ "regexp"
+ "runtime"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-testing/config"
+ "github.com/hashicorp/terraform-plugin-testing/helper/acctest"
+ "github.com/hashicorp/terraform-plugin-testing/helper/resource"
+ "github.com/stackitcloud/terraform-provider-stackit/stackit/internal/testutil"
+)
+
+//go:embed testdata/provider-credentials.tf
+var providerCredentialConfig string
+
+//go:embed testdata/provider-invalid-attribute.tf
+var providerInvalidAttribute string
+
+//go:embed testdata/provider-all-attributes.tf
+var providerValidAttributes string
+
+var testConfigProviderCredentials = config.Variables{
+ "project_id": config.StringVariable(testutil.ProjectId),
+ "name": config.StringVariable(fmt.Sprintf("tf-acc-prov%s", acctest.RandStringFromCharSet(3, acctest.CharSetAlphaNum))),
+}
+
+// Helper function to obtain the home directory on different systems.
+// Based on os.UserHomeDir().
+func getHomeEnvVariableName() string {
+ env := "HOME"
+ switch runtime.GOOS {
+ case "windows":
+ env = "USERPROFILE"
+ case "plan9":
+ env = "home"
+ }
+ return env
+}
+
+// create temporary home and initialize the credentials file as well
+func createTemporaryHome(createValidCredentialsFile bool, t *testing.T) string {
+ // create a temporary file
+ tempHome, err := os.MkdirTemp("", "tempHome")
+ if err != nil {
+ t.Fatalf("Failed to create temporary home directory: %v", err)
+ }
+
+ // create credentials file in temp directory
+ stackitFolder := path.Join(tempHome, ".stackit")
+ if err := os.Mkdir(stackitFolder, 0o750); err != nil {
+ t.Fatalf("Failed to create stackit folder: %v", err)
+ }
+
+ filePath := path.Join(stackitFolder, "credentials.json")
+ file, err := os.Create(filePath)
+ if err != nil {
+ t.Fatalf("Failed to create credentials file: %v", err)
+ }
+ defer func() {
+ if err := file.Close(); err != nil {
+ t.Fatalf("Error while closing the file: %v", err)
+ }
+ }()
+
+ // Define content, default = invalid token
+ token := "foo_token"
+ if createValidCredentialsFile {
+ token = testutil.GetTestProjectServiceAccountToken("")
+ }
+ content := fmt.Sprintf(`
+ {
+ "STACKIT_SERVICE_ACCOUNT_TOKEN": "%s"
+ }`, token)
+
+ if _, err = file.WriteString(content); err != nil {
+ t.Fatalf("Error writing to file: %v", err)
+ }
+
+ return tempHome
+}
+
+// Function to overwrite the home folder
+func setTemporaryHome(tempHomePath string) {
+ env := getHomeEnvVariableName()
+ if err := os.Setenv(env, tempHomePath); err != nil {
+ fmt.Printf("Error setting temporary home directory %v", err)
+ }
+}
+
+// cleanup the temporary home and reset the environment variable
+func cleanupTemporaryHome(tempHomePath string, t *testing.T) {
+ if err := os.RemoveAll(tempHomePath); err != nil {
+ t.Fatalf("Error cleaning up temporary folder: %v", err)
+ }
+ originalHomeDir, err := os.UserHomeDir()
+ if err != nil {
+ t.Fatalf("Failed to restore home directory back to normal: %v", err)
+ }
+ // revert back to original home folder
+ env := getHomeEnvVariableName()
+ if err := os.Setenv(env, originalHomeDir); err != nil {
+ fmt.Printf("Error resetting temporary home directory %v", err)
+ }
+}
+
+func getServiceAccountToken() (string, error) {
+ token, set := os.LookupEnv("TF_ACC_TEST_PROJECT_SERVICE_ACCOUNT_TOKEN")
+ if !set || token == "" {
+ return "", fmt.Errorf("Token not set, please set TF_ACC_TEST_PROJECT_SERVICE_ACCOUNT_TOKEN to a valid token to perform tests")
+ }
+ return token, nil
+}
+
+func TestAccEnvVarTokenValid(t *testing.T) {
+ // Check if acceptance tests should be run
+ if v := os.Getenv(resource.EnvTfAcc); v == "" {
+ t.Skipf(
+ "Acceptance tests skipped unless env '%s' set",
+ resource.EnvTfAcc)
+ return
+ }
+
+ token, err := getServiceAccountToken()
+ if err != nil {
+ t.Fatalf("Can't get token: %v", err)
+ }
+
+ t.Setenv("STACKIT_CREDENTIALS_PATH", "")
+ t.Setenv("STACKIT_SERVICE_ACCOUNT_TOKEN", token)
+ tempHomeFolder := createTemporaryHome(false, t)
+ defer cleanupTemporaryHome(tempHomeFolder, t)
+ resource.Test(t, resource.TestCase{
+ ProtoV6ProviderFactories: testutil.TestAccProtoV6ProviderFactories,
+ Steps: []resource.TestStep{
+ {
+ PreConfig: func() { setTemporaryHome(tempHomeFolder) },
+ ConfigVariables: testConfigProviderCredentials,
+ Config: providerCredentialConfig,
+ },
+ },
+ })
+}
+
+func TestAccEnvVarTokenInvalid(t *testing.T) {
+ t.Setenv("STACKIT_CREDENTIALS_PATH", "")
+ t.Setenv("STACKIT_SERVICE_ACCOUNT_TOKEN", "foo")
+ tempHomeFolder := createTemporaryHome(false, t)
+ defer cleanupTemporaryHome(tempHomeFolder, t)
+ resource.Test(t, resource.TestCase{
+ ProtoV6ProviderFactories: testutil.TestAccProtoV6ProviderFactories,
+ Steps: []resource.TestStep{
+ {
+ PreConfig: func() { setTemporaryHome(tempHomeFolder) },
+ ConfigVariables: testConfigProviderCredentials,
+ Config: providerCredentialConfig,
+ ExpectError: regexp.MustCompile(`undefined response type, status code 401`),
+ },
+ },
+ })
+}
+
+func TestAccCredentialsFileValid(t *testing.T) {
+ t.Setenv("STACKIT_CREDENTIALS_PATH", "")
+ t.Setenv("STACKIT_SERVICE_ACCOUNT_TOKEN", "")
+ tempHomeFolder := createTemporaryHome(true, t)
+ defer cleanupTemporaryHome(tempHomeFolder, t)
+ resource.Test(t, resource.TestCase{
+ ProtoV6ProviderFactories: testutil.TestAccProtoV6ProviderFactories,
+ Steps: []resource.TestStep{
+ {
+ PreConfig: func() { setTemporaryHome(tempHomeFolder) },
+ ConfigVariables: testConfigProviderCredentials,
+ Config: providerCredentialConfig,
+ },
+ },
+ })
+}
+
+func TestAccCredentialsFileInvalid(t *testing.T) {
+ t.Setenv("STACKIT_CREDENTIALS_PATH", "")
+ t.Setenv("STACKIT_SERVICE_ACCOUNT_TOKEN", "")
+ tempHomeFolder := createTemporaryHome(false, t)
+ defer cleanupTemporaryHome(tempHomeFolder, t)
+ resource.Test(t, resource.TestCase{
+ ProtoV6ProviderFactories: testutil.TestAccProtoV6ProviderFactories,
+ Steps: []resource.TestStep{
+ {
+ PreConfig: func() { setTemporaryHome(tempHomeFolder) },
+ ConfigVariables: testConfigProviderCredentials,
+ Config: providerCredentialConfig,
+ ExpectError: regexp.MustCompile(`Jwt is not in(\r\n|\r|\n)the form of Header.Payload.Signature`),
+ },
+ },
+ })
+}
+
+func TestAccProviderConfigureValidValues(t *testing.T) {
+ // Check if acceptance tests should be run
+ if v := os.Getenv(resource.EnvTfAcc); v == "" {
+ t.Skipf(
+ "Acceptance tests skipped unless env '%s' set",
+ resource.EnvTfAcc)
+ return
+ }
+ // use service account token for these tests
+ token, err := getServiceAccountToken()
+ if err != nil {
+ t.Fatalf("Can't get token: %v", err)
+ }
+
+ t.Setenv("STACKIT_CREDENTIALS_PATH", "")
+ t.Setenv("STACKIT_SERVICE_ACCOUNT_TOKEN", token)
+ tempHomeFolder := createTemporaryHome(true, t)
+ defer cleanupTemporaryHome(tempHomeFolder, t)
+ resource.Test(t, resource.TestCase{
+ ProtoV6ProviderFactories: testutil.TestAccProtoV6ProviderFactories,
+ Steps: []resource.TestStep{
+ { // valid provider attributes
+ ConfigVariables: testConfigProviderCredentials,
+ Config: providerValidAttributes,
+ },
+ },
+ })
+}
+
+func TestAccProviderConfigureAnInvalidValue(t *testing.T) {
+ // Check if acceptance tests should be run
+ if v := os.Getenv(resource.EnvTfAcc); v == "" {
+ t.Skipf(
+ "Acceptance tests skipped unless env '%s' set",
+ resource.EnvTfAcc)
+ return
+ }
+ // use service account token for these tests
+ token, err := getServiceAccountToken()
+ if err != nil {
+ t.Fatalf("Can't get token: %v", err)
+ }
+
+ t.Setenv("STACKIT_CREDENTIALS_PATH", "")
+ t.Setenv("STACKIT_SERVICE_ACCOUNT_TOKEN", token)
+ tempHomeFolder := createTemporaryHome(true, t)
+ defer cleanupTemporaryHome(tempHomeFolder, t)
+ resource.Test(t, resource.TestCase{
+ ProtoV6ProviderFactories: testutil.TestAccProtoV6ProviderFactories,
+ Steps: []resource.TestStep{
+ { // invalid test attribute should throw an error
+ ConfigVariables: testConfigProviderCredentials,
+ Config: providerInvalidAttribute,
+ ExpectError: regexp.MustCompile(`An argument named "test" is not expected here\.`),
+ },
+ },
+ })
+}
diff --git a/stackit/testdata/provider-all-attributes.tf b/stackit/testdata/provider-all-attributes.tf
new file mode 100644
index 00000000..59452c76
--- /dev/null
+++ b/stackit/testdata/provider-all-attributes.tf
@@ -0,0 +1,43 @@
+# Copyright (c) STACKIT
+
+variable "project_id" {}
+variable "name" {}
+
+provider "stackit" {
+ default_region = "eu01"
+ credentials_path = "~/.stackit/credentials.json"
+ service_account_token = ""
+ service_account_key_path = ""
+ service_account_key = ""
+ private_key_path = ""
+ private_key = ""
+ service_account_email = "abc@abc.de"
+ cdn_custom_endpoint = "https://cdn.api.eu01.stackit.cloud"
+ dns_custom_endpoint = "https://dns.api.stackit.cloud"
+ git_custom_endpoint = "https://git.api.stackit.cloud"
+ iaas_custom_endpoint = "https://iaas.api.stackit.cloud"
+ mongodbflex_custom_endpoint = "https://mongodbflex.api.stackit.cloud"
+ modelserving_custom_endpoint = "https://modelserving.api.stackit.cloud"
+ loadbalancer_custom_endpoint = "https://load-balancer.api.stackit.cloud"
+ mariadb_custom_endpoint = "https://mariadb.api.stackit.cloud"
+ authorization_custom_endpoint = "https://authorization.api.stackit.cloud"
+ objectstorage_custom_endpoint = "https://objectstorage.api.stackit.cloud"
+ observability_custom_endpoint = "https://observability.api.stackit.cloud"
+ opensearch_custom_endpoint = "https://opensearch.api.stackit.cloud"
+ postgresflex_custom_endpoint = "https://postgresflex.api.stackit.cloud"
+ redis_custom_endpoint = "https://redis.api.stackit.cloud"
+ server_backup_custom_endpoint = "https://server-backup.api.stackit.cloud"
+ server_update_custom_endpoint = "https://server-update.api.stackit.cloud"
+ service_account_custom_endpoint = "https://service-account.api.stackit.cloud"
+ resourcemanager_custom_endpoint = "https://resourcemanager.api.stackit.cloud"
+ sqlserverflex_custom_endpoint = "https://sqlserverflex.api.stackit.cloud"
+ ske_custom_endpoint = "https://ske.api.stackit.cloud"
+ service_enablement_custom_endpoint = "https://service-enablement.api.stackit.cloud"
+ token_custom_endpoint = "https://token.api.stackit.cloud"
+ enable_beta_resources = "true"
+}
+
+resource "stackit_network" "network" {
+ name = var.name
+ project_id = var.project_id
+}
diff --git a/stackit/testdata/provider-credentials.tf b/stackit/testdata/provider-credentials.tf
new file mode 100644
index 00000000..45778443
--- /dev/null
+++ b/stackit/testdata/provider-credentials.tf
@@ -0,0 +1,12 @@
+# Copyright (c) STACKIT
+
+variable "project_id" {}
+variable "name" {}
+
+provider "stackit" {
+}
+
+resource "stackit_network" "network" {
+ name = var.name
+ project_id = var.project_id
+}
\ No newline at end of file
diff --git a/stackit/testdata/provider-invalid-attribute.tf b/stackit/testdata/provider-invalid-attribute.tf
new file mode 100644
index 00000000..fff0834a
--- /dev/null
+++ b/stackit/testdata/provider-invalid-attribute.tf
@@ -0,0 +1,13 @@
+# Copyright (c) STACKIT
+
+variable "project_id" {}
+variable "name" {}
+
+provider "stackit" {
+ test = "test"
+}
+
+resource "stackit_network" "network" {
+ name = var.name
+ project_id = var.project_id
+}
\ No newline at end of file
diff --git a/tools/tools.go b/tools/tools.go
new file mode 100644
index 00000000..b142c65c
--- /dev/null
+++ b/tools/tools.go
@@ -0,0 +1,12 @@
+package tools
+
+// Generate copyright headers
+//go:generate go run github.com/hashicorp/copywrite headers -d .. --config ../.copywrite.hcl
+
+// Format Terraform code for use in documentation.
+// If you do not have Terraform installed, you can remove the formatting command, but it is suggested
+// to ensure the documentation is formatted properly.
+//go:generate terraform fmt -recursive ../examples/
+
+// Generate documentation.
+//go:generate go run github.com/hashicorp/terraform-plugin-docs/cmd/tfplugindocs generate --provider-dir .. -provider-name stackitprivatepreview