[![Contributors][contributors-shield]][contributors-url] [![Forks][forks-shield]][forks-url] [![Stargazers][stars-shield]][stars-url] [![Issues][issues-shield]][issues-url] [![MIT License][license-shield]][license-url]

EStash

An open source, cross-platform, programmed in rust, encrypted digital vault (store files and text) with the capability to set a path and with the click of a button to copy the content to that file. For example store your ssh keys safely, put your vault in like your github dotfiles, download it on another machine and easily install those keys.
Report Bug | Request Feature

Table of Contents
  1. About The Project
  2. Getting Started
  3. Usage
  4. Road Map
  5. Contributing
  6. License
  7. Contact

About The Project

Video showcase

https://user-images.githubusercontent.com/59087558/206248579-a786b277-b0fc-4306-be50-9db1c948e901.mp4

Built with

The stock libraries and these awesome 3rd party ones:

Getting Started

Running The Program

Windows

Portable EXE

  1. Go to the Releases Tab and download the estash-windows.exe file (might have to click show all).
  2. Double click the exe you just downloaded and there you go the program works.
  3. Might wanna take a look at the Usage Tab if you don't understand something about it.

Installer

  1. Go to the Releases Tab and download the estash-windows-installer.exe files (might have to click show all).
  2. Double click the installer and go through the it as you would with any other installer.
  3. If you look now in the start menu (or on the desktop if you ticked create desktop shortcut) you are gonna see a shortcut for estash, just run it like any other program.
  4. Might wanna take a look at the Usage Tab if you don't understand something about it.

Linux

Portable Bin

  1. Go to the Releases Tab and download the estash-linux file.
  2. Double click the bin you just downloaded and there you go the program works.
  3. Might wanna take a look at the Usage Tab if you don't understand something about it.

AppImage

  1. Go to the Releases Tab and download the estash-linux.AppImage file.
  2. Double click the AppImage you download and there you go the program just works. You may want to install AppImageLauncher if you don't have it already, when you start the AppImage you'll get a prompt asking if you want to integrate and run it and if you do so it will appear just as if you installed it.
  3. Might wanna take a look at the Usage Tab if you don't understand something about it.

AUR

The PKGs are: estash (for stable), estash-bin (for precompiled) and estash-git (to compile latest source code)

a. if you have an AUR manager (like paru or yay, which you should) 1. Just like with any other AUR pkg choose your prefered type and you can run the following command for example. shell paru -Sy estash 2. Search for estash in your app launcher and launch it. 3. Might wanna take a look at the Usage Tab if you don't understand something about it.

b. Manually cloning and building it from AUR 1. First install the basic build dependencies, if you don't already have them: shell sudo pacman -Sy gcc base-devel --needed 2. Then clone the build script shell git clone https://aur.archlinux.org/estash.git # or estash-bin & estash-git 3. Cd into the new cloned repository and run the following to build the package shell makepkg 4. In order to install the package run the following (where * is just an any other characters place holder) shell sudo pacman -U estash-*.pkg.tar.zst

Nix File

You are using NixOS, don't worry I got you bro. 1. Go to the Releases Tab and download the estash-linux.nix file. 2. If you use flakes then put it in your pkgs folder, and up-top add your tag (like my). If you don't just add the code in your default.nix file and install it this way. 3. Might wanna take a look at the Usage Tab if you don't understand something about it.

Deb File

You should use the app image. This does not provide a desktop file, you'll have to run it from the command line. It's here just as another means if needed. I will try to make a ppa. 1. Go to the Releases Tab and download the estash-linux.deb file. 2. Open a terminal in the folder where your download is and run the following command: shell sudo dpkg -i estash-linux.deb 3. Run estash in the terminal and there it is, the app. 4. Might wanna take a look at the Usage Tab if you don't understand something about it.

Arch Pkg File

You shouldn't use this method, install the estash-bin AUR pkg instead. This is here just as another means if needed. 1. Go to the Releases Tab and download the estash-linux.pkg.tar.zst file. 2. From you Arch Linux command line run the following command: shell sudo pacman -U estash-linux.pkg.tar.zst 3. Search for estash in your app launcher and launch it. 4. Might wanna take a look at the Usage Tab if you don't understand something about it.


