Skip to main content

Python package to automate MultiversX smart contracts deployment and contract interactions in general

Project description

MxOps

MxOps full logo

MxOps is tool created to facilitate and automate MultiversX interactions: be it smart contracts deployments, calls, queries or just simple transfers. Inspired from DevOps tools, it aims to ease and make reproducible any set of interactions with the blockchain.

MxOps is built to be especially useful in these situations:

  • smart-contract deployment automation
  • on-chain integration tests (chain simulator, localnet, testnet or devnet)
  • smart-contract interaction automation

The vision of MxOps is that interacting with the blockchain should be straight forward and that even non-technical users should be able to interact with the blockchain at will. For this reason, MxOps will handle all the hassle for you so that you can focus on the core of your activities.

Sponsors

MxOps is an open-source tool dedicated to enhancing the MultiversX ecosystem, and its development and maintenance rely on the generous support of our sponsors.

We extend our heartfelt thanks to Astrarizon, the first sponsor of MxOps! (announcement on X)

Astrarizon logo

If MxOps has been beneficial in your projects or professional endeavors, we invite you to join our community of sponsors. Your support will ensure the continued maintenance and future development of MxOps, helping to keep this tool at the forefront of the MultiversX ecosystem.

Interested? Reach out to us at contact@catenscia.com.

How does it works?

MxOps is built in python, on top of mx-sdk-py, but you don't need to know python nor to be a programmer to be able to benefit from MxOps. Indeed, you only have to write yaml files (aka formated text files) to describe what you want to to.

Snippets

To give you an idea of how simple it is to use MxOps, you will find below a few yaml snippets for some of its capacities.

Token Issuance

Here, MxOps is used to issue a fungible token from an account named by the user as alice:

  - type: FungibleIssue
    sender: alice
    token_name: AliceToken
    token_ticker: ATK
    initial_supply: 1000000000  # 1,000,000.000 ATK
    num_decimals: 3
    can_add_special_roles: true

Contract Query

MxOps is used below to fetch information from the live Onedex contract on mainnet. We specifically query the state of the pool n°9, which is the pool ONE/WEGLD.

  - type: ContractQuery
    contract: onedex-swap
    endpoint: viewPair
    arguments:
      - 9  # id of the pair to get the details of
:class-title: normal-title
:color: light

```json
[
    {
        "pair_id": 9,
        "state": {
            "__discriminant__": 1,
            "__name__": "Active"
        },
        "enabled": true,
        "owner": "erd1xkflzkx3hp52szy26zh9m5ts3v3j4dxhqkpxzj9npzp7wyp6qeysfpqz2m",
        "first_token_id": "ONE-f9954f",
        "second_token_id": "WEGLD-bd4d79",
        "lp_token_id": "ONEWEGLD-892244",
        "lp_token_decimal": 18,
        "first_token_reserve": 1372071779861493216032911,
        "second_token_reserve": 4820163353587346912393,
        "lp_token_supply": 1301904634411268529384,
        "lp_token_roles_are_set": true,
        "unkown": 0,
        "fees": 100
    }
]

Contract Call with Payments

Here, MxOps is used to call a contract while sending tokens. This example shows what it would look like to add some liquidity to a pool.

- type: ContractCall
  sender: thomas
  contract: pair-contract
  endpoint: addLiquidity
  esdt_transfers:
    - identifier: TOKENA-abcdef
      amount: 894916519846515
      nonce: 0
    - identifier: TOKENB-abcdef
      amount: 710549841216484
      nonce: 0
  gas_limit: 12000000

Account cloning

Let's say the contract you are developing in dependent of a third party contract for which you don't have the code. MxOps allows you to simply copy entirely this contract, including its code, its storage values and its tokens, so that you can run your tests in mainnet condition but locally on your machine.

- type: AccountClone
  address: egld_wrapper_shard_1
  source_network: mainnet
Cloning accounts necessits to directly write arbitrary values to the blockchain states, so it is only possible on the chain-simulator

Getting Started

You have seen above some basic use-cases but MxOps has much more avaible features! Heads up to the documentation to get started! You will find tutorials, user documentation and examples 🚀

Contribution

This tool is an humble proposal by Catenscia to have a standard way of writing deployment files, integration tests and others. If you want this tool to improve, please tell us your issues and proposals!

And if you're motivated, we will always welcome hepling hands onboard :grin: !

Read the contribution guidelines for more :wink:

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mxops-3.0.0.tar.gz (95.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mxops-3.0.0-py3-none-any.whl (96.4 kB view details)

Uploaded Python 3

File details

Details for the file mxops-3.0.0.tar.gz.

File metadata

  • Download URL: mxops-3.0.0.tar.gz
  • Upload date:
  • Size: 95.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for mxops-3.0.0.tar.gz
Algorithm Hash digest
SHA256 319945f102542efb682589108f83c8ba15314d360136acb79386790f810d5eae
MD5 1308a8831f0329a2f9746096e90249e3
BLAKE2b-256 1a68dace2220cde0b56d0d010a807f9705761f9dedc590c6d3d7356612a8858e

See more details on using hashes here.

File details

Details for the file mxops-3.0.0-py3-none-any.whl.

File metadata

  • Download URL: mxops-3.0.0-py3-none-any.whl
  • Upload date:
  • Size: 96.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for mxops-3.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0d8ccce0a9b9d45c066edf7705a674476821895871af259cdff5296817332c40
MD5 430a8b8718aee269169803718c0d408b
BLAKE2b-256 f054090cf9975c4650ac82322ac231692a0181fa85eececb12da4eecb2aa82ce

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page