2023-05-24 12:16:03 +09:00
|
|
|
package core
|
|
|
|
|
|
|
|
|
|
import (
|
2023-05-28 22:13:10 +09:00
|
|
|
"bytes"
|
2023-06-05 11:56:34 +09:00
|
|
|
"crypto/md5"
|
2023-05-28 22:13:10 +09:00
|
|
|
"encoding/binary"
|
|
|
|
|
"encoding/hex"
|
2023-05-24 12:16:03 +09:00
|
|
|
"encoding/json"
|
|
|
|
|
"errors"
|
|
|
|
|
"fmt"
|
|
|
|
|
"io"
|
|
|
|
|
"net/http"
|
2023-05-28 22:13:10 +09:00
|
|
|
"os"
|
|
|
|
|
"path"
|
|
|
|
|
"strconv"
|
2023-05-24 12:16:03 +09:00
|
|
|
"strings"
|
|
|
|
|
"sync/atomic"
|
|
|
|
|
"time"
|
|
|
|
|
"unsafe"
|
|
|
|
|
|
2023-06-29 21:21:49 +09:00
|
|
|
"repositories.action2quare.com/ayo/gocommon"
|
2023-05-24 15:31:01 +09:00
|
|
|
"repositories.action2quare.com/ayo/gocommon/logger"
|
2023-05-24 12:16:03 +09:00
|
|
|
|
|
|
|
|
"go.mongodb.org/mongo-driver/bson"
|
|
|
|
|
"go.mongodb.org/mongo-driver/bson/primitive"
|
|
|
|
|
"go.mongodb.org/mongo-driver/mongo/options"
|
|
|
|
|
)
|
|
|
|
|
|
2023-06-27 18:51:00 +09:00
|
|
|
type FileDocumentDesc struct {
|
2023-06-07 13:57:37 +09:00
|
|
|
Key string `bson:"key" json:"key"`
|
|
|
|
|
Src string `bson:"src" json:"src"`
|
|
|
|
|
Link string `bson:"link" json:"link"`
|
|
|
|
|
Desc string `bson:"desc" json:"desc"`
|
|
|
|
|
Extract bool `bson:"extract" json:"extract"`
|
|
|
|
|
Timestamp int64 `bson:"timestamp" json:"timestamp"`
|
|
|
|
|
Contents []byte `bson:"contents,omitempty" json:"contents,omitempty"`
|
2023-05-28 22:13:10 +09:00
|
|
|
}
|
|
|
|
|
|
2023-06-27 19:13:10 +09:00
|
|
|
func (fd *FileDocumentDesc) Save() error {
|
2023-05-28 22:13:10 +09:00
|
|
|
// 새 파일 올라옴
|
|
|
|
|
if len(fd.Contents) == 0 {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var destFile string
|
|
|
|
|
if fd.Extract {
|
|
|
|
|
os.MkdirAll(fd.Link, os.ModePerm)
|
|
|
|
|
destFile = path.Join(fd.Link, fd.Src)
|
|
|
|
|
} else {
|
|
|
|
|
os.MkdirAll(path.Dir(fd.Link), os.ModePerm)
|
|
|
|
|
destFile = fd.Link
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
f, err := os.Create(destFile)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
defer f.Close()
|
|
|
|
|
|
|
|
|
|
_, err = io.Copy(f, bytes.NewBuffer(fd.Contents))
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if fd.Extract {
|
|
|
|
|
switch path.Ext(destFile) {
|
|
|
|
|
case ".zip":
|
2023-06-29 21:21:49 +09:00
|
|
|
err = gocommon.Unzip(destFile)
|
2023-05-28 22:13:10 +09:00
|
|
|
case ".tar":
|
2023-06-29 21:21:49 +09:00
|
|
|
err = gocommon.Untar(destFile)
|
2023-05-28 22:13:10 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-19 21:19:45 +09:00
|
|
|
func (caller apiCaller) filesAPI(w http.ResponseWriter, r *http.Request) error {
|
|
|
|
|
if r.Method == "GET" {
|
2023-06-20 11:07:53 +09:00
|
|
|
allfiles, err := caller.mg.mongoClient.All(CollectionFile, options.Find().SetProjection(bson.M{
|
2023-06-05 11:56:34 +09:00
|
|
|
"contents": 0,
|
2023-06-20 11:07:53 +09:00
|
|
|
}).SetReturnKey(false))
|
2023-06-05 11:56:34 +09:00
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2023-05-28 22:13:10 +09:00
|
|
|
|
2023-06-20 11:07:53 +09:00
|
|
|
if len(allfiles) > 0 {
|
2023-06-05 11:56:34 +09:00
|
|
|
enc := json.NewEncoder(w)
|
2023-06-20 11:07:53 +09:00
|
|
|
return enc.Encode(allfiles)
|
2023-06-05 11:56:34 +09:00
|
|
|
}
|
|
|
|
|
} else if r.Method == "DELETE" {
|
|
|
|
|
key := r.FormValue("key")
|
2023-06-20 11:07:53 +09:00
|
|
|
if len(key) == 0 {
|
2023-06-05 11:56:34 +09:00
|
|
|
w.WriteHeader(http.StatusBadRequest)
|
|
|
|
|
return nil
|
|
|
|
|
}
|
2023-05-28 22:13:10 +09:00
|
|
|
|
2023-06-05 11:56:34 +09:00
|
|
|
_, err := caller.mg.mongoClient.Delete(CollectionFile, bson.M{
|
2023-06-20 11:07:53 +09:00
|
|
|
"key": key,
|
2023-06-05 11:56:34 +09:00
|
|
|
})
|
2023-05-28 22:13:10 +09:00
|
|
|
|
2023-06-05 11:56:34 +09:00
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2023-05-28 22:13:10 +09:00
|
|
|
}
|
|
|
|
|
|
2023-06-05 11:56:34 +09:00
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var seq = uint32(0)
|
|
|
|
|
|
|
|
|
|
func (caller apiCaller) uploadAPI(w http.ResponseWriter, r *http.Request) error {
|
|
|
|
|
if r.Method == "PUT" {
|
|
|
|
|
hasher := md5.New()
|
2023-08-21 11:01:21 +09:00
|
|
|
hasher.Write(caller.mg.service().serviceCodeBytes)
|
2023-06-05 11:56:34 +09:00
|
|
|
subfolder := hex.EncodeToString(hasher.Sum(nil))[:8]
|
|
|
|
|
|
|
|
|
|
infile, header, err := r.FormFile("file")
|
|
|
|
|
if err != nil {
|
|
|
|
|
w.WriteHeader(http.StatusBadRequest)
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
defer infile.Close()
|
|
|
|
|
|
|
|
|
|
desc := r.FormValue("desc")
|
|
|
|
|
contents, _ := io.ReadAll(infile)
|
|
|
|
|
extractstr := r.FormValue("extract")
|
|
|
|
|
extract, _ := strconv.ParseBool(extractstr)
|
|
|
|
|
|
|
|
|
|
var b [5]byte
|
|
|
|
|
binary.BigEndian.PutUint32(b[0:4], uint32(time.Now().Unix()))
|
|
|
|
|
b[4] = byte(atomic.AddUint32(&seq, 1) % 255)
|
|
|
|
|
rf := hex.EncodeToString(b[1:])
|
|
|
|
|
newidstr := subfolder + rf
|
|
|
|
|
newidbt, _ := hex.DecodeString(newidstr)
|
|
|
|
|
newidobj := primitive.NewObjectID()
|
|
|
|
|
copy(newidobj[:], newidbt[:8])
|
|
|
|
|
|
|
|
|
|
var link string
|
|
|
|
|
if extract {
|
|
|
|
|
link = path.Join("static", subfolder, rf)
|
|
|
|
|
} else {
|
|
|
|
|
link = path.Join("static", subfolder, rf, header.Filename)
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-27 18:51:00 +09:00
|
|
|
newdoc := FileDocumentDesc{
|
2023-06-05 11:56:34 +09:00
|
|
|
Contents: contents,
|
|
|
|
|
Src: header.Filename,
|
|
|
|
|
Timestamp: time.Now().UTC().Unix(),
|
|
|
|
|
Extract: extract,
|
|
|
|
|
Link: link,
|
|
|
|
|
Desc: desc,
|
|
|
|
|
Key: rf,
|
|
|
|
|
}
|
|
|
|
|
_, _, err = caller.mg.mongoClient.UpsertOne(CollectionFile, bson.M{
|
2023-08-21 11:01:21 +09:00
|
|
|
"_id": newidobj,
|
|
|
|
|
"key": rf,
|
2023-06-05 11:56:34 +09:00
|
|
|
}, newdoc)
|
|
|
|
|
|
|
|
|
|
if err == nil {
|
|
|
|
|
newdoc.Contents = nil
|
|
|
|
|
enc := json.NewEncoder(w)
|
|
|
|
|
enc.Encode(newdoc)
|
|
|
|
|
}
|
|
|
|
|
return err
|
2023-05-28 22:13:10 +09:00
|
|
|
}
|
2023-06-05 11:56:34 +09:00
|
|
|
return nil
|
2023-05-24 15:31:01 +09:00
|
|
|
}
|
|
|
|
|
|
2023-08-22 10:16:09 +09:00
|
|
|
func (caller apiCaller) blockAPI(w http.ResponseWriter, r *http.Request) error {
|
2023-05-24 12:16:03 +09:00
|
|
|
mg := caller.mg
|
|
|
|
|
if r.Method == "GET" {
|
2023-08-22 10:16:09 +09:00
|
|
|
enc := json.NewEncoder(w)
|
|
|
|
|
enc.Encode(mg.bl.all())
|
|
|
|
|
} else if r.Method == "PUT" {
|
|
|
|
|
body, _ := io.ReadAll(r.Body)
|
|
|
|
|
var bi blockinfo
|
|
|
|
|
if err := json.Unmarshal(body, &bi); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_, _, err := mg.mongoClient.Update(CollectionBlock, bson.M{
|
|
|
|
|
"_id": primitive.NewObjectID(),
|
|
|
|
|
}, bson.M{
|
|
|
|
|
"$set": &bi,
|
|
|
|
|
}, options.Update().SetUpsert(true))
|
2023-05-24 12:16:03 +09:00
|
|
|
|
2023-06-20 15:49:50 +09:00
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2023-08-22 10:16:09 +09:00
|
|
|
} else if r.Method == "DELETE" {
|
|
|
|
|
id := r.URL.Query().Get("id")
|
2023-05-24 12:16:03 +09:00
|
|
|
|
2023-08-22 10:16:09 +09:00
|
|
|
if len(id) == 0 {
|
|
|
|
|
return errors.New("id param is missing")
|
|
|
|
|
}
|
|
|
|
|
idobj, err := primitive.ObjectIDFromHex(id)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
2023-05-24 12:16:03 +09:00
|
|
|
}
|
2023-08-22 10:16:09 +09:00
|
|
|
|
|
|
|
|
_, _, err = mg.mongoClient.Update(CollectionBlock, bson.M{
|
|
|
|
|
"_id": idobj,
|
|
|
|
|
}, bson.M{
|
|
|
|
|
"$currentDate": bson.M{
|
|
|
|
|
"_ts": bson.M{"$type": "date"},
|
|
|
|
|
},
|
|
|
|
|
}, options.Update().SetUpsert(false))
|
|
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
mg.mongoClient.Delete(CollectionAuth, bson.M{"_id": idobj})
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (caller apiCaller) whitelistAPI(w http.ResponseWriter, r *http.Request) error {
|
|
|
|
|
mg := caller.mg
|
|
|
|
|
if r.Method == "GET" {
|
|
|
|
|
enc := json.NewEncoder(w)
|
|
|
|
|
enc.Encode(mg.wl.all())
|
2023-05-24 12:16:03 +09:00
|
|
|
} else if r.Method == "PUT" {
|
|
|
|
|
body, _ := io.ReadAll(r.Body)
|
|
|
|
|
var member whitelistmember
|
|
|
|
|
if err := json.Unmarshal(body, &member); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2023-08-22 10:16:09 +09:00
|
|
|
member.ExpiredAt = 0
|
2023-05-24 12:16:03 +09:00
|
|
|
|
|
|
|
|
_, _, err := mg.mongoClient.Update(CollectionWhitelist, bson.M{
|
|
|
|
|
"_id": primitive.NewObjectID(),
|
|
|
|
|
}, bson.M{
|
|
|
|
|
"$set": &member,
|
|
|
|
|
}, options.Update().SetUpsert(true))
|
|
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
} else if r.Method == "DELETE" {
|
2023-07-10 18:12:43 +09:00
|
|
|
id := r.URL.Query().Get("id")
|
|
|
|
|
|
2023-05-24 12:16:03 +09:00
|
|
|
if len(id) == 0 {
|
|
|
|
|
return errors.New("id param is missing")
|
|
|
|
|
}
|
|
|
|
|
idobj, err := primitive.ObjectIDFromHex(id)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_, _, err = mg.mongoClient.Update(CollectionWhitelist, bson.M{
|
|
|
|
|
"_id": idobj,
|
|
|
|
|
}, bson.M{
|
|
|
|
|
"$currentDate": bson.M{
|
|
|
|
|
"_ts": bson.M{"$type": "date"},
|
|
|
|
|
},
|
|
|
|
|
}, options.Update().SetUpsert(false))
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (caller apiCaller) serviceAPI(w http.ResponseWriter, r *http.Request) error {
|
|
|
|
|
mg := caller.mg
|
|
|
|
|
if r.Method == "GET" {
|
2023-06-20 11:07:53 +09:00
|
|
|
if mg.service().Id.IsZero() {
|
|
|
|
|
newService := serviceDescription{
|
|
|
|
|
ServiceDescriptionSummary: ServiceDescriptionSummary{
|
|
|
|
|
Id: primitive.NewObjectID(),
|
|
|
|
|
},
|
2023-05-24 12:16:03 +09:00
|
|
|
}
|
2023-06-20 11:07:53 +09:00
|
|
|
if err := newService.prepare(caller.mg); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
atomic.StorePointer(&mg.serviceptr, unsafe.Pointer(&newService))
|
2023-05-24 12:16:03 +09:00
|
|
|
}
|
2023-06-20 11:07:53 +09:00
|
|
|
|
2023-08-16 21:44:19 +09:00
|
|
|
w.Write(mg.service().divisionsSerialized)
|
2023-05-24 12:16:03 +09:00
|
|
|
} else if r.Method == "POST" {
|
|
|
|
|
body, _ := io.ReadAll(r.Body)
|
|
|
|
|
var service serviceDescription
|
|
|
|
|
if err := json.Unmarshal(body, &service); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-21 18:14:44 +09:00
|
|
|
if len(service.ServerApiTokens) == 0 {
|
|
|
|
|
service.ServerApiTokens = []primitive.ObjectID{
|
|
|
|
|
primitive.NewObjectIDFromTimestamp(time.Now().Add(-time.Hour * 24 * 30 * 465)),
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-24 12:16:03 +09:00
|
|
|
filter := bson.M{"_id": service.Id}
|
|
|
|
|
success, _, err := mg.mongoClient.Update(CollectionService, filter, bson.M{
|
|
|
|
|
"$set": &service,
|
|
|
|
|
}, options.Update().SetUpsert(true))
|
|
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if !success {
|
|
|
|
|
logger.Println("serviceAPI failed. not vaild user :", caller.userinfo)
|
|
|
|
|
w.WriteHeader(http.StatusBadRequest)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-05 11:56:34 +09:00
|
|
|
func (caller apiCaller) maintenanceAPI(w http.ResponseWriter, r *http.Request) error {
|
|
|
|
|
mg := caller.mg
|
|
|
|
|
if r.Method == "GET" {
|
2023-08-16 21:44:19 +09:00
|
|
|
w.Write(mg.service().divisionsSerialized)
|
2023-06-05 11:56:34 +09:00
|
|
|
} else if r.Method == "POST" {
|
2023-06-05 18:01:09 +09:00
|
|
|
var divs map[string]*Division
|
2023-06-05 11:56:34 +09:00
|
|
|
dec := json.NewDecoder(r.Body)
|
|
|
|
|
if err := dec.Decode(&divs); err != nil {
|
|
|
|
|
w.WriteHeader(http.StatusBadRequest)
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_, _, err := mg.mongoClient.Update(CollectionService, bson.M{
|
2023-06-21 18:14:44 +09:00
|
|
|
"_id": mg.service().Id,
|
2023-06-05 11:56:34 +09:00
|
|
|
}, bson.M{
|
|
|
|
|
"$set": bson.M{"divisions": divs},
|
|
|
|
|
}, options.Update().SetUpsert(false))
|
|
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
w.WriteHeader(http.StatusInternalServerError)
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-24 12:16:03 +09:00
|
|
|
var errApiTokenMissing = errors.New("mg-x-api-token is missing")
|
|
|
|
|
|
|
|
|
|
func (caller apiCaller) configAPI(w http.ResponseWriter, r *http.Request) error {
|
|
|
|
|
mg := caller.mg
|
|
|
|
|
|
2023-06-23 17:58:41 +09:00
|
|
|
if !*devflag {
|
|
|
|
|
apitoken := r.Header.Get("MG-X-API-TOKEN")
|
|
|
|
|
if len(apitoken) == 0 {
|
|
|
|
|
return errApiTokenMissing
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
apitokenObj, _ := primitive.ObjectIDFromHex(apitoken)
|
|
|
|
|
if !mg.service().isValidToken(apitokenObj) {
|
|
|
|
|
return fmt.Errorf("mg-x-api-token is not valid : %s", apitoken)
|
|
|
|
|
}
|
2023-05-24 12:16:03 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type apiCaller struct {
|
2023-06-19 21:19:45 +09:00
|
|
|
userinfo map[string]any
|
|
|
|
|
globalAdmins map[string]bool
|
|
|
|
|
mg *Maingate
|
|
|
|
|
apiToken primitive.ObjectID
|
2023-05-24 12:16:03 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (mg *Maingate) api(w http.ResponseWriter, r *http.Request) {
|
|
|
|
|
defer func() {
|
|
|
|
|
s := recover()
|
|
|
|
|
if s != nil {
|
|
|
|
|
logger.Error(s)
|
|
|
|
|
}
|
|
|
|
|
}()
|
|
|
|
|
|
|
|
|
|
defer func() {
|
|
|
|
|
io.Copy(io.Discard, r.Body)
|
|
|
|
|
r.Body.Close()
|
|
|
|
|
}()
|
|
|
|
|
|
|
|
|
|
var userinfo map[string]any
|
|
|
|
|
|
2023-06-23 17:58:41 +09:00
|
|
|
if !*devflag {
|
2023-05-24 12:16:03 +09:00
|
|
|
authheader := r.Header.Get("Authorization")
|
|
|
|
|
if len(authheader) == 0 {
|
|
|
|
|
logger.Println("Authorization header is not valid :", authheader)
|
|
|
|
|
w.WriteHeader(http.StatusBadRequest)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req, _ := http.NewRequest("GET", "https://graph.microsoft.com/oidc/userinfo", nil)
|
|
|
|
|
req.Header.Add("Authorization", authheader)
|
|
|
|
|
client := &http.Client{}
|
|
|
|
|
|
|
|
|
|
resp, err := client.Do(req)
|
|
|
|
|
if err != nil {
|
|
|
|
|
logger.Println("graph microsoft api call failed :", err)
|
|
|
|
|
w.WriteHeader(http.StatusBadRequest)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
defer resp.Body.Close()
|
|
|
|
|
|
|
|
|
|
raw, _ := io.ReadAll(resp.Body)
|
|
|
|
|
if err = json.Unmarshal(raw, &userinfo); err != nil {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if _, expired := userinfo["error"]; expired {
|
|
|
|
|
w.WriteHeader(http.StatusUnauthorized)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ptr := atomic.LoadPointer(&mg.admins)
|
|
|
|
|
adminsptr := (*globalAdmins)(ptr)
|
|
|
|
|
|
2023-06-29 21:21:49 +09:00
|
|
|
if adminsptr.modtime != gocommon.ConfigModTime() {
|
2023-05-24 12:16:03 +09:00
|
|
|
var config globalAdmins
|
2023-06-29 21:21:49 +09:00
|
|
|
if err := gocommon.LoadConfig(&config); err == nil {
|
2023-05-24 12:16:03 +09:00
|
|
|
config.parse()
|
|
|
|
|
adminsptr = &config
|
|
|
|
|
atomic.StorePointer(&mg.admins, unsafe.Pointer(adminsptr))
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-19 21:19:45 +09:00
|
|
|
var apiTokenObj primitive.ObjectID
|
2023-06-23 17:58:41 +09:00
|
|
|
if !*devflag {
|
|
|
|
|
apiToken := r.Header.Get("MG-X-API-TOKEN")
|
|
|
|
|
if len(apiToken) > 0 {
|
|
|
|
|
obj, err := primitive.ObjectIDFromHex(apiToken)
|
|
|
|
|
if err != nil {
|
|
|
|
|
logger.Error(err)
|
|
|
|
|
w.WriteHeader(http.StatusBadRequest)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
apiTokenObj = obj
|
2023-06-19 21:19:45 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-24 12:16:03 +09:00
|
|
|
logger.Println("api call :", r.URL.Path, r.Method, r.URL.Query(), userinfo)
|
|
|
|
|
caller := apiCaller{
|
2023-06-19 21:19:45 +09:00
|
|
|
userinfo: userinfo,
|
|
|
|
|
globalAdmins: adminsptr.emails,
|
|
|
|
|
mg: mg,
|
|
|
|
|
apiToken: apiTokenObj,
|
2023-05-24 12:16:03 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var err error
|
|
|
|
|
if strings.HasSuffix(r.URL.Path, "/service") {
|
|
|
|
|
err = caller.serviceAPI(w, r)
|
|
|
|
|
} else if strings.HasSuffix(r.URL.Path, "/whitelist") {
|
|
|
|
|
err = caller.whitelistAPI(w, r)
|
|
|
|
|
} else if strings.HasSuffix(r.URL.Path, "/config") {
|
|
|
|
|
err = caller.configAPI(w, r)
|
2023-05-24 15:31:01 +09:00
|
|
|
} else if strings.HasSuffix(r.URL.Path, "/upload") {
|
|
|
|
|
err = caller.uploadAPI(w, r)
|
2023-06-05 11:56:34 +09:00
|
|
|
} else if strings.HasSuffix(r.URL.Path, "/maintenance") {
|
|
|
|
|
err = caller.maintenanceAPI(w, r)
|
2023-05-28 22:13:10 +09:00
|
|
|
} else if strings.HasSuffix(r.URL.Path, "/files") {
|
|
|
|
|
err = caller.filesAPI(w, r)
|
2023-08-22 10:16:09 +09:00
|
|
|
} else if strings.HasSuffix(r.URL.Path, "/block") {
|
|
|
|
|
err = caller.blockAPI(w, r)
|
2023-05-24 12:16:03 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
logger.Error(err)
|
|
|
|
|
}
|
|
|
|
|
}
|