2019-01-17 19:53:03 +01:00
|
|
|
/*
|
2022-11-11 05:49:16 +01:00
|
|
|
* Copyright © 2019 Musing Studio LLC.
|
2019-01-17 19:53:03 +01:00
|
|
|
*
|
|
|
|
* This file is part of WriteFreely.
|
|
|
|
*
|
|
|
|
* WriteFreely is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License, included
|
|
|
|
* in the LICENSE file in this source code package.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package migrations
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
)
|
|
|
|
|
|
|
|
// TODO: use now() from writefreely pkg
|
|
|
|
func (db *datastore) now() string {
|
|
|
|
if db.driverName == driverSQLite {
|
|
|
|
return "strftime('%Y-%m-%d %H:%M:%S','now')"
|
|
|
|
}
|
|
|
|
return "NOW()"
|
|
|
|
}
|
|
|
|
|
|
|
|
func (db *datastore) typeInt() string {
|
|
|
|
if db.driverName == driverSQLite {
|
|
|
|
return "INTEGER"
|
|
|
|
}
|
|
|
|
return "INT"
|
|
|
|
}
|
|
|
|
|
|
|
|
func (db *datastore) typeSmallInt() string {
|
|
|
|
if db.driverName == driverSQLite {
|
|
|
|
return "INTEGER"
|
|
|
|
}
|
|
|
|
return "SMALLINT"
|
|
|
|
}
|
|
|
|
|
|
|
|
func (db *datastore) typeText() string {
|
|
|
|
return "TEXT"
|
|
|
|
}
|
|
|
|
|
|
|
|
func (db *datastore) typeChar(l int) string {
|
|
|
|
if db.driverName == driverSQLite {
|
|
|
|
return "TEXT"
|
|
|
|
}
|
|
|
|
return fmt.Sprintf("CHAR(%d)", l)
|
|
|
|
}
|
|
|
|
|
2019-04-11 19:56:07 +02:00
|
|
|
func (db *datastore) typeVarChar(l int) string {
|
|
|
|
if db.driverName == driverSQLite {
|
|
|
|
return "TEXT"
|
|
|
|
}
|
|
|
|
return fmt.Sprintf("VARCHAR(%d)", l)
|
|
|
|
}
|
|
|
|
|
2019-01-17 19:53:03 +01:00
|
|
|
func (db *datastore) typeBool() string {
|
|
|
|
if db.driverName == driverSQLite {
|
|
|
|
return "INTEGER"
|
|
|
|
}
|
|
|
|
return "TINYINT(1)"
|
|
|
|
}
|
|
|
|
|
|
|
|
func (db *datastore) typeDateTime() string {
|
|
|
|
return "DATETIME"
|
|
|
|
}
|
|
|
|
|
2019-04-11 19:56:07 +02:00
|
|
|
func (db *datastore) collateMultiByte() string {
|
|
|
|
if db.driverName == driverSQLite {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
return " COLLATE utf8_bin"
|
|
|
|
}
|
|
|
|
|
2019-01-17 19:53:03 +01:00
|
|
|
func (db *datastore) engine() string {
|
|
|
|
if db.driverName == driverSQLite {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
return " ENGINE = InnoDB"
|
|
|
|
}
|
2020-06-23 22:24:45 +02:00
|
|
|
|
|
|
|
func (db *datastore) after(colName string) string {
|
|
|
|
if db.driverName == driverSQLite {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
return " AFTER " + colName
|
|
|
|
}
|