Emmanuel BENOîT
e50775ec76
* The main loader script has been updated to generate the list of files it needs to load automatically. As a consequence, files that contained manually-maintained lists of scripts have been removed, and definition directories have been renamed accordingly. * PostgreSQL extension loading and configuration has been moved to a separate script to be loaded automatically in the main transaction. * Data and function definition scripts that had the -data or -functions suffix have been renamed (the suffix is unnecessary). * Unit tests have been reorganised to follow the definition's structure. * Documentation has been improved
85 lines
No EOL
2.7 KiB
SQL
85 lines
No EOL
2.7 KiB
SQL
-- LegacyWorlds Beta 6
|
|
-- PostgreSQL database scripts
|
|
--
|
|
-- General account view
|
|
--
|
|
-- Copyright(C) 2004-2010, DeepClone Development
|
|
-- --------------------------------------------------------
|
|
|
|
--
|
|
-- General account view
|
|
--
|
|
-- Allows most account-related data to be loooked up, and computes account statuses.
|
|
--
|
|
|
|
CREATE VIEW users.accounts_view
|
|
AS SELECT addr.id AS id , addr.address AS address , lang.language AS language ,
|
|
cred.pass_md5 AS pass_md5 , cred.pass_sha1 AS pass_sha1 , cred.credits AS game_credits ,
|
|
( CASE ( ban.account_id IS NULL )
|
|
WHEN TRUE THEN
|
|
( CASE ( iacc.credentials_id IS NULL )
|
|
WHEN TRUE THEN
|
|
( CASE ( aacc.credentials_id IS NULL )
|
|
WHEN TRUE THEN
|
|
'UNCONFIRMED'
|
|
ELSE
|
|
( CASE ( vac.status IS NULL )
|
|
WHEN TRUE THEN
|
|
'ACTIVE'
|
|
ELSE
|
|
( CASE vac.status
|
|
WHEN 'PROCESSED' THEN
|
|
'VACATION'
|
|
ELSE
|
|
'START_VACATION'
|
|
END )
|
|
END )
|
|
END )
|
|
ELSE
|
|
( CASE ( aacc.credentials_id IS NULL )
|
|
WHEN TRUE THEN
|
|
( CASE ( vkey.credentials_id IS NULL )
|
|
WHEN TRUE THEN
|
|
'DISABLED'
|
|
ELSE
|
|
'REACTIVATING'
|
|
END )
|
|
ELSE
|
|
'QUITTING'
|
|
END )
|
|
END )
|
|
ELSE
|
|
'BANNED'
|
|
END ) AS status ,
|
|
vkey.token AS validation_token , prr.token AS pwd_recovery_token ,
|
|
acr.token AS address_change_token , naddr.address AS new_address ,
|
|
aacc.vacation_credits AS vacation_credits ,
|
|
floor( aacc.vacation_credits / sys.get_constant( 'vacation.cost' ) ) AS vacation_time,
|
|
vac.since AS vacation_start ,
|
|
iacc.since AS inactivity_begin , ires.reason AS inactivity_reason ,
|
|
ban.ban_id AS ban_request_id
|
|
FROM users.addresses addr
|
|
INNER JOIN users.credentials cred
|
|
ON cred.address_id = addr.id
|
|
INNER JOIN defs.languages lang
|
|
ON lang.id = cred.language_id
|
|
LEFT OUTER JOIN users.validation_keys vkey
|
|
ON vkey.credentials_id = cred.address_id
|
|
LEFT OUTER JOIN users.pwd_recovery_requests prr
|
|
ON prr.credentials_id = cred.address_id AND NOT prr.used
|
|
LEFT OUTER JOIN users.address_change_requests acr
|
|
ON acr.credentials_id = cred.address_id AND NOT acr.used
|
|
LEFT OUTER JOIN users.addresses naddr
|
|
ON naddr.id = acr.address_id
|
|
LEFT OUTER JOIN users.active_accounts aacc
|
|
ON aacc.credentials_id = cred.address_id
|
|
LEFT OUTER JOIN users.vacations AS vac
|
|
ON vac.account_id = aacc.credentials_id
|
|
LEFT OUTER JOIN users.inactive_accounts AS iacc
|
|
ON iacc.credentials_id = cred.address_id
|
|
LEFT OUTER JOIN users.reasons AS ires
|
|
ON ires.account_id = iacc.credentials_id
|
|
LEFT OUTER JOIN users.bans AS ban
|
|
ON ban.account_id = iacc.credentials_id;
|
|
|
|
GRANT SELECT ON users.accounts_view TO :dbuser; |