BinCode/README.md

88 lines
3.1 KiB
Markdown
Raw Normal View History

2025-01-17 21:01:31 +00:00
# [BinCode](jsbin.asadk.dev) - A Complete Self-Hostable JSFiddle Alternative
2025-01-17 20:05:21 +00:00
## Overview
BinCode is a minimalist platform for managing and sharing code snippets, built with Vue.js and SQLite. Unlike similar tools that depend on external services, BinCode runs entirely on your own infrastructure, giving you complete control over your data and workflow.
## Key Features
- **Fully Self-Contained:** No external dependencies or services required
- **Modern Stack:** Built with Vue.js frontend and SQLite database
- **Secure Authentication:** Simple JWT-based user management
- **Instant Sharing:** Generate unique URLs for any code snippet
- **Minimal Setup:** Just create users manually and start sharing code
- **Performance Focused:** Lightweight design ensures fast operation
## Architecture
- Frontend: Vue.js
- Database: SQLite
- Authentication: JWT
- Deployment: Single server, self-contained
There is no signups its by design just create users manullay and they can start commits snippets to share
## Why BinCode?
During my search for open-source code sharing solutions, I found that most platforms required external services or had complex deployment requirements. I needed a straightforward, self-hostable tool that focused solely on creating and sharing code snippets.
BinCode was built with simplicity in mind. While it may not have all the features of larger platforms, its lightweight nature makes it perfect for teams and individuals who need a reliable, easy-to-maintain solution for code sharing.
## Design Choices
- **No Signups:** User accounts are created manually by administrators to keep the system simple and secure
- **Self-Contained:** Everything runs on your infrastructure, ensuring data privacy and control
## Contributing
While BinCode is intentionally minimal, contributions are always welcome! Feel free to add features that enhance its functionality while maintaining its lightweight nature.
## Getting Started
### 1. Clone and Install Dependencies
```bash
git clone https://git.sheetjs.com/asadbek064/BinCode.git
cd BinCode
pnpm install
```
### 2. Set Up Environment Variables
Create a .env file in the project root and define the following variables:
```env
NODE_ENV=development
PORT=3000
JWT_SECRET=your-secure-secret-here
JWT_EXPIRES_IN=7d
```
2025-01-17 20:36:28 +00:00
### 3. Adding user
2025-01-17 20:05:21 +00:00
```bash
node addUser.js "user@email.com" "password"
```
2025-01-17 20:36:28 +00:00
### 4. Development server
Before starting the development server, ensure you change the Vue.js library import from `_prod` to `_dev` in [`index.html`](https://git.sheetjs.com/asadbek064/BinCode/src/commit/3e35da0118e8e6b44863b3fee12c1e2dff96b02e/public/index.html#L129).
2025-01-17 20:05:21 +00:00
```bash
pnpm dev
```
### 5. Production
2025-01-17 20:36:28 +00:00
Copy .env.example to .env and generate unique secret and cahnge NODE_ENV=production
1. Copy .env.example to .env:
```bash
cp .env.example .env
```
2. Generate a unique secret and set NODE_ENV=production in the .env file.
3. Start the production server
2025-01-17 20:05:21 +00:00
```
pnpm start
2025-01-17 20:36:28 +00:00
````
### 5. Production
- For development, using the `_dev` version of Vue.js (vue.global.js) is recommended as it includes debugging tools and warnings.
- For production, switch to the `_prod` version (vue.global.prod.js) to optimize performance.