2016-09-01 01:51:02 +09:00
|
|
|
{- This file is part of Vervis.
|
|
|
|
-
|
2018-03-04 06:33:59 +09:00
|
|
|
- Written in 2016, 2018 by fr33domlover <fr33domlover@riseup.net>.
|
2016-09-01 01:51:02 +09:00
|
|
|
-
|
|
|
|
- ♡ Copying is an act of love. Please copy, reuse and share.
|
|
|
|
-
|
|
|
|
- The author(s) have dedicated all copyright and related and neighboring
|
|
|
|
- rights to this software to the public domain worldwide. This software is
|
|
|
|
- distributed without any warranty.
|
|
|
|
-
|
|
|
|
- You should have received a copy of the CC0 Public Domain Dedication along
|
|
|
|
- with this software. If not, see
|
|
|
|
- <http://creativecommons.org/publicdomain/zero/1.0/>.
|
|
|
|
-}
|
|
|
|
|
|
|
|
module Vervis.Migration
|
|
|
|
( migrateDB
|
|
|
|
)
|
|
|
|
where
|
|
|
|
|
|
|
|
import Prelude
|
|
|
|
|
|
|
|
import Control.Monad.IO.Class (MonadIO)
|
|
|
|
import Control.Monad.Trans.Reader (ReaderT, runReaderT)
|
2018-03-04 06:33:59 +09:00
|
|
|
import Data.ByteString (ByteString)
|
2016-09-01 01:51:02 +09:00
|
|
|
import Data.Maybe (fromMaybe)
|
2018-02-27 12:03:24 +09:00
|
|
|
import Data.Proxy
|
|
|
|
import Data.Text (Text)
|
2016-09-01 01:51:02 +09:00
|
|
|
import Database.Persist
|
|
|
|
import Database.Persist.Sql (SqlBackend, toSqlKey)
|
|
|
|
|
|
|
|
import Database.Persist.Schema
|
|
|
|
import Database.Persist.Schema.PostgreSQL (schemaBackend)
|
2018-02-25 20:14:07 +09:00
|
|
|
import Database.Persist.Migration
|
2016-09-01 01:51:02 +09:00
|
|
|
|
|
|
|
import Vervis.Model
|
|
|
|
|
|
|
|
changes :: MonadIO m => [SchemaT SqlBackend m ()]
|
|
|
|
changes =
|
2016-09-02 02:40:02 +09:00
|
|
|
[ addField "Workflow"
|
|
|
|
(Just "'WSSharer'")
|
2018-02-27 12:03:24 +09:00
|
|
|
(Field
|
|
|
|
"scope"
|
|
|
|
(FTPrim $ backendDataType (Proxy :: Proxy Text))
|
|
|
|
FieldRequired
|
|
|
|
)
|
2018-03-04 06:33:59 +09:00
|
|
|
, changeFieldType "Person" "hash" $
|
|
|
|
backendDataType (Proxy :: Proxy ByteString)
|
|
|
|
, unsetFieldMaybe "Person" "email" "'no@email'"
|
|
|
|
, addField "Person" (Just "TRUE") Field
|
|
|
|
{ fieldName = "verified"
|
|
|
|
, fieldType = FTPrim $ backendDataType (Proxy :: Proxy Bool)
|
|
|
|
, fieldMaybe = FieldRequired
|
|
|
|
}
|
|
|
|
, addField "Person" (Just "''") Field
|
|
|
|
{ fieldName = "verifiedKey"
|
|
|
|
, fieldType = FTPrim $ backendDataType (Proxy :: Proxy Text)
|
|
|
|
, fieldMaybe = FieldRequired
|
|
|
|
}
|
|
|
|
, addField "Person" (Just "''") Field
|
|
|
|
{ fieldName = "resetPassphraseKey"
|
|
|
|
, fieldType = FTPrim $ backendDataType (Proxy :: Proxy Text)
|
|
|
|
, fieldMaybe = FieldRequired
|
|
|
|
}
|
|
|
|
, renameField "Person" "hash" "passphraseHash"
|
2016-09-01 01:51:02 +09:00
|
|
|
]
|
|
|
|
|
|
|
|
migrateDB :: MonadIO m => ReaderT SqlBackend m ()
|
|
|
|
migrateDB = runMigrations schemaBackend changes
|