Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/paradigmxyz/mesc
MESC is a specification for how crypto tools configure their RPC endpoints
https://github.com/paradigmxyz/mesc
crypto cryptocurrency ethereum evm json-rpc rpc
Last synced: 4 days ago
JSON representation
MESC is a specification for how crypto tools configure their RPC endpoints
- Host: GitHub
- URL: https://github.com/paradigmxyz/mesc
- Owner: paradigmxyz
- License: apache-2.0
- Created: 2023-11-11T22:40:47.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-09-20T18:51:32.000Z (3 months ago)
- Last Synced: 2024-12-21T17:02:35.528Z (11 days ago)
- Topics: crypto, cryptocurrency, ethereum, evm, json-rpc, rpc
- Language: Rust
- Homepage:
- Size: 1.79 MB
- Stars: 172
- Watchers: 7
- Forks: 29
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
Awesome Lists containing this project
README
# Multiple Endpoint Shared Configuration (MESC) Standard
[![Specification](https://img.shields.io/badge/Spec-blueviolet)](https://github.com/paradigmxyz/mesc/blob/main/SPECIFICATION.md)
[![issues - badge-generator](https://img.shields.io/badge/Docs-blueviolet)](https://paradigmxyz.github.io/mesc)
[![Rust Tests](https://github.com/paradigmxyz/mesc/workflows/Rust%20Tests/badge.svg)](https://github.com/paradigmxyz/mesc/tree/main/tests)
[![Python Tests](https://github.com/paradigmxyz/mesc/workflows/Python%20Tests/badge.svg)](https://github.com/paradigmxyz/mesc/tree/main/tests)MESC is a standard for how crypto tools configure their RPC endpoints. By following this specification, a user creates a single RPC configuration that can be shared by all crypto tools on their system.
MESC has two main design goals:
1. make it easy to share RPC configuration data across tools, languages, and environments
2. make it easy to manage the configuration of a large number of RPC endpointsMESC is formally defined in [SPECIFICATION.md](./SPECIFICATION.md).
Additional information can be found in the [MESC Documentation](https://paradigmxyz.github.io/mesc/).
### Contents
- [Reference Implementations](#reference-implementations)
- [Quickstart](#quickstart)
- [Tutorial](#tutorial)
- [Tracked Information](#tracked-information)
- [Common Interface](#common-interface)
- [Typical Usage](#typical-usage)## Reference Implementations
Reference implementations are provided for each of the following:
- [cli](/cli)
- [go](/go) [WIP]
- [python](/python)
- [rust](/rust)
- [typescript](/typescript) [WIP]These implementations provide a consistent language-agnostic interface while still obeying the best practices of each language.
## Quickstart
The quickest way to use MESC is:
1. create a `mesc.json` config file
2. set the `MESC_PATH` environment variable to the path of this fileThese steps can be performed automatically using the interactive [`mesc`](./cli) CLI tool:
1. Install: `cargo install mesc_cli`
2. Perform interactive setup: `mesc setup`Installing the `mesc` cli on some linux distributions may require installing ssl libraries (e.g. `sudo apt-get install pkg-config libssl-dev` on ubunutu)
## Tutorial
Below is a brief tutorial on MESC. For more detail, see the MESC [Specification](./SPECIFICATION.md) and [Documentation](https://paradigmxyz.github.io/mesc).
Topics:
- [Tracked Information](#tracked-information)
- [Common Interface](#common-interface)
- [Typical Usage](#typical-usage)### Tracked Information
MESC tracks the following information:
1. a list of RPC endpoints, including their `name`, `chain_id`, and `url`
2. the default RPC endpoint to use
3. the default RPC endpoint to use for each networkMESC can also track other information like metadata and tool-specific defaults. Configuration data is stored in a JSON file. To create this file, follow the [Quickstart](#quickstart) instructions above.
### Common Interface
All reference MESC implementations use the same common interface.
Here is a comparison between the python interface and the rust interface:
###### python
```python
import mesc# check whether mesc is enabled
enabled: bool = mesc.is_mesc_enabled()# get the default endpoint
endpoint: Endpoint | None = mesc.get_default_endpoint()# get the default endpoint of a network
endpoint: Endpoint | None = mesc.get_endpoint_by_network(5)# get the default endpoint for a particular tool
endpoint: Endpoint | None = mesc.get_default_endpoint(profile='xyz_tool')# get the default endpoint of a network for a particular tool
endpoint: Endpoint | None = mesc.get_endpoint_by_network(5, profile='xyz_tool')# get an endpoint by name
endpoint: Endpoint | None = mesc.get_endpoint_by_name('local_goerli')# parse a user-provided string into a matching endpoint
# (first try 1. endpoint name, then 2. chain id, then 3. network name)
endpoint: Endpoint | None = mesc.get_endpoint_by_query(user_str, profile='xyz_tool')# find all endpoints matching given criteria
endpoints: list[Endpoint] = mesc.find_endpoints(chain_id=5)
```###### rust
```rust
use mesc::{MescError, Endpoint};
use std::collections::HashMap;type OptionalResult = Result, MescError>;
type MultiResult = Result, MescError>;
type MetadataResult = Result, MescError>;// check whether mesc is enabled
let enabled: bool = mesc::is_mesc_enabled();// get the default endpoint
let endpoint: OptionalResult = mesc::get_default_endpoint(None);// get the default endpoint of a network
let endpoint: OptionalResult = mesc::get_endpoint_by_network("5", None);// get the default network for a particular tool
let chain_id: OptionalResult = mesc::get_default_endpoint(Some("xyz_tool"));// get the default endpoint of a network for a particular tool
let endpoint: OptionalResult = mesc::get_endpoint_by_network("5", Some("xyz_tool"));// get an endpoint by name
let endpoint: OptionalResult = mesc::get_endpoint_by_name("local_goerli");// parse a user-provided string into a matching endpoint
// (first try 1. endpoint name, then 2. chain id, then 3. network name)
let user_str = "local_goerli";
let endpoint: OptionalResult = mesc::get_endpoint_by_query(user_str, Some("xyz_tool"));// find all endpoints matching given criteria
let query = mesc::MultiEndpointQuery::new().chain_id("5").unwrap();
let endpoints: MultiResult = mesc::find_endpoints(query);
```### Typical Usage
Imagine a crypto cli tool `xyz`. This tool has an argument `-r ` that specifies which RPC endpoint to use.
If `xyz` uses MESC, then `-r` can become a much more versatile argument. Instead of just accepting a plain URL, `-r` can accept 1. an endpoint name, 2. chain id, or 3. a network name. Each of the following might resolve to the same RPC url:
- `xyz -r localhost:8545` (url)
- `xyz -r local_goerli` (endpoint name)
- `xyz -r 5` (chain id)
- `xyz -r goerli` (network name)This url resolution can implemented within `xyz` using:
```python
# python code used by xyz tool
endpoint = mesc.get_endpoint_by_query(user_input, profile='xyz')
url = endpoint['url']
``````rust
// rust code used by xyz tool
let endpoint = mesc::get_endpoint_by_query(user_input, Some("xyz"))?;
let url = endpoint.url;
```