From 45b0c5f63ccaef054e5eab30821aac720a88efb8 Mon Sep 17 00:00:00 2001 From: Benjamin Marwell Date: Tue, 23 Jan 2024 10:20:13 +0100 Subject: [PATCH] [#185] rework to a v2/ structure --- src/site/content/command-line-hasher.adoc | 17 ++- src/site/content/v2/command-line-hasher.adoc | 118 +++++++++++++++++++ src/site/templates/macros/versions.ftl | 48 ++++++++ src/site/templates/page.ftl | 9 ++ 4 files changed, 182 insertions(+), 10 deletions(-) create mode 100644 src/site/content/v2/command-line-hasher.adoc diff --git a/src/site/content/command-line-hasher.adoc b/src/site/content/command-line-hasher.adoc index feb6a8a12f..4415afb7f8 100644 --- a/src/site/content/command-line-hasher.adoc +++ b/src/site/content/command-line-hasher.adoc @@ -4,6 +4,7 @@ :jbake-type: page :jbake-status: published :jbake-tags: documentation, hashes, command-line, cli, hasher, tool +:shiro-hasv2: true :idprefix: :icons: font :toc: @@ -37,14 +38,12 @@ Once you have access to the jar, you can run the following command: $ java -jar shiro-tools-hasher-${versions.latestRelease}-cli.jar ---- -This will print all available options for standard (argon2, bcrypt) and less secure hashing scenarios. +This will print all available options for both standard (MD5, SHA1) and more complex password hashing scenarios. [#CommandLineHasher-CommonScenarios] == Common Scenarios -Please read the printed instructions for the above command. -It will provide an exhaustive list of instructions which will help you use the hasher depending on your needs. -However, we've provided some quick reference usages/scenarios below for convenience. +Please read the printed instructions for the above command. It will provide an exhaustive list of instructions which will help you use the hasher depending on your needs. However, we've provided some quick reference usages/scenarios below for convenience. [#CommandLineHasher-shiro.iniUserPasswords] === `shiro.ini` User Passwords @@ -64,12 +63,11 @@ Password to hash: Password to hash (confirm): ---- -When this command executes, it will print out the securely-salted-iterated-and-hashed password. -For example: +When this command executes, it will print out the securely-salted-iterated-and-hashed password. For example: [source,bash] ---- -[INFO ] $shiro2$argon2id$v=19$t=1,m=65536,p=4$H5z81Jpr4ntZr3MVtbOUBw$fJDgZCLZjMC6A2HhnSpxULMmvVdW3su+/GCU3YbxfFQ +$shiro1$SHA-256$500000$eWpVX2tGX7WCP2J+jMCNqw==$it/NRclMOHrfOvhAEFZ0mxIZRdbcfqIBdwdwdDXW2dM= ---- Take this value and place it as the password in the user definition line (followed by any optional roles) as defined in the link:/configuration.html#Configuration-INIConfiguration-Sections-users[INI Users Configuration] documentation. For example: @@ -78,11 +76,10 @@ Take this value and place it as the password in the user definition line (follow ---- [users] ... -user1 = $shiro2$argon2id$v=19$t=1,m=65536,p=4$H5z81Jpr4ntZr3MVtbOUBw$fJDgZCLZjMC6A2HhnSpxULMmvVdW3su+/GCU3YbxfFQ +user1 = $shiro1$SHA-256$500000$eWpVX2tGX7WCP2J+jMCNqw==$it/NRclMOHrfOvhAEFZ0mxIZRdbcfqIBdwdwdDXW2dM= ---- -You will also need to ensure that the implicit `iniRealm` uses a `CredentialsMatcher` that knows how to perform secure hashed password comparisons. -So configure this in the `[main]` section as well: +You will also need to ensure that the implicit `iniRealm` uses a `CredentialsMatcher` that knows how to perform secure hashed password comparisons. So configure this in the `[main]` section as well: [source,ini] ---- diff --git a/src/site/content/v2/command-line-hasher.adoc b/src/site/content/v2/command-line-hasher.adoc new file mode 100644 index 0000000000..a6ed3fc379 --- /dev/null +++ b/src/site/content/v2/command-line-hasher.adoc @@ -0,0 +1,118 @@ +[#CommandLineHasher-CommandLineHasher] += Command Line Hasher +:jbake-date: 2010-03-18 00:00:00 +:jbake-type: page +:jbake-status: published +:jbake-tags: documentation, hashes, command-line, cli, hasher, tool +:idprefix: +:icons: font +:toc: + +Shiro 2.0.0 and later provides a command line program that can hash strings and resources (files, URLs, classpath entries) of almost any type. +To use it, you must have a Java Virtual Machine installed and the 'java' command must be accessible in your `$PATH` environment variable. + +[CAUTION] +==== +Do not use the hashes provided in the link:../command-line-hasher.html[command line hasher v1.x] versions anymore! +They are outdated and all considered insecure! +==== + +[#CommandLineHasher-Usage] +== Usage + +Ensure you have access to the `shiro-tools-hasher-${versions.latestRelease}-cli.jar` file. +You can either find this in a source build in the _buildroot_`/tools/hasher/target` directory or via download through Maven. + +[source,bash] +---- +# Use the following to download from Maven Central into +# ~/.m2/repository/org/apache/shiro/tools/shiro-tools-hasher/${versions.latestRelease}/shiro-tools-hasher-${versions.latestRelease}-cli.jar +$ mvn dependency:get -DgroupId=org.apache.shiro.tools -DartifactId=shiro-tools-hasher -Dclassifier=cli -Dversion=${versions.latestRelease} + +---- + +Once you have access to the jar, you can run the following command: + +[source,bash] +---- +$ java -jar shiro-tools-hasher-${versions.latestRelease}-cli.jar +---- + +This will print all available options for standard (argon2, bcrypt) and less secure hashing scenarios. + +[#CommandLineHasher-CommonScenarios] +== Common Scenarios + +Please read the printed instructions for the above command. +It will provide an exhaustive list of instructions which will help you use the hasher depending on your needs. +However, we've provided some quick reference usages/scenarios below for convenience. + +[#CommandLineHasher-shiro.iniUserPasswords] +=== `shiro.ini` User Passwords + +It is best to keep user passwords in the `shiro.ini` `[users]` section secure. To add a new user account line, use the above command with the `**-p**` (or `--password`) option: + +[source,bash] +---- +$ java -jar shiro-tools-hasher-${versions.latestRelease}-cli.jar -p +---- + +It will then ask you to enter the password and then confirm it: + +[source,bash] +---- +Password to hash: +Password to hash (confirm): +---- + +When this command executes, it will print out the securely-salted-iterated-and-hashed password. +For example: + +[source,bash] +---- +[INFO ] $shiro2$argon2id$v=19$t=1,m=65536,p=4$H5z81Jpr4ntZr3MVtbOUBw$fJDgZCLZjMC6A2HhnSpxULMmvVdW3su+/GCU3YbxfFQ +---- + +Take this value and place it as the password in the user definition line (followed by any optional roles) as defined in the link:/configuration.html#Configuration-INIConfiguration-Sections-users[INI Users Configuration] documentation. For example: + +[source,ini] +---- +[users] +... +user1 = $shiro2$argon2id$v=19$t=1,m=65536,p=4$H5z81Jpr4ntZr3MVtbOUBw$fJDgZCLZjMC6A2HhnSpxULMmvVdW3su+/GCU3YbxfFQ +---- + +You will also need to ensure that the implicit `iniRealm` uses a `CredentialsMatcher` that knows how to perform secure hashed password comparisons. +So configure this in the `[main]` section as well: + +[source,ini] +---- +[main] +... +passwordMatcher = org.apache.shiro.authc.credential.PasswordMatcher +iniRealm.credentialsMatcher = $passwordMatcher +... +---- + +[#CommandLineHasher-MD5checksum] +=== MD5 checksum + +Although you can perform any hash with any algorithm supported on the JVM, the default hashing algorithm is MD5, common for file checksums. Just use the `**-r**` (or `--resource`) option to indicate the following value is a resource location (and not text you wish hashed): + +[source,bash] +---- +$ java -jar shiro-tools-hasher-X.X.X-cli.jar -r RESOURCE_PATH +---- + +By default `RESOURCE_PATH` is expected to be a file path, but you may specify classpath or URL resources by using the `classpath:` or `url:` prefix respectively. + +Some examples: + +[source,bash] +---- + -r fileInCurrentDirectory.txt + -r ../../relativePathFile.xml + -r ~/documents/myfile.pdf + -r /usr/local/logs/absolutePathFile.log + -r url:http://foo.com/page.html -r classpath:/WEB-INF/lib/something.jar +---- diff --git a/src/site/templates/macros/versions.ftl b/src/site/templates/macros/versions.ftl index 0f617ebc91..b08398e602 100644 --- a/src/site/templates/macros/versions.ftl +++ b/src/site/templates/macros/versions.ftl @@ -5,3 +5,51 @@ <#assign oldReleases = data.get('releases.yaml').oldReleases> <#assign artifacts = data.get('artifacts.yaml').artifacts> + +<#macro shirov2> + <#assign theDate = .now?date> +
+ + + + + + + +
+ + +
Shiro v2 alpha notice
+
+

As of ${theDate?iso_utc}, this version of Apache Shiro is in Alpha stage.

+
+
+
+ + +<#macro shirov1 sourcepage="" hasv2=false> + <#assign theDate = .now?date> +
+ + + + + + + +
+
Handy Hint
+
+
Shiro v1 version notice
+
+

As of ${theDate?iso_utc}, Shiro v1 will soon be superseded by v2.

+ <#if (sourcepage)?? && (sourcepage)?is_string && (sourcepage) != "" && hasv2 == true> + <#assign target=sourcepage?keep_after_last("/") /> +

+ Read this page in the v2 documentation. +

+ +
+
+
+ diff --git a/src/site/templates/page.ftl b/src/site/templates/page.ftl index 868fabc3e1..cba2d98af9 100644 --- a/src/site/templates/page.ftl +++ b/src/site/templates/page.ftl @@ -31,6 +31,15 @@ + <#import "macros/versions.ftl" as versions> + <#if (content.uri)?contains("/v2/") || (content.uri)?starts_with("v2/")> + <@versions.shirov2 /> + <#else> + <#-- this is a shiro v1 page --> + <#assign hasv2=((content["shiro-hasv2"])?? && (content["shiro-hasv2"]) == "true") /> + <@versions.shirov1 (content.uri) hasv2 /> + + <@content.body?interpret />