surrealpatch/cnf/cnf.go

146 lines
3.3 KiB
Go
Raw Normal View History

2016-02-26 17:25:32 +00:00
// Copyright © 2016 Abcum Ltd
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package cnf
import (
"net"
"time"
)
var Settings *Options
type Kind int
func (k Kind) String() string {
switch k {
default:
return "NO"
case AuthKV:
return "KV"
case AuthNS:
return "NS"
case AuthDB:
return "DB"
case AuthSC:
return "SC"
}
}
func (k Kind) MarshalText() (data []byte, err error) {
return []byte(k.String()), err
}
func (k Kind) UnmarshalText(text []byte) error {
return nil
}
const (
// Root access
AuthKV Kind = iota
// Namespace access
AuthNS
// Database access
AuthDB
// Scoped user access
AuthSC
// No access
AuthNO
)
type Auth struct {
Kind Kind
Data interface{}
Scope string
Possible struct {
NS string
DB string
}
Selected struct {
NS string
DB string
}
}
2016-04-08 17:55:15 +00:00
// Options defines global configuration options
type Options struct {
2016-04-08 17:55:15 +00:00
DB struct {
2017-02-20 16:16:19 +00:00
Key []byte // Data encryption key
2017-02-22 01:40:54 +00:00
Code string // Data encryption key string
2017-02-20 16:16:19 +00:00
Path string // Path to store the data file
Type string // HTTP scheme type to use
2017-02-20 16:16:19 +00:00
Host string // Surreal host to connect to
Port string // Surreal port to connect to
Base string // Base key to use in KV stores
Time time.Duration // Timeframe for syncing data
Cert struct {
CA string
Crt string
Key string
SSL bool
}
2016-04-08 17:55:15 +00:00
}
2016-02-27 12:04:53 +00:00
2016-07-04 10:33:07 +00:00
Port struct {
Web int // Web port as an number
Tcp int // Tcp port as an number
}
Conn struct {
Web string // Web port as a string
Tcp string // Tcp port as a string
}
2016-04-08 17:55:15 +00:00
Cert struct {
2016-07-04 10:33:07 +00:00
Crt string // File location of server crt
Key string // File location of server key
2016-04-08 17:55:15 +00:00
}
2016-02-27 12:04:53 +00:00
2016-04-08 17:55:15 +00:00
Auth struct {
2017-02-22 01:40:54 +00:00
Auth string // Master authentication user:pass
User string // Master authentication username
Pass string // Master authentication password
Addr []string // Allowed ip ranges for authentication
Nets []*net.IPNet // Allowed cidr ranges for authentication
2016-04-08 17:55:15 +00:00
}
2016-02-26 17:25:32 +00:00
2016-04-08 17:55:15 +00:00
Node struct {
Host string // Node hostname
Name string // Name of this node
UUID string // UUID of this node
2017-02-20 16:16:19 +00:00
Join []string // Slice of cluster peers to join
2016-04-08 17:55:15 +00:00
}
Format struct {
Type string // Stores the cli output format
}
2016-04-08 17:55:15 +00:00
Logging struct {
Level string // Stores the configured logging level
Output string // Stores the configured logging output
Format string // Stores the configured logging format
Google struct {
Name string // Stores the GCE logging name
Project string // Stores the GCE logging project
Credentials string // Store the path to the credentials file
}
Syslog struct {
Tag string // Stores the syslog tag name
Host string // Stores the syslog remote host:port
Protocol string // Stores the syslog protocol to use
Priority string // Stores the syslog logging priority
}
2016-04-08 17:55:15 +00:00
}
2016-02-26 17:25:32 +00:00
}