Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
This is a small library to make it easy to work with 1Password's .cloudKeychain files.
This implementation is based on the official Agile Bits documentation and also the python library OnePasswordPy.
IMPORTANT NOTE: I am not in any way affiliated with AgileBits, the makers of 1Password. Their software is awesome and you should probably go buy it.
Currently supported:
Todo:
npm install 1password
Step 1: Open the keychain
Keychain = require( '1password' );
keychain = new Keychain();
keychain.load( './1password.cloudkeychain', function( err ) {
console.log( 'Keychain has loaded' );
});
Step 2: Unlocking the keychain
keychain.unlock( 'password' );
if ( keychain.unlocked ) {
console.log( 'Successfully unlocked keychain' );
} else {
console.log( 'Error: Could not unlock keychain' );
}
Step 3: Get items
keychain.eachItem( function( item ) {
console.log( item );
});
Step 4: Decrypt item details
item = keychain.findItems( 'Facebook' )[0];
item.unlockDetails();
console.log( item.details );
Returns an empty keychain encrypted using the password specified.
keychain = Keychain.create( 'password', {
passwordHint: 'hint'
});
profile = keychain.exportProfile();
console.log( profile );
The settings
parameter is an object and can overwrite any of the default
values. However extra settings cannot be added. The default settings are:
settings = {
uuid: Crypto.generateUuid(),
salt: Crypto.randomBytes(16),
createdAt: currentTime,
updatedAt: currentTime,
iterations: 10000,
profileName: 'default',
passwordHint: '',
lastUpdatedBy: 'Dropbox'
};
This logs the following (indented and trimmed for readibility):
var profile={
"lastUpdatedBy": "Dropbox",
"updatedAt": 1362617665,
"profileName": "default",
"salt": "W0wV8jBiFnRWmqWDl3vaPA==",
"passwordHint": "hint",
"masterKey": "b3BkYXRhMDEAAQAAAAAAAGnpNQQJuFTg ..."
"iterations": 20000,
"uuid": "A2C1050B56C89557AC2A0FA230F90174",
"overviewKey": "b3BkYXRhMDFAAAAAAAAAAAbP+65OIhYy ...",
"createdAt": 1362617665
};
Events are implemented using the NodeJS EventEmitter. The API is available on the NodeJS.org website.
To use the EventEmitter:
keychain = new Keychain();
keychain.event.on('event', function(args) {
console.log('Event fired!', args);
});
keychain.event.emit('event', 'random data');
function() { }
When the keychain is unlocked.
function (autolock) { }
When the keychain is locked. If the keychain was locked automatically by a
timer, then autolock
will be true. Used to run code before the keychain is
locked.
function (autolock) { }
When the keychain is locked. If the keychain was locked automatically by the
timer, then autolock
will be true. Used to run code after the keychain has
been locked.
Load keychain data from a file on disk.
This is the main loading function and probably the only one you'll only ever need to use.
filepath
points to a .cloudkeychain
folder and it will go through and load all files it finds using the other functions.
keychain.load( './1password.cloudkeychain', function(err) {
if ( err ) return console.log( err.message );
console.log( 'Successfully loaded keychain' );
});
Loads the profile.js
file data into the keychain.
If you already have profile.js then set rawData
to true
.
filename = './1password.cloudkeychain/default/profile.js';
keychain.loadProfile( filename );
// Alternative
profileData = readFileContents( filename )
keychain.loadProfile( profileData, true )
Warning: Not yet implemented.
Load the folders.js
file data into the keychain.
keychain.loadFolders( './1password.cloudkeychain/default/folders.js' );
bands
is an array of filepaths pointing to each band file.
keychain.loadBands([
'./1password.cloudkeychain/default/band_0.js',
'./1password.cloudkeychain/default/band_1.js',
'./1password.cloudkeychain/default/band_2.js'
]);
Warning: Not yet implemented
attachments
is an array of filepaths pointing to each band file.
keychain.loadAttachments([
'./1password.cloudkeychain/default/026AA7B7333B4F925F16DE9E21B912B7_5754B83288A34CD39DE64B45C2F05A9D.attachment',
'./1password.cloudkeychain/default/6F8CDF100CC99FD55053B77492D97487_072A1462CBDE4E2488FB2DA16D96B84B.attachment'
]);
Handle the keychain unlocked status.
Unlock the keychain's master and overview keys using password
.
It will automatically lock itself after 60 seconds, unless rescheduleAutoLock
is called.
status = keychain.unlock( 'password' );
console.log( 'Keychain was unlocked successfully: ' + status );
Lock the keychain. This will dump the contents of all decrypted data, returning the state back to when the keychain was originally locked.
keychain.lock();
This will reschedule the autolock time. It should only be called when the user does something importantt in the app.
keychain.rescheduleAutoLock()
Warning: Not yet tested
This function will regenerate the master and overview keys using newPassword
.
The currentPassword
is required, as it is not stored in memory for security
reasons.
keychain.changePassword( 'fred', 'phil' );
Working with items.
Creates a new instance of an item using the information in data
.
It returns the item instance, but it does not add it to the keychain. Use addItem()
to do that.
item = keychain.createItem({
title: 'Github',
username: 'wendyappleseed',
password: 'password',
url: 'github.com',
notes: ''
});
Adds an item to the keychain.
If item
is not an instance of an item, it is turned into one using new Item(item)
.
keychain.addItem(item);
Get an item by its UUID.
item = keychain.getItem('B1198E4C643E73A6226B89BB600371A9');
Search the keychain for an item by its name or location. Returns an array of items.
items = keychain.findItems('github');
Loop through all the items in the keychain.
Calls fn with the arguments [item]
.
keychain.eachItem(function(item) {
console.log( item );
});
Export keychain data into stringified JSON. Ready for writing to disk.
Export the profile.js file.
profile = keychain.exportProfile();
writeFile('profile.js', profile);
Export the band files (which holds the item data). Returns an object.
bands = keychain.exportBands()
console.log( bands );
{
"band_0.js": "ld({\n \"B1198E4C643E73A6226B89BB600371A9\": {\n \"category\": \"001\" ...",
filename: filedata
}
This is used to load the raw JSON data in a band file into an item.
Fields such as hmac
, k
, o
and d
are converted from base64.
item.load({
category: '106',
created: 1361850113,
d: 'b3BkYXRhMDHlAgAAAAAAANQpT0oUzF1E ...',
hmac: '/Qzi7Gy37hIV18NgXffDMmt3iPZKVxIFlvvULxf5iCQ=',
k: '3OoNrhpqKeBkeVAHTgwXPjlEL++QJAhx ...',
o: 'b3BkYXRhMDElAAAAAAAAAEfvS1hvP9Ue …',
tx: 1361857114,
updated: 1361857114,
uuid: 'F11FC7E27E3645D09D2670F04EF5F252'
});
Lock the item by deleting secure information such as the item keys, overview data and details.
console.log( item.overview ); // {...} Overview data
item.lock('overview');
console.log( item.overview ); // undefined
Unlock the item by decrypting secure information such as the item keys, overview data and details.
details = item.unlock('details')
Encrypt item details.
item.unlock('details');
item.details.data = true;
item.encrypt('details');
item.lock('details');
Export an item into a JSON object that can be saved in a band file.
json = item.toJSON();
Check if an item matches a query. Useful for searching through a keychain. It checks the title and URL of the item and is case insensitive.
item.overview.title == 'Facebook';
item.match('facebook'); // true
item.match('book'); // true
item.match('skype'); // false
To compile the coffeescript into javascript use cake
:
cake build
Tests are written in JavaScript using Mocha. To run the tests
sudo npm install -g mocha
mocha tests
Or if you don't want to install mocha globally:
npm install .
cake tests
Also remember to recompile the coffeescript before testing!
This work is licensed under the ISC license.
FAQs
Work With 1Password Keychains
The npm package 1password receives a total of 33 weekly downloads. As such, 1password popularity was classified as not popular.
We found that 1password demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.