A clean, Markdown-based publishing platform made for writers. Write together, and build a community. https://writefreely.org
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

37 lines
851 B

  1. package migrations
  2. import (
  3. "context"
  4. "database/sql"
  5. wf_db "github.com/writeas/writefreely/db"
  6. )
  7. func oauthAttach(db *datastore) error {
  8. dialect := wf_db.DialectMySQL
  9. if db.driverName == driverSQLite {
  10. dialect = wf_db.DialectSQLite
  11. }
  12. return wf_db.RunTransactionWithOptions(context.Background(), db.DB, &sql.TxOptions{}, func(ctx context.Context, tx *sql.Tx) error {
  13. builders := []wf_db.SQLBuilder{
  14. dialect.
  15. AlterTable("oauth_client_states").
  16. AddColumn(dialect.
  17. Column(
  18. "attach_user_id",
  19. wf_db.ColumnTypeInteger,
  20. wf_db.OptionalInt{Set: true, Value: 24}).SetNullable(false).SetDefault("0")),
  21. }
  22. for _, builder := range builders {
  23. query, err := builder.ToSQL()
  24. if err != nil {
  25. return err
  26. }
  27. if _, err := tx.ExecContext(ctx, query); err != nil {
  28. return err
  29. }
  30. }
  31. return nil
  32. })
  33. }