From 8b966bb7470f281854818c5a9f341054e784ec80 Mon Sep 17 00:00:00 2001
From: Simon Wallner
Date: Fri, 10 Nov 2023 16:36:13 +0100
Subject: [PATCH] updated API key to auth token, fixed web app links
---
content/en/getting-started/api-key.md | 121 -----------------
content/en/getting-started/auth-token.md | 123 ++++++++++++++++++
content/en/getting-started/faq.md | 22 ++--
content/en/getting-started/glossary.md | 2 +-
content/en/getting-started/installation.md | 32 ++---
content/en/getting-started/quickstart.md | 8 +-
content/en/overview/_index.html | 2 +-
content/en/references/configuration.md | 6 +-
content/en/references/docker-images.md | 4 +-
.../transparent-endpoint-injection/_index.md | 2 +-
.../en/references/persistence-mechanism.md | 6 +-
content/en/references/usage-tracking.md | 10 +-
.../tutorials/ecs-ecr-container-app/index.md | 4 +-
.../en/tutorials/elb-load-balancing/index.md | 2 +-
.../tutorials/java-notification-app/index.md | 4 +-
.../lambda-ecr-container-images/index.md | 4 +-
.../index.md | 6 +-
.../schema-evolution-glue-msk/index.md | 2 +-
.../aws/elastic-compute-cloud/index.md | 2 +-
content/en/user-guide/ci/_index.md | 12 +-
content/en/user-guide/ci/circle-ci/index.md | 10 +-
content/en/user-guide/ci/drone-ci/index.md | 8 +-
.../en/user-guide/ci/github-actions/index.md | 16 +--
content/en/user-guide/ci/gitlab-ci/index.md | 8 +-
content/en/user-guide/ci/harness-ci/index.md | 16 +--
content/en/user-guide/ci/travis-ci/index.md | 10 +-
.../extensions/developing-extensions/index.md | 4 +-
.../extensions/managing-extensions/index.md | 6 +-
.../integrations/kafka/docker-compose.yml | 2 +-
.../tools/cloud-pods/getting-started/index.md | 8 +-
.../web-application/ci-keys/ci-keys.png | Bin 0 -> 11672226 bytes
.../web-application/ci-keys/index.md | 4 +-
.../custom-local-endpoint.md | 5 +-
.../web-application/resource-browser/index.md | 6 +-
.../web-application/single-sign-on/_index.md | 2 +-
.../single-sign-on/azure-ad/index.md | 4 +-
.../web-application/stack-insights/index.md | 4 +-
.../web-application/users-licences/index.md | 2 +-
38 files changed, 246 insertions(+), 243 deletions(-)
delete mode 100644 content/en/getting-started/api-key.md
create mode 100644 content/en/getting-started/auth-token.md
create mode 100644 content/en/user-guide/web-application/ci-keys/ci-keys.png
diff --git a/content/en/getting-started/api-key.md b/content/en/getting-started/api-key.md
deleted file mode 100644
index 0f4c7297b5..0000000000
--- a/content/en/getting-started/api-key.md
+++ /dev/null
@@ -1,121 +0,0 @@
----
-title: "API Key"
-weight: 20
-categories: ["LocalStack Pro & Enterprise"]
-description: >
- Configure your API key to start LocalStack
-aliases:
- - /get-started/pro/
----
-
-The LocalStack API key is a unique identifier to activate your LocalStack license needed to start LocalStack Pro.
-You can find your API key in the [LocalStack Web app](https://app.localstack.cloud/account/apikeys).
-This guide demonstrates how you can use your new LocalStack licenses and go over some best practices regarding the usage, activation, and safety of your LocalStack API key.
-
-## Getting your API key
-
-To get started, you need to have a LocalStack license. If you don't have one, you can [sign up for a free trial](https://localstack.cloud/pricing/) without any credit card required. The free trial will last 14 days, and you can use it to test all the features of LocalStack. After a free trial, you can find your API key in the [LocalStack Web app](https://app.localstack.cloud) in the [**Account Settings** β **API Keys** section](https://app.localstack.cloud/account/apikeys).
-
-{{< alert title="Important" color="danger" >}}
-- Avoid sharing your API key with anyone. Ensure that you do not commit it to any source code management systems (like Git repositories).
-- If you push an API key to a public repository, it has potentially been exposed and might remain in the history (even if you try to rewrite it).
-- If you accidentally publish your API key, please [contact us](https://localstack.cloud/contact/) immediately to get your API key rotated!
-- If you want to use your API key in your CI environment, check out our [CI documentation]({{< ref "user-guide/ci" >}}) to see the proper way to handle secrets in your CI environment to store your API key securely.
-{{< /alert >}}
-
-### Starting LocalStack via CLI
-
-LocalStack expects your API key to be present in the environment variable `LOCALSTACK_API_KEY`. You can define the `LOCALSTACK_API_KEY` environment variable before or while starting LocalStack using the `localstack` CLI.
-
-{{< tabpane >}}
-{{< tab header="macOS/Linux" lang="shell" >}}
-export LOCALSTACK_API_KEY=
-localstack start
-{{< /tab >}}
-{{< tab header="Windows" lang="powershell" >}}
-$env:LOCALSTACK_API_KEY=""; localstack start
-{{< /tab >}}
-{{< /tabpane >}}
-
-You can optionally run your LocalStack container in background mode by adding the `-d` flag to the `localstack start` command.
-
-The `localstack` CLI will detect the API key and properly pass it to the LocalStack container.
-
-{{< alert title="Note" >}}
-If you are using LocalStack with an API Key, you need to pull the [LocalStack Pro image](https://docs.localstack.cloud/references/docker-images/#localstack-pro-image) that includes the Pro services and several other advanced features.
-{{< /alert >}}
-
-### Starting LocalStack via Docker
-
-To start LocalStack using Docker, you have to specify the API key using the `-e` flag for environment variables:
-
-{{< command "hl_lines=5" >}}
-$ docker run \
- --rm -it \
- -p 4566:4566 \
- -p 4510-4559:4510-4559 \
- -e LOCALSTACK_API_KEY=${LOCALSTACK_API_KEY:- } \
- localstack/localstack-pro
-{{< / command >}}
-
-For more information about starting LocalStack with Docker, take a look at our [Docker installation](https://docs.localstack.cloud/getting-started/installation/#docker) guide.
-
-### Starting LocalStack via Docker-Compose
-
-To start LocalStack using `docker-compose`, you have to include the `LOCALSTACK_API_KEY` environment variable in your `docker-compose.yml` file:
-
-```yaml
-environment:
- - LOCALSTACK_API_KEY=${LOCALSTACK_API_KEY- }
-```
-
-You can set the API key manually, or you can use the `export` command to set the API key in your current shell session. The API key will be passed into your LocalStack container, such that the key activation can take place.
-
-## Licensing-related configuration
-
-If you want to make sure that LocalStack is only started if you can activate LocalStack Pro or Enterprise, or if you wish to suppress licensing-related error messages, take a look at our [configuration guide]({{< ref "configuration.md#localstack-pro">}}) regarding LocalStack Pro.
-
-## Checking license activation
-
-The easiest way to check if LocalStack is activated is to query the health endpoint for a list of the running services:
-
-{{< command >}}
-$ curl localhost:4566/_localstack/health | jq
-{{< / command >}}
-
-If a Pro-only [service]({{< ref "aws" >}}) -- like [XRay]({{< ref "xray" >}}) -- is running, LocalStack has started successfully. You can also check the logs of the LocalStack container to see if the activation was successful.
-
-{{< command >}}
-[...] Successfully activated API key
-{{< / command >}}
-
-Otherwise, check our collected most [common activation issues](#common-activation-issues).
-
-## Common activation issues
-
-Since LocalStack v2.0.0, the image `localstack/localstack-pro` requires a successful key activation to start.
-If the key activation fails, LocalStack will quit with an error messages that may look something like this:
-
-```
-===============================================
-API key activation failed! πβ
-
-The API key you provided in the `LOCALSTACK_API_KEY` environment variable '"foo..."(6)' could not beactivated against our licensing server. Server message: Unable to verify API key.
-
-Due to this error, Localstack has quit. LocalStack pro features can only be used with a valid license.
-
-- Please check that your API key is set up correctly and that you are using the correct key.
- You can find your API key in our webapp at https://app.localstack.cloud.
-- If you want to continue using LocalStack without pro features you can set `ACTIVATE_PRO=0`.
-```
-
-There are several reasons a key activation can fail:
-* Missing credentials: Using `localstack/localstack-pro` requires per default to have an API key set.
-* Invalid key: there is no valid license associated with the key, for example because the license has expired.
-* License server cannot be reached: LocalStack will try to perform an offline license activation if the license server cannot be reached, but will require a re-activation every 24 hours.
-
-If you are using the `localstack/localstack-pro` image, but cannot activate your license key, we recommend falling back to the community version `localstack/localstack`.
-If that is not an option, you can set `ACTIVATE_PRO=0` which will attempt to start LocalStack without pro features.
-
-Navigate to our [FAQ page]({{< ref "faq" >}}) if your are having troubles with the LocalStack API key activation.
-If you have any further problems concerning your API key activation, or if the steps do not help, do not hesitate to [contact us](https://localstack.cloud/contact/).
diff --git a/content/en/getting-started/auth-token.md b/content/en/getting-started/auth-token.md
new file mode 100644
index 0000000000..3726e61189
--- /dev/null
+++ b/content/en/getting-started/auth-token.md
@@ -0,0 +1,123 @@
+---
+title: "Auth Token"
+weight: 20
+categories: ["LocalStack Pro & Enterprise"]
+description: >
+ Configure your auth token to start LocalStack
+aliases:
+ - /get-started/pro/
+---
+
+LocalStack uses auth tokens to to authenticate users and to activate your LocalStack license.
+You can find your auth token on the [Getting Started page in the web app](https://app.localstack.cloud/getting-started) or on the [Auth Token page](https://app.localstack.cloud/workspace/auth-token)
+
+## Managing your License
+
+To get started, you need to have a LocalStack license. If you don't have one, you can [sign up for a free trial](https://localstack.cloud/pricing/) without any credit card required. The free trial will last 14 days, and you can use it to test all the features of LocalStack.
+
+You can assign licenses to users on the [Users & Licenses](https://app.localstack.cloud/workspace/members) page or you can check your assigned license on the [My License](https://app.localstack.cloud/workspace/my-license) page.
+
+
+{{< alert title="Important" color="danger" >}}
+- Avoid sharing your auth token with anyone. Ensure that you do not commit it to any source code management systems (like Git repositories).
+- If you push an auth token to a public repository, it has potentially been exposed and might remain in the history (even if you try to rewrite it).
+- If you accidentally publish your auth token, you can rotate it on the [Auth Token](https://app.localstack.cloud/workspace/auth-token) page
+- Use in CI or other machine environments requires a CI key. Check out our [CI documentation]({{< ref "user-guide/ci" >}}) to see the proper way to handle secrets in your CI environment to store your CI key securely.
+{{< /alert >}}
+
+### Starting LocalStack via CLI
+
+LocalStack expects your auth token to be present in the environment variable `LOCALSTACK_AUTH_TOKEN`. You can define the `LOCALSTACK_AUTH_TOKEN` environment variable before or while starting LocalStack using the `localstack` CLI.
+
+{{< tabpane >}}
+{{< tab header="macOS/Linux" lang="shell" >}}
+export LOCALSTACK_AUTH_TOKEN=
+localstack start
+{{< /tab >}}
+{{< tab header="Windows" lang="powershell" >}}
+$env:LOCALSTACK_AUTH_TOKEN=""; localstack start
+{{< /tab >}}
+{{< /tabpane >}}
+
+You can optionally run your LocalStack container in background mode by adding the `-d` flag to the `localstack start` command.
+
+The `localstack` CLI will detect the auth token and properly pass it to the LocalStack container.
+
+{{< alert title="Note" >}}
+If you are using LocalStack with an auth token, you need to pull the [LocalStack Pro image](https://docs.localstack.cloud/references/docker-images/#localstack-pro-image) that includes the Pro services and several other advanced features.
+{{< /alert >}}
+
+### Starting LocalStack via Docker
+
+To start LocalStack using Docker, you have to specify the auth token using the `-e` flag for environment variables:
+
+{{< command "hl_lines=5" >}}
+$ docker run \
+ --rm -it \
+ -p 4566:4566 \
+ -p 4510-4559:4510-4559 \
+ -e LOCALSTACK_AUTH_TOKEN=${LOCALSTACK_AUTH_TOKEN:- } \
+ localstack/localstack-pro
+{{< / command >}}
+
+For more information about starting LocalStack with Docker, take a look at our [Docker installation](https://docs.localstack.cloud/getting-started/installation/#docker) guide.
+
+### Starting LocalStack via Docker-Compose
+
+To start LocalStack using `docker-compose`, you have to include the `LOCALSTACK_AUTH_TOKEN` environment variable in your `docker-compose.yml` file:
+
+```yaml
+environment:
+ - LOCALSTACK_AUTH_TOKEN=${LOCALSTACK_AUTH_TOKEN- }
+```
+
+You can set the auth token manually, or you can use the `export` command to set the auth token in your current shell session. The auth token will be passed into your LocalStack container, such that the key activation can take place.
+
+## Licensing-related configuration
+
+If you want to make sure that LocalStack is only started if you can activate LocalStack Pro or Enterprise, or if you wish to suppress licensing-related error messages, take a look at our [configuration guide]({{< ref "configuration.md#localstack-pro">}}) regarding LocalStack Pro.
+
+## Checking license activation
+
+The easiest way to check if LocalStack is activated is to query the health endpoint for a list of the running services:
+
+{{< command >}}
+$ curl localhost:4566/_localstack/health | jq
+{{< / command >}}
+
+If a Pro-only [service]({{< ref "aws" >}}) -- like [XRay]({{< ref "xray" >}}) -- is running, LocalStack has started successfully. You can also check the logs of the LocalStack container to see if the activation was successful.
+
+{{< command >}}
+[...] Successfully activated license
+{{< / command >}}
+
+Otherwise, check our collected most [common activation issues](#common-activation-issues).
+
+## Common activation issues
+
+Since LocalStack v2.0.0, the image `localstack/localstack-pro` requires a successful license activation to start.
+If the license activation fails, LocalStack will quit with an error messages that may look something like this:
+
+```
+===============================================
+License activation failed! πβ
+
+Reason: The credentials defined in your environment are invalid. Please make sure to either set the LOCALSTACK_AUTH_TOKEN variable to a valid auth token, or the LOCALSTACK_API_KEY variable to a valid LocalStack API key. You can find your auth token or API key in the LocalStack web app https://app.localstack.cloud.
+
+Due to this error, Localstack has quit. LocalStack pro features can only be used with a valid license.
+
+- Please check that your credentials are set up correctly and that you have an active license.
+ You can find your credentials in our webapp at https://app.localstack.cloud.
+- If you want to continue using LocalStack without pro features you can set `ACTIVATE_PRO=0`.
+```
+
+There are several reasons a key activation can fail:
+* Missing credentials: Using `localstack/localstack-pro` requires per default to have an auth token or legacy API key set.
+* Invalid license: there is no valid license associated with your user account, for example because the license has expired.
+* License server cannot be reached: LocalStack will try to perform an offline license activation if the license server cannot be reached, but will require a re-activation every 24 hours.
+
+If you are using the `localstack/localstack-pro` image, but cannot activate your license, we recommend falling back to the community version `localstack/localstack`.
+If that is not an option, you can set `ACTIVATE_PRO=0` which will attempt to start LocalStack without pro features.
+
+Navigate to our [FAQ page]({{< ref "faq" >}}) if your are having troubles with the LocalStack license activation.
+If you have any further problems concerning your license activation, or if the steps do not help, do not hesitate to [contact us](https://localstack.cloud/contact/).
diff --git a/content/en/getting-started/faq.md b/content/en/getting-started/faq.md
index 5d83843179..da92784ce6 100644
--- a/content/en/getting-started/faq.md
+++ b/content/en/getting-started/faq.md
@@ -3,7 +3,7 @@ title: "Frequently Asked Questions"
linkTitle: "FAQ"
weight: 40
description: >
- This page answers the frequently asked questions about LocalStack Pro, Enterprise, and Community Editions.
+ This page answers the frequently asked questions about LocalStack Pro, Enterprise, and Community Editions.
cascade:
type: docs
hide_readingtime: true
@@ -48,7 +48,7 @@ You can access LocalStack from an alternative computer, by exposing portΒ `4566`
### How to fix LocalStack CLI (Python) UTF-8 encoding issue under Windows?
-If you are using LocalStack CLI under Windows, you might run into encoding issues. To fix this, set the following environment variables:
+If you are using LocalStack CLI under Windows, you might run into encoding issues. To fix this, set the following environment variables:
Set the system locale (language for non-Unicode programs) to UTF-8 to avoid Unicode errors.
Follow these steps:
@@ -67,8 +67,8 @@ A company proxy can lead to connection issues. To allow access to the `localstac
```yaml
...
-environment:
-- HTTP_PROXY =
+environment:
+- HTTP_PROXY =
- NO_PROXY = .s3.localhost.localstack.cloud,127.0.0.1,*.localhost
...
```
@@ -109,7 +109,7 @@ You might be able to connect to the internet, but your Docker container can't co
More details can be found on [official docker documentation](https://docs.docker.com/network/bridge/#enable-forwarding-from-docker-containers-to-the-outside-world).
-Solution for this is enabling the IP forwarding:
+Solution for this is enabling the IP forwarding:
```bash
sudo sysctl -w net.ipv4.ip_forward=1
@@ -162,7 +162,7 @@ For example, these options may interfere with the functionality of AppSync funct
We advise you to exercise caution.
{{< /alert >}}
-You can change the LocalStack `volume` folder to use the WSL Linux file system instead of the Windows host folder.
+You can change the LocalStack `volume` folder to use the WSL Linux file system instead of the Windows host folder.
To do so, you need to change the [`docker-compose.yml`](https://github.com/localstack/localstack/blob/master/docker-compose-pro.yml) file and add the following lines:
{{< tabpane text=true >}}
@@ -200,7 +200,7 @@ For more details visit [Docker WSL documentation](https://docs.docker.com/deskto
## LocalStack Platform FAQs
-### How do I check if my API key is valid and activated?
+### How do I check if my license is valid and activated?
The easiest way to check if LocalStack Pro or Enterprise is activated is to check the health endpoint of LocalStack for a list of the running services:
@@ -208,13 +208,13 @@ The easiest way to check if LocalStack Pro or Enterprise is activated is to chec
$ curl localhost:4566/_localstack/health | jq
{{< / command >}}
-If a Pro-only [service]({{< ref "aws" >}}) -- like [XRay]({{< ref "xray" >}}) -- is running, LocalStack Pro or Enterprise has started successfully. If your API key is invalid, you will see an error message like this in the logs of LocalStack:
+If a Pro-only [service]({{< ref "aws" >}}) -- like [XRay]({{< ref "xray" >}}) -- is running, LocalStack Pro or Enterprise has started successfully. If your auth token is invalid, you will see an error message like this in the logs of LocalStack:
```bash
-Activation key "abc..."(10) is invalid or expired! Reason: ...
+license activation failed! Reason: ...
```
-If this error occurs, something is wrong with your API key or license. Make sure your API key is set correctly (check for typos!) and your license is valid. If the API key still does not work, please [contact us](https://localstack.cloud/contact/).
+If this error occurs, something is wrong with your auth token or license. Make sure your auth token is set correctly (check for typos!) and your license is valid. If the auth token still does not work, please [contact us](https://localstack.cloud/contact/).
### How are CI credits in LocalStack calculated?
@@ -256,7 +256,7 @@ Some corporate DNS servers might filter requests to certain domains. Contact you
We take security seriously and respond to any emergency vulnerabilities as soon as possible. Our cloud provider (AWS) handles most of the infrastructure maintenance for us. We also use Infrastructure-as-Code scripts to ensure that our infrastructure configuration is consistent and recoverable in case of a disaster.
-### How does LocalStack ensure the security of its containers and images?
+### How does LocalStack ensure the security of its containers and images?
Our software assets are regularly checked for vulnerabilities, such as code issues and outdated dependencies. We use Dependabot to scan our GitHub repositories, and Trivy as well as Snyk (among other security tools) to scan our Docker images.
diff --git a/content/en/getting-started/glossary.md b/content/en/getting-started/glossary.md
index de90224355..b51829675b 100644
--- a/content/en/getting-started/glossary.md
+++ b/content/en/getting-started/glossary.md
@@ -18,7 +18,7 @@ hide_readingtime: true
| [Edge Port]({{< ref "endpoint-url" >}}) | The HTTP port LocalStack listens on for any type of request (e.g. from AWS SDKs). The default port is 4566. |
| [External Service Ports]({{< ref "external-ports" >}}) | The ports reserved for infrastructure that is started as part of a managed service like database server, Redis cluster, and are exposed through the LocalStack Container. |
| [Lambda Hot Reloading]({{< ref "hot-reloading" >}}) | The ability to make changes in Lambda handler files, and have them immediately reflected on each invocation of a Lambda function, without the need to redeploy the Lambda function. |
-| [LocalStack API Key]({{< ref "api-key" >}}) | An API key that can be configured via the LOCALSTACK_API_KEY environment variable, to enable advanced features in your LocalStack instance. We distinguish between individual developer keys, as well as CI keys for continuous integration environments (e.g., Github Actions, CircleCI, etc). |
+| [LocalStack auth token]({{< ref "auth-token" >}}) | An auth token that can be configured via the LOCALSTACK_AUTH_TOKEN environment variable, to enable advanced features in your LocalStack instance. We distinguish between individual developer auth tokens, as well as CI keys for continuous integration environments (e.g., Github Actions, CircleCI, etc). |
| [LocalStack Container]({{< ref "installation" >}}) | The Docker/Podman container or Kubernetes pod running LocalStack. |
| [LocalStack Extensions]({{< ref "references/extensions" >}}) | Extend and customize LocalStack using pluggable Python distributions to run applications alongside the main process in the LocalStack Docker container. |
| [LocalStack Platform]({{< ref "web-application" >}}) | The LocalStack Web Application for licensed users to use advanced features, such as Stack Insights, CI Analytics, Resource Browser, and Team Collaboration. |
diff --git a/content/en/getting-started/installation.md b/content/en/getting-started/installation.md
index cdc5871190..aca95eb95d 100644
--- a/content/en/getting-started/installation.md
+++ b/content/en/getting-started/installation.md
@@ -60,7 +60,7 @@ $ python3 -m pip install --upgrade localstack
{{% /markdown %}}
{{< alert title="Important" color="danger" >}}
-Do not use `sudo` or the `root` user - LocalStack should be installed and started entirely under a local non-root user.
+Do not use `sudo` or the `root` user - LocalStack should be installed and started entirely under a local non-root user.
If you have problems with permissions in MacOS X Sierra, install with `python3 -m pip install --user localstack`.
{{< /alert >}}
@@ -119,7 +119,7 @@ $ python3 -m pip install --upgrade localstack
{{< / command >}}
{{% /markdown %}}
{{< alert title="Important" color="danger" >}}
-Do not use `sudo` or the `root` user - LocalStack should be installed and started entirely under a local non-root user.
+Do not use `sudo` or the `root` user - LocalStack should be installed and started entirely under a local non-root user.
{{< /alert >}}
{{< /tab >}}
@@ -127,7 +127,7 @@ Do not use `sudo` or the `root` user - LocalStack should be installed and starte
{{< tab header="Windows" >}}
-You can download the respective binary for your architecture directly:
+You can download the respective binary for your architecture directly:
{{< cli-binary-download os="windows" >}}
Then extract the archive and execute the binary using Powershell.
@@ -146,7 +146,7 @@ $ python3 -m pip install --upgrade localstack
{{% /markdown %}}
{{< alert title="Important" color="danger" >}}
-Do not use `sudo` or the `root` user - LocalStack should be installed and started entirely under a local non-root user.
+Do not use `sudo` or the `root` user - LocalStack should be installed and started entirely under a local non-root user.
{{< /alert >}}
{{< /tab >}}
@@ -168,7 +168,7 @@ $ python3 -m pip install --upgrade localstack
{{< alert title="Note" >}}
To download a specific version of LocalStack, check out our [release page](https://github.com/localstack/localstack) and download it in the following manner:
-{{< command >}}
+{{< command >}}
$ python3 -m pip install localstack==
{{< / command >}}
{{% markdown %}}
@@ -177,7 +177,7 @@ Here `` depicts the particular LocalStack version that you would like t
{{< /alert >}}
{{< alert title="Important" color="danger" >}}
-Do not use `sudo` or the `root` user - LocalStack should be installed and started entirely under a local non-root user.
+Do not use `sudo` or the `root` user - LocalStack should be installed and started entirely under a local non-root user.
{{< /alert >}}
{{< /tab >}}
{{< /tabpane >}}
@@ -189,7 +189,7 @@ $ localstack --version
{{< / command >}}
You are all set!
-To use all of LocalStack's features we recommend to [get a LocalStack account and set up your api key]({{< ref "api-key" >}}).
+To use all of LocalStack's features we recommend to [get a LocalStack account and set up your auth token]({{< ref "auth-token" >}}).
Afterwards, check out our [Quickstart guide]({{< ref "quickstart" >}}) to start your local cloud!
## Alternatives
@@ -272,7 +272,7 @@ services:
environment:
- DEBUG=${DEBUG-}
- PERSISTENCE=${PERSISTENCE-}
- - LOCALSTACK_API_KEY=${LOCALSTACK_API_KEY-} # required for Pro
+ - LOCALSTACK_AUTH_TOKEN=${LOCALSTACK_AUTH_TOKEN-} # required for Pro
- DOCKER_HOST=unix:///var/run/docker.sock
volumes:
- "${LOCALSTACK_VOLUME_DIR:-./volume}:/var/lib/localstack"
@@ -290,7 +290,7 @@ $ docker-compose up
- This command pulls the current nightly build from the `master` branch (if you don't have the image locally) and **not** the latest supported version.
If you want to use a specific version, set the appropriate localstack image tag at `services.localstack.image` in the `docker-compose.yml` file (for example `localstack/localstack:`).
-- If you are using LocalStack with an [API key]({{< ref "api-key" >}}), you need to specify the image tag as `localstack/localstack-pro` in the `docker-compose.yml` file.
+- If you are using LocalStack with an [auth token]({{< ref "auth-token" >}}), you need to specify the image tag as `localstack/localstack-pro` in the `docker-compose.yml` file.
Going forward, `localstack/localstack-pro` image will contain our Pro-supported services and APIs.
- This command reuses the image if it's already on your machine, i.e. it will **not** pull the latest image automatically from Docker Hub.
@@ -303,7 +303,7 @@ $ docker-compose up
- If using the Docker default bridge network using `network_mode: bridge`, container name resolution will not work inside your containers.
Please consider removing it, if this functionality is needed.
-- To configure an API key, refer to the [API Key](https://docs.localstack.cloud/getting-started/api-key/) documentation.
+- To configure an auth token, refer to the [auth token](https://docs.localstack.cloud/getting-started/auth-token/) documentation.
{{< /alert >}}
Please note that there are a few pitfalls when configuring your stack manually via docker-compose (e.g., required container name, Docker network, volume mounts, and environment variables).
@@ -342,7 +342,7 @@ docker run \
--rm -it \
-p 4566:4566 \
-p 4510-4559:4510-4559 \
- -e LOCALSTACK_API_KEY=${LOCALSTACK_API_KEY:- } \
+ -e LOCALSTACK_AUTH_TOKEN=${LOCALSTACK_AUTH_TOKEN:- } \
localstack/localstack-pro{{< /tab >}}
{{< /tabpane >}}
@@ -350,7 +350,7 @@ docker run \
- This command pulls the current nightly build from the `master` branch (if you don't have the image locally) and **not** the latest supported version.
If you want to use a specific version of LocalStack, use the appropriate tag: `docker run --rm -it -p 4566:4566 -p 4510-4559:4510-4559 localstack/localstack:`. Check-out the [LocalStack releases](https://github.com/localstack/localstack/releases) to know more about specific LocalStack versions.
-- If you are using LocalStack with an [API key]({{< ref "api-key" >}}), you need to specify the image tag as `localstack/localstack-pro` in your Docker setup.
+- If you are using LocalStack with an [auth token]({{< ref "auth-token" >}}), you need to specify the image tag as `localstack/localstack-pro` in your Docker setup.
Going forward, `localstack/localstack-pro` image will contain our Pro-supported services and APIs.
- This command reuses the image if it's already on your machine, i.e. it will **not** pull the latest image automatically from Docker Hub.
@@ -362,7 +362,7 @@ docker run \
- To facilitate interoperability, configuration variables can be prefixed with `LOCALSTACK_` in docker. For instance, setting `LOCALSTACK_PERSISTENCE=1` is equivalent to `PERSISTENCE=1`.
-- To configure an API key, refer to the [API Key](https://docs.localstack.cloud/getting-started/api-key/) documentation.
+- To configure an auth token, refer to the [auth token]({{< ref "auth-token" >}}) documentation.
{{< /alert >}}
### Helm
@@ -425,13 +425,13 @@ If you have installed the CLI with Brew or directly as a binary, please simply p
You can now avail logging output and error reporting using LocalStack logs. To access the logs, run the following command:
{{< command >}}
- $ localstack logs
+ $ localstack logs
{{< / command >}}
-
+
AWS requests are now logged uniformly in the INFO log level (set by default or when `DEBUG=0`).
The shape is `AWS . => ()`.
Requests to HTTP endpoints are logged in a similar way:
-
+
```sh
2022-09-12T10:39:21.165 INFO --- [ asgi_gw_0] localstack.request.aws : AWS s3.ListBuckets => 200
2022-09-12T10:39:41.315 INFO --- [ asgi_gw_0] localstack.request.aws : AWS s3.CreateBucket => 200
diff --git a/content/en/getting-started/quickstart.md b/content/en/getting-started/quickstart.md
index 0b4a459861..7f69c5faad 100644
--- a/content/en/getting-started/quickstart.md
+++ b/content/en/getting-started/quickstart.md
@@ -8,7 +8,7 @@ cascade:
type: docs
---
-This quickstart guide will walk you through starting LocalStack on your local machine to deploying a sample AWS application locally using LocalStack's cloud emulation. This guide assumes that you have [installed LocalStack on your local machine]({{< ref "installation" >}}), [signed up](https://app.localstack.cloud) for a LocalStack account and configured your [API key]({{< ref "api-key" >}}) to authenticate your LocalStack container on startup.
+This quickstart guide will walk you through starting LocalStack on your local machine to deploying a sample AWS application locally using LocalStack's cloud emulation. This guide assumes that you have [installed LocalStack on your local machine]({{< ref "installation" >}}), [signed up](https://app.localstack.cloud) for a LocalStack account and configured your [auth token]({{< ref "auth-token" >}}) to authenticate your LocalStack container on startup.
{{< alert title="Note" >}}
The quickest way to experiment with LocalStack is to use one of our [LocalStack quickstart samples](https://app.localstack.cloud/quickstart) to deploy a thumbnail creator, request worker application, or an asynchronous microservice with tracing/debugging. The quickstart samples will automatically connect to your running LocalStack container on your local machine and run the applications.
@@ -18,7 +18,7 @@ To quickly see the outcome of this quickstart guide, try deploying the [Request
## Start your LocalStack container
-After installing LocalStack and configuring your API key, let us start LocalStack. To run our sample AWS application, we will start LocalStack using the `localstack` CLI.
+After installing LocalStack and configuring your auth token, let us start LocalStack. To run our sample AWS application, we will start LocalStack using the `localstack` CLI.
{{< command >}}
$ localstack start
@@ -34,8 +34,8 @@ You can optionally run your LocalStack container in background mode by adding th
- The default image [`localstack/localstack`](https://hub.docker.com/r/localstack/localstack) on Docker Hub refers to the community version of LocalStack.
The [`localstack/localstack-pro`](https://hub.docker.com/r/localstack/localstack-pro) image refers to the Pro version of LocalStack. Previously we maintained `localstack-light` and `localstack-full` images which have been deprecated and removed with the LocalStack 2.0 release.
-- If an [API key]({{< ref "api-key" >}}) is set in your environment, `localstack start` will attempt to start LocalStack with the `localstack/localtack-pro` image.
- A successful key activation is required to start LocalStack Pro but can be disabled by setting `ACTIVATE_PRO=0`.
+- If an [auth token]({{< ref "auth-token" >}}) is set in your environment, `localstack start` will attempt to start LocalStack with the `localstack/localtack-pro` image.
+ A successful license activation is required to start LocalStack Pro but can be disabled by setting `ACTIVATE_PRO=0`.
{{< /alert >}}
## Setup the sample AWS application
diff --git a/content/en/overview/_index.html b/content/en/overview/_index.html
index 2221d09dfa..6ab2c8a862 100644
--- a/content/en/overview/_index.html
+++ b/content/en/overview/_index.html
@@ -91,7 +91,7 @@ Featured guides and articles
- - }}">How do I get started with a LocalStack API key?
+ - }}">How do I get started with a LocalStack auth token?
- }}">What are Local Cloud Pods and how do I use them?
- }}">How LocalStack improves your Lambda developer experience
- }}">Which AWS services does LocalStack support?
diff --git a/content/en/references/configuration.md b/content/en/references/configuration.md
index 608e9f70e7..eda8e4116a 100644
--- a/content/en/references/configuration.md
+++ b/content/en/references/configuration.md
@@ -330,7 +330,7 @@ To learn more about these configuration options, see [DNS Server]({{< ref "dns-s
| Variable | Example Values | Description |
|----------------------|----------------| - |
| `ACTIVATE_PRO` | 1 (default) | Whether pro should be activated or not. This is set to true by default if using the `localstack/localstack-pro` container image. If set to `1`, LocalStack will fail to start if the license key activation did not work. If set to `0`, an attempt is made to start LocalStack without pro features.
-| `LOCALSTACK_API_KEY` | | API key to activate LocalStack Pro.
+| `LOCALSTACK_AUTH_TOKEN` | | AUTH_TOKEN to activate LocalStack Pro.
| `LOG_LICENSE_ISSUES` | 1 (default) | Whether to log issues with the license activation to the console.
@@ -361,7 +361,7 @@ These configurations are deprecated and will be removed in the upcoming major ve
| `SKIP_INFRA_DOWNLOADS` | | **Deprecated.** Whether to skip downloading additional infrastructure components (e.g., specific Elasticsearch versions)
| `MOCK_UNIMPLEMENTED` | | **Deprecated.** Whether to return mocked success responses (instead of 501 errors) for currently unimplemented API methods
| `ACTIVATE_NEW_POD_CLIENT` | `0`\|`1` (default) | **Deprecated.** Whether to use the new Cloud Pods client leveraging LocalStack container's APIs. |
-| `BIGDATA_MONO_CONTAINER` | `0`\|`1` (default) | **Deprecated.** Whether to spin Big Data services inside the LocalStack main container. Glue jobs breaks when using `BIGDATA_MONO_CONTAINER=0`. |
+| `BIGDATA_MONO_CONTAINER` | `0`\|`1` (default) | **Deprecated.** Whether to spin Big Data services inside the LocalStack main container. Glue jobs breaks when using `BIGDATA_MONO_CONTAINER=0`. |
## Profiles
@@ -382,7 +382,7 @@ Here is an example of what a specific environment profile looks like
{{< command >}}
$ cat ~/.localstack/pro-debug.env
-LOCALSTACK_API_KEY=XXXXX
+LOCALSTACK_AUTH_TOKEN=XXXXX
DEBUG=1
DEVELOP=1
{{< / command >}}
diff --git a/content/en/references/docker-images.md b/content/en/references/docker-images.md
index c6d9851a9f..709bcbf90e 100644
--- a/content/en/references/docker-images.md
+++ b/content/en/references/docker-images.md
@@ -17,7 +17,7 @@ The LocalStack Community image (`localstack/localstack`) contains the community
$ docker pull localstack/localstack:latest
{{< / command >}}
-To use the LocalStack Community image, you don't need to sign-up for an account on [LocalStack Web Application](https://app.localstack.cloud). The Community image is free to use and does not require any API key to run. The Community image can be used to run [local AWS services](https://docs.localstack.cloud/user-guide/aws/) with [integrations](https://docs.localstack.cloud/user-guide/integrations/) on your local machine or in your [continuous integration pipelines](https://docs.localstack.cloud/user-guide/ci/).
+To use the LocalStack Community image, you don't need to sign-up for an account on [LocalStack Web Application](https://app.localstack.cloud). The Community image is free to use and does not require any API key to run. The Community image can be used to run [local AWS services](https://docs.localstack.cloud/user-guide/aws/) with [integrations](https://docs.localstack.cloud/user-guide/integrations/) on your local machine or in your [continuous integration pipelines](https://docs.localstack.cloud/user-guide/ci/).
The Community image also covers a limited set of [LocalStack Tools](https://docs.localstack.cloud/user-guide/tools/) to make your life as a cloud developer easier. You can use [LocalStack Cockpit](https://localstack.cloud/products/cockpit/) or [LocalStack Docker Extension](https://docs.localstack.cloud/user-guide/tools/localstack-docker-extension/) to use LocalStack with a graphical user interface.
@@ -31,7 +31,7 @@ LocalStack Pro contains various advanced extensions to the LocalStack base platf
$ docker pull localstack/localstack-pro:latest
{{< / command >}}
-To use the LocalStack Pro image, you must configure an environment variable named `LOCALSTACK_API_KEY` to contain your API key. The LocalStack Pro image will display a warning if you do not set an API key (or if the key is invalid/expired) and will not activate the Pro features. LocalStack Pro gives you access to the complete set of LocalStack features, including the [LocalStack Web Application](https://app.localstack.cloud) and [dedicated customer support](https://docs.localstack.cloud/getting-started/help-and-support/#pro-support).
+To use the LocalStack Pro image, you must configure an environment variable named `LOCALSTACK_AUTH_TOKEN` to contain your auth token. The LocalStack Pro image will display a warning if you do not set an auth token (or if the license is invalid/expired) and will not activate the Pro features. LocalStack Pro gives you access to the complete set of LocalStack features, including the [LocalStack Web Application](https://app.localstack.cloud) and [dedicated customer support](https://docs.localstack.cloud/getting-started/help-and-support/#pro-support).
You can use the Pro image to start your LocalStack container using various [installation methods](https://docs.localstack.cloud/getting-started/installation/). While configuring to run LocalStack with Docker or Docker Compose, run the `localstack/localstack-pro` image with the appropriate tag you have pulled (if not `latest`).
diff --git a/content/en/references/network-troubleshooting/transparent-endpoint-injection/_index.md b/content/en/references/network-troubleshooting/transparent-endpoint-injection/_index.md
index 16af1e8743..d2d616d0d7 100644
--- a/content/en/references/network-troubleshooting/transparent-endpoint-injection/_index.md
+++ b/content/en/references/network-troubleshooting/transparent-endpoint-injection/_index.md
@@ -12,7 +12,7 @@ Suppose you're attempting to access LocalStack, but you're relying on transparen
{{< figure src="../images/2.svg" width="400" >}}
-If you're using LocalStack with an [API key]({{[}}), then you can utilize the [DNS server]({{][}}) to perform requests to LocalStack as if it were AWS.
+If you're using LocalStack with an [auth token]({{][}}), then you can utilize the [DNS server]({{][}}) to perform requests to LocalStack as if it were AWS.
You need to make two changes:
* Publish port 53 from the LocalStack docker container to your host.
diff --git a/content/en/references/persistence-mechanism.md b/content/en/references/persistence-mechanism.md
index 64be28c8c1..d9317bebd4 100644
--- a/content/en/references/persistence-mechanism.md
+++ b/content/en/references/persistence-mechanism.md
@@ -26,19 +26,19 @@ When you restart LocalStack, you can resume your work from where you left off.
{{< tabpane >}}
{{< tab header="LocalStack CLI" lang="bash" >}}
-LOCALSTACK_API_KEY=... PERSISTENCE=1 localstack start
+LOCALSTACK_AUTH_TOKEN=... PERSISTENCE=1 localstack start
{{< /tab >}}
{{< tab header="Docker Compose" lang="yaml" >}}
...
image: localstack/localstack-pro
environment:
- - LOCALSTACK_API_KEY=...
+ - LOCALSTACK_AUTH_TOKEN=...
- PERSISTENCE=1
volumes:
- "${LOCALSTACK_VOLUME_DIR:-./volume}:/var/lib/localstack"
{{< /tab >}}
{{< tab header="Docker" lang="bash" >}}
-docker run -e LOCALSTACK_API_KEY=... -e PERSISTENCE=1 -v ./volume:/var/lib/localstack -p 4566:4566 localstack/localstack-pro
+docker run -e LOCALSTACK_AUTH_TOKEN=... -e PERSISTENCE=1 -v ./volume:/var/lib/localstack -p 4566:4566 localstack/localstack-pro
{{< /tab >}}
{{< /tabpane >}}
diff --git a/content/en/references/usage-tracking.md b/content/en/references/usage-tracking.md
index 6745284072..c3f5450939 100644
--- a/content/en/references/usage-tracking.md
+++ b/content/en/references/usage-tracking.md
@@ -9,7 +9,7 @@ aliases:
## Overview
-For API Key activations, we track the timestamp and the API key. We need to do this to make CI credits work. It is tracked regardless of whether the user disables event tracking since we collect this in the backend, not the client.
+For license activations, we track the timestamp and the licensing credentials. We need to do this to make CI credits work. It is tracked regardless of whether the user disables event tracking since we collect this in the backend, not the client.
## LocalStack usage statistics
@@ -20,7 +20,7 @@ For Pro users, most of the information is collected to populate the [Stack Insig
The current usage event collection on the client side includes:
- A randomly generated ID pertaining to the session
-- The API Key (if any)
+- The auth token or legacyAPI key (if any)
- A randomly generated machine ID is kept throughout the session but deleted once the LocalStack cache directory is removed
- The operating system (mostly Linux since LocalStack typically runs in our Debian container)
- The LocalStack version being used
@@ -58,7 +58,7 @@ The AWS API call metadata includes:
Here is an example of AWS API call metadata:
-```json
+```json
{
"name": "aws_request",
"metadata": {
@@ -83,7 +83,7 @@ For the community version, we only track service, operation, status code, and ho
### CLI invocations
-We collect an anonymized event if a CLI command was invoked, but do not collect any of the parameter values. This event is not connected to the session or the API key.
+We collect an anonymized event if a CLI command was invoked, but do not collect any of the parameter values. This event is not connected to the session or the auth token.
Here is an example of a CLI invocation event:
@@ -109,7 +109,7 @@ We collect the usage of particular features in an anonymized and aggregated way.
- If you use init scripts, we collect the stage, how many scripts are being executed, and how long they took
- Nothing else at the moment, but we may track additional features
-## What we are not collecting?
+## What we are not collecting?
- Specific LocalStack configuration values
- Content or file names of files being uploaded to S3
diff --git a/content/en/tutorials/ecs-ecr-container-app/index.md b/content/en/tutorials/ecs-ecr-container-app/index.md
index 3fad332deb..01d2b981fa 100644
--- a/content/en/tutorials/ecs-ecr-container-app/index.md
+++ b/content/en/tutorials/ecs-ecr-container-app/index.md
@@ -47,10 +47,10 @@ FROM nginx
ENV foo=bar
```
-The `Dockerfile` uses the official `nginx` image from Docker Hub, which allows us to serve the default index page. Before building our Docker image, we need to start LocalStack and create an ECR repository to push our Docker image. To start LocalStack with the `LOCALSTACK_API_KEY` environment variable, run the following command:
+The `Dockerfile` uses the official `nginx` image from Docker Hub, which allows us to serve the default index page. Before building our Docker image, we need to start LocalStack and create an ECR repository to push our Docker image. To start LocalStack with the `LOCALSTACK_AUTH_TOKEN` environment variable, run the following command:
{{< command >}}
-$ LOCALSTACK_API_KEY= localstack start -d
+$ LOCALSTACK_AUTH_TOKEN= localstack start -d
{{< / command >}}
Next, we will create an ECR repository to push our Docker image. We will use the `awslocal` CLI to create the repository.
diff --git a/content/en/tutorials/elb-load-balancing/index.md b/content/en/tutorials/elb-load-balancing/index.md
index b99d3c8454..bda242c8da 100644
--- a/content/en/tutorials/elb-load-balancing/index.md
+++ b/content/en/tutorials/elb-load-balancing/index.md
@@ -264,7 +264,7 @@ With these resource definitions, you have completed the configuration of your Se
Now that we have completed the initial setup let's run LocalStack's AWS emulation on our local machine. Start LocalStack by running the following command:
{{< command >}}
-$ LOCALSTACK_API_KEY= localstack start -d
+$ LOCALSTACK_AUTH_TOKEN= localstack start -d
{{< / command >}}
This command launches LocalStack in the background, enabling you to use the AWS services locally. Now, let's deploy our Serverless project and verify the resources created in LocalStack. Run the following command:
diff --git a/content/en/tutorials/java-notification-app/index.md b/content/en/tutorials/java-notification-app/index.md
index 0bd58b224d..e76db91260 100644
--- a/content/en/tutorials/java-notification-app/index.md
+++ b/content/en/tutorials/java-notification-app/index.md
@@ -522,7 +522,7 @@ services:
- DEBUG=1
- HOST_TMP_FOLDER=${TMPDIR:-/tmp/}localstack
- DOCKER_HOST=unix:///var/run/docker.sock
- - LOCALSTACK_API_KEY=${LOCALSTACK_API_KEY-}
+ - LOCALSTACK_AUTH_TOKEN=${LOCALSTACK_AUTH_TOKEN-}
- SMTP_HOST=smtp:1025
volumes:
- "${TMPDIR:-/tmp}/localstack:/tmp/localstack"
@@ -538,7 +538,7 @@ services:
The above `docker-compose` file will start LocalStack and pull the MailHog image to start the SMTP server (if it doesn't exist yet!) on port `8025`. You can start LocalStack using the following command:
{{< command >}}
-$ LOCALSTACK_API_KEY= docker-compose up -d
+$ LOCALSTACK_AUTH_TOKEN= docker-compose up -d
{{< / command >}}
Once LocalStack is started, we can deploy the CloudFormation stack (which might take a few moments):
diff --git a/content/en/tutorials/lambda-ecr-container-images/index.md b/content/en/tutorials/lambda-ecr-container-images/index.md
index c2678e96ec..ba44928f5a 100644
--- a/content/en/tutorials/lambda-ecr-container-images/index.md
+++ b/content/en/tutorials/lambda-ecr-container-images/index.md
@@ -90,10 +90,10 @@ By executing these steps, you have defined the Dockerfile that instructs Docker
## Publishing the image to ECR
-Now that the initial setup is complete let's explore how to leverage LocalStack's AWS emulation by pushing our image to ECR and deploying the Lambda container image. Start LocalStack by executing the following command. Make sure to replace `` with your actual API key:
+Now that the initial setup is complete let's explore how to leverage LocalStack's AWS emulation by pushing our image to ECR and deploying the Lambda container image. Start LocalStack by executing the following command. Make sure to replace `` with your actual auth token:
{{< command >}}
-$ LOCALSTACK_API_KEY= DEBUG=1 localstack start -d
+$ LOCALSTACK_AUTH_TOKEN= DEBUG=1 localstack start -d
{{< / command >}}
Once the LocalStack container is running, we can create a new ECR repository to store our container image. Use the `awslocal` CLI to achieve this. Run the following command to create the repository, replacing `localstack-lambda-container-image` with the desired name for your repository:
diff --git a/content/en/tutorials/reproducible-machine-learning-cloud-pods/index.md b/content/en/tutorials/reproducible-machine-learning-cloud-pods/index.md
index b4f4a87773..ec979e47c1 100644
--- a/content/en/tutorials/reproducible-machine-learning-cloud-pods/index.md
+++ b/content/en/tutorials/reproducible-machine-learning-cloud-pods/index.md
@@ -28,7 +28,7 @@ leadimage: "reproducible-machine-learning-cloud-pods-featured-image.png"
Cloud Pods is supported by both [LocalStack Pro](https://app.localstack.cloud/) and [LocalStack Community](https://github.com/localstack/localstack). Using [Community Cloud Pods]({{< ref "user-guide/tools/cloud-pods/community" >}}), you get a limited experience saving and loading your LocalStack state in a Cloud Pod, only with the AWS services emulated in the Community Edition. With LocalStack Pro, you can utilize an extended CLI that allows you to inspect your Cloud Pods, version them using tags, and push them to the LocalStack platform for storage and collaboration.
-In this tutorial, we will use [LocalStack Pro]({{< ref "getting-started/api-key" >}}) to train a simple machine-learning model that recognizes handwritten digits on an image. We will rely on Cloud Pods to create a reproducible sample by using:
+In this tutorial, we will use [LocalStack Pro]({{< ref "getting-started/auth-token" >}}) to train a simple machine-learning model that recognizes handwritten digits on an image. We will rely on Cloud Pods to create a reproducible sample by using:
- S3 to create a bucket to host our training data
- Lambda to create a function to train and save the model to an S3 bucket
@@ -174,7 +174,7 @@ To perform inference on the test set, we will download both the trained SVN mode
Before creating our Lambda functions, let us start LocalStack to use emulated S3 and Lambda services to deploy and train our model. Let's start LocalStack:
{{< command >}}
-$ DEBUG=1 LOCALSTACK_API_KEY= localstack start -d
+$ DEBUG=1 LOCALSTACK_AUTH_TOKEN= localstack start -d
{{< / command >}}
We have specified `DEBUG=1` to get the printed LocalStack logs from our Lambda invocation in the console. We can now create an S3 bucket to upload our Lambda functions and the dataset:
@@ -282,7 +282,7 @@ $ localstack pod save --name --visibility public
The above command does not create a new version and requires a version already registered with the platform.
{{< /alert >}}
-You can also attach an optional message and a list of services to a Cloud Pod using the `--message` and `--services` flags. You can check all the Cloud Pods in your organization over the [LocalStack Web Application](https://app.localstack.cloud/cloudpods). Now that we have created a Cloud Pod, we can ask one of our team members to start LocalStack and load the Cloud Pod using the `load` command.
+You can also attach an optional message and a list of services to a Cloud Pod using the `--message` and `--services` flags. You can check all the Cloud Pods in your organization over the [LocalStack Web Application](https://app.localstack.cloud/pods). Now that we have created a Cloud Pod, we can ask one of our team members to start LocalStack and load the Cloud Pod using the `load` command.
{{< command >}}
$ localstack pod load reproducible-ml
diff --git a/content/en/tutorials/schema-evolution-glue-msk/index.md b/content/en/tutorials/schema-evolution-glue-msk/index.md
index dc0fbeb031..bbe4f19d85 100644
--- a/content/en/tutorials/schema-evolution-glue-msk/index.md
+++ b/content/en/tutorials/schema-evolution-glue-msk/index.md
@@ -481,7 +481,7 @@ public void startConsumer() {
Now that the initial coding is done, we can give it a try. Let's start LocalStack:
```bash
-LOCALSTACK_API_KEY= localstack start -d
+LOCALSTACK_AUTH_TOKEN= localstack start -d
```
Once LocalStack is started, we can create a new Kafka cluster using `awslocal`:
diff --git a/content/en/user-guide/aws/elastic-compute-cloud/index.md b/content/en/user-guide/aws/elastic-compute-cloud/index.md
index ed684dc0b2..4c7e07cc52 100644
--- a/content/en/user-guide/aws/elastic-compute-cloud/index.md
+++ b/content/en/user-guide/aws/elastic-compute-cloud/index.md
@@ -241,7 +241,7 @@ To confirm, execute `localstack --help` and check if `daemons` is among the avai
{{< command >}}
$ pip install localstack[runtime]
-$ export LOCALSTACK_API_KEY=...
+$ export LOCALSTACK_AUTH_TOKEN=...
$ localstack daemons start
{{< /command >}}
diff --git a/content/en/user-guide/ci/_index.md b/content/en/user-guide/ci/_index.md
index 02feb6a647..1b37bef401 100644
--- a/content/en/user-guide/ci/_index.md
+++ b/content/en/user-guide/ci/_index.md
@@ -11,9 +11,9 @@ aliases:
- /ci/
---
-LocalStack enables organizations to automate their application testing and integration process through DevOps practices, such as continuous integration (CI). To meet your organizational needs, LocalStack lets you move away from complicated AWS testing and staging environments by enabling a key component of testing and delivering cloud-native applications.
+LocalStack enables organizations to automate their application testing and integration process through DevOps practices, such as continuous integration (CI). To meet your organizational needs, LocalStack lets you move away from complicated AWS testing and staging environments by enabling a key component of testing and delivering cloud-native applications.
-You can easily integrate LocalStack with your existing CI platform. We provide native plugins for CircleCI and a generic driver for any other CI platform you might use. This enables you to incorporate LocalStack's local AWS cloud emulation in your CI pipelines, use advanced features like Cloud Pods and CI analytics, and run your test & integration suite before pushing to production.
+You can easily integrate LocalStack with your existing CI platform. We provide native plugins for CircleCI and a generic driver for any other CI platform you might use. This enables you to incorporate LocalStack's local AWS cloud emulation in your CI pipelines, use advanced features like Cloud Pods and CI analytics, and run your test & integration suite before pushing to production.
## Hypothetical CI workflow
@@ -21,19 +21,19 @@ Let's assume that your team has an automated CI workflow into which you want to
{{< figure src="localstack-in-ci.svg" alt="An example CI/CD workflow using LocalStack" width="90%">}}
-The CI build is triggered by pushing code to a version control repository, like GitHub. The CI runner starts LocalStack and executes the test suite. You can also use the same Infrastructure-as-Code (IaC) configuration that you use to set up AWS in your production environment to set up LocalStack in the CI environment. You can also pre-seed state into the local AWS services (e.g., DynamoDB entries or S3 files) provided by LocalStack in your CI environment via [Cloud Pods](https://docs.localstack.cloud/tools/cloud-pods/).
+The CI build is triggered by pushing code to a version control repository, like GitHub. The CI runner starts LocalStack and executes the test suite. You can also use the same Infrastructure-as-Code (IaC) configuration that you use to set up AWS in your production environment to set up LocalStack in the CI environment. You can also pre-seed state into the local AWS services (e.g., DynamoDB entries or S3 files) provided by LocalStack in your CI environment via [Cloud Pods](https://docs.localstack.cloud/tools/cloud-pods/).
After a successful test run, you can execute the more expensive AWS CodeBuild pipeline for deploying your application. You can enrich the test reports created by your testing framework with traces and analytics generated inside LocalStack.
## CI Credits
-A _CI key_ is a special type of API key that allows you to use LocalStack in your CI environment. Each key activation, i.e., each single startup of the LocalStack container in your CI environment, consumes one build credit. LocalStack Pro offers a CI key with a limited number of build credits to help you start experimenting with larger CI settings. LocalStack Team is focused on using LocalStack on individual user machines, across teams, and in larger CI settings to help teams collaborate and use LocalStack extensively in CI.
+A _CI key_ is a special type of API key that allows you to use LocalStack in your CI environment. Each key activation, i.e., each single startup of the LocalStack container in your CI environment, consumes one build credit. LocalStack Pro offers a limited number of build credits to help you start experimenting with larger CI settings. LocalStack Team is focused on using LocalStack on individual user machines, across teams, and in larger CI settings to help teams collaborate and use LocalStack extensively in CI.
-The Pro subscription is mainly intended for use on individual user machines. We recommend our Team plan if you intend to use LocalStack extensively for team collaboration and in CI environments. For the CI environment, each subscription (both Pro and Team) comes with one extra CI key (included in the subscription at no extra charge), which allows you to use LocalStack in your CI environment. The CI key has a certain number of credits, depending on the number of individual user seats and the plan you have purchased.
+The Pro subscription is mainly intended for use on individual user machines. We recommend our Team plan if you intend to use LocalStack extensively for team collaboration and in CI environments.
## CI integrations
-The steps required for the integration differ slightly depending on your preferred CI platform. Please refer to the relevant sections below for detailed instructions on the integration process. To follow the instructions, you can first retrieve the CI key from the [Account settings page](https://app.localstack.cloud/account/apikeys) in the [LocalStack Web app](https://app.localstack.cloud).
+The steps required for the integration differ slightly depending on your preferred CI platform. Please refer to the relevant sections CI keys settings page](https://app.localstack.cloud/workspace/ci-keys) in the [LocalStack Web app](https://app.localstack.cloud).
## CI images
diff --git a/content/en/user-guide/ci/circle-ci/index.md b/content/en/user-guide/ci/circle-ci/index.md
index 57e4876ffc..8a2c839e89 100644
--- a/content/en/user-guide/ci/circle-ci/index.md
+++ b/content/en/user-guide/ci/circle-ci/index.md
@@ -1,6 +1,6 @@
---
title: "CircleCI"
-tags: ["continuous-integration", "ci", "continuous-delivery", "testing"]
+tags: ["continuous-integration", "ci", "continuous-delivery", "testing"]
weight: 4
description: >
Use LocalStack in [Circle CI](https://circleci.com/)
@@ -36,10 +36,10 @@ workflows:
- run-integration-tests
```
-## Configuring an API key
+## Configuring an CI key
-You can easily enable LocalStack Pro by adding your API key to the project's environment variables. The LocalStack Orb will automatically pick it up and activate the Pro features.
+You can easily enable LocalStack Pro by adding your CI key to the project's environment variables. The LocalStack Orb will automatically pick it up and activate the Pro features.
-Just go to the project settings in CircleCI, click on `Environment Variables` in the sidebar and add your API key:
+Just go to the project settings in CircleCI, click on `Environment Variables` in the sidebar and add your CI key:
-![Adding the LocalStack API key in CircleCI](circleci-env-config.png)
+![Adding the LocalStack CI key in CircleCI](circleci-env-config.png)
diff --git a/content/en/user-guide/ci/drone-ci/index.md b/content/en/user-guide/ci/drone-ci/index.md
index c7657bd460..c6ba5609c3 100644
--- a/content/en/user-guide/ci/drone-ci/index.md
+++ b/content/en/user-guide/ci/drone-ci/index.md
@@ -1,6 +1,6 @@
---
title: "Drone CI"
-tags: ["continuous-integration", "ci", "continuous-delivery", "testing"]
+tags: ["continuous-integration", "ci", "continuous-delivery", "testing"]
weight: 5
description: >
Use LocalStack in [Drone CI](https://drone.io/)
@@ -40,9 +40,9 @@ steps:
- until curl -s http://localstack:4566/_localstack/health; do echo -n . && sleep 1; done
```
-## Configuring an API key
+## Configuring a CI key
-You can easily enable LocalStack Pro by by using the `localstack/localstack-pro` image and adding your API key to Drone Repository secrets. You can manage them from your repository settings screen. Navigate to your Repository secrets on your Drone repository and add the LocalStack API key as `localstack_api_key`. Here is an example:
+You can easily enable LocalStack Pro by by using the `localstack/localstack-pro` image and adding your API key to Drone Repository secrets. You can manage them from your repository settings screen. Navigate to your Repository secrets on your Drone repository and add the LocalStack CI key as `localstack_ci_key`. Here is an example:
```yml
services:
@@ -50,5 +50,5 @@ services:
image: localstack/localstack-pro
environment:
LOCALSTACK_API_KEY:
- from_secret: localstack_api_key
+ from_secret: localstack_ci_key
```
diff --git a/content/en/user-guide/ci/github-actions/index.md b/content/en/user-guide/ci/github-actions/index.md
index 31e34402fa..18b3adbec2 100644
--- a/content/en/user-guide/ci/github-actions/index.md
+++ b/content/en/user-guide/ci/github-actions/index.md
@@ -1,6 +1,6 @@
---
title: "GitHub Actions"
-tags: ["continuous-integration", "ci", "continuous-delivery", "testing"]
+tags: ["continuous-integration", "ci", "continuous-delivery", "testing"]
weight: 5
description: >
Use LocalStack in [GitHub Actions](https://github.com/features/actions)
@@ -37,9 +37,9 @@ jobs:
pip install localstack awscli-local[ver1] # install LocalStack cli and awslocal
docker pull localstack/localstack # Make sure to pull the latest version of the image
localstack start -d # Start LocalStack in the background
-
+
echo "Waiting for LocalStack startup..." # Wait 30 seconds for the LocalStack container
- localstack wait -t 30 # to become ready before timing out
+ localstack wait -t 30 # to become ready before timing out
echo "Startup complete"
- name: Run some Tests against LocalStack
run: |
@@ -50,9 +50,9 @@ jobs:
If you want to add further configuration for LocalStack, you can use the `env` section of your build step to set the configuration variables as described [here][2].
-## Configuring an API key
+## Configuring a CI key
-You can easily enable LocalStack Pro by using the `localstack/localstack-pro` image and adding your API key as a [Github Encrypted Secret][3] to store your API key securely. You can set the `LOCALSTACK_API_KEY` environment variable to the value of the secret `LOCALSTACK_API_KEY`. You can set your secret at an environment, repository or organization level. Navigate to your repository **Settings**, click **Secrets**, and press **New Repository Secret**. Here is an example:
+You can easily enable LocalStack Pro by using the `localstack/localstack-pro` image and adding your CI key as a [Github Encrypted Secret][3] to store your CI key securely. You can set the `LOCALSTACK_API_KEY` environment variable to the value of the secret `LOCALSTACK_API_KEY`. You can set your secret at an environment, repository or organization level. Navigate to your repository **Settings**, click **Secrets**, and press **New Repository Secret**. Here is an example:
```yaml
- name: Start LocalStack
@@ -62,13 +62,13 @@ You can easily enable LocalStack Pro by using the `localstack/localstack-pro` im
pip install localstack awscli-local[ver1] # install LocalStack cli and awslocal
docker pull localstack/localstack-pro # Make sure to pull the latest version of the image
localstack start -d # Start LocalStack in the background
-
+
echo "Waiting for LocalStack startup..." # Wait 30 seconds for the LocalStack container
- localstack wait -t 30 # to become ready before timing out
+ localstack wait -t 30 # to become ready before timing out
echo "Startup complete"
```
-![Adding the LocalStack API key as secret in GitHub](github-create-secret.png)
+![Adding the LocalStack CI key as secret in GitHub](github-create-secret.png)
[1]: https://docs.github.com/en/actions/learn-github-actions/understanding-github-actions#steps "GitHub Action Build Steps"
[2]: https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsenv "GitHub Action Steps - Environment variables"
diff --git a/content/en/user-guide/ci/gitlab-ci/index.md b/content/en/user-guide/ci/gitlab-ci/index.md
index e9decb440f..d2e01946c8 100644
--- a/content/en/user-guide/ci/gitlab-ci/index.md
+++ b/content/en/user-guide/ci/gitlab-ci/index.md
@@ -1,6 +1,6 @@
---
title: "GitLab CI"
-tags: ["continuous-integration", "ci", "continuous-delivery", "testing"]
+tags: ["continuous-integration", "ci", "continuous-delivery", "testing"]
weight: 7
description: >
Use LocalStack in [GitLab CI](https://docs.gitlab.com/ee/ci/)
@@ -66,9 +66,9 @@ test:
While working with a Docker-in-Docker (`dind`) setup, the Docker runner requires `privileged` mode. You must always use `privileged = true` in your GitLab CI's `config.toml` file while setting up LocalStack in GitLab CI runners. For more information, see [GitLab CI Docker-in-Docker](https://docs.gitlab.com/ee/ci/docker/using_docker_build.html#use-docker-in-docker-executor) documentation.
{{< /alert >}}
-## Configuring an API key
+## Configuring a CI key
-You can easily enable LocalStack Pro by using the `localstack/localstack-pro` image and adding your API key to the repository's environment variables. Go to your project's **Settings > CI/CD** and expand the **Variables** section. Select the **Add Variable** button and fill in the necessary details. After you create a variable, you can use it in the `.gitlab-ci.yml` file.
+You can easily enable LocalStack Pro by using the `localstack/localstack-pro` image and adding your CI key to the repository's environment variables. Go to your project's **Settings > CI/CD** and expand the **Variables** section. Select the **Add Variable** button and fill in the necessary details. After you create a variable, you can use it in the `.gitlab-ci.yml` file.
However Variables set in the GitLab UI are not passed down to service containers. We need to assign them to variables in the UI, and then re-assign them in our `.gitlab-ci.yml`:
@@ -89,4 +89,4 @@ test:
...
```
-You can check the logs of the LocalStack container to see if the activation was successful. If the API key activation fails, LocalStack container will exit with an error code.
+You can check the logs of the LocalStack container to see if the activation was successful. If the CI key activation fails, LocalStack container will exit with an error code.
diff --git a/content/en/user-guide/ci/harness-ci/index.md b/content/en/user-guide/ci/harness-ci/index.md
index e9c50a26ab..fe5f55e84e 100644
--- a/content/en/user-guide/ci/harness-ci/index.md
+++ b/content/en/user-guide/ci/harness-ci/index.md
@@ -1,6 +1,6 @@
---
title: "Harness CI"
-tags: ["continuous-integration", "ci", "continuous-delivery", "testing"]
+tags: ["continuous-integration", "ci", "continuous-delivery", "testing"]
weight: 8
description: >
Use LocalStack in [Harness CI](https://harness.io/products/continuous-integration)
@@ -16,13 +16,13 @@ To get started, create a new pipeline in Harness CI:
- Click **Add Stage**.
- Click **Build** and set a name for the stage.
-- Optionally configure the repository you are looking to be cloned and click on **Set Up Stage**.
+- Optionally configure the repository you are looking to be cloned and click on **Set Up Stage**.
- Select **Cloud** in the **Infrastructure** tab.
- Click **Add Service Dependency** in the **Execution** tab.
- In the **Configure Service Dependency** dialogue box, enter `localstack` as the name of the service dependency.
-- Click **Container Registry** field and select **Docker Hub** connector.
+- Click **Container Registry** field and select **Docker Hub** connector.
- Enter the desired LocalStack Docker image in the **Image** field.
-- Select **Optional Configuration** to add an environment variable named **LOCALSTACK_API_KEY** to have an API key configured.
+- Select **Optional Configuration** to add an environment variable named **LOCALSTACK_API_KEY** to have an CI key configured.
- Click on **Apply Changes**.
## YAML configuration
@@ -57,10 +57,10 @@ stages:
To run the pipeline, click **Save** and then **Run Pipeline**. You will be able to see LocalStack Service Dependency logs that verify that the LocalStack Container is healthy and running.
-## Configuring an API key
+## Configuring a CI key
-You can easily enable LocalStack Pro by using the `localstack/localstack-pro` image and adding your API key
-by selecting **Optional Configuration** to add an environment variable named **LOCALSTACK_API_KEY** to have an API key configured. Here is an example:
+You can easily enable LocalStack Pro by using the `localstack/localstack-pro` image and adding your CI key
+by selecting **Optional Configuration** to add an environment variable named **LOCALSTACK_API_KEY** to have an CI key configured. Here is an example:
```yaml
serviceDependencies:
@@ -71,5 +71,5 @@ serviceDependencies:
connectorRef: my_connector
image: localstack/localstack-pro
envVariables:
- LOCALSTACK_API_KEY: <+secrets.getValue("localstack-api-key")>
+ LOCALSTACK_API_KEY: <+secrets.getValue("localstack-ci-key")>
```
diff --git a/content/en/user-guide/ci/travis-ci/index.md b/content/en/user-guide/ci/travis-ci/index.md
index 4646c43f6f..a8b0eb57fc 100644
--- a/content/en/user-guide/ci/travis-ci/index.md
+++ b/content/en/user-guide/ci/travis-ci/index.md
@@ -1,6 +1,6 @@
---
title: "Travis CI"
-tags: ["continuous-integration", "ci", "continuous-delivery", "testing"]
+tags: ["continuous-integration", "ci", "continuous-delivery", "testing"]
weight: 6
description: >
Use LocalStack in [Travis CI](https://www.travis-ci.com/)
@@ -48,13 +48,13 @@ script:
- echo "Execute your tests here :)"
```
-## Configuring an API key
+## Configuring a CI key
-You can easily enable LocalStack Pro by using the `localstack/localstack-pro` image and adding your API key to the project's environment variables. The LocalStack CLI will automatically pick it up and activate the Pro features.
+You can easily enable LocalStack Pro by using the `localstack/localstack-pro` image and adding your CI key to the project's environment variables. The LocalStack CLI will automatically pick it up and activate the Pro features.
-Just go to the project settings in Travis CI (`More options` β `Settings`), scroll down to the `Environment Variables` section, and add your API key:
+Just go to the project settings in Travis CI (`More options` β `Settings`), scroll down to the `Environment Variables` section, and add your CI key:
-![Adding the LocalStack API key in Travis CI](travis-ci-env-config.png)
+![Adding the LocalStack CI key in Travis CI](travis-ci-env-config.png)
Here is an example:
diff --git a/content/en/user-guide/extensions/developing-extensions/index.md b/content/en/user-guide/extensions/developing-extensions/index.md
index 5cd9502311..a11835fdc9 100644
--- a/content/en/user-guide/extensions/developing-extensions/index.md
+++ b/content/en/user-guide/extensions/developing-extensions/index.md
@@ -106,7 +106,7 @@ class ReadyAnnouncerExtension(Extension):
A note on importing LocalStack modules: since extensions run in the same Python process as the LocalStack runtime,
you can also import other LocalStack modules outside the `localstack.extensions.api` module, and work with them.
However, be aware that these modules are not part of our public API, and can change even with patch versions any time.
-Your extension may break in unexpected ways, and we cannot provide support for internal APIs.
+Your extension may break in unexpected ways, and we cannot provide support for internal APIs.
{{}}
### Packaging extensions
@@ -212,7 +212,7 @@ $ localstack extensions dev enable ./my-localstack-extension
Then, start LocalStack with `EXTENSION_DEV_MODE=1`
{{< command >}}
-$ EXTENSION_DEV_MODE=1 LOCALSTACK_API_KEY=... localstack start
+$ EXTENSION_DEV_MODE=1 LOCALSTACK_AUTH_TOKEN=... localstack start
{{< / command >}}
In the LocalStack logs you should then see something like:
diff --git a/content/en/user-guide/extensions/managing-extensions/index.md b/content/en/user-guide/extensions/managing-extensions/index.md
index 8c31267e4a..c430b5b403 100644
--- a/content/en/user-guide/extensions/managing-extensions/index.md
+++ b/content/en/user-guide/extensions/managing-extensions/index.md
@@ -1,6 +1,6 @@
---
title: "Managing extensions"
-tags: ["extensions"]
+tags: ["extensions"]
weight: 5
description: >
How to manage LocalStack extensions in your LocalStack environment
@@ -99,7 +99,7 @@ services:
- "127.0.0.1:4510-4559:4510-4559"
environment:
- DEBUG=1
- - LOCALSTACK_API_KEY=${LOCALSTACK_API_KEY-}
+ - LOCALSTACK_AUTH_TOKEN=${LOCALSTACK_AUTH_TOKEN-}
- EXTENSION_AUTO_INSTALL=localstack-extension-mailhog,localstack-extension-httpbin
volumes:
- "./volume:/var/lib/localstack"
@@ -130,7 +130,7 @@ An example project could look something like this:
* `docker-compose.yaml`
```yaml
version: "3.8"
-
+
services:
localstack:
...
diff --git a/content/en/user-guide/integrations/kafka/docker-compose.yml b/content/en/user-guide/integrations/kafka/docker-compose.yml
index f6baa13daf..5e11ff2efb 100644
--- a/content/en/user-guide/integrations/kafka/docker-compose.yml
+++ b/content/en/user-guide/integrations/kafka/docker-compose.yml
@@ -61,7 +61,7 @@ services:
environment:
- DEBUG=${DEBUG- }
- PERSISTENCE=${PERSISTENCE- }
- - LOCALSTACK_API_KEY=${LOCALSTACK_API_KEY- }
+ - LOCALSTACK_AUTH_TOKEN=${LOCALSTACK_AUTH_TOKEN- }
- DOCKER_HOST=unix:///var/run/docker.sock
volumes:
- "${LOCALSTACK_VOLUME_DIR:-./volume}:/var/lib/localstack"
diff --git a/content/en/user-guide/tools/cloud-pods/getting-started/index.md b/content/en/user-guide/tools/cloud-pods/getting-started/index.md
index 5ccf8cae3c..8404491a64 100644
--- a/content/en/user-guide/tools/cloud-pods/getting-started/index.md
+++ b/content/en/user-guide/tools/cloud-pods/getting-started/index.md
@@ -12,7 +12,7 @@ Using the LocalStack Cloud Pods command-line interface (CLI) via the `pod` comma
## Installation
-The LocalStack Cloud Pods CLI is included in the [LocalStack CLI installation](https://docs.localstack.cloud/getting-started/installation/#localstack-cli), so there's no need for additional installations to begin using it. If you're a licensed user, we suggest setting the `LOCALSTACK_API_KEY` as an environment variable. This enables you to access the complete range of LocalStack Cloud Pods features.
+The LocalStack Cloud Pods CLI is included in the [LocalStack CLI installation](https://docs.localstack.cloud/getting-started/installation/#localstack-cli), so there's no need for additional installations to begin using it. If you're a licensed user, we suggest setting the `LOCALSTACK_AUTH_TOKEN` as an environment variable. This enables you to access the complete range of LocalStack Cloud Pods features.
You can access the Cloud Pods CLI by running the `pod` command from your terminal.
@@ -56,7 +56,7 @@ $ awslocal s3 ls s3://test/
### Save your Cloud Pod state
You can now your Pod state using the `save` command, specifying the desired Cloud Pod name as the first argument. This action will save the pod and register it with the LocalStack Web Application:
-
+
{{< command >}}
$ localstack pod save s3-test
@@ -84,7 +84,7 @@ $ localstack pod list
### Inspect the contents of a Cloud Pod
-4. Optional: You can inspect the contents of a Cloud Pod using the `inspect` command:
+4. Optional: You can inspect the contents of a Cloud Pod using the `inspect` command:
{{< command >}}
$ localstack pod inspect s3-test --format json
@@ -110,7 +110,7 @@ $ localstack pod inspect s3-test --format json
### Pull your Pod state
- On a separate machine, start LocalStack while ensuring the API key is properly configured. Then, retrieve the previously created Cloud Pod by employing the `load` command, specifying the Cloud Pod name as the first argument:
+ On a separate machine, start LocalStack while ensuring the auth token is properly configured. Then, retrieve the previously created Cloud Pod by employing the `load` command, specifying the Cloud Pod name as the first argument:
{{< command >}}
$ localstack pod load s3-test
diff --git a/content/en/user-guide/web-application/ci-keys/ci-keys.png b/content/en/user-guide/web-application/ci-keys/ci-keys.png
new file mode 100644
index 0000000000000000000000000000000000000000..56e5124838a1304d118cb9fd109bbc863ab8ddb9
GIT binary patch
literal 11672226
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]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
B*DO
zJy#6t_h?$>dkbx1=k`Mj;}SOdd%mAXITEBl+Ph%-|2AHTmt6?KH8iW~KV<%_(LR;4
zO%#I6M_VTi+mc*sPS_zQXT8}ibj??RA*^c#6~iT8*ctlOt9^6l;)>Vuj|;b4)gS!)
zGTg0<^N&odC3$su-Hchw_D8;x3sKUxQLnL6r}wBOwa>o_UH$WvuyS2Csy0T-#qr%v
z-=F{I=ZT?ema7^VIF3Hz>&AAb#dpgHB`kP>#dP}le#pVQ<$ml^H~-94
zNiysZXMnH*WY_W=JiXnKDnh^72(G7
zg3Q=`^M2dlyd)nOBh6Y)U)@q^e)5x}Am#R7z5CC<`o^%VYnPwtp$nDK8G
z)suZ=JB-^KpH{5u4}Au7_xGu3XKu<*e0=M|vEA$UTwXK2TWtKMU6boc?UCP1Fuf#X
zUT^T918S*=%B)7Ug7NN-&zH7Oni4hItF>N?k=M5^m>SZwMh9=Jd^1{zzxR;VMAqy2
z`>bDTt0=7e?)>@Y-`xlO9b-@}@VD{9+BbHywJ_!IKP1FlIJkD+ietN`4l%F_Ue+di
zy`6pwG&g7*I?ddb>)VEWSfg^o1Yrv|fiF)_&K*1TpR1`(&Q_dziR?35==w_e@uaqT
ziEH3Fc=3{)F@FZ{{6GKO5&hNY=Q({mb7qf~uyJM&89wzl=w*8^jEbGFY8}_ubHc{W
z`AQ`9!e9WPo)4~qfS3S`k*EnE00JNY0tJYGiM>yIdxpIC5_Zk!JTB$fs8f*qG~OI5
zCBuJFI^?Hi2)F_(i}K%o?OL_T-Nx#7E`T62a{JbcA8FyvKWit~mE6)BncI6b8|mR@
z_odx{gXh+4i0C$}p0J2hVsAY8%E8S(+v=WjWX2e>M4GwuS+#9W>&jAVgsrn%qc%N)
zRt)MtGxYG(-x~Ss=vh$arLxU>0rdAJ`gRmwAg}KVU`Fz%$XWMS51Y6*;cNMTshie}
ztSz-TR&j8u*Su>_|5-tU)`c&f_*c{5sSQfx&n&2y%EYElr=WbgkWRhi%&Sp1Z>4aG
zFWmBc}Ny<}N0C`fc4BBq#- A
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
8iA4b6NDxa`S+p
z=+Q!sK>!3m00asefl^L&>SS+dDHNS+Xkt;4HZSC-i^fc^BO?=znM=B5
zC(12pQ`^Tze3JGqDe)7Z!%s^~7CyHUd`TDH>?;3Q`cBwzxo^ywBf+Q7U%q%P;{LT0
z^xe8_PD%SlgC@il8i{$q$njO%#QHmb~z
zSzT`zlLKK(Z%D@meme=;zx>*a01^h8fs>bjNM7#|mNFOB0;f{i?4KQytx&7E0-=H?~22Jao6
zh0ky#A9E8E4wp|An;v`^rRxibBz9K673=$m_t6sjW}{@vKY19JnpMoHnxpiYu`sYn
zEpI2&JtCtRtCUrGGIprbh@q_5h-770wXSEy)p1wm4V?OAME8KE?pC5bXH9d|r;_B@
zHyN40nIhARkzQLvP6EpHh9K^C)VoaMnqJ;zWz~2MPj4&3dv|ZerV412y^8*wo6kLU
z^wjQ_wN-
zcu71SKP@vYjsH5$h$G;pq@@Zk(4z;9s$LWU$JWzbMyZmzqbD6{X)>Bi>{ayN!o$2=43Fq0pM>GSVQVrShk73Qa?&Vg;
zy_4iX$*+Y|ohIVWkk3neo07&)<7e=bGK6h4oi8)$5RSkZDvoPtW?`N)0@qCdjao>M
zd53-PuU}QXOoD+0}zu
zdM~ELr@+Z)hT
zc!#TEfEVFh<)maTfN&;(;(aa~nGK9xeHzG&8RSB7EBQ9AQSAEdn-TmTekNSO%Ud_%
z4BWckeHNA
z4@mEA?NM&4)J<|gOEr>`k}?EV4F8gAtbQx?oVWVX=U@Llzij;F<Y+RBzP8*RO4d
zK!5k_w+-r+y5MbcB1cfXtd*I(V3yY93pYVMTjF0fy0pmmDElM)Zg@?uHPt^;b=&7K&xhbumG>`<>l(6nRz*S%#zA`L-J(jU6VYb>`)0R)Ksp(
z#7y)8J4uGgA}Rgo5r{NS%?EOonT?VuCuAWgZZ5A<%&janr^muaaVsmP7G)!nm62Jy
zxhp5X9knEM%lJN9CYV@OukZ6C>CetVUeQ`AL^`Cu^!7(hxOMD~Xl;qO1-JSte4{QuObnJDY=#`6ij+~4Zl<(1{
zwbBQY@=;07E!!=*x4Nz5Oy#fO{q3zwmu)zFG3up^#xantSL~$JV_7X_#Aq4H
z(l@9vZ1v*!{!_LcUO4*jLQWZ5uX;Z;YU3Z+p+$9tW|tFQv%nI+a_vImtjn)(VY%2q
zo)g+k-1(-+c5RaD$tiC#MWN(78tZbxCYJIpiEyjQrX(JAzpPZBQ4%dbmeZLE(X+=Z
z7nC0E)C(F+UvmEtA9FoC{NkxY+fUs+^mo5|FII<0UfV4ficU4AD0n9t|4<3YkALJM
zOHYYe+i&&W=uf5F^c&*CFpA0fQ+BGG@=+EOt=X2#oa9Ac$+AVuE33S&;kls1CaC)UkyW`XRe-uT
zOrg}qa${V^b7EF^g4*18s@Du`80t}^qFJ$NCmo$shvs3nfoXwVPjUeywY3QK61ovBQ@yCvZIN1uw5&dh)eWyJmH0
zADqux+f20g>*CT4_lX8AnFPQtbI>0E$}?
z1V8`;K;WAa5N+R5xn7rUbt@>Q%QdT`VDMA)rN+gw<@D{h`rSGf9DMph_@%37_r#pt
z`|m=ZflJrU{!utS)h%`LqaPzx&o24mXw`_N-6b~3Wk@E(s~%!xJ>1s4!<6t3O6owbFjp^5S5laqQc$=Sk1vt%X}+!}SJ@6ZXimksK;;Oz0gH{a|!oyO~mLD{AF
zRWYEViy-s)(XG!bIN6qZa`W%8%Np$;&2rZ_#i-c3yxcd=fApcZX09EF&u-!AWM^KS
zV`7qZ?e7k>^IUE}mQHphI9F3*qT)D#*-I948zq@@XlAFt%pVO@`}W<7~>k{a;LU3db>fA3defYwf5}Zxpj{+P8fz
zc?%V#V`%AETCCGde(2uLY3t%k`wzzV8E%^ydHnbTW9x3+e$1ZHqP0w_0|?S@&+XRz
z@5uD3KXjWt#mBu;1yd6flVS;5Mi1ZoND@riY80B4#E0&`4uStW+w7N%!G}(tzjQi0
z;^g+5C%6CmXOmIu*N^sM>~SDXfR(@!-}3E3;;z%LiHVlkPZO?cSN0LdlOdcqqBmot
zwAm^M$xwZn8pjD*;Z>HmY&Q!#*PrOyeaP6$^MiV=j6Jw^)5w5P&Pt}0uu4%fAW@T|
z_)_G--6iZCZPOl|m^Wcp!!6yaDoIgQBswS`RZ+>gv&*CA0Tr7(8W=dX`MI@|veA))
zXb~@|eVsljAyaz|+!$k2t<~UJ{yt9D79~xoMMSP2F=mf;yAJCpfJQAO&6m0+z&7jJ
z>Ls@Evhl~RuPou(Ywfvqn@ol$h;R-#4C0Bv5eDpGZZvV(Xwf*bTES
z13EOCdH%$SW6|S1Yg4ax?D&&n;{C}};XI>yU4k6NG3d2-qbO-kt@wooIRYvi
zx%)P>{Acs6D+!#s6|aY1%_{$6BNqd%k!M|}tgY7~Qhu?|xOO}0OX)UE>18sMHA#3~
z`(O39PV6eJhEY1Z`lIOqk&cR5!l$VID%6Xj3Ih2C0T9R)fk)jIEW=!YTp>i@?@qwH
ztR;<{%v`%onNm*=!er8(qcUs$D9++`bvh5FFHH?hjy$nt#;m2`>nF~sAG)kfS>00S
znwyz(xG!i0r2IObln=ZtTJ&b7?76MZxnq@_iJ3)71HpS<3a#d0Y|6+;lz(B}>Pv5p
z>ixQD-*2_0PhGPTB57|+hBx+yCLTk3H(zn#$g8-x6oHqLbq}mkG&d_x!n}D)i{#XQ
zjJ^9TT|1}#l@aZSA6YhjPMtlowS94<`uOFq(r#oMRs<&tY=$o1IY;s)7xI+)R4)q|
zP3rkHG~aXZe(<526Ki=%-smSQ1V3`;=EpTUckpCs_As+DrwOo`F0DsRX_H$aX}g+^
z?Q8zC@N)3!_kmqMA3qZD)wGUQZ_4A8G_x=@5Tq#9Nq%CAa6)SN^0I3bWHYaiGkpTl
zSspe@CbN_o?TAUJhzoNPFYjHl=5&=QJ@uj3h$M-@q=HAQLG-2j+jkF7ZCgBJ(b26_
zrg}Ht(oMnOt#gy%Iy4mSb@$(8>FPsC>N&rHSLaqA%WTufPs_C?D)k1}ygaG#^fF$9
zr;N#d#E_Gk%#lIuc0E1T%)S{C^54)wA5R{8^0mgGz(&g3tV}>{Pu>S_*bw=tY~xw`
zcMg>9rYXoYuwbfa&8lA8WM%ww&24_@K7zipIsB*B53iUzcjLvsMlWo1W==h6uOSV<
zN?@sPT@TWPyJ^dQGE!1L$+~b-KBNj%cfMv;X0&G&FNG&uj>Zhh6LmebfxAAH5i8Ya
zWM)oVYVnd4M3Rc9cf4g94eal|b=C?L}Ern_Lw{v1QwWzt&Qqn
zKg_P!vYlVKQ)f>FNB>sK;nI=gNf}kU2R6#y9+=hbxoi>1ooN$;HUl>HBXc={6i>~|
znhPH<@Dv^|q`cu}2n;OLym-Q_O^=o{Pi+Z15}x*>$I;-ksihhQ21>S3&QFPXRsGTUfJiq*tv&w27DDThVqpV-{D1%mfB*;-VFFd$9j%NwucIR3
zwS-_|Dm0t%>5Yes&zHE^XL4gZ>7+37W@70PIBw&lR`j0oTUQ^FgKnwQOCg;~8l*po
zc_=ia(C3BSu>`rf0D^?r=y#chr5)Xrn*+rGwf?V=bao8PID4D6b8@wYRv>hkCO9u8R%
z>nBb<{z@W8-u&_(J&4aRGW2TPglP-pU%Yfv2C=S*m+|iuU}u!}c=POKca=u?`TD9~
zf1f?P+k`{!Sl+srIlEV*7tF=b3nKOLsol1%Tk(&VPlmmJc=CAUM++bA-jqih%hak-
zLRcs1jctsNAoE^S>?bNvXJ;h~(ik3df2e05x(UQa;c#tj?2HUj;~zduWtKJnZe$#j
z9a{ycNl-Q-WyitLrQEWPEl2%5vx9Bs$6HsTm~u+e)3wP6U)0j0o(VVQUpNn)&i)#webldF44gH&3Mskwbs>)4}lv9B>Fjz?WM8uBR1C9sn>
ztK_xx^eir(M{g4J@sV00DFQ))aPuW;Oe|Er)UWmjjN+!g)4pDpKNpRzYs!5U5&m3R
zWNZXh7EXnm5yymHZJ8=JUHwtifAWS$+CnPszKoU=yn7y>lxa}H)=qinYvx?58ZE|-
zz8x)_HoZ_%`1VGZ8q7Dx$$HWLjGgKeY9|sYPFAF>r$^@fK6}9qVW*%2-qZ{8TQzWV
z>AF5ix!C*^dSSPbNon~_#j}00Nm1Nz(x2XpPGL4x{`r5VPnxwf^qF)xVeIl_HyycN^eXcxZl{@om|J(4DqLPD
zJ3Cu)N{WkPmY48NPxsXA(JFZI_`i%SGxuhV7?wyHHC>9(dQhaB02;LryCxt{L*+T6
zCMeZQrZfwS!%vavJvsl~r>33T58J*{MnaB-Q=>tD&FSw{?9;uQ5$~ieBDca&_`K*V
zS+{5z`SY}f%cS%@PS}>atZaI0n6eQI&)D1vk~e*g5)}ndbYUryVn9WgqFb@GRUNE{
z+1xU|otj(nAD%oB_2J^tb8oU7TXz(`_fYg9rp?HlA=cDm7h%
zj~Ak49xsr`5BDC$We7?+xhmbXKpayE-_9Lvi#-oL6#DS&@k=RIeqH?~y)E0`%}BU3
zFe^2MIhl^;bpH2J)ixc<@*r{JmT1t}yL8Hp%hw|>Uy3(yZ|ozQKW9>_L7fsGZe5Cu
zxOC-JX^%$YApu(nC6O!ss=0L%dS+2+H5EFm`a^nH{R1N16t!Z0i<%3JkwvY