mirror of
https://github.com/TrinityCore/TrinityCore.git
synced 2026-01-22 18:15:31 +01:00
[3.3.5] Core/Authserver: TOTP rewrite: (PR #23633)
- Proper management commands (.account 2fa)
- Secrets can now be encrypted (set TOTPTokenSecret in .conf)
- Secret now stored in binary
- Argon2 and AES primitives
- Base32/64 support
(cherry picked from commit 4211645834)
This commit is contained in:
@@ -32,7 +32,7 @@ CREATE TABLE `account` (
|
||||
`sha_pass_hash` varchar(40) NOT NULL DEFAULT '',
|
||||
`v` varchar(64) NOT NULL DEFAULT 'dummy value, use `verifier` instead',
|
||||
`s` varchar(64) NOT NULL DEFAULT 'dummy value, use `salt` instead',
|
||||
`token_key` varchar(100) NOT NULL DEFAULT '',
|
||||
`totp_secret` varbinary(128) DEFAULT NULL,
|
||||
`email` varchar(255) NOT NULL DEFAULT '',
|
||||
`reg_mail` varchar(255) NOT NULL DEFAULT '',
|
||||
`joindate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
@@ -1454,6 +1454,9 @@ INSERT INTO `rbac_linked_permissions` VALUES
|
||||
(199,223),
|
||||
(199,225),
|
||||
(199,263),
|
||||
(199,378),
|
||||
(199,379),
|
||||
(199,380),
|
||||
(199,496),
|
||||
(199,507),
|
||||
(199,525),
|
||||
@@ -1710,6 +1713,10 @@ INSERT INTO `rbac_permissions` VALUES
|
||||
(375,'Command: gm list'),
|
||||
(376,'Command: gm visible'),
|
||||
(377,'Command: go'),
|
||||
(378,'Command: account 2fa'),
|
||||
(379,'Command: account 2fa setup'),
|
||||
(380,'Command: account 2fa remove'),
|
||||
(381,'Command: account set 2fa'),
|
||||
(387,'Command: gobject'),
|
||||
(388,'Command: gobject activate'),
|
||||
(389,'Command: gobject add'),
|
||||
@@ -2237,6 +2244,29 @@ INSERT INTO `realmlist` VALUES
|
||||
/*!40000 ALTER TABLE `realmlist` ENABLE KEYS */;
|
||||
UNLOCK TABLES;
|
||||
|
||||
--
|
||||
-- Table structure for table `secret_digest`
|
||||
--
|
||||
|
||||
DROP TABLE IF EXISTS `secret_digest`;
|
||||
/*!40101 SET @saved_cs_client = @@character_set_client */;
|
||||
/*!40101 SET character_set_client = utf8 */;
|
||||
CREATE TABLE `secret_digest` (
|
||||
`id` int(10) unsigned not null,
|
||||
`digest` varchar(100) not null,
|
||||
PRIMARY KEY (`id`)
|
||||
) ENGINE=InnoDB;
|
||||
/*!40101 SET character_set_client = @saved_cs_client */;
|
||||
|
||||
--
|
||||
-- Dumping data for table `secret_digest`
|
||||
--
|
||||
|
||||
LOCK TABLES `secret_digest` WRITE;
|
||||
/*!40000 ALTER TABLE `secret_digest` DISABLE KEYS */;
|
||||
/*!40000 ALTER TABLE `secret_digest` ENABLE KEYS */;
|
||||
UNLOCK TABLES;
|
||||
|
||||
--
|
||||
-- Table structure for table `updates`
|
||||
--
|
||||
@@ -2414,6 +2444,8 @@ INSERT INTO `updates` VALUES
|
||||
('2019_07_16_00_auth.sql','36CB53A9EBD64BFDCF7030083E36E534F1753773','ARCHIVED','2019-07-16 00:00:00',0),
|
||||
('2019_07_17_00_auth.sql','4F983F039904894ACC483BE885676C5F0A18F06B','ARCHIVED','2019-07-17 00:00:00',0),
|
||||
('2019_07_26_00_auth.sql','DC9D0651602AE78B1243B40555A1A7B8447D01B2','ARCHIVED','2019-07-26 18:21:34',0),
|
||||
('2019_08_10_00_auth.sql','E936802893474BB9B459D01BB5F181F54EDF0653','ARCHIVED','2019-08-10 00:00:00',0),
|
||||
('2019_08_10_01_auth.sql','C58357260F0C70DA226A71F7E05DE2C49AAEFD74','ARCHIVED','2019-08-10 00:00:00',0),
|
||||
('2019_08_11_00_auth.sql','04DCC2ABDA15BC7C015E8BFEA383C62A362B166F','ARCHIVED','2019-08-11 10:56:39',0),
|
||||
('2019_08_18_00_auth.sql','0479A04B669A67D2E5A498CFB91507E742EFB34F','ARCHIVED','2019-08-17 11:51:02',0),
|
||||
('2019_10_27_00_auth.sql','C943A651B5C9AC51BB7DF69821886F4B59F57153','ARCHIVED','2019-10-27 13:06:06',0),
|
||||
|
||||
Reference in New Issue
Block a user