Skip to content

🔑 Javascript Password Vault - Multi-Platform Desktop Application

License

Notifications You must be signed in to change notification settings

cuulee/buttercup

 
 

Repository files navigation


Buttercup Desktop


Cross-platform, free and open-source password manager based on NodeJS.

Buttercup Build Status Build status Github All Releases encryption Gitter

Buttercup

Under Development

Buttercup is currently under heavy development, and updates will be pushed here very frequently. The application is currently in alpha, and should be considered unstable.

Please check buttercup-core for more information on Buttercup’s core module.

Download & Install

Head over to our website, or checkout the releases page to download different builds and versions.

If you're using macOS, you can also use Homebrew Cask to download and install Buttercup:

$ brew cask install buttercup

Buttercup is available for macOS (dmg), Windows (exe) and Linux (deb, rpm, tarball) (only 64bit versions).

Encryption & Format

Buttercup uses a delta-system to manage archive changes and save conflicts. The archive, upon saving, is encrypted with AES 256bit CBC mode with a SHA256 HMAC. Encryption is performed once the password has been salted and prepared with PBKDF2 at between 200-250k iterations.

Because security with password storage is of the utmost importance, Buttercup will remain in alpha/beta release mode until some level of professional scrutiny has occurred. It is completely possible that security-related changes will occur, but this is inevitable and we handle every question and criticism with great care when it comes to the safety of using our software.

Features

Buttercup supports loading and saving credentials archives both locally and remotely. Remote archives can be stored in a variety of service providers like Dropbox, ownCloud and Nextcloud (and others that support WebDAV, such as Yandex).

Archives store groups and entries in a simple hierarchy. Both groups and entries can be moved into other groups. Deleted items are trashed before being removed permanently.

Buttercup has basic merge conflict resolution when 2 changes are made at once on the file (locally or remote).

You can import from other password managers (such as 1Password and KeePass) by opening your archive and choosing Import from the menu.

Development

If you're interested in developing Buttercup:

Install Dependencies & Run

## Install
$ npm install 
# or 
$ yarn

## Run
$ npm run start

Package & Release

Install Dependencies

You will need some extra dependencies to build for different platforms on a single platform. Please refer to this guide and install required software for your platform.

Building libraries before releasing

$ npm run build

Package

To package the app and make installers for all supported platforms:

$ npm run release

This may take a while depending on how fast your computer is. All apps and installers will be in app directory.

To package only for the current platform:

$ npm run package:current

Or for a specific platform:

$ npm run package:mac
$ npm run package:win
$ npm run package:linux

Contributors

Creation

Contributions

We welcome contributions. Please read Contribution Guide before sending a PR.

License

Released under GNU/GPL Version 3

About

🔑 Javascript Password Vault - Multi-Platform Desktop Application

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 76.8%
  • CSS 22.3%
  • Other 0.9%