surrealpatch/db/info.go

262 lines
5.2 KiB
Go
Raw Normal View History

2016-09-19 10:08:44 +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 db
import (
"context"
2019-01-31 10:03:50 +00:00
"github.com/abcum/surreal/cnf"
2016-09-19 10:08:44 +00:00
"github.com/abcum/surreal/sql"
"github.com/abcum/surreal/util/data"
)
2017-11-16 20:53:39 +00:00
func (e *executor) executeInfo(ctx context.Context, ast *sql.InfoStatement) (out []interface{}, err error) {
2016-09-19 10:08:44 +00:00
switch ast.Kind {
2018-10-24 10:24:24 +00:00
case sql.ALL:
return e.executeInfoKV(ctx, ast)
case sql.NAMESPACE, sql.NS:
2017-11-16 20:53:39 +00:00
return e.executeInfoNS(ctx, ast)
2018-10-24 10:24:24 +00:00
case sql.DATABASE, sql.DB:
2017-11-16 20:53:39 +00:00
return e.executeInfoDB(ctx, ast)
2018-09-13 14:23:17 +00:00
case sql.SCOPE:
return e.executeInfoSC(ctx, ast)
case sql.TABLE:
2017-11-16 20:53:39 +00:00
return e.executeInfoTB(ctx, ast)
}
2016-10-18 13:27:17 +00:00
return
}
2018-10-24 10:24:24 +00:00
func (e *executor) executeInfoKV(ctx context.Context, ast *sql.InfoStatement) (out []interface{}, err error) {
2019-01-31 10:03:50 +00:00
if err := e.access(ctx, cnf.AuthKV); err != nil {
return nil, err
}
2019-11-20 13:20:27 +00:00
ns, err := e.tx.AllNS(ctx)
2018-10-24 10:24:24 +00:00
if err != nil {
return nil, err
}
res := data.New()
nspac := make(map[string]interface{})
for _, v := range ns {
nspac[v.Name.VA] = v.String()
}
res.Set(nspac, "namespace")
return []interface{}{res.Data()}, nil
}
2017-11-16 20:53:39 +00:00
func (e *executor) executeInfoNS(ctx context.Context, ast *sql.InfoStatement) (out []interface{}, err error) {
2019-01-31 10:03:50 +00:00
if err := e.access(ctx, cnf.AuthNS); err != nil {
return nil, err
}
2019-11-20 13:20:27 +00:00
db, err := e.tx.AllDB(ctx, e.ns)
if err != nil {
return nil, err
}
2016-09-19 10:08:44 +00:00
2019-11-20 13:20:27 +00:00
nt, err := e.tx.AllNT(ctx, e.ns)
if err != nil {
return nil, err
}
2019-11-20 13:20:27 +00:00
nu, err := e.tx.AllNU(ctx, e.ns)
if err != nil {
return nil, err
}
res := data.New()
dbase := make(map[string]interface{})
for _, v := range db {
dbase[v.Name.VA] = v.String()
}
2016-09-20 23:36:37 +00:00
token := make(map[string]interface{})
for _, v := range nt {
token[v.Name.VA] = v.String()
}
2016-09-19 10:08:44 +00:00
login := make(map[string]interface{})
for _, v := range nu {
login[v.User.VA] = v.String()
}
2016-09-19 10:08:44 +00:00
res.Set(dbase, "database")
res.Set(token, "token")
res.Set(login, "login")
2017-11-16 20:53:39 +00:00
return []interface{}{res.Data()}, nil
2016-09-19 10:08:44 +00:00
}
2017-11-16 20:53:39 +00:00
func (e *executor) executeInfoDB(ctx context.Context, ast *sql.InfoStatement) (out []interface{}, err error) {
2019-01-31 10:03:50 +00:00
if err := e.access(ctx, cnf.AuthDB); err != nil {
return nil, err
}
2019-11-20 13:20:27 +00:00
tb, err := e.tx.AllTB(ctx, e.ns, e.db)
if err != nil {
return nil, err
}
2019-11-20 13:20:27 +00:00
dt, err := e.tx.AllDT(ctx, e.ns, e.db)
if err != nil {
return nil, err
}
2016-09-19 10:08:44 +00:00
2019-11-20 13:20:27 +00:00
du, err := e.tx.AllDU(ctx, e.ns, e.db)
2017-11-16 20:53:39 +00:00
if err != nil {
return nil, err
}
2019-11-20 13:20:27 +00:00
sc, err := e.tx.AllSC(ctx, e.ns, e.db)
if err != nil {
return nil, err
}
res := data.New()
table := make(map[string]interface{})
for _, v := range tb {
table[v.Name.VA] = v.String()
}
token := make(map[string]interface{})
for _, v := range dt {
token[v.Name.VA] = v.String()
}
login := make(map[string]interface{})
for _, v := range du {
login[v.User.VA] = v.String()
}
scope := make(map[string]interface{})
2017-11-16 20:53:39 +00:00
for _, v := range sc {
scope[v.Name.VA] = v.String()
2017-11-16 20:53:39 +00:00
}
res.Set(table, "table")
res.Set(token, "token")
res.Set(login, "login")
res.Set(scope, "scope")
2017-11-16 20:53:39 +00:00
return []interface{}{res.Data()}, nil
}
2018-09-13 14:23:17 +00:00
func (e *executor) executeInfoSC(ctx context.Context, ast *sql.InfoStatement) (out []interface{}, err error) {
2019-01-31 10:03:50 +00:00
if err := e.access(ctx, cnf.AuthDB); err != nil {
return nil, err
}
2019-11-20 13:20:27 +00:00
st, err := e.tx.AllST(ctx, e.ns, e.db, ast.What.VA)
2018-09-13 14:23:17 +00:00
if err != nil {
return nil, err
}
res := data.New()
token := make(map[string]interface{})
for _, v := range st {
token[v.Name.VA] = v.String()
}
res.Set(token, "token")
return []interface{}{res.Data()}, nil
}
2017-11-16 20:53:39 +00:00
func (e *executor) executeInfoTB(ctx context.Context, ast *sql.InfoStatement) (out []interface{}, err error) {
2019-01-31 10:03:50 +00:00
if err := e.access(ctx, cnf.AuthDB); err != nil {
return nil, err
}
2019-11-20 13:20:27 +00:00
ev, err := e.tx.AllEV(ctx, e.ns, e.db, ast.What.VA)
if err != nil {
return nil, err
}
2016-09-19 10:08:44 +00:00
2019-11-20 13:20:27 +00:00
fd, err := e.tx.AllFD(ctx, e.ns, e.db, ast.What.VA)
if err != nil {
return nil, err
}
2016-09-19 10:08:44 +00:00
2019-11-20 13:20:27 +00:00
ix, err := e.tx.AllIX(ctx, e.ns, e.db, ast.What.VA)
if err != nil {
return nil, err
2016-09-19 10:08:44 +00:00
}
2019-11-20 13:20:27 +00:00
ft, err := e.tx.AllFT(ctx, e.ns, e.db, ast.What.VA)
if err != nil {
return nil, err
}
lv, err := e.tx.AllLV(ctx, e.ns, e.db, ast.What.VA)
if err != nil {
return nil, err
}
res := data.New()
event := make(map[string]interface{})
2017-11-16 20:53:39 +00:00
for _, v := range ev {
event[v.Name.VA] = v.String()
}
field := make(map[string]interface{})
for _, v := range fd {
field[v.Name.VA] = v.String()
2017-11-16 20:53:39 +00:00
}
index := make(map[string]interface{})
2017-11-16 20:53:39 +00:00
for _, v := range ix {
index[v.Name.VA] = v.String()
}
table := make(map[string]interface{})
for _, v := range ft {
table[v.Name.VA] = v.String()
}
2019-11-20 13:20:27 +00:00
lives := make(map[string]interface{})
for _, v := range lv {
lives[v.ID] = v.String()
}
res.Set(event, "event")
res.Set(field, "field")
res.Set(index, "index")
res.Set(table, "table")
2019-11-20 13:20:27 +00:00
res.Set(lives, "lives")
2017-11-16 20:53:39 +00:00
return []interface{}{res.Data()}, nil
2016-09-19 10:08:44 +00:00
}