Spaces:
Running
Running
File size: 2,928 Bytes
5c6037b e96a62a 5c6037b e96a62a 3a2ce2a 5c6037b e96a62a 5c6037b 7d3399c 5c6037b e96a62a 5c6037b 3a2ce2a 7d3399c 5c6037b 3a2ce2a 7d3399c 5c6037b 7d3399c 5c6037b 3a2ce2a e96a62a 7d3399c e96a62a 7d3399c 5c6037b 3a2ce2a 5c6037b 3a2ce2a 5c6037b 3a2ce2a 5c6037b 3a2ce2a 5c6037b 3a2ce2a 7d3399c 3a2ce2a 7d3399c 5c6037b 7d3399c 5c6037b 3a2ce2a e96a62a 7d3399c |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 |
from flask import Flask, render_template_string
from apscheduler.schedulers.background import BackgroundScheduler
import subprocess
from datetime import datetime
app = Flask(__name__)
execution_logs = []
MAX_LOG_ENTRIES = 20
def run_cli_script():
timestamp = datetime.utcnow().strftime("%Y-%m-%d %H:%M:%S UTC")
log_entry = {'time': timestamp, 'output': '', 'error': ''}
try:
result = subprocess.run(
["python", "cli.py"],
capture_output=True,
text=True,
timeout=300
)
log_entry['output'] = result.stdout
log_entry['error'] = result.stderr
except Exception as e:
log_entry['error'] = str(e)
finally:
execution_logs.append(log_entry)
if len(execution_logs) > MAX_LOG_ENTRIES:
execution_logs.pop(0)
# Initialize scheduler properly
scheduler = BackgroundScheduler(daemon=True)
scheduler.add_job(run_cli_script, 'interval', hours=3, id='main_job')
scheduler.start()
run_cli_script() # Initial run
@app.route('/')
def home():
job = scheduler.get_job('main_job')
next_run = job.next_run_time.strftime('%Y-%m-%d %H:%M:%S UTC') if job else 'N/A'
return render_template_string('''
<!DOCTYPE html>
<html>
<head>
<title>Script Scheduler</title>
<meta http-equiv="refresh" content="10">
<style>
body { font-family: Arial, sans-serif; padding: 20px; }
.log-box {
background: #000;
color: #0f0;
padding: 15px;
border-radius: 5px;
margin-top: 20px;
white-space: pre-wrap;
}
.timestamp { color: #888; margin-bottom: 10px; }
.error { color: #ff4444; }
</style>
</head>
<body>
<h1>Script Scheduler</h1>
<p>Next run: {{ next_run }}</p>
<h2>Latest Execution Logs</h2>
<div class="log-box">
{% for log in logs|reverse %}
<div class="timestamp">{{ log.time }}</div>
{% if log.output %}
<div class="output">{{ log.output }}</div>
{% endif %}
{% if log.error %}
<div class="error">{{ log.error }}</div>
{% endif %}
<hr>
{% else %}
<div>No logs available yet</div>
{% endfor %}
</div>
<p><a href="/force-run">Trigger Manual Run</a></p>
</body>
</html>
''', next_run=next_run, logs=execution_logs)
@app.route('/force-run')
def force_run():
run_cli_script()
return "Script executed manually", 200
if __name__ == '__main__':
app.run(host='0.0.0.0', port=7860) |