2018-10-30 23:42:04 -07:00
|
|
|
#!/usr/bin/env nomsu -V4.8.10
|
2018-07-15 19:41:22 -07:00
|
|
|
#
|
|
|
|
This file defines some actions for hashing files and looking up files by hash.
|
|
|
|
|
2018-07-30 14:11:45 -07:00
|
|
|
use "lib/os.nom"
|
|
|
|
use "lib/base64.nom"
|
|
|
|
|
2018-11-08 15:23:22 -08:00
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2018-08-30 14:16:09 -07:00
|
|
|
lua> "local \%use_sha1, \%hashlib = pcall(require, 'openssl.digest')"
|
2018-07-30 14:11:45 -07:00
|
|
|
|
|
|
|
test:
|
2018-09-14 19:17:09 -07:00
|
|
|
assume (hash "hello world") == (hash "hello world")
|
|
|
|
assume ((hash "hello world") != (hash "goodbye")) or barf "\
|
|
|
|
..Hash collision:
|
2018-08-29 19:38:14 -07:00
|
|
|
(hash "hello world") = \(hash "hello world")
|
2018-09-14 19:17:09 -07:00
|
|
|
(hash "goodbye") = \(hash "goodbye")"
|
2018-08-30 14:16:09 -07:00
|
|
|
|
2018-08-29 19:38:14 -07:00
|
|
|
assume (..)
|
|
|
|
(..)
|
2018-09-14 19:17:09 -07:00
|
|
|
hash "\
|
|
|
|
..This is a really long string meant to stress test the hashing function and
|
|
|
|
ensure that it's not overflowing with long inputs."
|
2018-08-29 19:38:14 -07:00
|
|
|
..!= "inf"
|
2018-08-30 14:16:09 -07:00
|
|
|
|
2018-09-14 19:17:09 -07:00
|
|
|
assume ((hash "\000") != (hash "\000\000\000\000\000")) or barf "\
|
|
|
|
..Incorrect hashing of null strings"
|
2018-08-29 19:38:14 -07:00
|
|
|
if %use_sha1:
|
|
|
|
assume ((hash "hello world") == "Kq5sNclPz7QV2+lfQIuc6R7oRu0=")
|
|
|
|
if %use_sha1:
|
2018-10-30 23:42:04 -07:00
|
|
|
externally (hash %) means:
|
2018-08-29 19:38:14 -07:00
|
|
|
%hash = (=lua "\%hashlib.new('sha1'):final(\%)")
|
|
|
|
return (base64 %hash)
|
|
|
|
..else:
|
|
|
|
# TODO: remove warning?
|
2018-09-14 19:17:09 -07:00
|
|
|
say "\
|
|
|
|
..\027[31;1mWARNING: OpenSSL module not found. Defaulting to a non-cryptographically secure hash function.\027[0m"
|
2018-10-30 23:42:04 -07:00
|
|
|
externally (hash %) means:
|
2018-09-10 16:26:08 -07:00
|
|
|
%bytes = (%::bytes)
|
2018-08-29 19:38:14 -07:00
|
|
|
%hash = (%bytes.1 << 7)
|
|
|
|
for %i in 2 to (size of %bytes):
|
|
|
|
%hash = ((1000003 * %hash) ~ %bytes.%i)
|
|
|
|
%hash = (%hash ~ (size of %bytes))
|
|
|
|
return "\%hash"
|
2018-07-30 14:11:45 -07:00
|
|
|
|
2018-10-30 23:42:04 -07:00
|
|
|
externally (file with hash %hash) means:
|
2018-07-30 14:11:45 -07:00
|
|
|
for file %filename in ".":
|
|
|
|
%contents = (read file %filename)
|
|
|
|
%file_hash = (hash %contents)
|
2018-07-30 15:05:41 -07:00
|
|
|
if (%file_hash == %hash): return %filename
|
2018-02-02 15:48:28 -08:00
|
|
|
|
2018-10-30 23:42:04 -07:00
|
|
|
(hash of file %filename) parses as (hash (read file %filename))
|