summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndinus <andinus@nand.sh>2022-10-15 22:49:47 +0530
committerAndinus <andinus@nand.sh>2022-10-15 22:49:47 +0530
commit77025ae12bba4c23f173329c04bd1f1e41c9867e (patch)
tree29c0ad2a4ef60873d6bdac27197af4d17616382e
parentecafbe5bb11cd056f4e6f11cd1d03af98a8eeb88 (diff)
downloadorion-77025ae12bba4c23f173329c04bd1f1e41c9867e.tar.gz
Add comments, print dots on verbosity
-rw-r--r--README.org2
-rw-r--r--lib/Orion/CLI.rakumod13
2 files changed, 12 insertions, 3 deletions
diff --git a/README.org b/README.org
index 6b33738..3c2e030 100644
--- a/README.org
+++ b/README.org
@@ -34,7 +34,7 @@ Match means the password is present in HIBP database & has been compromised.
*** verbose
-This option does nothing.
+If enabled, it prints a "." for every password entry it checks.
* History
diff --git a/lib/Orion/CLI.rakumod b/lib/Orion/CLI.rakumod
index 3fe01b8..985f8e1 100644
--- a/lib/Orion/CLI.rakumod
+++ b/lib/Orion/CLI.rakumod
@@ -16,9 +16,13 @@ multi sub MAIN(
}
for @files -> $file {
+ print "." if $verbose;
+
my $proc = run <gpg2>, '--decrypt', '--quiet', $file, :out;
+ # Read the password, convert it to hex & uppercase.
my Str $hash = uc buf_to_hex sha1 $proc.out.slurp(:close).lines.head;
+ # Send the prefix to HIBP API.
for LWP::Simple.get(
"$api/range/{ $hash.substr(0, 5) }",
{
@@ -26,12 +30,17 @@ multi sub MAIN(
User-Agent => "Andinus / Orion - https://andinus.nand.sh/orion",
}
).lines.map(*.split(":")).grep(*[1] > 0) -> ($entry, $freq) {
+ # Compare all the suffixes with our hash suffix.
if $hash.substr(5, *) eq $entry {
+ # Get the password name.
my Str $pass = $file.Str.split('.password-store/').tail.split('.gpg').first;
- say $pass, " " x (72 - $pass.chars - $freq.chars), $freq;
- };
+ # Print the compromised password entry.
+ print "\n" if $verbose;
+ put $pass, " " x (72 - $pass.chars - $freq.chars), $freq;
+ }
}
}
+ print "\n" if $verbose;
}
sub buf_to_hex { [~] $^buf.list».fmt: "%02x" }