Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/SiennaNetwork/SiennaNetwork
Sienna Network Monorepo
https://github.com/SiennaNetwork/SiennaNetwork
amm blockchain defi lending privacy
Last synced: 2 months ago
JSON representation
Sienna Network Monorepo
- Host: GitHub
- URL: https://github.com/SiennaNetwork/SiennaNetwork
- Owner: SiennaNetwork
- License: agpl-3.0
- Created: 2021-10-09T15:00:39.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2022-04-29T18:34:43.000Z (over 2 years ago)
- Last Synced: 2024-08-02T03:07:55.749Z (6 months ago)
- Topics: amm, blockchain, defi, lending, privacy
- Language: Rust
- Homepage: https://app.sienna.network
- Size: 27.3 MB
- Stars: 11
- Watchers: 2
- Forks: 13
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-blockchain-rust - Sienna Network
README
[![](/logo.svg)](https://sienna.network/)
[![Twitter Follow](https://img.shields.io/twitter/follow/sienna_network?style=plastic&logo=twitter)](https://twitter.com/sienna_network)
[![Coverage Status](https://coveralls.io/repos/github/SiennaNetwork/sienna/badge.svg?branch=dev&t=s6kRdI)](https://coveralls.io/github/SiennaNetwork/sienna?branch=dev)
[![Contributions welcome](https://img.shields.io/badge/contributions-welcome-brightgreen.svg?style=flat)](CONTRIBUTING.md)
[![Code style](https://img.shields.io/badge/code%20style-open--minded-%239013fe)](CONTRIBUTING.md#coding-style)## Mainnet addresses
MOVED: See [**`receipts/secret-4/deployments/prod.yml`**](./receipts/secret-4/deployments/prod.yml)
for the up-to-date mainnet addresses of all production contracts.## Development quickstart
```sh
git clone
``````sh
git submodule update --init --recursive
nix-shell # optional, or bring your own Cargo and PNPM
pnpm i
pnpm build latest
FADROMA_CHAIN=Scrt_1_2_Devnet pnpm deploy latest
```The smart contracts are written in Rust, targeting SecretNetwork's fork of `cosmwasm-std 0.10`
on `wasm32-unknown-unknown`.See [**`package.json`**](package.json) and [**`scripts/`**](./scripts/)
for the available workflow commands.See also:
- **[Git submodules](https://git-scm.com/book/en/v2/Git-Tools-Submodules)** documentation,
and most importantly the `git submodule update --init --recursive` command.
- The **[pnpm](https://pnpm.io/)** package manager, and most importantly
its [Workspaces feature](https://pnpm.io/workspaces).## Repository content
* [**artifacts**](./artifacts) contains the compiled smart contracts (gitignored)
and their checksums (not gitignored).* [**contracts**](./contracts) contains the Rust source code of the smart contracts,
as well as the TypeScript code necessary to build them and interact with them.* [📖 tge](./contracts/tge) - **Token Generation Event (TGE)**: mints and vests a new token
* **Contract:** [snip20-sienna](./contracts/tge/snip20-sienna) - Main SIENNA governance token
* **Contract:** [mgmt](./contracts/tge/mgmt) - Vesting management contract
* **Contract:** [rpt](./contracts/tge/rpt) - Remaining pool token splitter contract
* **Script:** [deploy.ts](./contracts/tge/deploy.ts) - TGE deployment* [📖 amm](./contracts/amm) - **Automated Market Maker (AMM)**: Sienna Swap and friends
* **Contract:** [amm-snip20](./contracts/amm/amm-snip20) - Vanilla SNIP20 token usable by the AMM
* **Contract:** [factory](./contracts/amm/factory) - Sienna Swap Factory
* **Contract:** [exchange](./contracts/amm/exchange) - Sienna Swap Exchange
* **Contract:** [lp-token](./contracts/amm/lp-token) - Sienna Swap LP Token
* **Contract:** [router](./contracts/amm/router) - Sienna Swap Router
* **Contract:** [📖 rewards](./contracts/amm/rewards) - Sienna Rewards
* **Contract:** [launchpad](./contracts/amm/launchpas) - Sienna Launchpad
* **Contract:** [ido](./contracts/amm/ido) - Sienna IDO
* **Script:** [deploy.ts](./contracts/amm/deploy.ts) - AMM deployment
* **Script:** [upgrade.ts](./contracts/amm/upgrade.ts) - AMM migrations* [📖 lend](./contracts/lend) - **Sienna Lend** - Private Lending Protocol
* **Contract:** [market](./contracts/lend/market)
* **Contract:** [oracle](./contracts/lend/oracle)
* **Contract:** [overseer](./contracts/lend/overseer)
* **Contract:** [interest_model](./contracts/lend/interest_model)* [**deps**](./deps) contains submodules of our foundational frameworks.
* [fadroma](./deps/fadroma) is a Git submodule pointing to the top of
the [Fadroma deployment framework](https://github.com/hackbg/fadroma), which takes care of building and uploading the
contracts behind the scenes.* [**frontends**](./frontends) contains clients for the smart contracts, written in JS/TS.
Some of them are transcluded as git submodules pointing to other repos.
* [siennajs](./frontends/siennajs) - current client library
* [@sienna/api](./frontends/api) - upcoming mixed deploy/client library
* [dashboard](./frontends/dashboard) - rewards simulation dashboard
* [reward-pools-monitor](./frontends/reward-pools-monitor) - query status of reward pools
* [claim](./frontends/claim) - TGE claim frontend
* [vest](./frontends/vest) - TGE vest frontend* [**libraries**](./libraries) contains Rust libraries used by one or more smart contracts.
* [amm-shared](./libraries/amm-shared) defines the contract API of Sienna Swap.
* [lend-shared](./libraries/lend-shared) defines the contract API of Sienna Lend.* [**receipts**](./receipts) contains the responses to upload and init transactions
performed by the framework, grouped by chain ID. This lets you keep track of uploaded
contracts.
* [secret-4/deployments/prod](./receipts/secret-4/deployments/prod.yml) - current mainnet deployment
* [pulsar-2/deployments/.active](./receipts/pulsar-2/deployments/.active) - current testnet deployment* [**scripts**](./scripts) contains utility scripts pertaining to the whole repo.
* [Build.ts.md](./scripts/Build.ts.md) - build with `pnpm build`
* [Chain.ts.md](./scripts/Chain.ts.md)
* [Configure.ts.md](./scripts/Configure.ts.md)
* [Deploy.ts.md](./scripts/Deploy.ts.md) - deploy with `pnpm deploy`
* [Deployment.ts.md](./scripts/Deployment.ts.md)
* [Generate.ts.md](./scripts/Generate.ts.md)
* [Live.ts.md](./scripts/Live.ts.md)
* [Receipts.ts.md](./scripts/Receipts.ts.md)
* [Schema.ts.md](./scripts/Schema.ts.md)
* [Status.ts.md](./scripts/Status.ts.md)
* [Test.ts.md](./scripts/Test.ts.md) - test with `pnpm test`
* [Tokens.ts.md](./scripts/Tokens.ts.md)
* [Upload.ts.md](./scripts/Upload.ts.md)* [**settings**](./settings) contains the values of configurable properties for each
smart contract, again grouped by chain ID. This is a NPM module that can be imported
by the deploy scripts to access the settings for deploying to a specific chain
(as testnet configuration may need to systematically differ from mainnet).
* [schedule.json](./settings/schedule.json) - vesting schedule## Post-deployment configuration
After deployment the contracts should be
transferred to the master multisig account.
The CLI and API wrappers in this repo
do not support generating multisig transactions.See [hackbg/motika](https://github.com/hackbg/motika)
for a GUI-based multisig transaction signer.