Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/strangelove-ventures/lens
⚛️❤️👁 Brought to you by the LensCrafters
https://github.com/strangelove-ventures/lens
Last synced: 3 months ago
JSON representation
⚛️❤️👁 Brought to you by the LensCrafters
- Host: GitHub
- URL: https://github.com/strangelove-ventures/lens
- Owner: strangelove-ventures
- License: apache-2.0
- Archived: true
- Created: 2021-12-01T05:10:38.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2023-07-05T21:39:35.000Z (over 1 year ago)
- Last Synced: 2024-04-13T02:15:37.407Z (9 months ago)
- Language: Go
- Homepage:
- Size: 18.4 MB
- Stars: 167
- Watchers: 15
- Forks: 85
- Open Issues: 37
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ccamel - strangelove-ventures/lens - ⚛️❤️👁 Brought to you by the LensCrafters (Go)
- awesome-cosmos - lens - CLI tool to interact with any Cosmos chain supporting the core Cosmos-SDK modules. (Tools / CLI)
README
# `lens`
## Inactive :
This repository is now inactive. It will be kept open (non-archived) but will no longer be actively developed by Strangelove.
**Lens provides a command line tool to interact with any cosmos chain supporting the core [Cosmos-SDK modules](https://github.com/cosmos/cosmos-sdk/tree/master/x).**
**Lens is meant to be imported as a library in other repos and projects to easily navigate and interact with the Cosmos Hub along with IBC chains.**
---
`lens` is your lens to view the Cosmos :atom:. `lens` packs all the best practices in golang cosmos client development into one place and provides a simple and easy to use APIs provided by standard Cosmos chains. The `cmd` package implements the `lens` command line tool while the `client` package contains all the building blocks to build your own, complex, feature rich, Cosmos client in go.
Intended use cases:
- Trading Bots
- Server side query integrations for alerting or other automation
- Indexers and search engines
- Transaction automation (`x/authz` for security) for farming applications
- ...:atom::rocket::moon:This is the start of ideas around how to implement the cosmos client libraries in a seperate repo.
## **--INSTALL--**
---
```bash
git clone https://github.com/strangelove-ventures/lens.gitcd lens
make install
```
Now run:
```bash
lens
```
You should see:```
❯ lens
This is my lens, there are many like it, but this one is mine.Usage:
lens [command]Available Commands:
chains manage local chain configurations
keys manage keys held by the relayer for each chain
query query things about a chain
tendermint all tendermint query commands
tx query things about a chain
help Help about any commandFlags:
--chain string override default chain
-d, --debug debug output
-h, --help help for lens
--home string set home directory (default "/Users/lenscrafters/.lens")Use "lens [command] --help" for more information about a command.
```## **--CONFIG--**
---
The config file describes how lens will interact with blockchains. This is where information such as grpc addresses and chain-ids are held.**Config File Location:** `~/.lens/config.yaml`
> NOTE: The config file is not created at install, it is created the first time lens needs to query your config. Just to get it created, you can run something like:
>```
>lens chains show-default
>```### **CHAINS**
Lens comes with two default chains. Cosmos Hub and Osmosis.To interact with other chains, you need to add them to your config. To do this, run:
```
lens chains add
#Example:
lens chains add juno
```To view all possible chain names, run:
```
lens chains registry-list
```
> NOTE: These two commands check the chain registry located [here](https://github.com/cosmos/chain-registry), for the requested chain.When running a command, it will run the command for the defaulted chain.
To view your default chain, run:
```
lens chains show-default
```To change your default, run:
```
lens chains set-default
```### **Keys**
Lens uses the keyring from the Cosmos-sdk. There is more information about it [here](https://github.com/cosmos/cosmos-sdk/blob/master/crypto/keyring/doc.go).To add a key to lens you have two options:
* `lens keys add` - This will add a key to you default chain and name it "default". You can optionally add a name as an argument.
* `lens keys restore ` - This will restore a key to your default chain. Replace '\' with a key name. This command will THEN ask for your mnemonic which is needed to restore and use it to boradcast transactions.>❗️ NOTE: IF you name your key anything other than "default", you will need to manually change the `key:` value in your config to link key with chain.
>```bash
>default_chain: cosmoshub
>chains:
> cosmoshub:
> key: default #CHANGE THIS NAME
> chain-id: cosmoshub-4
> rpc-addr: https://cosmoshub-4.technofractal.com:443
> ...
>```After generating or restoring a key, it should appear in your list by running: `lens keys list`, by default it will show the Cosmos Hub address.
To see the key encoded for use on other chains run `lens keys enumerate `.
## --EXAMPLES--
Find examples of using Lens as a Go module in our [Examples Repository](https://github.com/strangelove-ventures/lens-examples)