Go to file
Christian Kamm 6439eb5531
Client: Print the error kind on simulation failure (#462)
2023-02-16 10:55:35 +01:00
.github License: Mark instructions GPLv3 and everything else MIT (#454) 2023-02-15 08:42:07 +01:00
3rdparty License: Mark instructions GPLv3 and everything else MIT (#454) 2023-02-15 08:42:07 +01:00
anchor-tests switch to new vanity address 2022-12-08 10:23:12 +01:00
cli Client: Move data feeds to client/ 2023-02-15 15:12:14 +01:00
client Client: Print the error kind on simulation failure (#462) 2023-02-16 10:55:35 +01:00
docs Add doc generation job (#450) 2023-02-13 08:29:50 +01:00
keeper Client: Move data feeds to client/ 2023-02-15 15:12:14 +01:00
lib/checked_math Checked math: support cm!(a += b) 2022-09-06 08:55:27 +02:00
liquidator Client: Print the error kind on simulation failure (#462) 2023-02-16 10:55:35 +01:00
migrations First commit 2022-01-21 19:21:46 +01:00
programs Settle pnl: Always grant the fractional fee on low health 2023-02-15 15:11:58 +01:00
py rename 2022-03-01 20:55:10 +01:00
ts/client fix fillevent type in client (#460) 2023-02-16 10:55:12 +01:00
.dockerignore wip docker 2022-07-29 11:15:26 +02:00
.env.sample add dotenv for client config vars 2022-12-05 14:48:06 -05:00
.eslintignore add eslint config and fix errors 2022-08-04 13:42:41 -04:00
.eslintrc.json ts client improvement (#254) 2022-09-29 15:51:09 +02:00
.gitignore add dotenv for client config vars 2022-12-05 14:48:06 -05:00
.gitmodules License: Mark instructions GPLv3 and everything else MIT (#454) 2023-02-15 08:42:07 +01:00
.prettierignore run prettier and add prettierignore 2022-08-04 14:13:46 -04:00
Anchor.toml Don't compile the margin-trade fixture all the time 2022-12-08 20:48:44 +01:00
CHANGELOG.md Add program v0.6.0 release info 2023-02-14 16:07:15 +01:00
Cargo.lock Client: Move data feeds to client/ 2023-02-15 15:12:14 +01:00
Cargo.toml License: Mark instructions GPLv3 and everything else MIT (#454) 2023-02-15 08:42:07 +01:00
DEVELOPING.md Readme: Try to add a licensing summary. (#456) 2023-02-15 19:03:29 +09:00
Dockerfile Bump dockerfile rust version 2023-01-12 20:34:13 +00:00
HOW-TO-RELEASE.md update 2022-07-14 10:14:23 +02:00
LICENSE License: Mark instructions GPLv3 and everything else MIT (#454) 2023-02-15 08:42:07 +01:00
Procfile Setup MM for Heroku deployments (#358) 2023-01-02 19:21:08 +00:00
Program ts: Additional serum3 support (#196) 2022-08-31 11:36:44 +02:00
README.md Readme: Try to add a licensing summary. (#456) 2023-02-15 19:03:29 +09:00
SECURITY.md add security policy and on-chain metadata (#361) 2023-01-04 18:13:29 +00:00
fix-npm-tag.sh add script to rename tag added by npm 2023-02-01 13:49:31 +01:00
idl-fixup.sh idl deploy workaround, reduce size by cutting largest fields i.e. docs (#334) 2022-12-14 09:55:25 +01:00
package.json upgrade a bunch of ts packages (#449) 2023-02-09 18:02:28 +01:00
release-to-devnet.sh License: Mark instructions GPLv3 and everything else MIT (#454) 2023-02-15 08:42:07 +01:00
release-to-mainnet.sh License: Mark instructions GPLv3 and everything else MIT (#454) 2023-02-15 08:42:07 +01:00
run-anchor-tests.sh License: Mark instructions GPLv3 and everything else MIT (#454) 2023-02-15 08:42:07 +01:00
tsconfig.build.json integrate initial pass of orcas devnet swap 2022-06-10 09:02:10 -04:00
tsconfig.cjs.json integrate initial pass of orcas devnet swap 2022-06-10 09:02:10 -04:00
tsconfig.esm.json add esm tsconfig 2022-06-30 13:17:10 -04:00
tsconfig.json Setup MM for Heroku deployments (#358) 2023-01-02 19:21:08 +00:00
update-local-idl.sh License: Mark instructions GPLv3 and everything else MIT (#454) 2023-02-15 08:42:07 +01:00
yarn.lock upgrade a bunch of ts packages (#449) 2023-02-09 18:02:28 +01:00

README.md

work in progress

License

See the LICENSE file.

The majority of this repo is MIT licensed, but some parts needed for compiling the solana program are under GPL.

All GPL code is gated behind the enable-gpl feature. If you use the mango-v4 crate as a dependency with the client or cpi features, you use only MIT parts of it.

The intention is for you to be able to depend on the mango-v4 crate for building closed-source tools and integrations, including other solana programs that call into the mango program.

But deriving a solana program with similar functionality to the mango program from this codebase would require the changes and improvements to stay publicly available under GPL.

Development

See DEVELOPING.md

Dependencies

  • rust version 1.65.0
  • solana-cli 1.14.9
  • npm 8.1.2
  • node v16.13.1

Submodules

After cloning this repo you'll need to init and update its git submodules. Consider setting the git option submodule.recurse=true.

Deployments

  • devnet: 4MangoMjqJ2firMokCjjGgoK8d4MXcrgL7XJaL3w6fVg
  • mainnet-beta: 4MangoMjqJ2firMokCjjGgoK8d4MXcrgL7XJaL3w6fVg
  • primary mango group on mainnet-beta: 78b8f4cGCwmZ9ysPFMWLaLTkkaYnUjwMJYStWe5RTSSX

Release

Here are steps followed while performing a program deployment to mainnet-beta

  • review diff of last deployed tag to mainnet-beta, e.g. https://github.com/blockworks-foundation/mango-v4/compare/program-v0.4.0..dev, pay special attention to account layout changes, backward compatibility of newly introduced account fields, etc.
  • deploy to mainnet-beta
  • update changelog with deploy timestamp and tx
  • add a git tag e.g. program-v0.0.1, should match the version the program has
  • reset main to currently deployed tag
  • notify other contributors for bringing in changes from new release by merging main into their branch, e.g. ts-client and deploy-mm
  • notify other contributors for appropriately handling offchain services e.g. scrapers, market makers, etc.
  • bump program version in Cargo.toml on dev branch for next release

Here are steps followed while performing a npm package release note: the UI currently uses code directly from github, pointing to the ts-client branch

  • use yarn publish to release a new package, ensure compatibility with program release to mainnet-beta
  • fix the tag auto added by yarn to match our internal convention, see script fix-npm-tag.sh, tags should look like this e.g.npm-v0.0.1, note: the npm package version/tag should not necessarily match the latest program deployment