upd
This commit is contained in:
75
Jenkinsfile
vendored
Normal file
75
Jenkinsfile
vendored
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
pipeline {
|
||||||
|
agent any
|
||||||
|
|
||||||
|
environment {
|
||||||
|
BOT_DIR = '/srv/fymious-tg-bot'
|
||||||
|
VENV_DIR = '/srv/fymious-tg-bot/.venv'
|
||||||
|
}
|
||||||
|
|
||||||
|
stages {
|
||||||
|
stage('Checkout') {
|
||||||
|
steps {
|
||||||
|
echo 'Pulling latest code...'
|
||||||
|
checkout scm
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stage('Setup') {
|
||||||
|
steps {
|
||||||
|
echo 'Setting up virtual environment and dependencies...'
|
||||||
|
sh '''
|
||||||
|
# Create bot directory if it doesn't exist
|
||||||
|
mkdir -p ${BOT_DIR}
|
||||||
|
|
||||||
|
# Copy files to bot directory
|
||||||
|
cp -r * ${BOT_DIR}/
|
||||||
|
|
||||||
|
cd ${BOT_DIR}
|
||||||
|
|
||||||
|
# Create virtual environment if it doesn't exist
|
||||||
|
if [ ! -d "${VENV_DIR}" ]; then
|
||||||
|
python3 -m venv ${VENV_DIR}
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Install/update dependencies
|
||||||
|
${VENV_DIR}/bin/pip install -r requirements.txt
|
||||||
|
'''
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stage('Deploy') {
|
||||||
|
steps {
|
||||||
|
echo 'Restarting bot...'
|
||||||
|
sh '''
|
||||||
|
# Kill existing bot process
|
||||||
|
pkill -f "python.*bot.py" || true
|
||||||
|
|
||||||
|
# Wait a moment
|
||||||
|
sleep 2
|
||||||
|
|
||||||
|
# Start bot in background
|
||||||
|
cd ${BOT_DIR}
|
||||||
|
nohup ${VENV_DIR}/bin/python bot.py > ${BOT_DIR}/bot.log 2>&1 &
|
||||||
|
|
||||||
|
# Verify bot started
|
||||||
|
sleep 3
|
||||||
|
if pgrep -f "python.*bot.py" > /dev/null; then
|
||||||
|
echo "Bot started successfully!"
|
||||||
|
else
|
||||||
|
echo "Failed to start bot. Check logs at ${BOT_DIR}/bot.log"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
'''
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
post {
|
||||||
|
success {
|
||||||
|
echo 'Deployment successful!'
|
||||||
|
}
|
||||||
|
failure {
|
||||||
|
echo 'Deployment failed!'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
54
main.py
Normal file
54
main.py
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
import os
|
||||||
|
import logging
|
||||||
|
from telegram import Update
|
||||||
|
from telegram.ext import Application, CommandHandler, MessageHandler, filters, ContextTypes
|
||||||
|
|
||||||
|
# Enable logging
|
||||||
|
logging.basicConfig(
|
||||||
|
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
|
||||||
|
level=logging.INFO
|
||||||
|
)
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
# Bot token from environment variable
|
||||||
|
TOKEN = os.getenv('TELEGRAM_BOT_TOKEN')
|
||||||
|
|
||||||
|
async def start(update: Update, context: ContextTypes.DEFAULT_TYPE):
|
||||||
|
"""Send a message when the command /start is issued."""
|
||||||
|
await update.message.reply_text(
|
||||||
|
'Hi! I am Fymious Bot. Send me any message and I will echo it back!'
|
||||||
|
)
|
||||||
|
|
||||||
|
async def help_command(update: Update, context: ContextTypes.DEFAULT_TYPE):
|
||||||
|
"""Send a message when the command /help is issued."""
|
||||||
|
await update.message.reply_text(
|
||||||
|
'Available commands:\n'
|
||||||
|
'/start - Start the bot\n'
|
||||||
|
'/help - Show this help message\n'
|
||||||
|
'\nJust send me any text and I will echo it back!'
|
||||||
|
)
|
||||||
|
|
||||||
|
async def echo(update: Update, context: ContextTypes.DEFAULT_TYPE):
|
||||||
|
"""Echo the user message."""
|
||||||
|
await update.message.reply_text(f"You said: {update.message.text}")
|
||||||
|
|
||||||
|
def main():
|
||||||
|
"""Start the bot."""
|
||||||
|
if not TOKEN:
|
||||||
|
logger.error("TELEGRAM_BOT_TOKEN environment variable not set!")
|
||||||
|
return
|
||||||
|
|
||||||
|
# Create the Application
|
||||||
|
application = Application.builder().token(TOKEN).build()
|
||||||
|
|
||||||
|
# Register handlers
|
||||||
|
application.add_handler(CommandHandler("start", start))
|
||||||
|
application.add_handler(CommandHandler("help", help_command))
|
||||||
|
application.add_handler(MessageHandler(filters.TEXT & ~filters.COMMAND, echo))
|
||||||
|
|
||||||
|
# Start the Bot
|
||||||
|
logger.info("Bot is starting...")
|
||||||
|
application.run_polling(allowed_updates=Update.ALL_TYPES)
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
||||||
1
requirements.txt
Normal file
1
requirements.txt
Normal file
@@ -0,0 +1 @@
|
|||||||
|
python-telegram-bot==21.0
|
||||||
Reference in New Issue
Block a user