mirror of
https://github.com/sot-tech/mochi.git
synced 2026-04-27 08:00:00 -07:00
Storage API matured, docs, tests & more
This commit is contained in:
@@ -7,6 +7,7 @@ package config
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"io"
|
||||
"os"
|
||||
"time"
|
||||
)
|
||||
@@ -26,11 +27,7 @@ func (d *Duration) UnmarshalJSON(b []byte) error {
|
||||
return err
|
||||
}
|
||||
|
||||
type Client struct {
|
||||
Name string `json:"name"`
|
||||
PeerID string `json:"peer_id"`
|
||||
}
|
||||
|
||||
// Storage represents the configuration for any storage.DS.
|
||||
type Storage struct {
|
||||
Driver string `json:"driver"`
|
||||
Network string `json:"network`
|
||||
@@ -41,11 +38,12 @@ type Storage struct {
|
||||
Encoding string `json:"encoding,omitempty"`
|
||||
Prefix string `json:"prefix,omitempty"`
|
||||
|
||||
ConnectTimeout *Duration `json:"conn_timeout,omitempty"`
|
||||
ReadTimeout *Duration `json:"read_timeout,omitempty"`
|
||||
WriteTimeout *Duration `json:"write_timeout,omitempty"`
|
||||
MaxIdleConn int `json:"max_idle_conn"`
|
||||
IdleTimeout *Duration `json:"idle_timeout"`
|
||||
ConnTimeout *Duration `json:"conn_timeout"`
|
||||
}
|
||||
|
||||
// Config represents a configuration for a server.Server.
|
||||
type Config struct {
|
||||
Addr string `json:"addr"`
|
||||
Storage Storage `json:"storage"`
|
||||
@@ -57,11 +55,11 @@ type Config struct {
|
||||
MinAnnounce Duration `json:"min_announce"`
|
||||
ReadTimeout Duration `json:"read_timeout"`
|
||||
DefaultNumWant int `json:"default_num_want"`
|
||||
|
||||
Whitelist []Client `json:"whitelist"`
|
||||
}
|
||||
|
||||
func New(path string) (*Config, error) {
|
||||
// Open is a shortcut to open a file, read it, and generate a Config.
|
||||
// It supports relative and absolute paths.
|
||||
func Open(path string) (*Config, error) {
|
||||
expandedPath := os.ExpandEnv(path)
|
||||
f, err := os.Open(expandedPath)
|
||||
if err != nil {
|
||||
@@ -69,29 +67,19 @@ func New(path string) (*Config, error) {
|
||||
}
|
||||
defer f.Close()
|
||||
|
||||
conf := &Config{}
|
||||
err = json.NewDecoder(f).Decode(conf)
|
||||
conf, err := New(f)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return conf, nil
|
||||
}
|
||||
|
||||
func (c *Config) ClientWhitelisted(peerID string) (matched bool) {
|
||||
for _, client := range c.Whitelist {
|
||||
length := len(client.PeerID)
|
||||
if length <= len(peerID) {
|
||||
matched = true
|
||||
for i := 0; i < length; i++ {
|
||||
if peerID[i] != client.PeerID[i] {
|
||||
matched = false
|
||||
break
|
||||
}
|
||||
}
|
||||
if matched {
|
||||
return true
|
||||
}
|
||||
}
|
||||
// New decodes JSON from a Reader into a Config.
|
||||
func New(raw io.Reader) (*Config, error) {
|
||||
conf := &Config{}
|
||||
err := json.NewDecoder(raw).Decode(conf)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return false
|
||||
return conf, nil
|
||||
}
|
||||
|
||||
42
config/config_test.go
Normal file
42
config/config_test.go
Normal file
@@ -0,0 +1,42 @@
|
||||
// Copyright 2013 The Chihaya Authors. All rights reserved.
|
||||
// Use of this source code is governed by the BSD 2-Clause license,
|
||||
// which can be found in the LICENSE file.
|
||||
|
||||
package config
|
||||
|
||||
import (
|
||||
"strings"
|
||||
"testing"
|
||||
)
|
||||
|
||||
var exampleConfig = `{
|
||||
|
||||
"network": "tcp",
|
||||
"addr": ":34000",
|
||||
"storage": {
|
||||
"driver": "redis",
|
||||
"addr": "127.0.0.1:6379",
|
||||
"user": "root",
|
||||
"pass": "",
|
||||
"prefix": "test:",
|
||||
|
||||
"max_idle_conn": 3,
|
||||
"idle_timeout": "240s",
|
||||
"conn_timeout": "5s"
|
||||
},
|
||||
|
||||
"private": true,
|
||||
"freeleech": false,
|
||||
|
||||
"announce": "30m",
|
||||
"min_announce": "15m",
|
||||
"read_timeout": "20s",
|
||||
"default_num_want": 50
|
||||
|
||||
}`
|
||||
|
||||
func TestNew(t *testing.T) {
|
||||
if _, err := New(strings.NewReader(exampleConfig)); err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user