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

* fix: support multitenancy in org * fix: register and login working now * fix: changes to migration * fix: migrations run both on sqlite and postgres * fix: remove user flags from fe and be * fix: remove ingestion keys from update * fix: multitenancy support for apdex settings * fix: render ts for users correctly * fix: fix migration to run for new tenants * fix: clean up migrations * fix: address comments * Update pkg/sqlmigration/013_update_organization.go Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com> * fix: fix build * fix: force invites with org id * Update pkg/query-service/auth/auth.go Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com> * fix: address comments * fix: address comments * fix: provier with their own dialect * fix: update dialects * fix: remove unwanted change * Update pkg/query-service/app/http_handler.go Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com> * fix: different files for types --------- Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com>
115 lines
2.6 KiB
Go
115 lines
2.6 KiB
Go
package sqlmigration
|
|
|
|
import (
|
|
"context"
|
|
"database/sql"
|
|
"errors"
|
|
|
|
"github.com/uptrace/bun"
|
|
"github.com/uptrace/bun/dialect"
|
|
"github.com/uptrace/bun/migrate"
|
|
"go.signoz.io/signoz/pkg/factory"
|
|
)
|
|
|
|
// SQLMigration is the interface for a single migration.
|
|
type SQLMigration interface {
|
|
// Register registers the migration with the given migrations. Each migration needs to be registered
|
|
//in a dedicated `*.go` file so that the correct migration semantics can be detected.
|
|
Register(*migrate.Migrations) error
|
|
// Up runs the migration.
|
|
Up(context.Context, *bun.DB) error
|
|
// Down rolls back the migration.
|
|
Down(context.Context, *bun.DB) error
|
|
}
|
|
|
|
var (
|
|
ErrNoExecute = errors.New("no execute")
|
|
)
|
|
|
|
func New(
|
|
ctx context.Context,
|
|
settings factory.ProviderSettings,
|
|
config Config,
|
|
factories factory.NamedMap[factory.ProviderFactory[SQLMigration, Config]],
|
|
) (*migrate.Migrations, error) {
|
|
migrations := migrate.NewMigrations()
|
|
|
|
for _, factory := range factories.GetInOrder() {
|
|
migration, err := factory.New(ctx, settings, config)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
err = migration.Register(migrations)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
|
|
return migrations, nil
|
|
}
|
|
|
|
func MustNew(
|
|
ctx context.Context,
|
|
settings factory.ProviderSettings,
|
|
config Config,
|
|
factories factory.NamedMap[factory.ProviderFactory[SQLMigration, Config]],
|
|
) *migrate.Migrations {
|
|
migrations, err := New(ctx, settings, config, factories)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
return migrations
|
|
}
|
|
|
|
func WrapIfNotExists(ctx context.Context, db *bun.DB, table string, column string) func(q *bun.AddColumnQuery) *bun.AddColumnQuery {
|
|
return func(q *bun.AddColumnQuery) *bun.AddColumnQuery {
|
|
if db.Dialect().Name() != dialect.SQLite {
|
|
return q.IfNotExists()
|
|
}
|
|
|
|
var result string
|
|
err := db.
|
|
NewSelect().
|
|
ColumnExpr("name").
|
|
Table("pragma_table_info").
|
|
Where("arg = ?", table).
|
|
Where("name = ?", column).
|
|
Scan(ctx, &result)
|
|
if err != nil {
|
|
if err == sql.ErrNoRows {
|
|
return q
|
|
}
|
|
return q.Err(err)
|
|
}
|
|
|
|
return q.Err(ErrNoExecute)
|
|
}
|
|
}
|
|
|
|
func GetColumnType(ctx context.Context, bun bun.IDB, table string, column string) (string, error) {
|
|
var columnType string
|
|
var err error
|
|
|
|
if bun.Dialect().Name() == dialect.SQLite {
|
|
err = bun.NewSelect().
|
|
ColumnExpr("type").
|
|
TableExpr("pragma_table_info(?)", table).
|
|
Where("name = ?", column).
|
|
Scan(ctx, &columnType)
|
|
} else {
|
|
err = bun.NewSelect().
|
|
ColumnExpr("data_type").
|
|
TableExpr("information_schema.columns").
|
|
Where("table_name = ?", table).
|
|
Where("column_name = ?", column).
|
|
Scan(ctx, &columnType)
|
|
}
|
|
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
return columnType, nil
|
|
}
|