https://github.com/multiformats/go-multihash
Multihash implementation in Go
https://github.com/multiformats/go-multihash
Last synced: 19 days ago
JSON representation
Multihash implementation in Go
- Host: GitHub
- URL: https://github.com/multiformats/go-multihash
- Owner: multiformats
- License: mit
- Created: 2014-05-23T03:06:46.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2025-04-15T00:41:34.000Z (19 days ago)
- Last Synced: 2025-04-15T01:30:37.593Z (19 days ago)
- Language: Go
- Homepage:
- Size: 281 KB
- Stars: 240
- Watchers: 24
- Forks: 59
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- go-awesome - go-multihash - Implementation of various hash algorithms (Open source library / Algorithm)
- my-awesome - multiformats/go-multihash - 04 star:0.2k fork:0.1k Multihash implementation in Go (Go)
README
# go-multihash
[](http://ipn.io)
[](https://github.com/multiformats/multiformats)
[](https://webchat.freenode.net/?channels=%23ipfs)
[](https://github.com/RichardLitt/standard-readme)
[](https://godoc.org/github.com/multiformats/go-multihash)
[](https://travis-ci.org/multiformats/go-multihash)
[](https://codecov.io/github/multiformats/go-multihash?branch=master)> [multihash](https://github.com/multiformats/multihash) implementation in Go
## Table of Contents
- [Install](#install)
- [Usage](#usage)
- [Maintainers](#maintainers)
- [Contribute](#contribute)
- [License](#license)## Install
`go-multihash` is a standard Go module which can be installed with:
```sh
go get github.com/multiformats/go-multihash
```## Usage
### Example
This example takes a standard hex-encoded data and uses `EncodeName` to calculate the SHA1 multihash value for the buffer.
The resulting hex-encoded data corresponds to: ``, which could be re-parsed
with `Multihash.FromHexString()`.```go
package mainimport (
"encoding/hex"
"fmt""github.com/multiformats/go-multihash"
)func main() {
// ignores errors for simplicity.
// don't do that at home.
// Decode a SHA1 hash to a binary buffer
buf, _ := hex.DecodeString("0beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33")// Create a new multihash with it.
mHashBuf, _ := multihash.EncodeName(buf, "sha1")
// Print the multihash as hex string
fmt.Printf("hex: %s\n", hex.EncodeToString(mHashBuf))// Parse the binary multihash to a DecodedMultihash
mHash, _ := multihash.Decode(mHashBuf)
// Convert the sha1 value to hex string
sha1hex := hex.EncodeToString(mHash.Digest)
// Print all the information in the multihash
fmt.Printf("obj: %v 0x%x %d %s\n", mHash.Name, mHash.Code, mHash.Length, sha1hex)
}
```To run, copy to [example/foo.go](example/foo.go) and:
```
> cd example/
> go build
> ./example
hex: 11140beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33
obj: sha1 0x11 20 0beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33
```## Contribute
Contributions welcome. Please check out [the issues](https://github.com/multiformats/go-multihash/issues).
Check out our [contributing document](https://github.com/multiformats/multiformats/blob/master/contributing.md) for more information on how we work, and about contributing in general. Please be aware that all interactions related to multiformats are subject to the IPFS [Code of Conduct](https://github.com/ipfs/community/blob/master/code-of-conduct.md).
Small note: If editing the README, please conform to the [standard-readme](https://github.com/RichardLitt/standard-readme) specification.
## License
[MIT](LICENSE) © 2014 Juan Batiz-Benet