Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
A tool to update a beacon server value on a time interval
Airkeeper will fetch the value from the API (similarly to Airnode) and if a specifided condition is true then it will update the beacon value.
There are two different lambda functions that can be used to update the beacon value:
rrp-beacon-update
uses the
RrpBeaconServer
contract from airnode-protocol v0.4. See Beacons
This function will fetch the API values for all triggers set in the airkeeper.json
file, read current the beacon
value in RrpBeaconServer and update it if the API value is not within the threshold (also defined in the
airkeeper.json
file).
psp-beacon-update
uses the
DapiServer
contract from airnode-protocol v1.
This function will fetch the API values for all subscriptions in the airkeeper.json
file, call a condition function
on chain and update the beacon value if the condition is true.
Both functions will require a sponsor to be defined in the airkeeper.json
file in order to derive a sponsor wallet
that will be used by Airkeeper to submit transactions. These sponsor wallets must be funded by a sponsor before
Airkeeper can start updating beacon values. The protocol ID to be used when deriving the sponsor wallet for RRP beacon
updates is 12345
and for PSP it is 2
.
Airkeeper will require a configuration file that matches the one being used by the target Airnode. The Airnode's
config.json
and secrets.env
file can be copied from the Airnode repo and placed in the /config directory of this
repo. Examples of these two files can be found in the /config directory of this repo.
Airkeeper will also require an additional configuration file named airkeeper.json
, which will be merged with the
configuration. airkeeper.json
will contain configuration specific to Airkeeper. An example is available in the
/config directory of this repo.
Another requirement is to have an AWS account where these lambda functions can be deployed. Cloud provider credentials
must be provided in the aws.env
file and placed in the /config directory of this repo.
Use the docker image to deploy or remove an Airkeeper to and from a cloud provider such as AWS.
The docker image supports two commands.
deploy
: Deploys both Airkeeper lambda functions using the provided configuration files.remove
: Removes both previously deployed Airkeeper lambda functions.The docker image can be built by running the following command from the root directory:
docker build . -t api3/airkeeper
The deploy
command will create a new AWS lambda function set and a new AWS cloud scheduler.
docker run -it --rm \
--env-file config/aws.env \
-v "$(pwd)/config:/app/config" \
api3/airkeeper:latest deploy --stage dev --region us-east-1
For Windows, use CMD (and not PowerShell).
docker run -it --rm ^
--env-file config/aws.env ^
-v "$(pwd)/config:/app/config" ^
api3/airkeeper:latest deploy --stage dev --region us-east-1
The remove
command will delete the previously deployed AWS lambda function and its AWS cloud scheduler.
docker run -it --rm \
--env-file config/aws.env \
-v "$(pwd)/config:/app/config" \
api3/airkeeper:latest remove --stage dev --region us-east-1
For Windows, use CMD (and not PowerShell).
docker run -it --rm ^
--env-file config/aws.env ^
-v "$(pwd)/config:/app/config" ^
api3/airkeeper:latest remove --stage dev --region us-east-1
Make sure to have yarn installed, then run:
yarn install
Follow these steps to run Airkeeper locally:
yarn install
.config.json
and airkeeper.json
files.yarn sls:invoke-local:psp-beacon-update
to invoke the psp.beaconUpdate
handler function or run
yarn sls:invoke-local:rrp-beacon-update
to invoke the rrp.beaconUpdate
handler function.Airkeeper is meant to be deployed to the AWS lambda service and for this you will need to add your credentials to the
config/aws.env
file. Once done, the export-aws-env.sh
script can be used to load them into the environment.
yarn sls:config
to configure the AWS credentials. You must first configure the config/aws.env
file
with your AWS account details and then run source export-aws-env.sh
script to load the env vars.yarn sls:deploy
to deploy the Airkeeper lambda function.yarn sls:invoke:psp
to invoke the Airkeeper PSP beacon update lambda function.yarn sls:remove
to remove the Airkeeper lambda function.The request sponsor account must first call AirnodeRrp.setSponsorshipStatus(rrpBeaconServer.address, true)
to allow
the RrpBeaconServer contract to make requests to AirnodeRrp contract.
A keeperSponsorWallet
needs to be derived for the sponsor-airnode pair. This is a similar process to deriving the
sponsor wallet used by Airnode to fulfill requests but in this case the wallet derivation path is slightly different.
This wallet needs to be funded with the native token in order for Airkeeper to use it to submit beacon updates
requests.
Request sponsor account must also call RrpBeaconServer.setUpdatePermissionStatus(keeperSponsorWallet.address, true)
to allow the keeperSponsorWallet
to update beacon server value.
The template used by the RrpBeaconServer contract is expected to contain all the parameters required in the API call.
Current PSP beacon update implementation is a prototype; allocators, authorizers and sponsorship have been ignored. This is because the current implementation is not ready for production.
Subscription and template details are expected to be provided in the airkeeper.json
file meaning that Airkeeper will
not fetch that information from AirnodeProtocol contract.
The scripts
directory contains scripts that can be used to test the lambda functions against a local running eth node.
First you need to start a local ethereum node and grab private keys of funded test accounts to add them to each account in the psp-beacon-local.json config file. Then you need to start the local 'Currency Converter API' server.
After that you can run the following command:
yarn run setup:psp-local
: Deploys the DapiServer contract and registers a single subscription. Use the values
displayed in the console to fill in the airkeeper.json
file. Then you can run
yarn sls:invoke-local:psp-beacon-update
to update the beacon using PSP.FAQs
A tool to update a beacon server value on a time interval
The npm package airkeeper receives a total of 0 weekly downloads. As such, airkeeper popularity was classified as not popular.
We found that airkeeper demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.