Updated Advanced Database Import (markdown)

This commit is contained in:
sorcerykid 2018-09-05 13:37:41 -05:00
parent fb3f8a15f8
commit f1eab3f12d

View File

@ -1,16 +1,34 @@
*Auth Redux Lite* is available for server operators that want a barebones, no-frills authentication handler for their server. The entire mod consists of a single 12.8 kB file (for comparison, I believe the sauth mod is about 11 kB).
While the convert.awk script populates most fields with nil values, the extract.awk script will analyze your debug.txt file and generate a transaction log that can be applied to the authentication database, giving you an accurate historic record of player login activity (dating as far back as your debug logs go, at least) -- including values for OldLogin, Lifetime, TotalSessions, and TotalFailures. This step, of course, is entirely optional and can be skipped.
[Download Auth Redux Lite](https://bitbucket.org/snippets/sorcerykid/keGzda/auth-redux-lite-barebones-fork-of-auth_rx)
![](https://i.imgur.com/8Weg8kc.png)
This fork uses the same database API and architecture as Auth Redux, so migration is completely seamless. It is also fully compatible with DataMiner. If you are already using Auth Redux, simply backup your existing auth_rx subdirectory (as a tar.gz) and then save the above snippet as an "init.lua" file. The same license terms apply, of course.
![](https://i.imgur.com/lJtJc8k.png)
However, if you are migrating from the builtin auth handler of Minetest 0.4, then there are a couple additional steps:
I stress tested the script on the debug log from JT2 dating back to December 2016. The input file size was 11.0 GB, and it only took about 9 minutes and 30 seconds to complete the operation. Despite the myriad of server crashes and missing accounts that accumulated in my debug log before I developed this mod, it still churned out some impressive results!
1. Create an "auth_rx" subdirectory under mods.
2. Download the [Auth Redux Database Import Script](https://bitbucket.org/snippets/sorcerykid/GeLe5b/auth-redux-database-import-script) snippet and save as "convert.awk"
3. Download the [Auth Redux Lite](https://bitbucket.org/snippets/sorcerykid/keGzda/auth-redux-lite-barebones-fork-of-auth_rx) snippet and save as "init.lua".
4. Run the command below to convert the database (with your correct world path).
![](https://i.imgur.com/9XuqiOd.png)
`awk -f convert.awk -v mode=install ~/.minetest/worlds/world/auth.txt`
The parser is sophisticated enough to compensate for inconsistencies between the authentication database and the debug log. It will also detect server startup, shutdown, and abnormal termination events which are necessary for calculating session lengths. Unfortunately, client connections are not logged (in the vanilla Minetest config), so TotalAttempts is the only statistic that is unavailable using this method.
I'd also recommend moving or simply renaming the auth.txt file in your world directory to "auth.txt.bak" for safekeeping. That's it!
![](https://i.imgur.com/qrFj7zC.png)
For more detailed output from the script, you can change the debug level to 'verbose'. This will display both errors and warnings. It might be helpful to redirect output to a temporary file for this purpose. To see only errors, the default debug level of 'terse' should be sufficient.
> awk -f extract.awk -v debug=verbose /tmp/auth.txt /home/minetest/.minetest/debug.txt
Warnings occur if there are orphaned accounts in the auth.txt file that do not appear in the corresponding debug log. This happens when the debug log is incomplete. Orphaned accounts will have no player login activity applied. Errors occur if the auth.txt file is inconsistent with the debug log. This could be the result of a server crash or intentional deletion of accounts. Such accounts are deemed invalid and player login activity will be ignored. However, you should verify that you are using the correct auth.txt file.
Afterward, it is simply a matter of replaying the import journal against the newly converted database using the provided rollback.lua script. The import journal must reside in the same directory as the database to be updated.
![](https://i.imgur.com/ahPWeJi.png)
The rollback.lua script will automatically backup the import journal by renaming it "~auth.dbx". It will also prepare an empty journal within the same directory.
Here is the required sequence of commands to perform a conversion and extraction:
> cd auth_rx/tools
> awk -f convert.awk -v mode=convert ~/.minetest/worlds/world/auth.txt
> awk -f extract.awk -v debug=terse ~/.minetest/worlds/world/auth.txt ~/.minetest/debug.txt
> lua rollback.lua ~/.minetest/worlds/world/auth.db
You are now ready to start your Minetest server with a fully populated authentication database. Congratulations!