Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nikolap994/navnode-gui
Navnode GUI is a project designed to facilitate running commands on remote servers via webhooks and managing cronjobs.
https://github.com/nikolap994/navnode-gui
cronjob deployment remote remote-execution scheduled-tasks webhooks
Last synced: about 2 months ago
JSON representation
Navnode GUI is a project designed to facilitate running commands on remote servers via webhooks and managing cronjobs.
- Host: GitHub
- URL: https://github.com/nikolap994/navnode-gui
- Owner: nikolap994
- License: mit
- Created: 2024-05-09T21:52:50.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-09-18T07:48:59.000Z (4 months ago)
- Last Synced: 2024-09-18T10:16:57.528Z (4 months ago)
- Topics: cronjob, deployment, remote, remote-execution, scheduled-tasks, webhooks
- Language: JavaScript
- Homepage:
- Size: 512 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Navnode GUI
Navnode GUI is a project designed to facilitate running commands on remote servers via webhooks and managing cronjobs.
## Project Overview
Navnode GUI provides a web interface for managing remote server commands via webhooks. It allows you to configure and trigger commands remotely, and if necessary, set up recurring tasks using cronjobs.
### Features
- **Webhooks**: Configure endpoints to trigger specific commands on remote servers.
- **Cronjobs**: Schedule recurring tasks to automate processes.
- **PM2 Integration**: Use PM2 to manage scheduled processes and view logs.## Getting Started
To start the project locally, follow these steps:
1. **Clone the Repository**
```bash
git clone https://github.com/nikolap994/navnode-gui.git
cd navnode-gui
```2. **Install Dependencies**
Ensure you have Node.js and npm installed on your machine. Then, install the project dependencies:
```bash
npm install
```3. **Set Up Environment Variables**
Create a `.env` file in the root directory of the project with the following content:```bash
MONGODB_URI="mongodb+srv://:@/"
SITE_URI="http://localhost:3000"
NEXTAUTH_JWT_SECRET="sercret"
NEXTAUTH_SECRET="secret"
```- Replace `MONGODB_URI` with your MongoDB connection string.
- Replace `SITE_URI` with the URL of your deployed site or development server.
- Replace `NEXTAUTH_JWT_SECRET` with secret for example `b4ed764b60a9a9be8452f06ca06519f9`
- Replace `NEXTAUTH_SECRET` with secret for example `b4ed764b60a9a9be8452f06ca06519f9`1. **Start the Development Server**
Run the following command to start the development server:
```bash
npm run dev
```This will start the project on `http://localhost:3000`.
## Cronjobs
Navnode GUI includes functionality to manage cronjobs. You can use PM2 to manage the scheduler process. Here are the available commands:
- **Start the Cronjob Scheduler**
```bash
npm run start-cron-job
```- **Stop the Cronjob Scheduler**
```bash
npm run stop-cron-job
```
- **Restart the Cronjob Scheduler**
```bash
npm run restart-cron-job
```
- **Display Logs of the Cronjob Scheduler**
```bash
npm run logs-cron-job
```
- **List All PM2-Managed Processes**
```bash
npm run list-processes
```
# User Authentication Flow## Initial Setup
To begin using Navnode GUI, follow these steps to set up your account:
1. **Register**: If there are no existing users in the database, visit the registration page.
- Provide your email address and choose a password.
- Submit the registration form to create your account.
2. **Login**: Once registered, log in using your email and password to access the dashboard.## User Management
After logging in, you can manage users as follows:
1. **Add New User**:
- Navigate to the user management section in the dashboard.
- Select the option to add a new user.
- Enter the new user's email address and assign a password.
- Submit the form to create the new user account.2. **User Access**:
- All users have equal access to the available resources within the application.
- Ensure new users log in using their registered email and password to access the dashboard.## Authentication Details
- **Authentication Method**: Navnode GUI uses basic email and password authentication.
- **First User Registration**: The first user to register becomes the initial administrator.
- **Subsequent User Management**: Admin users can add, modify, or remove users from the dashboard.## Custom Hooks in Navnode GUI
Custom hooks allow you to execute specific actions before and after running remote commands in your Navnode GUI project. These hooks are defined in `src/hooks`.
```css
navnode-gui/
├── src/
│ ├── hooks/
│ │ ├── cronjobHook.js
│ │ ├── deploymentHook.js
│ │ └── webhookHook.js
│ └── ...
└── ...
```In the **Navnode GUI** application, the `beforeDeployHook` and `afterDeployHook` are custom hooks designed to execute specific actions before and after deployment tasks, respectively. These hooks provide a flexible way to intervene in the deployment process, allowing users to customize server-side actions based on their specific needs.
The `beforeDeployHook` is triggered before a deployment action occurs. This hook can be modified to perform any pre-deployment tasks, such as environment validation, setup checks, or custom preparations needed for the deployment process. Users have the flexibility to define and incorporate their own logic within this hook to ensure that deployments proceed smoothly and efficiently.
Conversely, the `afterDeployHook` is called after a deployment action completes. This hook enables users to execute post-deployment tasks, such as logging deployment results, sending notifications, or performing additional actions based on the outcome of the deployment. Users can tailor this hook to implement specific follow-up procedures that enhance the management and monitoring of deployment activities within the **Navnode GUI** environment.
By leveraging these hooks, developers can extend the functionality of the **Navnode GUI** application, introducing custom behaviors that align with project requirements and operational workflows. This modular approach empowers users to exert fine-grained control over deployment processes and seamlessly integrate server-side actions tailored to their unique use cases and preferences.
### Tech Stack
- **Frontend**: Next.js
- **Backend**: Node.js
- **Database**: MongoDB### Contributing
Contributions are welcome! Please follow the standard GitHub flow:
1. Fork the repository.
2. Create a new branch (`git checkout -b feature/my-feature`).
3. Make your changes.
4. Commit your changes (`git commit -am 'Add new feature'`).
5. Push to the branch (`git push origin feature/my-feature`).
6. Create a new Pull Request.### License
This project is licensed under the [MIT License](LICENSE).