Skip to content

curiouscoder-cmd/ENV_Storage

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

19 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

πŸ” ENV Storage Manager

A secure, offline-first desktop application for managing environment variables across multiple projects. Built with Electron, React, and modern web technologies.

License Node Electron React

✨ Features

  • πŸ”’ Secure Encryption - AES-256-GCM encryption for all environment variables
  • πŸ–₯️ Desktop Application - Native cross-platform desktop app (Windows, macOS, Linux)
  • πŸ“ Project Management - Organize variables by projects
  • πŸ“€ Import/Export - Support for .env and JSON formats
  • πŸ”„ Copy Between Projects - Easily duplicate configurations across environments
  • πŸ“ Audit Logging - Track all changes to your environment variables
  • πŸŒ™ Dark Theme - Beautiful dark-themed UI
  • πŸ” Master Password - Single password to access all your secrets
  • πŸ’Ύ Offline First - All data stored locally, no cloud required

πŸš€ Quick Start

Prerequisites

  • Node.js 20 or higher
  • npm (comes with Node.js)

Installation

# Clone the repository
git clone https://github.com/curiouscoder-cmd/ENV_Storage.git
cd ENV_Storage

# Install dependencies
npm install

# Generate Prisma client
npx prisma generate

# Run in development mode
npm run electron:dev

Building

# Build for your platform
npm run electron:build

# The built application will be in the dist folder

πŸ“– Usage

First Time Setup

  1. Launch the application
  2. Create a master password (remember this - it cannot be recovered!)
  3. Start creating projects and adding environment variables

Managing Projects

  • Click "New Project" to create a project
  • Select a project from the sidebar to view its variables
  • Delete projects by clicking the delete icon

Managing Environment Variables

  • Click "Add Variable" to create a new environment variable
  • Toggle visibility to show/hide values
  • Copy values to clipboard with one click
  • Edit or delete variables as needed

Import/Export

Export:

  • Click "Export .env" or "Export JSON" to download your variables
  • Choose the format that suits your needs

Import:

  • Click "Import" button
  • Upload a .env or JSON file, or paste content directly
  • Choose to skip or overwrite existing variables
  • Comments in .env files are preserved as descriptions

Copy Between Projects

  • Select variables using checkboxes
  • Click "Copy to Project (N)" button
  • Choose target project
  • Toggle overwrite mode if needed
  • Review and confirm

πŸ› οΈ Technology Stack

Backend

  • Electron 38 - Desktop application framework
  • Node.js 20+ - Runtime environment
  • Prisma ORM - Database management
  • SQLite - Local database
  • Node.js Crypto - AES-256-GCM encryption

Frontend

  • React 19 - UI framework
  • Vite 7 - Build tool and dev server
  • Ant Design 5 - UI component library
  • Tailwind CSS 4 - Utility-first CSS
  • shadcn/ui - Additional UI components
  • Lucide React - Icon library

πŸ”’ Security

  • All environment variables are encrypted using AES-256-GCM
  • Master password is hashed using PBKDF2 with 100,000 iterations
  • Data is stored locally in an SQLite database
  • No data is sent to any external servers
  • Encryption keys are derived from your master password

πŸ“ Project Structure

ENV_Storage/
β”œβ”€β”€ electron/           # Electron main process
β”‚   β”œβ”€β”€ main.js        # Application entry point
β”‚   β”œβ”€β”€ preload.js     # IPC bridge
β”‚   β”œβ”€β”€ ipc-handlers.js # Backend handlers
β”‚   β”œβ”€β”€ crypto.js      # Encryption utilities
β”‚   └── database.js    # Prisma client
β”œβ”€β”€ src/               # React frontend
β”‚   β”œβ”€β”€ components/    # React components
β”‚   β”œβ”€β”€ lib/          # Utility functions
β”‚   └── assets/       # Static assets
β”œβ”€β”€ prisma/           # Database schema
β”‚   └── schema.prisma # Prisma schema
└── public/           # Public assets

🀝 Contributing

Contributions are welcome! Please read our Contributing Guide for details on our code of conduct and the process for submitting pull requests.

Development Setup

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Make your changes
  4. Run linting (npm run lint)
  5. Commit your changes (git commit -m 'feat: add amazing feature')
  6. Push to the branch (git push origin feature/amazing-feature)
  7. Open a Pull Request

πŸ“ License

This project is licensed under the MIT License - see the LICENSE file for details.

πŸ™ Acknowledgments

πŸ“§ Support

πŸŽƒ Hacktoberfest

This project participates in Hacktoberfest! Check out the official Hacktoberfest site for contribution ideas and guidelines.


Made with ❀️ by the ENV Storage Manager team

About

No description, website, or topics provided.

Resources

License

Code of conduct

Contributing

Security policy

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project

Packages

No packages published

Contributors 3

  •  
  •  
  •