mirror of
https://github.com/boringproxy/boringproxy.git
synced 2025-02-25 18:55:29 -06:00
182 lines
3.0 KiB
Go
182 lines
3.0 KiB
Go
package main
|
|
|
|
import (
|
|
"encoding/json"
|
|
"errors"
|
|
"io/ioutil"
|
|
"log"
|
|
"sync"
|
|
)
|
|
|
|
type Database struct {
|
|
Tokens map[string]TokenData `json:"tokens"`
|
|
Tunnels map[string]Tunnel `json:"tunnels"`
|
|
Users map[string]User `json:"users"`
|
|
mutex *sync.Mutex
|
|
}
|
|
|
|
type TokenData struct {
|
|
Id string `json:"id"`
|
|
}
|
|
|
|
type User struct {
|
|
IsAdmin bool `json:"is_admin"`
|
|
}
|
|
|
|
type Tunnel struct {
|
|
ServerAddress string `json:"server_address"`
|
|
ServerPort int `json:"server_port"`
|
|
ServerPublicKey string `json:"server_public_key"`
|
|
Username string `json:"username"`
|
|
TunnelPort int `json:"tunnel_port"`
|
|
TunnelPrivateKey string `json:"tunnel_private_key"`
|
|
ClientName string `json:"client_name"`
|
|
ClientPort int `json:"client_port"`
|
|
}
|
|
|
|
func NewDatabase() (*Database, error) {
|
|
|
|
dbJson, err := ioutil.ReadFile("boringproxy_db.json")
|
|
if err != nil {
|
|
log.Println("failed reading boringproxy_db.json")
|
|
dbJson = []byte("{}")
|
|
}
|
|
|
|
var db *Database
|
|
|
|
err = json.Unmarshal(dbJson, &db)
|
|
if err != nil {
|
|
log.Println(err)
|
|
db = &Database{}
|
|
}
|
|
|
|
if db.Tokens == nil {
|
|
db.Tokens = make(map[string]TokenData)
|
|
}
|
|
|
|
if db.Tunnels == nil {
|
|
db.Tunnels = make(map[string]Tunnel)
|
|
}
|
|
|
|
if db.Users == nil {
|
|
db.Users = make(map[string]User)
|
|
}
|
|
|
|
db.mutex = &sync.Mutex{}
|
|
|
|
db.mutex.Lock()
|
|
defer db.mutex.Unlock()
|
|
db.persist()
|
|
|
|
return db, nil
|
|
}
|
|
|
|
func (d *Database) GetTokenData(token string) (TokenData, bool) {
|
|
d.mutex.Lock()
|
|
defer d.mutex.Unlock()
|
|
|
|
tokenData, exists := d.Tokens[token]
|
|
|
|
if !exists {
|
|
return TokenData{}, false
|
|
}
|
|
|
|
return tokenData, true
|
|
}
|
|
|
|
func (d *Database) SetTokenData(token string, tokenData TokenData) {
|
|
d.mutex.Lock()
|
|
defer d.mutex.Unlock()
|
|
|
|
d.Tokens[token] = tokenData
|
|
d.persist()
|
|
}
|
|
|
|
func (d *Database) GetTunnels() map[string]Tunnel {
|
|
d.mutex.Lock()
|
|
defer d.mutex.Unlock()
|
|
|
|
tunnels := make(map[string]Tunnel)
|
|
|
|
for k, v := range d.Tunnels {
|
|
tunnels[k] = v
|
|
}
|
|
|
|
return tunnels
|
|
}
|
|
|
|
func (d *Database) GetTunnel(domain string) (Tunnel, bool) {
|
|
d.mutex.Lock()
|
|
defer d.mutex.Unlock()
|
|
|
|
tun, exists := d.Tunnels[domain]
|
|
|
|
if !exists {
|
|
return Tunnel{}, false
|
|
}
|
|
|
|
return tun, true
|
|
}
|
|
|
|
func (d *Database) SetTunnel(domain string, tun Tunnel) {
|
|
d.mutex.Lock()
|
|
defer d.mutex.Unlock()
|
|
|
|
d.Tunnels[domain] = tun
|
|
d.persist()
|
|
}
|
|
|
|
func (d *Database) DeleteTunnel(domain string) {
|
|
d.mutex.Lock()
|
|
defer d.mutex.Unlock()
|
|
|
|
delete(d.Tunnels, domain)
|
|
|
|
d.persist()
|
|
}
|
|
|
|
func (d *Database) GetUsers() map[string]User {
|
|
d.mutex.Lock()
|
|
defer d.mutex.Unlock()
|
|
|
|
users := make(map[string]User)
|
|
|
|
for k, v := range d.Users {
|
|
users[k] = v
|
|
}
|
|
|
|
return users
|
|
}
|
|
|
|
func (d *Database) AddUser(username string, isAdmin bool) error {
|
|
d.mutex.Lock()
|
|
defer d.mutex.Unlock()
|
|
|
|
_, exists := d.Users[username]
|
|
|
|
if exists {
|
|
return errors.New("User exists")
|
|
}
|
|
|
|
d.Users[username] = User{
|
|
isAdmin,
|
|
}
|
|
|
|
d.persist()
|
|
|
|
return nil
|
|
}
|
|
|
|
func (d *Database) DeleteUser(username string) {
|
|
d.mutex.Lock()
|
|
defer d.mutex.Unlock()
|
|
|
|
delete(d.Users, username)
|
|
|
|
d.persist()
|
|
}
|
|
|
|
func (d *Database) persist() {
|
|
saveJson(d, "boringproxy_db.json")
|
|
}
|