Trocla
A password store for password creation and retrieval
Install / Use
/learn @duritong/TroclaREADME
trocla
Trocla provides you a simple way to create and store (random) passwords on a central server, which can be retrieved by other applications. An example for such an application is puppet and trocla can help you to not store any plaintext or hashed passwords in your manifests by keeping these passwords only on your puppetmaster.
Furthermore it provides you a simple cli that helps you to modify the password storage from the cli.
Trocla does not only create and/or store a plain password, it is also able to generate (and store) any kind of hashed passwords based on the plain password. As long as the plain password is preset, trocla is able to generate any kind of hashed passwords through an easy extendible plugin system.
It is not necessary to store the plain password on the server, you can also just feed trocla with the hashed password and use that in your other tools. A common example for that is that you let puppet retrieve (and hence create) a salted sha512 password for a user. This will then store the salted sha512 of a random password AND the plain text password in trocla. Later you can retrieve (by deleting) the plain password and send it to the user. Puppet will still simply retrieve the hashed password that is stored in trocla, while the plain password is not anymore stored on the server.
By default trocla uses moneta to store the passwords and can use any kind of key/value based storage supported by moneta for trocla. By default it uses a simple yaml file. However, since version 0.2.0 trocla also supports a pluggable storage backend which allows you to write your custom backend. See more about stores below.
Trocla can also be integrated into Hiera by using ZeroPointEnergy's hiera-backend.
Usage
create
Assuming that we have an empty trocla storage.
trocla create user1 plain
This will create (if not already stored in trocla) a random password and store its plain text under key user1. The password will also be returned by trocla.
trocla create user2 mysql
This will create a random password and store its plain and mysql-style hashed sha1 password in trocla. The hashed password is returned.
trocla create user1 mysql
This will take the already stored plain text password of key user1 and generate and store the mysql-style hashed sha1 password.
It is possible that certain hash formats require additional options. For example the pgsql hash requires also the user to create the md5 hash for the password. You can pass these additional requirements as yaml-based strings to the format:
trocla create user1 pgsql 'username: user1'
This will create a pgsql password hash using the username user1.
Valid global options are:
- length: int - Define any lenght that a newly created password should have. Default: 16 - or whatever you define in your global settings.
- charset: (default|alphanumeric|shellsafe) - Which set of chars should be used for a random password? Default: default - or whatever you define in your global settings.
- profiles: a profile name or an array of profiles matching a profile_name in your configuration. Learn more about profiles below.
- random: boolean - Whether we allow creation of random passwords or we expect a password to be preset. Default: true - or whatever you define in your global settings.
- expires: An integer indicating the amount of seconds a value (e.g. password) is available. After expiration a value will not be available anymore and trying to
getthis key will return no value (nil). Meaning that calling create after expiration, would create a new password automatically. There is more about expiration in the storage backends section. - render: A hash providing flags for formats to render the output specifially. This is a global option, but support depends on a per format basis.
Example:
trocla create some_shellsafe_password plain 'charset: shellsafe'
trocla create another_alphanumeric_20_char_password plain "charset: alphanumeric
length: 20"
get
Get simply returns a stored password. It will not create a new password.
Assuming that we are still working with the same storage
trocla get user2 plain
will return the plain text password of the key user2.
trocla get user3 plain
This will return nothing, as no password with this format have been stored so far.
set
trocla set user3 plain
This will ask you for a password and set it under the appropriate key/format. We expect a plain password to be entered and will format the password with the selected format before storing it.
trocla set --password mysupersecretpassword user4 plain
This will take the password from the cli without asking you.
trocla set user5 mysql -p mysuperdbpassword
This will store a mysql sha1 hash for the key user5, without storing any kind
of plain text password.
If you like trocla not to format a password, as you are passing in an already
formatted password (like the sha512 hash), then you must use --no-format to
skip formatting. Like:
trocla set user5 sha512crypt --no-format -p '$6$1234$xxxx....'
You can also pipe in a password:
echo -n foo | trocla set user6 plain -p
or a file
cat some_file | trocla set user6 plain -p
trocla set user6 plain -p < some_file
reset
trocla reset user1 md5crypt
This will recreate the salted md5 shadow-style hash. However, it will not create a new plain text passwords. Hence, this is mainly usefull to create new hashed passwords based on new salts.
If the plain password of a key is resetted, every already hashed password is deleted as well, as the hashes wouldn't match anymore the plain text password.
delete
trocla delete user1 plain
This will delete the plain password of the key user1 and return it.
formats
trocla formats
This will list all available and supported formats.
Attention
If you don't feed trocla initially with a hash and/or delete the generated plain text passwords trocla will likely create a lot of plain text passwords and store them on your machine/server. This is by intend and is all about which problems (mainly passwords in configuration management manifests) trocla tries to address. It is possible to store all passwords encrypted in the specific backend. See backend encryption for more information, however be aware that the key must always also reside on the trocla node. So it mainly makes sense if you store them on a remote backend like a central database server.
Formats
Most formats are straight forward to use. Some formats require some additional options to work properly. These are documented here:
pgsql
Password hashes for PostgreSQL servers. Since postgesql 10 you can use the sha256 hash, you have two options:
- Create a ssh256 hash password with option
encode: sha256(default value) - Create a md5 hash, the username is require for the salt key, with option
encode: md5andusername: your_user
bcrypt
You are able to tune the cost factor of bcrypt by passing the option cost.
Note: ruby bcrypt does not support a cost > 31.
x509
This format takes a set of additional options. Required are:
subject: A subject for the target certificate. E.g. /C=ZZ/O=Trocla Inc./CN=test/emailAddress=example@example.com
OR
CN: The CN of the the target certificate. E.g. 'This is my self-signed certificate which doubles as CA'
Additional options are:
ca The trocla key of CA (imported into or generated within trocla) that
will be used to sign that certificate.
become_ca Whether the certificate should become a CA or not. Default: false,
to enable set it to true.
hash Hash to be used. Default sha2
keysize Keysize for the new key. Default is: 4096
serial Serial to be used, default is selecting a random one.
days How many days should the certificate be valid. Default 365
C instead within the subject string
ST instead within the subject string
L instead within the subject string
O instead within the subject string
OU instead within the subject string
emailAddress instead within the subject string
key_usages Any specific key_usages different than the default ones. If you specify
any, you must specify all that you want. If you don't want to have any,
you must specify an empty array.
altnames An array of subjectAltNames. By default for non CA certificates we
ensure that the CN ends up here as well. If you don't want that.
You need to pass an empty array.
name_constraints An array of domains that are added as permitted x509 NameConstraint.
By default, we do not add any contraint, meaning all domains are
signable by the CA, as soon as we have one item in the list, only
DNS entries matching this list are allowed. Be aware, that older
openssl versions have a bug with [leading dots](https://rt.openssl.org/Ticket/Display.html?id=3562) for name
constraints. So using them might not work everywhere as expected.
Output render options are:
certonly If set to true the x509 format will return only the certificate
keyonly If set to true the x509 format will return only the private key
publickeyonly If set to true the x509 format will return only t
