Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/benjaminch/make-my-life-easier
A couple scripts I use on a daily basis to make my life easier.
https://github.com/benjaminch/make-my-life-easier
go golang
Last synced: about 1 month ago
JSON representation
A couple scripts I use on a daily basis to make my life easier.
- Host: GitHub
- URL: https://github.com/benjaminch/make-my-life-easier
- Owner: benjaminch
- Created: 2016-11-17T13:21:58.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2019-11-13T14:07:18.000Z (about 5 years ago)
- Last Synced: 2024-10-27T05:47:48.224Z (3 months ago)
- Topics: go, golang
- Language: Go
- Size: 30.3 KB
- Stars: 0
- Watchers: 2
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
[![Go Report Card](https://goreportcard.com/badge/github.com/benjaminch/make-my-life-easier)](https://goreportcard.com/report/github.com/benjaminch/make-my-life-easier)
# make-my-life-easier
A couple scripts I use on a daily basis to make my life easier.
They are all ready to go command line tools :)## Installation
### Preliminary
- `go` needs to be installed, version 1.12 or above
### Pulling the code
- retrieve the code from the repo
-- go get github.com/benjaminch/make-my-life-easier
- or install the module + code
-- go install github.com/benjaminch/make-my-life-easier
### Launching the code
- run `go run mmle.go help`## Price encryption / decryption (Google Private Data specs)
### Usage examples
#### Help
```
go run mmle.go help
usage: mmle [] [ ...]Flags:
--help Show context-sensitive help (also try --help-long and --help-man).
-v, --verbose Verbose mode.Commands:
help [...]
Show help.price-encryption []
Encrypt a price using a given algorithm.price-decryption []
Decrypt a price using a given algorithm.hex-key-generator []
Generate a random hex key of the specified length (by default: 64)
```
#### Decrypt only
The command line below will try to decrypt the encrypted price passed in command line.
```
go run mmle.go price-decryption [YOUR_EKEY] [YOUR_IKEY] [ENCRYPTED_PRICE]
```
Details:
```
usage: mmle price-decryption []Decrypt a price using a given algorithm.
Flags:
--help Show context-sensitive help (also try --help-long and --help-man).
-v, --verbose Verbose mode.
--algorithm=google Name of the algorithm
--keystype=hexa Keys type
--keysb64 Keys are base 64.
--scale=1000000 Price scale factorArgs:
Encryption key
Integrity key
Price to decrypt
```
#### Encrypt only
The command line below will try to encrypt the clear price passed in command line.
```
go run mmle.go price-encryption [YOUR_EKEY] [YOUR_IKEY] [CLEAR_PRICE]
```
Details:
```
usage: mmle price-encryption []Encrypt a price using a given algorithm.
Flags:
--help Show context-sensitive help (also try --help-long and --help-man).
-v, --verbose Verbose mode.
--algorithm=google Name of the algorithm
--keystype=hexa Keys type
--keysb64 Keys are base 64.
--scale=1000000 Price scale factor
--seed="" SeedArgs:
Encryption key
Integrity key
Price to encrypt
```
### Verbose mode
The verbose mode describle the process step by steps.
```
go run mmle.go price-encryption [YOUR_EKEY] [YOUR_IKEY] [CLEAR_PRICE] --verbose
Verbose activated
Keys decoding mode : utf-8
Encryption key : 6356770B3C111C07F778AFD69F16643E9110090FD4C479D91181EED2523788F1
Encryption key (bytes) : [99 86 119 11 60 17 28 7 247 120 175 214 159 22 100 62 145 16 9 15 212 196 121 217 17 129 238 210 82 55 136 241]
Integrity key : 3588BF6D387E8AEAD4EEC66798255369AF47BFD48B056E8934CEFEF3609C469E
Integrity key (bytes) : [53 136 191 109 56 126 138 234 212 238 198 103 152 37 83 105 175 71 191 212 139 5 110 137 52 206 254 243 96 156 70 158]
ERROR: logging before flag.Parse: I0329 16:58:01.062251 19950 helpers.go:109] Micro price bytes: [0 0 0 0 0 22 90 168]
Seed :
Initialization vector : [212 29 140 217 143 0 178 4 233 128 9 152 236 248 66 126]
// pad = hmac(e_key, iv), first 8 bytes
Pad : [125 170 63 123 246 12 99 173]
// enc_data = pad data
Encoded price bytes : [125 170 63 123 246 26 57 5]
// signature = hmac(i_key, data || iv), first 4 bytes
Signature : [74 124 216 232]
Encrypted price: 1B2M2Y8AsgTpgAmY7PhCfn2qP3v2GjkFSnzY6A==
```## Hexa keys generation
### Usage examples
The command line below will generate an hexa key of the desired length (by default, 64 bytes).
```
go run mmle.go hex-key-generator
go run mmle.go hex-key-generator --keylength=32
```
Details:
```
usage: mmle hex-key-generator []Generate a random hex key of the specified length (by default: 64)
Flags:
--help Show context-sensitive help (also try --help-long and --help-man).
-v, --verbose Verbose mode.
--keylength=32 Key Length
```## Base64 to Base64 web safe and Base64 web safe to Base64
### Usage examples
TODO