Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vulpemventures/go-elements
Go support for Liquid/Elements transactions
https://github.com/vulpemventures/go-elements
Last synced: about 2 months ago
JSON representation
Go support for Liquid/Elements transactions
- Host: GitHub
- URL: https://github.com/vulpemventures/go-elements
- Owner: vulpemventures
- License: mit
- Created: 2020-04-24T15:37:31.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-10-18T11:30:51.000Z (3 months ago)
- Last Synced: 2024-10-19T11:58:37.190Z (3 months ago)
- Language: Go
- Homepage:
- Size: 1.03 MB
- Stars: 27
- Watchers: 7
- Forks: 13
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-liquid - go-elements
- awesome-liquid-network - go-elements - elements.svg?style=social) - Go support for Liquid transactions (Libraries)
- awesome-liquid-network - go-elements - elements.svg?style=social) - Go support for Liquid transactions (Libraries)
README
# go-elements
[![Go](https://github.com/vulpemventures/go-elements/actions/workflows/ci.yml/badge.svg)](https://github.com/vulpemventures/go-elements/actions/workflows/ci.yml)
[![PkgGoDev](https://pkg.go.dev/badge/github.com/vulpemventures/go-elements)](https://pkg.go.dev/github.com/vulpemventures/go-elements)
[![Release](https://img.shields.io/github/release/vulpemventures/go-elements.svg?style=flat-square)](https://github.com/vulpemventures/go-elements/releases/latest)
[![Go Report Card](https://goreportcard.com/badge/github.com/vulpemventures/go-elements)](https://goreportcard.com/report/github.com/vulpemventures/go-elements)
[![Bitcoin Donate](https://badgen.net/badge/Bitcoin/Donate/F7931A?icon=bitcoin)](https://blockstream.info/address/3MdERN32qiMnQ68bSSee5CXQkrSGx1iStr)Go support for confidential transactions on Elements-based blockchains
**The package is currently being developed.** For stable versions, you must refer to the [latest release](https://github.com/vulpemventures/go-elements/releases)
## Install
```sh
# Install latest tagged release
$ go get github.com/vulpemventures/go-elements@latest
```## 👀 Examples
- [Broadcast unblinded transaction](pset/pset_test.go#L82)
- [Broadcast blinded transaction - with unblinded input](pset/pset_test.go#L335)
- [Broadcast blinded transaction - with blinded input](pset/pset_test.go#L490)
- [Broadcast issuance transaction - with unblinded inputs, unblinded issuance, blinded outputs](pset/pset_test.go#L689)
- [Broadcast issuance transaction - with unblinded inputs, blinded issuance, blinded outputs](pset/pset_test.go#L867)## 🛣 Roadmap
- [x] Chain parameters (prefixes, magic numbers, …)
- [x] Pay to Public Key Hash
- [x] Pay to Script Hash
- [x] Pay to Witness Public Key Hash
- [x] Pay to Witness Script Hash
- [x] Tx serialization / deserialization
- [x] Use of confidential values instead of pure numbers
- [x] Fix order of witness in transaction serialization
- [x] Add confidential fields
- [x] Serialization for (witness) signature
- [x] [PSET / Bip174 for Elements](https://github.com/vulpemventures/go-elements/tree/master/pset)
- [x] [Blech32](https://github.com/vulpemventures/go-elements/tree/master/blech32)
- [x] [CGO bindings for secp256k1-zkp](https://github.com/vulpemventures/go-secp256k1-zkp)
- [x] Unblinding ins / Blinding outs / Blinding issuance ins
- [x] Signing a confidential input (use 0 value amounts to produce the hash for the signature)
- [x] Asset issuance
- [x] Asset re-issuance
- [x] Slip77
- [ ] Upcoming [PSET spec](https://github.com/ElementsProject/elements/pull/951) support## 🖥 Development
* Clone repository:
```sh
$ git clone https://github.com/vulpemventures/go-elements.git
```* Enter into the project folder and install dependencies:
```sh
$ cd go-elements
$ go get -t -v ./...
```* Run tests
> For running tests it is required to have a running [Nigiri](https://github.com/vulpemventures/nigiri) locally, or at least a remote one reachable from the outside.
To run the tests it is mandatory to export an `API_URL` environment variable pointing to the URL of `nigiri-chopsticks`.```
$ nigiri start --liquid
$ make test
```* More detailed documentation
```
$ godoc -http ":8080"
```> http://localhost:8080/pkg/github.com/vulpemventures/go-elements/
## 👷♂️ Contributors
- [@tiero](https://github.com/tiero)
- [@altafan](https://github.com/altafan)
- [@sekulicd](https://github.com/sekulicd)
- [@francismars](https://github.com/francismars)## License [MIT](https://github.com/vulpemventures/go-elements/blob/master/LICENSE)