Skip to main content
Version: v2.x

Transfer existing Hasura Cloud project to a new project

Available on: Cloud

Introduction

To transfer a project you will have to create a new Hasura project and configure it with the same Hasura metadata and other configuration as in the previous project.

The following is a guide to achieve this.

Step 1: Export metadata from existing project

See exporting metadata to get a copy of the current Hasura metadata on your project.

Do ensure no further changes are made to the Hasura metadata post this.

Step 2: Create a new Cloud project with the same configuration

See Step 1 of creating projects to create a new Hasura Cloud project.

After project creation, update the Hasura Cloud configuration of the new project with the same configuration as the earlier project. i.e. add the same ENV vars, custom domains, collaborators, billing, etc.

Step 3: Apply the exported metadata to the new project

See applying metadata to apply the earlier exported metadata to the new project.

The new project should now be generating the same GraphQL API as the earlier project.

Step 4: Delete the earlier project

See deleting projects to delete the earlier project.

Optional steps

  • If you are using Hasura migrations on your project, please mark all existing migrations as applied on the new project using the following Hasura CLI command:

    hasura migrate apply --skip-execution --endpoint <new-project-endpoint> --admin-secret <new-project-admin-secret> --all-databases
  • You can rename your new project to the same name as the earlier project if you wish.

  • If you haven't renamed your new project or set up a custom domain for your project, you might want to update any clients consuming the GraphQL API to point to the new project's GraphQL endpoint.

Zero-downtime transfer

To achieve a zero-downtime transfer, you will need to have a custom domain attached to your Cloud project. Once the new project is set up identically as the old one, you can update the DNS entries for your custom domain to the new project to have a seamless transfer of traffic to the new project.

If you simply want to avoid updating your clients with the new project's API endpoint, you can simply rename your new project with the same name as the earlier project. This will cause a short downtime of your API after you delete your old project until you rename the new one.

Caveats

You will lose the following data from your earlier project in the process:

  • all existing scheduled events
  • all existing async actions
  • past invocation logs of cron triggers

If you would like these to be transferred to the new project as well please get in touch with support regarding this before deleting the old project.