@tribally.games/contracts
v1.5.0
Published
Tribally Games smart contracts.
Downloads
24
Readme
@tribally.games/contracts
Core smart contracts for Tribally Games.
This is a Diamond Standard upgradeable proxy contract managed using Gemforge.
Note: the TRIBAL token contract is separate to this one.
On-chain addresses
- Base:
0x3249787E176d97298f5137A1C50CD33ae23EBd97(Basescan, Louper) - Base Sepolia:
0x999C1045C7430642e6D05cb4Be30C0b3D310a2E7(Basescan, Louper)
Usage guide
Install the NPM package:
- NPM:
npm install @tribally.games/contracts - Yarn:
yarn add @tribally.games/contracts - PNPM:
pnpm add @tribally.games/contracts - Bun:
bun add @triballuy.games/contracts
Use it within your code:
const { abi, diamondProxy } = require('@tribally.games/contracts');
console.log(abi) // JSON ABI of the diamond proxy
console.log(diamondProxy.baseSepolia) // address of contracts on Base SepoliaDevelopment guide
If you're working on this repo itself then these instructions are for you.
Ensure the following pre-requisites are installed
- Node.js 20+
- PNPM (NOTE:
yarnandnpmcan also be used) - Foundry
Setup
$ foundryup
$ pnpm i
$ pnpm bootstrapCreate .env and set the following within:
DEPLOYER_PRIVATE_KEY=<your deployment wallet private key>
BASESCAN_API_KEY=<your basescan api key>Usage
Run a local dev node in a separate terminal:
pnpm devnetTo build the code:
$ pnpm buildTo run the tests:
$ pnpm testTo deploy to the local target:
$ pnpm dep localTo deploy to public networks:
- Base sepolia:
pnpm dep base_sepolia - Base mainnet:
pnpm dep base
Once deployed you can verify contract source-codes on Basescan using:
- Base sepolia:
pnpm verify base_sepolia - Base:
pnpm verify base
For verbose output simply add -v:
$ pnpm build -v
$ pnpm dep -vSimulating live upgrades
You can simulate a live upgrade locally.
Run a local fork of the Base mainnet:
$ pnpm devnet-baseForkThe RPC server will now be running at http://localhost:8545
Now try deploying to this fork:
$ pnpm dep baseFork --verboseThis will go though the upgrade process for the Diamond in the locally running Base fork
You should see output that looks like the following:
GEMFORGE: Resolving what changes need to be applied ...
GEMFORGE: Resolving methods on-chain ...
GEMFORGE: Calling facets() on contract IDiamondProxy deployed at 0x3249787E176d97298f5137A1C50CD33ae23EBd97 with args () ...
GEMFORGE: Resolving methods in artifacts ...
GEMFORGE: Getting bytecode for contract at address 0xb16B2f6396185a516f1D8DD70A0E30c174559A4f ...
GEMFORGE: [Replace] method setSigner(address) [0x6c19e783] by deploying new facet ConfigFacet
GEMFORGE: [Replace] method setStakingToken(address) [0x1e9b12ef] by deploying new facet ConfigFacetNote that it will not actually call diamondCut() and upgrade the Diamond since the owner is the SAFE multisig. Instead it will output the parameters for you to send the transaction manually:
GEMFORGE: Outputting upgrade tx params so that you can do the upgrade manually...
GEMFORGE: ================================================================================
GEMFORGE: Diamond: 0x3249787E176d97298f5137A1C50CD33ae23EBd97
GEMFORGE: Tx data: 0x1f931c1c00000000000000000000000000000000000000000000000000000000..
.......................................................................................
.......................................................................................
So now we can pretend to the SAFE multisig and send this tx through:
$ cast rpc anvil_impersonateAccount 0x4b78Bc43E63AD6524A411F17Ff376Fd362DBB531 # base multisig wallet
$ cast send --from 0x4b78Bc43E63AD6524A411F17Ff376Fd362DBB531 --unlocked 0x3249787E176d97298f5137A1C50CD33ae23EBd97 0x.... # final arg is the tx data blob from aboveThis transaction should succeed. At this point, the Diamond in the locally running Base fork should be fully upgraded. Check using:
$ pnpm query baseForkYou should hopefully see at the end:
Unrecognized facets: 0
Unrecognized functions: 0Publishing releases
To create a new release of the package, first set your Github token env var:
$ export GITHUB_TOKEN=<use a Personal Access Token created in Github that gives access to public repos>Now create a release PR:
$ pnpm create-release-prThis will create a new release PR. The PR can be updated with new commits by again calling the same command.
Once the PR is merged into the master branch, run:
$ pnpm finalize-releaseThis will create a release tag and cause the npm-publish workflow to run, publishing the package to NPM.
License
AGPLv3 - see LICENSE.md
Tribally Games smart contracts Copyright (C) 2024 Tribally Games
This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License along with this program. If not, see http://www.gnu.org/licenses/.
