2016-03-17 00:23:41 +03:00
|
|
|
package registry
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"compress/zlib"
|
|
|
|
"encoding/hex"
|
|
|
|
"encoding/json"
|
|
|
|
"io/ioutil"
|
|
|
|
)
|
|
|
|
|
|
|
|
func encode(buf []byte) string {
|
|
|
|
var b bytes.Buffer
|
|
|
|
defer b.Reset()
|
|
|
|
|
|
|
|
w := zlib.NewWriter(&b)
|
|
|
|
if _, err := w.Write(buf); err != nil {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
w.Close()
|
|
|
|
|
|
|
|
return hex.EncodeToString(b.Bytes())
|
|
|
|
}
|
|
|
|
|
|
|
|
func decode(d string) []byte {
|
|
|
|
hr, err := hex.DecodeString(d)
|
|
|
|
if err != nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
br := bytes.NewReader(hr)
|
|
|
|
zr, err := zlib.NewReader(br)
|
|
|
|
if err != nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
rbuf, err := ioutil.ReadAll(zr)
|
|
|
|
if err != nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
return rbuf
|
|
|
|
}
|
|
|
|
|
|
|
|
func encodeEndpoints(en []*Endpoint) []string {
|
|
|
|
var tags []string
|
|
|
|
for _, e := range en {
|
|
|
|
if b, err := json.Marshal(e); err == nil {
|
2016-03-29 19:44:46 +03:00
|
|
|
// old encoding
|
|
|
|
// TODO: remove in 09/2016
|
|
|
|
tags = append(tags, "e="+string(b))
|
|
|
|
// new encoding
|
2016-03-17 00:23:41 +03:00
|
|
|
tags = append(tags, "e-"+encode(b))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return tags
|
|
|
|
}
|
|
|
|
|
|
|
|
func decodeEndpoints(tags []string) []*Endpoint {
|
|
|
|
var en []*Endpoint
|
2016-03-29 20:32:16 +03:00
|
|
|
|
|
|
|
// use the first format you find
|
|
|
|
var ver byte
|
|
|
|
|
2016-03-17 00:23:41 +03:00
|
|
|
for _, tag := range tags {
|
|
|
|
if len(tag) == 0 || tag[0] != 'e' {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
2016-03-29 20:32:16 +03:00
|
|
|
// check version
|
|
|
|
if ver > 0 && tag[1] != ver {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
2016-03-17 00:23:41 +03:00
|
|
|
var e *Endpoint
|
|
|
|
var buf []byte
|
|
|
|
|
|
|
|
// Old encoding was plain
|
|
|
|
if tag[1] == '=' {
|
|
|
|
buf = []byte(tag[2:])
|
|
|
|
}
|
|
|
|
|
|
|
|
// New encoding is hex
|
|
|
|
if tag[1] == '-' {
|
|
|
|
buf = decode(tag[2:])
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := json.Unmarshal(buf, &e); err == nil {
|
|
|
|
en = append(en, e)
|
|
|
|
}
|
2016-03-29 20:32:16 +03:00
|
|
|
|
|
|
|
// set version
|
|
|
|
ver = tag[1]
|
2016-03-17 00:23:41 +03:00
|
|
|
}
|
|
|
|
return en
|
|
|
|
}
|
|
|
|
|
|
|
|
func encodeMetadata(md map[string]string) []string {
|
|
|
|
var tags []string
|
|
|
|
for k, v := range md {
|
|
|
|
if b, err := json.Marshal(map[string]string{
|
|
|
|
k: v,
|
|
|
|
}); err == nil {
|
2016-03-29 19:44:46 +03:00
|
|
|
// old encoding
|
|
|
|
// TODO: remove in 09/2016
|
|
|
|
tags = append(tags, "t="+string(b))
|
|
|
|
// new encoding
|
2016-03-17 00:23:41 +03:00
|
|
|
tags = append(tags, "t-"+encode(b))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return tags
|
|
|
|
}
|
|
|
|
|
|
|
|
func decodeMetadata(tags []string) map[string]string {
|
|
|
|
md := make(map[string]string)
|
2016-03-29 20:32:16 +03:00
|
|
|
|
|
|
|
var ver byte
|
|
|
|
|
2016-03-17 00:23:41 +03:00
|
|
|
for _, tag := range tags {
|
|
|
|
if len(tag) == 0 || tag[0] != 't' {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
2016-03-29 20:32:16 +03:00
|
|
|
// check version
|
|
|
|
if ver > 0 && tag[1] != ver {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
2016-03-17 00:23:41 +03:00
|
|
|
var kv map[string]string
|
|
|
|
var buf []byte
|
|
|
|
|
|
|
|
// Old encoding was plain
|
|
|
|
if tag[1] == '=' {
|
|
|
|
buf = []byte(tag[2:])
|
|
|
|
}
|
|
|
|
|
|
|
|
// New encoding is hex
|
|
|
|
if tag[1] == '-' {
|
|
|
|
buf = decode(tag[2:])
|
|
|
|
}
|
|
|
|
|
|
|
|
// Now unmarshal
|
|
|
|
if err := json.Unmarshal(buf, &kv); err == nil {
|
|
|
|
for k, v := range kv {
|
|
|
|
md[k] = v
|
|
|
|
}
|
|
|
|
}
|
2016-03-29 20:32:16 +03:00
|
|
|
|
|
|
|
// set version
|
|
|
|
ver = tag[1]
|
2016-03-17 00:23:41 +03:00
|
|
|
}
|
|
|
|
return md
|
|
|
|
}
|
|
|
|
|
2016-03-29 19:44:46 +03:00
|
|
|
func encodeVersion(v string) []string {
|
|
|
|
return []string{
|
|
|
|
// old encoding,
|
|
|
|
// TODO: remove in 09/2016
|
|
|
|
"v=" + v,
|
|
|
|
// new encoding,
|
|
|
|
"v-" + encode([]byte(v)),
|
|
|
|
}
|
2016-03-17 00:23:41 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
func decodeVersion(tags []string) (string, bool) {
|
|
|
|
for _, tag := range tags {
|
|
|
|
if len(tag) < 2 || tag[0] != 'v' {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
// Old encoding was plain
|
|
|
|
if tag[1] == '=' {
|
|
|
|
return tag[2:], true
|
|
|
|
}
|
|
|
|
|
|
|
|
// New encoding is hex
|
|
|
|
if tag[1] == '-' {
|
|
|
|
return string(decode(tag[2:])), true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return "", false
|
|
|
|
}
|