2023-01-17 09:44:21 +01:00
|
|
|
package app
|
|
|
|
|
|
|
|
import (
|
2023-01-22 15:30:27 +01:00
|
|
|
"encoding/json"
|
|
|
|
"math"
|
2023-01-17 09:44:21 +01:00
|
|
|
|
|
|
|
"github.com/wailsapp/wails/v2/pkg/runtime"
|
|
|
|
"go.mongodb.org/mongo-driver/bson"
|
2023-01-22 15:30:27 +01:00
|
|
|
"go.mongodb.org/mongo-driver/mongo"
|
2023-01-17 20:49:07 +01:00
|
|
|
"go.mongodb.org/mongo-driver/mongo/options"
|
2023-01-17 09:44:21 +01:00
|
|
|
)
|
|
|
|
|
2023-06-23 17:22:47 +02:00
|
|
|
type GetIndexesResult struct {
|
|
|
|
Indexes []bson.M `json:"indexes"`
|
|
|
|
Error string `json:"error"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a *App) GetIndexes(hostKey, dbKey, collKey string) (result GetIndexesResult) {
|
2023-01-17 09:44:21 +01:00
|
|
|
client, ctx, close, err := a.connectToHost(hostKey)
|
|
|
|
if err != nil {
|
2023-06-23 17:22:47 +02:00
|
|
|
return
|
2023-01-17 09:44:21 +01:00
|
|
|
}
|
|
|
|
defer close()
|
|
|
|
|
|
|
|
cur, err := client.Database(dbKey).Collection(collKey).Indexes().List(ctx)
|
|
|
|
if err != nil {
|
2023-06-24 20:27:48 +02:00
|
|
|
runtime.LogWarningf(a.ctx, "Encountered an error while creating index cursor: %s", err.Error())
|
2023-06-23 17:22:47 +02:00
|
|
|
result.Error = err.Error()
|
|
|
|
return
|
2023-01-17 09:44:21 +01:00
|
|
|
}
|
|
|
|
|
2023-06-23 17:22:47 +02:00
|
|
|
err = cur.All(ctx, &result.Indexes)
|
2023-01-17 09:44:21 +01:00
|
|
|
if err != nil {
|
2023-06-24 20:27:48 +02:00
|
|
|
runtime.LogWarningf(a.ctx, "Encountered an error while executing index cursor: %s", err.Error())
|
2023-06-23 17:22:47 +02:00
|
|
|
result.Error = err.Error()
|
2023-01-17 09:44:21 +01:00
|
|
|
}
|
|
|
|
|
2023-06-23 17:22:47 +02:00
|
|
|
return
|
2023-01-17 09:44:21 +01:00
|
|
|
}
|
2023-01-17 20:49:07 +01:00
|
|
|
|
2023-01-22 15:30:27 +01:00
|
|
|
func (a *App) CreateIndex(hostKey, dbKey, collKey, jsonData string) string {
|
|
|
|
client, ctx, close, err := a.connectToHost(hostKey)
|
|
|
|
if err != nil {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
defer close()
|
|
|
|
|
|
|
|
type modelItem struct {
|
|
|
|
Key string `json:"key"`
|
|
|
|
Sort interface{} `json:"sort"`
|
|
|
|
}
|
|
|
|
|
|
|
|
var form struct {
|
|
|
|
Name string `json:"name"`
|
|
|
|
Background bool `json:"background"`
|
|
|
|
Unique bool `json:"unique"`
|
|
|
|
DropDuplicates bool `json:"dropDuplicates"`
|
|
|
|
Sparse bool `json:"sparse"`
|
|
|
|
Model []modelItem `json:"model"`
|
|
|
|
}
|
|
|
|
|
|
|
|
err = json.Unmarshal([]byte(jsonData), &form)
|
|
|
|
if err != nil {
|
2023-06-24 20:27:48 +02:00
|
|
|
runtime.LogErrorf(a.ctx, "Could not parse index JSON: %s", err.Error())
|
|
|
|
runtime.MessageDialog(a.ctx, runtime.MessageDialogOptions{
|
|
|
|
Title: "Malformed JSON",
|
|
|
|
Message: err.Error(),
|
|
|
|
Type: runtime.ErrorDialog,
|
|
|
|
})
|
2023-01-22 15:30:27 +01:00
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
if form.Model == nil {
|
|
|
|
form.Model = make([]modelItem, 0)
|
|
|
|
}
|
|
|
|
|
|
|
|
var keys bson.D
|
|
|
|
for _, v := range form.Model {
|
|
|
|
asFloat, canBeFloat := v.Sort.(float64)
|
|
|
|
if canBeFloat {
|
|
|
|
v.Sort = int8(math.Floor(asFloat))
|
|
|
|
}
|
|
|
|
|
|
|
|
keys = append(keys, bson.E{
|
|
|
|
Key: v.Key,
|
|
|
|
Value: v.Sort,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
indexModel := mongo.IndexModel{
|
|
|
|
Keys: keys,
|
|
|
|
Options: options.Index().SetUnique(form.Unique).SetSparse(form.Sparse),
|
|
|
|
}
|
|
|
|
|
|
|
|
name, err := client.Database(dbKey).Collection(collKey).Indexes().CreateOne(ctx, indexModel)
|
|
|
|
if err != nil {
|
2023-06-24 20:27:48 +02:00
|
|
|
runtime.LogWarningf(a.ctx, "Encountered an error while creating index: %s", err.Error())
|
|
|
|
runtime.MessageDialog(a.ctx, runtime.MessageDialogOptions{
|
|
|
|
Title: "Error creating index",
|
|
|
|
Message: err.Error(),
|
|
|
|
Type: runtime.ErrorDialog,
|
|
|
|
})
|
2023-01-22 15:30:27 +01:00
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
return name
|
|
|
|
}
|
|
|
|
|
2023-01-17 20:49:07 +01:00
|
|
|
func (a *App) DropIndex(hostKey, dbKey, collKey, indexName string) bool {
|
|
|
|
client, ctx, close, err := a.connectToHost(hostKey)
|
|
|
|
if err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
defer close()
|
|
|
|
|
|
|
|
_, err = client.Database(dbKey).Collection(collKey).Indexes().DropOne(ctx, indexName, &options.DropIndexesOptions{})
|
|
|
|
if err != nil {
|
2023-06-24 20:27:48 +02:00
|
|
|
runtime.LogErrorf(a.ctx, "Encountered an error while creating index drop cursor: %s", err.Error())
|
|
|
|
runtime.MessageDialog(a.ctx, runtime.MessageDialogOptions{
|
|
|
|
Title: "Error creating drop cursor",
|
|
|
|
Message: err.Error(),
|
|
|
|
Type: runtime.ErrorDialog,
|
|
|
|
})
|
2023-01-17 20:49:07 +01:00
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
return true
|
|
|
|
}
|