• Stars
    star
    118
  • Rank 297,958 (Top 6 %)
  • Language
    C
  • License
    BSD 2-Clause "Sim...
  • Created over 11 years ago
  • Updated over 2 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

A shared library that implements scrypt() functionality - a replacement for bcrypt()

libscrypt

Linux scrypt shared library.

Full credit to algorithm designer and example code from Colin Percival here: http://www.tarsnap.com/scrypt.html

Utilises BASE64 encoding library from ISC.

Official project page, including stable tarballs found here: http://www.lolware.net/libscrypt.html

Simple hashing interface

The (reference) internal hashing function can be directly called as follows:

int libscrypt_scrypt(const uint8_t *passwd, size_t passwdlen,
        const uint8_t *salt, size_t saltlen, uint64_t N, uint32_t r, 
        uint32_t p, /*@out@*/ uint8_t *buf, size_t buflen);

Libscrypt's easier to use interface wraps this up to deal with the salt and produce BASE64 output as so:

int libscrypt_hash(char *dst, char *passphrase, uint32_t N, uint8_t r, uint8_t p);

Sane constants have been created for N, r and p so you can create a hash like this:

libscrypt_hash(outbuf, "My cats's breath smells like cat food", SCRYPT_N, SCRYPT_r, SCRYPT_p);

This function sets errno as required for any error conditions.

Output stored in "outbuf" is stored in a standardised MCF form, which means includes the randomly created, 128 bit salt, all N, r and p values, and a BASE64 encoded version of the hash. The entire MCF can be stored in a database, and compared for use as below:

retval = libscrypt_check(mcf, "pleasefailme");
retval < 0 error
retval = 0 password incorrect
retval > 0 pass

mcf should be defined as at least SCRYPT_MCF_LEN in size.

Note that libscrypt_check needs to modify the mcf string and will not return it to the original state. Pass it a copy if you need to keep the original mcf.

A number of internal functions are exposed, and users wishing to create more complex use cases should consult the header file, which is aimed at documenting the API fully.

The test reference is also aimed at providing a well documented use case. Building

make
make check

Check the Makefile for advice on linking against your application.

OSX

Please compile and install with:

make LDFLAGS= CFLAGS_EXTRA=
make install-osx

BUGS

SCRYPT_* constants are probably a little high for something like a Raspberry pi. Using '1' as SCRYPT_p is acceptable from a security and performance standpoint if needed. Experiments were performed with using memset() to zero out passwords as they were checked. This often caused issues with calling applications where the password based have been passed as a const*. We highly recommend implementing your own zeroing function the moment this library is called.

There is apparently an issue when used on Samsung (and perhaps Android in general) devices. See this issue for more information.

Notes on Code Development

Code is now declared "stable", the master branch will always be "stable" and development will be done on branches. The reference machines are Fedora, CentOS, FreeBSD and Raspbian, and the code is expected to compile and run on all of these before being moved to stable branch. Full transparancy on the regular application of thorough testing can be found by reviewing recent test harness results here: http://www.lolware.net/libscrypttesting.txt

Please, no more pull requests for Windows compatibility. If it's important to you - fork the project. I have no intention of pulling an OpenSSL and becoming a maze of ifdefs for platforms I don't even have a build environment for.

I utilise Facebook's "infer" static analyser, in addition to clang's analyzer. Command to run is:

infer -- make

Contact

I can be contacted at: [email protected]

If required, my GPG key can be found at: https://lolware.net/technion-GPG-KEY

Future releases will have the Git tag signed.

Changenotes

v1.1a: Single Makefile line change. I wouldn't ordinarily tag this as a new "release", but the purpose here is to assist with packaging in distributions.

v1.12: The static library is built, but no longer installed by default. You can install it with "make install-static". This is because static libraries are not typically bundled in packages.

v1.13: Minor packaging related update

v1.15: Replaced the b64 libraries with more portable one from ISC. Now tested and verified on a wider variety of architectures. Note, libscrypt_b64_encrypt was originally an exported function. This is no longer the case as it is considered an internal function only.

v1.18: God damnit Apple

v1.19: Code safety cleanups. Now running Coverity.

v1.20: Bigfixes involving large N values, return values on error

Coverity Scan Build Status

More Repositories

1

ruby-argon2

A Ruby gem offering bindings for Argon2 password hashing
Ruby
219
star
2

lol_dht22

A Raspberry Pi DHT22/AM2302 polling application
Shell
81
star
3

maia_mailguard

A fork of maia Mailguard
PHP
50
star
4

reactxss

An XSS smoke test for ReactJS
TypeScript
38
star
5

matasano_challenge

Working through the Matasano Crypto Challenges (cryptopals.com)
Ruby
35
star
6

ct_advisor

A monitoring service for Certificate Transparency
Erlang
32
star
7

open_safety

An application to assist with securing script execution
Rust
29
star
8

3652fa

Office 365 MFA capture toolkit
HTML
12
star
9

erlvulnscan

Concurrent network scanner for CVE-2015-1635
Erlang
10
star
10

azure_enum

Office 365 and Exchange domain federation enumeration tool
Ruby
10
star
11

ssl_manager

Self-hosted service for creating multi-domain SSL certificates
CSS
9
star
12

DisableSMBCompression

CVE-2020-0796 Flaw Mitigation - Active Directory Administrative Templates
8
star
13

messagesodium

Patches ActiveSupport's MessageEncryptor to use libsodium
Ruby
7
star
14

ProxyShellnmap

An nmap script to scan for ProxyShell vulnerable Exchange servers
Lua
6
star
15

IISBackdoorDetect

Detects IIS modules such as IIS-RAID
PowerShell
6
star
16

trackingsadness

GoDaddy's tracking code
JavaScript
5
star
17

vssshield

A Rust project to mitigate Windows ransomware
Rust
5
star
18

mod_randpad

Nginx module that adds a random amount of random data as padding
C
4
star
19

libressl_nginx

Files to create my nginx RPM with libressl
Shell
3
star
20

CVE-2021-34470scanner

A Powrshell script to scan for CVE-2021-34470
PowerShell
2
star
21

pwncheck

Clojure client for Pwned Passwords
Clojure
2
star
22

use_urandom

A Ruby gem that patches SecureRandom to use /dev/urandom
Ruby
2
star
23

ct_advisor_int

Front End Interface for Google Certificate Transparency Monitoring
Ruby
2
star
24

lhnskey

Remote password generator for HP StoreVirtual systems
Shell
2
star
25

wintrayinfo

A Rust based Windows systray app that has BGInfo like capabiities
Rust
2
star
26

p3

Active Directory Password reset web interface
Erlang
1
star
27

SUNBURSTsim

A Powershell script to simulate SUNBURST's evasion techniques
PowerShell
1
star
28

loldns

Fork of djbdns
C
1
star
29

paddingoracle

Ruby framework for exploiting padding oracle vulnerabilities
Ruby
1
star
30

rustypwneddownloader

Rust based pwnedpasswords Downloader
Rust
1
star
31

thaxident

A Gatsby website
JavaScript
1
star
32

fetch_with_checks

TypeScript
1
star
33

lunchcoin

Blockchain application for tracking lunch and coffee orders
Erlang
1
star