Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d0f4381a59 | ||
|
|
d200d3d1d5 | ||
|
|
530e6def77 | ||
|
|
40924e10c0 | ||
|
|
8c6b081379 |
14
Dockerfile
Normal file
14
Dockerfile
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
FROM python:3.10-slim
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
|
COPY requirements.txt requirements.txt
|
||||||
|
RUN pip install --no-cache-dir -r requirements.txt
|
||||||
|
|
||||||
|
COPY . .
|
||||||
|
|
||||||
|
ENV DISCORD_TOKEN=$DISCORD_TOKEN
|
||||||
|
ENV DISCORD_CHANNEL_ID=$DISCORD_CHANNEL_ID
|
||||||
|
ENV PORT=$PORT
|
||||||
|
|
||||||
|
CMD ["python", "bot.py"]
|
||||||
76
app.py
Normal file
76
app.py
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
from flask import Flask, render_template, request, redirect, url_for, session, jsonify
|
||||||
|
import os
|
||||||
|
import requests
|
||||||
|
import discord
|
||||||
|
from discord.ext import commands
|
||||||
|
|
||||||
|
# Discord bot setup
|
||||||
|
intents = discord.Intents.default()
|
||||||
|
intents.message_content = True
|
||||||
|
bot = commands.Bot(command_prefix="!", intents=intents)
|
||||||
|
|
||||||
|
DISCORD_TOKEN = os.getenv("DISCORD_TOKEN")
|
||||||
|
CHANNEL_ID = int(os.getenv("DISCORD_CHANNEL_ID"))
|
||||||
|
|
||||||
|
# Flask app setup
|
||||||
|
app = Flask(__name__)
|
||||||
|
app.secret_key = os.urandom(24)
|
||||||
|
|
||||||
|
# Function to check the status of the other bot
|
||||||
|
def check_bot_status():
|
||||||
|
try:
|
||||||
|
response = requests.get("https://nww8w44sgg0c8okcc8wg8soc.simolzimol.net/")
|
||||||
|
if response.status_code == 200:
|
||||||
|
return "Online"
|
||||||
|
else:
|
||||||
|
return "Offline"
|
||||||
|
except requests.exceptions.RequestException:
|
||||||
|
return "Offline"
|
||||||
|
|
||||||
|
@app.route("/")
|
||||||
|
def index():
|
||||||
|
if "username" in session:
|
||||||
|
bot_status = check_bot_status()
|
||||||
|
return render_template("index.html", bot_status=bot_status)
|
||||||
|
return redirect(url_for("login"))
|
||||||
|
|
||||||
|
@app.route("/login", methods=["GET", "POST"])
|
||||||
|
def login():
|
||||||
|
if request.method == "POST":
|
||||||
|
username = request.form["username"]
|
||||||
|
password = request.form["password"]
|
||||||
|
# Simple auth check, replace with a proper method
|
||||||
|
if username == "admin" and password == "password":
|
||||||
|
session["username"] = username
|
||||||
|
return redirect(url_for("index"))
|
||||||
|
else:
|
||||||
|
return "Login Failed"
|
||||||
|
return render_template("login.html")
|
||||||
|
|
||||||
|
@app.route("/logout")
|
||||||
|
def logout():
|
||||||
|
session.pop("username", None)
|
||||||
|
return redirect(url_for("login"))
|
||||||
|
|
||||||
|
@app.route("/post_message", methods=["POST"])
|
||||||
|
def post_message():
|
||||||
|
if "username" in session:
|
||||||
|
category = request.form.get("category")
|
||||||
|
message = request.form.get("message")
|
||||||
|
bot.loop.create_task(post_to_discord(category, message))
|
||||||
|
return redirect(url_for("index"))
|
||||||
|
return redirect(url_for("login"))
|
||||||
|
|
||||||
|
async def post_to_discord(category, message):
|
||||||
|
channel = bot.get_channel(CHANNEL_ID)
|
||||||
|
await channel.send(f"**[{category.upper()}]** {message}")
|
||||||
|
|
||||||
|
# Run the Flask app and Discord bot
|
||||||
|
def start_bot():
|
||||||
|
bot.run(DISCORD_TOKEN)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
from threading import Thread
|
||||||
|
bot_thread = Thread(target=start_bot)
|
||||||
|
bot_thread.start()
|
||||||
|
app.run(host="0.0.0.0", port=5000)
|
||||||
57
bot.py
Normal file
57
bot.py
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
import discord
|
||||||
|
import os
|
||||||
|
from discord.ext import commands
|
||||||
|
from flask import Flask, request, jsonify
|
||||||
|
|
||||||
|
intents = discord.Intents.default()
|
||||||
|
intents.message_content = True
|
||||||
|
bot = commands.Bot(command_prefix="!", intents=intents)
|
||||||
|
|
||||||
|
DISCORD_TOKEN = os.getenv("DISCORD_TOKEN")
|
||||||
|
CHANNEL_ID = int(os.getenv("DISCORD_CHANNEL_ID"))
|
||||||
|
|
||||||
|
app = Flask(__name__)
|
||||||
|
|
||||||
|
@bot.event
|
||||||
|
async def on_ready():
|
||||||
|
channel = bot.get_channel(CHANNEL_ID)
|
||||||
|
await channel.send("Info-Bot is now online!")
|
||||||
|
|
||||||
|
@bot.command()
|
||||||
|
async def post(ctx, category: str, *, message: str):
|
||||||
|
await ctx.send(f"**[{category.upper()}]** {message}")
|
||||||
|
|
||||||
|
@app.route("/webhook", methods=["POST"])
|
||||||
|
def webhook():
|
||||||
|
data = request.json
|
||||||
|
if 'commits' in data:
|
||||||
|
commits = data['commits']
|
||||||
|
for commit in commits:
|
||||||
|
message = f"New commit by {commit['author']['name']}: {commit['message']} - {commit['url']}"
|
||||||
|
bot.loop.create_task(post_commit(message))
|
||||||
|
return jsonify({"status": "success"}), 200
|
||||||
|
|
||||||
|
async def post_commit(message):
|
||||||
|
channel = bot.get_channel(CHANNEL_ID)
|
||||||
|
await channel.send(message)
|
||||||
|
|
||||||
|
# Flask route for manual posts
|
||||||
|
@app.route("/post", methods=["POST"])
|
||||||
|
def manual_post():
|
||||||
|
category = request.form.get("category")
|
||||||
|
message = request.form.get("message")
|
||||||
|
bot.loop.create_task(post_manual(category, message))
|
||||||
|
return jsonify({"status": "success"}), 200
|
||||||
|
|
||||||
|
async def post_manual(category, message):
|
||||||
|
channel = bot.get_channel(CHANNEL_ID)
|
||||||
|
await channel.send(f"**[{category.upper()}]** {message}")
|
||||||
|
|
||||||
|
def start_flask():
|
||||||
|
app.run(host="0.0.0.0", port=os.getenv("PORT"))
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
from threading import Thread
|
||||||
|
flask_thread = Thread(target=start_flask)
|
||||||
|
flask_thread.start()
|
||||||
|
bot.run(DISCORD_TOKEN)
|
||||||
4
requirements.txt
Normal file
4
requirements.txt
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
discord.py
|
||||||
|
flask
|
||||||
|
requests
|
||||||
|
psutil
|
||||||
36
templates/index.html
Normal file
36
templates/index.html
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>Info-Bot Admin Panel</title>
|
||||||
|
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css" rel="stylesheet">
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div class="container mt-5">
|
||||||
|
<h1 class="text-center">Info-Bot Admin Panel</h1>
|
||||||
|
|
||||||
|
<h2 class="mt-4">Bot Status</h2>
|
||||||
|
<p class="lead">Other Bot Status: <strong>{{ bot_status }}</strong></p>
|
||||||
|
|
||||||
|
<h2 class="mt-4">Post a Message to Discord</h2>
|
||||||
|
<form action="/post_message" method="post">
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="category">Category:</label>
|
||||||
|
<select class="form-control" id="category" name="category">
|
||||||
|
<option value="Important">Important</option>
|
||||||
|
<option value="Info">Info</option>
|
||||||
|
<option value="Update">Update</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="message">Message:</label>
|
||||||
|
<textarea class="form-control" id="message" name="message" rows="3" required></textarea>
|
||||||
|
</div>
|
||||||
|
<button type="submit" class="btn btn-success">Post Message</button>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<a href="/logout" class="btn btn-secondary btn-block mt-4">Logout</a>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
25
templates/login.html
Normal file
25
templates/login.html
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>Login</title>
|
||||||
|
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css" rel="stylesheet">
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div class="container mt-5">
|
||||||
|
<h1 class="text-center">Login</h1>
|
||||||
|
<form action="/login" method="post">
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="username">Username:</label>
|
||||||
|
<input type="text" class="form-control" id="username" name="username" required>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="password">Password:</label>
|
||||||
|
<input type="password" class="form-control" id="password" name="password" required>
|
||||||
|
</div>
|
||||||
|
<button type="submit" class="btn btn-primary btn-block">Login</button>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
22
templates/post.html
Normal file
22
templates/post.html
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>Info-Bot Post</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<h1>Post a Message to Discord</h1>
|
||||||
|
<form action="/post" method="post">
|
||||||
|
<label for="category">Category:</label>
|
||||||
|
<select name="category" id="category">
|
||||||
|
<option value="Important">Important</option>
|
||||||
|
<option value="Info">Info</option>
|
||||||
|
<option value="Update">Update</option>
|
||||||
|
</select><br><br>
|
||||||
|
<label for="message">Message:</label><br>
|
||||||
|
<textarea name="message" id="message" rows="4" cols="50"></textarea><br><br>
|
||||||
|
<input type="submit" value="Post">
|
||||||
|
</form>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
Reference in New Issue
Block a user