migrate from model to store

This commit is contained in:
Asim Aslam
2021-12-10 20:37:14 +00:00
parent c28d9a8cc4
commit 50e3377f32
3 changed files with 150 additions and 318 deletions

View File

@@ -8,29 +8,34 @@ import (
"github.com/micro/micro/v3/service/errors"
log "github.com/micro/micro/v3/service/logger"
"github.com/micro/micro/v3/service/model"
"github.com/micro/micro/v3/service/store"
file "github.com/micro/services/file/proto"
"github.com/micro/services/pkg/tenant"
)
type File struct {
db model.Model
}
type File struct{}
func NewFile() *File {
i := model.ByEquality("project")
i.Order.Type = model.OrderTypeUnordered
f := &File{}
go f.Migrate()
return f
}
db := model.New(
file.Record{},
&model.Options{
Key: "Path",
Indexes: []model.Index{i},
},
)
func (e *File) Migrate() {
records, err := store.Read("file.Record:eqByProjectUnordByProject:", store.ReadPrefix())
if err != nil {
log.Errorf("failed to migrate: %v", err)
return
}
return &File{
db: db,
for _, rec := range records {
parts := strings.Split(rec.Key, ":")
if len(parts) != 4 {
continue
}
key := "file/" + parts[3]
log.Infof("Migrating %v to %v\n", rec.Key, key)
store.Write(&store.Record{Key: key, Value: rec.Value})
}
}
@@ -44,32 +49,21 @@ func (e *File) Delete(ctx context.Context, req *file.DeleteRequest, rsp *file.De
tenantId = "micro"
}
path := filepath.Join(tenantId, req.Project, req.Path)
project := tenantId + "/" + req.Project
path := filepath.Join("file", tenantId, req.Project, req.Path)
// delete one file
if !strings.HasSuffix(req.Path, "/") {
return e.db.Delete(model.QueryEquals("Path", path))
return store.Delete(path)
}
var files []*file.Record
// read all the files for the project
err := e.db.Read(model.QueryEquals("project", project), &files)
records, err := store.List(store.ListPrefix(path))
if err != nil {
return err
}
for _, file := range files {
// delete a list of files
if file.Project != project {
continue
}
if !strings.HasPrefix(file.Path, path) {
continue
}
// delete the file
e.db.Delete(model.QueryEquals("Path", file.Path))
for _, file := range records {
store.Delete(file)
}
return nil
@@ -87,31 +81,30 @@ func (e *File) Read(ctx context.Context, req *file.ReadRequest, rsp *file.ReadRe
tenantId = "micro"
}
var files []*file.Record
path := filepath.Join("file", tenantId, req.Project, req.Path)
project := tenantId + "/" + req.Project
var opts []store.ReadOption
// read all the files for the project
err := e.db.Read(model.QueryEquals("project", project), &files)
if strings.HasSuffix(req.Path, "/") {
opts = append(opts, store.ReadPrefix())
}
records, err := store.Read(path, opts...)
if err != nil {
return err
}
// filter the file
for _, file := range files {
// check project matches tenants
if file.Project != project {
for _, rec := range records {
file := new(file.Record)
if err := rec.Decode(file); err != nil {
continue
}
// strip the tenant id
file.Project = strings.TrimPrefix(file.Project, tenantId+"/")
file.Path = strings.TrimPrefix(file.Path, filepath.Join(tenantId, req.Project))
// check the path matches the request
if req.Path == file.Path {
rsp.File = file
}
}
return nil
@@ -123,11 +116,13 @@ func (e *File) Save(ctx context.Context, req *file.SaveRequest, rsp *file.SaveRe
tenantId = "micro"
}
if req.File == nil {
return errors.BadRequest("file.save", "missing file")
}
log.Info("Received File.Save request")
// prefix the tenant
req.File.Project = filepath.Join(tenantId, req.File.Project)
req.File.Path = filepath.Join(req.File.Project, req.File.Path)
path := filepath.Join("file", tenantId, req.File.Project, req.File.Path)
if len(req.File.Created) == 0 {
req.File.Created = time.Now().Format(time.RFC3339Nano)
@@ -137,35 +132,7 @@ func (e *File) Save(ctx context.Context, req *file.SaveRequest, rsp *file.SaveRe
req.File.Updated = time.Now().Format(time.RFC3339Nano)
// create the file
err := e.db.Create(req.File)
if err != nil {
return err
}
return nil
}
func (e *File) BatchSave(ctx context.Context, req *file.BatchSaveRequest, rsp *file.BatchSaveResponse) error {
tenantId, ok := tenant.FromContext(ctx)
if !ok {
tenantId = "micro"
}
log.Info("Received File.BatchSave request")
for _, reqFile := range req.Files {
// prefix the tenant
reqFile.Project = filepath.Join(tenantId, reqFile.Project)
reqFile.Path = filepath.Join(reqFile.Project, reqFile.Project)
// create the file
err := e.db.Create(reqFile)
if err != nil {
return err
}
}
return nil
return store.Write(store.NewRecord(path, req.File))
}
func (e *File) List(ctx context.Context, req *file.ListRequest, rsp *file.ListResponse) error {
@@ -177,20 +144,17 @@ func (e *File) List(ctx context.Context, req *file.ListRequest, rsp *file.ListRe
}
// prefix tenant id
project := tenantId + "/" + req.Project
path := filepath.Join("file", tenantId, req.Project, req.Path)
var files []*file.Record
// read all the files for the project
if err := e.db.Read(model.QueryEquals("project", project), &files); err != nil {
records, err := store.Read(path, store.ReadPrefix())
if err != nil {
return err
}
// @todo funnily while this is the archetypical
// query for the KV store interface, it's not supported by the model
// so we do client side filtering here
for _, file := range files {
if file.Project != project {
for _, rec := range records {
file := new(file.Record)
if err := rec.Decode(file); err != nil {
continue
}
@@ -202,14 +166,7 @@ func (e *File) List(ctx context.Context, req *file.ListRequest, rsp *file.ListRe
// no file listing ever contains it
file.Content = ""
// if requesting all files or path matches
if req.Path != "" {
if strings.HasPrefix(file.Path, req.Path) {
rsp.Files = append(rsp.Files, file)
}
} else {
rsp.Files = append(rsp.Files, file)
}
rsp.Files = append(rsp.Files, file)
}
return nil