Hygraph migrate cli
It is possible to upgrade your Hygraph schema using the Graphcommerce Hygraph
CLI: yarn graphcommerce hygraph-migrate
This is a tool that automatically modifies your Hygraph schema without having to
add models, components field and enumerations manually.
Please note that:
All migrations are backwards compatible with previous versions of
GraphCommerce. This means that after running a migration, older versions of
GraphCommerce will still work (unless specified otherwise)
There is no rollback functionality in the Hygraph migrate cli. Please create a
copy of the project to test te migration on first. Once you run a migration,
you can't undo these schema changes with the CLI. You will be required
rollback the from the UI yourself.
Steps
The following steps are needed to utilize this tool:
Create a Hygraph migration token
Open your Hygraph project. Go to: Project settings > Permanent auth tokens
Click 'Add token' and give it a name, something like 'GraphCommerce Write
Access Token' and keep stage on 'Published'.
Under 'Management API', click 'Yes, Initialize defaults'
Click 'Edit Permissions' and enable: 'Update' and 'Delete' permissions for
'models', 'enumerations', 'fields', 'components' and 'sources':
Update existing models
Delete existing models
Update existing fields
Delete existing fields
Update existing enumerations
Delete existing enumerations
Update existing components
Delete existing components
Update remote sources
Delete remote sources
Read existing environments
Read public content views
Create public content views
Update public content views
Delete public content views
Can see schema view
Add this new token to your env file:
GC_HYGRAPH_WRITE_ACCESS_TOKEN="{YOUR_WRITE_ACCESS_TOKEN}"
Run yarn graphcommerce hygraph-migrate
Select the migration you want to run and press enter.
The migrations should now be applied, check your Hygraph Schema if changes
are made.
Addtional config
These configurations should not be necessary and can be deduced from the
hygraphEndpoint URL. This allows you to override them in case something goes
wrong.
Before adding these make sure you've configure the 'High Performance Content
API' als your hygraphEndpoint.
Add your hygraphProjectId to your env file like this:
Settings > Project > Id
Add the project ID to your env file:
GC_HYGRAPH_PROJECT_ID="{YOUR_PROJECT_ID}"
Add your hygraphManagementApi to your env file like this:
Copy the Management API URL and add to your env file:
GC_HYGRAPH_MANAGEMENT_API="{YOUR_MANAGEMENT_API}"