Agent keys
Hyperlane agents - validators and the relayer - must be configured with private keys in order to operate. Validators use private keys to sign message checkpoints, and the relayer uses private keys to sign transactions that deliver messages.
Hyperlane agents currently support being configured with private keys in one of two ways.
1. Hexadecimal keys
A raw hexadecimal private key used for in-memory signing. This is the easiest and fastest setup for testing.
Hexadecimal keys are not recommended for production environments. Use AWS KMS keys instead.
Generate a hexadecimal key
Keep track of your address and private key for use with your agent. Do not lose or leak it.
- Cast CLI
- Using privatekeys.pw
Using Foundry's cast, you can create a new key pair:
cast wallet new
The output will look something like this:
Successfully created new keypair.
Address: 0x32e6d32E7b1C8691Ef4ad3841003371214a0eebC
Private Key: 0x2958f0eb2ab71bbfb5ea1422835e20e488778b61e3c107f369572e2b53b578f9
You can visit https://privatekeys.pw/keys/ethereum/random, which will automatically display a list of hexadecimal private keys and their addresses.
Please note that because these are generated by a website, these private keys should be considered insecure and should not be used for anything other than testing purposes!
2. AWS KMS
A key generated by AWS and stored in a CloudHSM. This is the recommended setup for production agents, especially for validators.
Create an IAM user
This IAM user will be given permission to sign with the KMS key that you will later configure. Your Hyperlane agent will use this identity when signing transactions.
- Go to AWS's Identity and Access Management (IAM) in the AWS console.
- On the left, under "Access management", click "Users".
- Click the blue button "Add users".
- Pick a friendly and informative username, like
hyperlane-validator-${chain_name}
orhyperlane-relayer-${chain_name}
. This username will be referenced in future steps, so if you choose a different username be sure to use your correct username in the future. - Click "Next", you do not need to assign the user any permissions.
- Click "Create user".
- Click into the user that you just created
- Click the "Security Credentials" tab
- Scroll down to "Access Keys" and click "Create Access Key"
- Select "Application running outside AWS" and click "Next"
- Click "Next", no need to add a description tag
- Click "Create access key"
- Copy the "Access key ID" and "Secret access key" to a safe place. These will be passed to your Hyperlane relayer as environment variables.
Create a KMS key
This key will be used by your agent for signing.
- Go to AWS's Key Management Service (KMS) in the AWS console.
- Ensure you are in the region you want to create the key in. This can be confirmed by viewing the region at the top right of the console, or by finding the name in the URL's subdomain (e.g.
us-west-2.console.aws.amazon.com
means you're operating in the regionus-west-2
). - On the left, click "Customer managed keys".
- Click "Create key".
- Select the "Asymmetric" key type.
- Select the "Sign and verify" key usage.
- Select the
ECC_SECG_P256K1
key spec. - Click "Next".
- Set the Alias to something friendly and informative, like
hyperlane-validator-signer-${chain_name}
orhyperlane-relayer-signer-${chain_name}
- While not necessary, feel free to write a description and add any tags that you think will be useful.
- Click "Next".
- A key administrator is not required, but if you want, you can select one.
- Click "Next".
- Give usage permissions to the IAM user you created in section #1.
- Click "Next".
- In the Review page, scroll to the "Key policy". The generated key policy is acceptable, but you can make the access even less permissive if you wish by:
- Removing the
kms:DescribeKey
andkms:Verify
actions from the statement whose "Sid" is "Allow use of the key" - Removing the entire statement whose "Sid" is "Allow attachment of persistent resources".
- Removing the
- Click "Finish"
Query address
In some cases you may need to know the address associated with the KMS key you generated.
- With `cast`
- Using a script
AWS_ACCESS_KEY_ID=<redacted> AWS_SECRET_ACCESS_KEY=<redacted> AWS_KMS_KEY_ID=alias/your-key-alias cast wallet address --aws
The script at the following repo will allow you to query this address: https://github.com/tkporter/get-aws-kms-address