mirror of
https://git.mirrors.martin98.com/https://github.com/SigNoz/signoz
synced 2025-06-04 11:25:52 +08:00

* chore(dashboard): intial commit * chore(dashboard): bring all the code in module * chore(dashboard): remove lock unlock from ee codebase * chore(dashboard): go deps * chore(dashboard): fix lint * chore(dashboard): implement the store * chore(dashboard): add migration * chore(dashboard): fix lint * chore(dashboard): api and frontend changes * chore(dashboard): frontend changes for new dashboards * chore(dashboard): fix test cases * chore(dashboard): add lock unlock APIs * chore(dashboard): add lock unlock APIs * chore(dashboard): move integrations controller out from module * chore(dashboard): move integrations controller out from module * chore(dashboard): move integrations controller out from module * chore(dashboard): rename migration file * chore(dashboard): surface errors for lock/unlock dashboard * chore(dashboard): some testing cleanups * chore(dashboard): fix postgres migrations --------- Co-authored-by: Vibhu Pandey <vibhupandey28@gmail.com>
142 lines
3.7 KiB
Go
142 lines
3.7 KiB
Go
package sqlmigration
|
|
|
|
import (
|
|
"context"
|
|
"database/sql"
|
|
|
|
"github.com/SigNoz/signoz/pkg/factory"
|
|
"github.com/SigNoz/signoz/pkg/sqlstore"
|
|
"github.com/SigNoz/signoz/pkg/types"
|
|
"github.com/SigNoz/signoz/pkg/valuer"
|
|
"github.com/uptrace/bun"
|
|
"github.com/uptrace/bun/migrate"
|
|
)
|
|
|
|
type updateDashboard struct {
|
|
store sqlstore.SQLStore
|
|
}
|
|
|
|
type existingDashboard36 struct {
|
|
bun.BaseModel `bun:"table:dashboards"`
|
|
|
|
types.TimeAuditable
|
|
types.UserAuditable
|
|
OrgID string `json:"-" bun:"org_id,notnull"`
|
|
ID int `json:"id" bun:"id,pk,autoincrement"`
|
|
UUID string `json:"uuid" bun:"uuid,type:text,notnull,unique"`
|
|
Data map[string]interface{} `json:"data" bun:"data,type:text,notnull"`
|
|
Locked *int `json:"isLocked" bun:"locked,notnull,default:0"`
|
|
}
|
|
|
|
type newDashboard36 struct {
|
|
bun.BaseModel `bun:"table:dashboard"`
|
|
|
|
types.Identifiable
|
|
types.TimeAuditable
|
|
types.UserAuditable
|
|
Data map[string]interface{} `bun:"data,type:text,notnull"`
|
|
Locked bool `bun:"locked,notnull,default:false"`
|
|
OrgID valuer.UUID `bun:"org_id,type:text,notnull"`
|
|
}
|
|
|
|
func NewUpdateDashboardFactory(store sqlstore.SQLStore) factory.ProviderFactory[SQLMigration, Config] {
|
|
return factory.NewProviderFactory(factory.MustNewName("update_dashboards"), func(ctx context.Context, ps factory.ProviderSettings, c Config) (SQLMigration, error) {
|
|
return newUpdateDashboard(ctx, ps, c, store)
|
|
})
|
|
}
|
|
|
|
func newUpdateDashboard(_ context.Context, _ factory.ProviderSettings, _ Config, store sqlstore.SQLStore) (SQLMigration, error) {
|
|
return &updateDashboard{store: store}, nil
|
|
}
|
|
|
|
func (migration *updateDashboard) Register(migrations *migrate.Migrations) error {
|
|
if err := migrations.Register(migration.Up, migration.Down); err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (migration *updateDashboard) Up(ctx context.Context, db *bun.DB) error {
|
|
tx, err := db.BeginTx(ctx, nil)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
defer func() {
|
|
_ = tx.Rollback()
|
|
}()
|
|
|
|
err = migration.store.Dialect().RenameTableAndModifyModel(ctx, tx, new(existingDashboard36), new(newDashboard36), []string{OrgReference}, func(ctx context.Context) error {
|
|
existingDashboards := make([]*existingDashboard36, 0)
|
|
err = tx.NewSelect().Model(&existingDashboards).Scan(ctx)
|
|
if err != nil {
|
|
if err != sql.ErrNoRows {
|
|
return err
|
|
}
|
|
}
|
|
|
|
if err == nil && len(existingDashboards) > 0 {
|
|
newDashboards, err := migration.CopyExistingDashboardsToNewDashboards(existingDashboards)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
_, err = tx.
|
|
NewInsert().
|
|
Model(&newDashboards).
|
|
Exec(ctx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
return nil
|
|
})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
err = tx.Commit()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
func (migration *updateDashboard) Down(context.Context, *bun.DB) error {
|
|
return nil
|
|
}
|
|
|
|
func (migration *updateDashboard) CopyExistingDashboardsToNewDashboards(existingDashboards []*existingDashboard36) ([]*newDashboard36, error) {
|
|
newDashboards := make([]*newDashboard36, len(existingDashboards))
|
|
|
|
for idx, existingDashboard := range existingDashboards {
|
|
dashboardID, err := valuer.NewUUID(existingDashboard.UUID)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
orgID, err := valuer.NewUUID(existingDashboard.OrgID)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
locked := false
|
|
if existingDashboard.Locked != nil && *existingDashboard.Locked == 1 {
|
|
locked = true
|
|
}
|
|
|
|
newDashboards[idx] = &newDashboard36{
|
|
Identifiable: types.Identifiable{
|
|
ID: dashboardID,
|
|
},
|
|
TimeAuditable: existingDashboard.TimeAuditable,
|
|
UserAuditable: existingDashboard.UserAuditable,
|
|
Data: existingDashboard.Data,
|
|
Locked: locked,
|
|
OrgID: orgID,
|
|
}
|
|
}
|
|
|
|
return newDashboards, nil
|
|
}
|