https://github.com/NutPowerGrid/Collector
  
  
    Collect data from your nut server and send notification on power loss 
    https://github.com/NutPowerGrid/Collector
  
bun discord gotify influxdb ts ups
        Last synced: 7 months ago 
        JSON representation
    
Collect data from your nut server and send notification on power loss
- Host: GitHub
- URL: https://github.com/NutPowerGrid/Collector
- Owner: NutPowerGrid
- License: gpl-3.0
- Created: 2022-05-18T14:02:06.000Z (over 3 years ago)
- Default Branch: latest
- Last Pushed: 2024-10-21T20:37:28.000Z (about 1 year ago)
- Last Synced: 2024-11-06T08:40:48.892Z (12 months ago)
- Topics: bun, discord, gotify, influxdb, ts, ups
- Language: TypeScript
- Homepage:
- Size: 268 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
- 
            Metadata Files:
            - Readme: Readme.md
- License: LICENSE
 
Awesome Lists containing this project
README
          # ⚡ NutPowerGrid/Collector
#### 📢 Development is still in progress. Expect some bugs.
Easily export data from your ups to
- InfluxDB
- JSON (file)
- CSV (file)
Easily send notification on power loss to
- Discord
- Gotify
Easily access the data from your ups with a
- JSON Api
## 🔧 Requirement
- Docker/Podman
- Nut server
## 📝 To Do :
- Export to
  - API (JSON)
  - SQL DB
## 📦 Installation :
### Docker
```bash
docker run -d -it \
  --name=nut_collector \ # name of your container
  -e NUT_IP=127.0.0.1 \ # IP of your nut server
  -e NUT_UPS_NAME=upsName \ # name of your ups
  -e DISCORD_URL=https://discord.com/api/webhooks/... \ # discord webhook url (see all availables options in .env)
  -v nut_Log:/app/log \ # volume for logs (optional)
  --restart unless-stopped \
  ghcr.io/nutpowergrid/collector:latest
```
## 🌄 Screenshot :
#### InfluxDB + Chronograf

#### On startup
```bash
$ bun run src/index.ts
warn: Missing required environment variable: PATH -> JSON
warn: Missing required environment variable: PATH -> CSV
info: Power monitor enable
info: Loaded plugins (3):
 • DiscordHook
 • Gotify
 • Influx
```
## Creating Plugins
Enhance the functionality by implementing custom plugins.
Feel free to utilize the provided plugins as a reference to create your own custom plugins.
Follow these steps to create and integrate a plugin:
### 1. Create a New File
Begin by creating a new file in the plugin folder of your application. Name it appropriately, reflecting the purpose of your plugin.
### 2. Define the Plugin Class
Define a class that extends the Plugin class. This class serves as the foundation for your plugin's functionality. Ensure that it includes the necessary methods and properties.
### 3. Implement Required Functions
#### Constructor
Create a constructor function within your class to initialize the plugin. The constructor will receive environment variables as its only parameter. Utilize this function to set up essential configurations and resources needed by your plugin.
#### Send Function
Implement a send function to handle data transmission from the UPS.
#### Close Function
Define a close function to gracefully shut down the plugin when necessary. (Release any resources or connections established by the plugin during its operation.)
### Plugin Properties
#### _prefix
The _prefix property serves as a unique identifier for the plugin within the application. It helps distinguish the plugin's functionality and configuration from others when managing multiple plugins.
#### _model
The _model property defines the environment variables required by the plugin to function correctly. These variables will be automatically injected into the constructor.