MacOS

Portable binary

  1. Go to the Releases Tab and download the estash-macos file.
  2. Double click the bin you just downloaded and there you go the program works.
  3. Might wanna take a look at the Usage Tab if you don't understand something about it.

App Folder

Very simillar to portable binary, only real difference is this has an icon. 1. Go to the Releases Tab and download the estash-macos-app.tar.gz file. 2. Use your archive manager or run in the terminal the following command: shell tar -xzf estash-macos-app.tar.gz 3. Double clikc the app folder you just downloaded and there you go the program works. 4. Might wanna take a look at the Usage Tab if you don't understand something about it.

DMG Installer

Works just like any other dmg installer you've used. 1. Go to the Releases Tab and download the estash-macos-installer.dmg file. 2. Double click to run the dmg. 3. Drag the app folder over the Applications folder. 4. Done, you've just installed the app, should see it in launchpad now. 5. Might wanna take a look at the Usage Tab if you don't understand something about it.

Homebrew

Note this method doesn't come with a desktop entry. You'll have to run the estash command or just create a shortcut yourself, it's really easy. 1. You will need to have homebrew installed, if you don't have it installed run the following command: shell /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)" 2. You'll need to add my tap repo, run the following command for that: shell brew tap Obscurely/tap 3. Install the pkg. shell brew install estash 4. Might wanna take a look at the Usage Tab if you don't understand something about it.


All Platforms

This method will work across any Linux distribution, Windows 10/11 and macOS (Big Sur+ tested).

  1. Install rust, either using the official rustup installer or any pkg manager you may use. (There is also a shell.nix file in the repo if you use nix)
  2. Run the following command in your terminal of choice: shell cargo install estash
  3. Make sure you have .cargo/bin in path, for linux and macOS you would need to add the following line in your terminal RC file (e.g $HOME/.zshrc) shell export PATH=$HOME/.cargo/bin:$PATH # This is for Linux & macOS, look below for Windows. On windows it should work automatically (restart if just installed), if not you can follow this guide for how to add something to path. The cargo bin folder will be {your-user-folder}\.cargo\bin

  4. You may want to create a symlink on Linux & macOS or create a shortcut if you are on Windows to the bin file for easy access.

  5. In order to update run the install command again, and you can now follow usage for more information on how to use it.


Compilation

This program only uses cross platform libraries. The following steps require that you have rust installed, check their official installation page or use any pkg manager you may want. (There is also a shell.nix file in the repo if you use nix).

  1. Clone this repo on your PC, you can use "git clone", if you have git installed, like this: shell git clone https://github.com/Obscurely/estash.git Otherwise in the right up side of the repo page you will see a download button, download the repo as zip and extract it in a folder

  2. Open a new terminal/cmd window in the folder you extracted the repo in, if you can't right click on the folder and open it there do: shell cd the/path and you will get there.

  3. From there run this compile command in the terminal: shell cargo build --release It will take a bit depending on your system because of executable size optimizations, but be patient.

  4. Done, navigate to target/release and grab only the "estash" file from there.

Usage

In the provided video it's presented everything you should know on how to use EStash. I also think the UI is intuitive enough, but I obviously can't have an unbiased opinion or a first look experience, so here you go.

Basics

Login

  1. First click on signup. The first field is the name of the vault, the second field is the password, and the third one is to verify the password. After inputting you desired credentials (note you can also make a vault with nothing as the vault name and password) click Singup and wait.
  2. After the vault has been created in left up corner you will se a back arrow, click that.
  3. Now that we are in the main menu click on Login. The first field is the name of the vault and the second one is the password. After inputting your credentials hit Login.

The Vault

Advanced

Road Map

To be added.

Contributing

Edit a file you want, do a pull request, I will look at it and if the change makes sense and is a good one I will accept it and that's it.

License

Is under GPL-3.0 so stick to the license conditions and have fun :)

Contact

Either post an issue in the Issues Tab or contact me at this email adddress if you have more to say: obscurely.social@protonmail.com