Go to file
Serge Farny e57e321306 Program: more explicit error when missing bank/oracle for serum 2024-06-28 15:02:30 +02:00
.github Clients: log git commit info at start time - try to fix for CI (#968) 2024-05-28 15:10:16 +02:00
anchor-tests chore: fix typos (#778) 2023-11-23 08:59:19 +01:00
audits add audit report for v0.24.0 (#941) 2024-04-15 08:36:10 +02:00
bin token update index and rate- skip bad oracle (#975) 2024-06-26 08:51:41 +02:00
cd service-mango-health: monitors/historizes accounts health (#890) 2024-02-29 17:05:29 +01:00
docs Add doc generation job (#450) 2023-02-13 08:29:50 +01:00
lib Clients: log git commit info at start time - try to fix for CI (#968) 2024-05-28 15:10:16 +02:00
migrations
programs Program: more explicit error when missing bank/oracle for serum 2024-06-28 15:02:30 +02:00
py rename 2022-03-01 20:55:10 +01:00
scripts deploy -> dev (#759) 2023-10-19 10:03:07 +02:00
ts/client Cancel openbook v2 order by client order id (#969) 2024-06-05 18:01:37 +02:00
.dockerignore Update to solana 1.16.14 and anchor 0.28.0 (#718) 2023-10-05 10:56:45 +02:00
.env.sample add dotenv for client config vars 2022-12-05 14:48:06 -05:00
.eslintignore
.eslintrc.json
.gitignore deploy -> dev (#759) 2023-10-19 10:03:07 +02:00
.mocharc.json
.prettierignore
Anchor.toml Don't compile the margin-trade fixture all the time 2022-12-08 20:48:44 +01:00
CHANGELOG.md Changelog for v0.25.0 2024-04-23 19:17:11 +02:00
Cargo.lock Program: add switchboard on demand oracle support (#974) 2024-06-25 17:02:33 +02:00
Cargo.toml Openbook V2 Integration (#836) 2024-04-22 11:37:53 +02:00
DEVELOPING.md Enable self-trading protection (#533) 2023-05-15 10:40:41 +02:00
Dockerfile Clients: log git commit info at start time - try to fix for CI (#968) 2024-05-28 15:10:16 +02:00
FAQ-DEV.md separate file, editing 2023-11-07 09:02:07 +01:00
HOW-TO-RELEASE.md update 2022-07-14 10:14:23 +02:00
LICENSE
Procfile Revert "try to override bad node-fetch code" 2023-06-18 09:59:49 +02:00
Program ts: Additional serum3 support (#196) 2022-08-31 11:36:44 +02:00
README.md Openbook V2 Integration (#836) 2024-04-22 11:37:53 +02:00
RELEASING.md doc: releasing.md update 2024-02-28 15:49:18 +01:00
SECURITY.md
fix-npm-tag.sh
fly.toml quote less 2023-03-20 19:23:47 +01:00
idl-fixup.sh Openbook V2 Integration (#836) 2024-04-22 11:37:53 +02:00
mango_v4.json Cancel openbook v2 order by client order id (#969) 2024-06-05 18:01:37 +02:00
package.json Merge deploy into dev 2024-04-23 11:00:25 +02:00
release-to-devnet.sh Update anchor to v0.27.0, stop using submodule (#582) 2023-05-12 13:54:53 +02:00
run-anchor-tests.sh Update anchor to v0.27.0, stop using submodule (#582) 2023-05-12 13:54:53 +02:00
rust-toolchain.toml Openbook V2 Integration (#836) 2024-04-22 11:37:53 +02:00
tsconfig.cjs.json Ts keeper (backup for rust keeper) (#546) 2023-04-19 17:42:13 +02:00
tsconfig.esm.json make consistent 2023-03-14 13:14:45 +01:00
tsconfig.json Openbook V2 Integration (#836) 2024-04-22 11:37:53 +02:00
tsconfig.types.json
update-local-idl.sh Update anchor to v0.27.0, stop using submodule (#582) 2023-05-12 13:54:53 +02:00
yarn.lock Merge deploy into dev 2024-04-23 11:00:25 +02: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 and FAQ-DEV.md

Dependencies

  • rust version 1.70.0
  • solana-cli 1.16.7
  • anchor-cli 0.28.0
  • npm 8.1.2
  • node v16.13.1

Deployments

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

Release

For program deployment, see RELEASING.md.

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