Added flask web app

This commit is contained in:
2024-02-25 10:51:37 +01:00
parent 306a739e08
commit b35aa593d2
17 changed files with 362 additions and 2 deletions

25
.vscode/launch.json vendored
View File

@@ -11,6 +11,29 @@
"program": "${workspaceFolder}/alert-scheduler/src/watchdog.py", "program": "${workspaceFolder}/alert-scheduler/src/watchdog.py",
"console": "integratedTerminal", "console": "integratedTerminal",
"cwd": "${workspaceFolder}/alert-scheduler" "cwd": "${workspaceFolder}/alert-scheduler"
} },
{
"name": "Web (Flask)",
"type": "python",
"request": "launch",
"module": "flask",
"env": {
"FLASK_APP": "web.src.webapp"
},
"args": [
"run",
"--no-debugger",
"--no-reload"
]
},
{
"name": "Python: Current File",
"type": "python",
"request": "launch",
"program": "${file}",
"env": {
"FLASK_ENV": "development"
}
}
] ]
} }

View File

@@ -3,12 +3,21 @@ version: '3.4'
services: services:
watchdog: watchdog:
image: watchdog image: alert-scheduler
restart: always restart: always
build: build:
context: ./alert-scheduler context: ./alert-scheduler
dockerfile: ./Dockerfile dockerfile: ./Dockerfile
web:
image: web
restart: unless-stopped
ports:
- 5200:5200
build:
context: ./web
dockerfile: ./Dockerfile
mongo: mongo:
image: mongo image: mongo
restart: always restart: always

26
web/.dockerignore Normal file
View File

@@ -0,0 +1,26 @@
**/__pycache__
**/.venv
**/.classpath
**/.dockerignore
**/.env
**/.git
**/.gitignore
**/.project
**/.settings
**/.toolstarget
**/.vs
**/.vscode
**/*.*proj.user
**/*.dbmdl
**/*.jfm
**/bin
**/charts
**/docker-compose*
**/compose*
**/Dockerfile*
**/node_modules
**/npm-debug.log
**/obj
**/secrets.dev.yaml
**/values.dev.yaml
README.md

107
web/.gitignore vendored Normal file
View File

@@ -0,0 +1,107 @@
# Byte-compiled / optimized / DLL files
__pycache__/
*.py[cod]
*$py.class
# C extensions
*.so
# Distribution / packaging
.Python
build/
develop-eggs/
dist/
downloads/
eggs/
.eggs/
lib/
lib64/
parts/
sdist/
var/
wheels/
*.egg-info/
.installed.cfg
*.egg
MANIFEST
# PyInstaller
# Usually these files are written by a python script from a template
# before PyInstaller builds the exe, so as to inject date/other infos into it.
*.manifest
*.spec
# Installer logs
pip-log.txt
pip-delete-this-directory.txt
# Unit test / coverage reports
htmlcov/
.tox/
.coverage
.coverage.*
.cache
nosetests.xml
coverage.xml
*.cover
.hypothesis/
.pytest_cache/
# Translations
*.mo
*.pot
# Django stuff:
*.log
local_settings.py
db.sqlite3
# Flask stuff:
instance/
.webassets-cache
# Scrapy stuff:
.scrapy
# Sphinx documentation
docs/_build/
# PyBuilder
target/
# Jupyter Notebook
.ipynb_checkpoints
# pyenv
.python-version
# celery beat schedule file
celerybeat-schedule
# SageMath parsed files
*.sage.py
# Environments
.env
.venv
env/
venv/
ENV/
env.bak/
venv.bak/
# Spyder project settings
.spyderproject
.spyproject
# Rope project settings
.ropeproject
# mkdocs documentation
/site
# mypy
.mypy_cache/
.vscode/
settings.json

27
web/Dockerfile Normal file
View File

@@ -0,0 +1,27 @@
# For more information, please refer to https://aka.ms/vscode-docker-python
FROM python:3.11-slim-bullseye
EXPOSE 5200
# Keeps Python from generating .pyc files in the container
ENV PYTHONDONTWRITEBYTECODE=1
# Turns off buffering for easier container logging
ENV PYTHONUNBUFFERED=1
#RUN apt-get update && apt-get install -y iputils-ping
# Install pip requirements
COPY requirements.txt .
RUN python -m pip install -r requirements.txt
WORKDIR /app
COPY . /app
# Creates a non-root user with an explicit UID and adds permission to access the /app folder
# For more info, please refer to https://aka.ms/vscode-docker-python-configure-containers
RUN adduser -u 5678 --disabled-password --gecos "" appuser && chown -R appuser /app
USER appuser
# During debugging, this entry point will be overridden. For more information, please refer to https://aka.ms/vscode-docker-python-debug
CMD ["gunicorn", "--bind", "0.0.0.0:5200", "--timeout", "60", "--workers", "2", "src.webapp:app"]

3
web/requirements.txt Normal file
View File

@@ -0,0 +1,3 @@
Flask==3.0.2
gunicorn==21.2.0
paho_mqtt==2.0.0

10
web/src/__init__.py Normal file
View File

@@ -0,0 +1,10 @@
from flask import Flask # Import the Flask class
app = Flask(__name__) # Create an instance of the class for our use
import paho.mqtt.client as mqtt
print("Starting up...")
client = mqtt.Client(mqtt.CallbackAPIVersion.VERSION2)
client.connect("192.168.178.36",1884,keepalive=60)
client.publish("web2mqtt/status","Web2Mqtt starting up...")

5
web/src/static/data.json Normal file
View File

@@ -0,0 +1,5 @@
{
"01": {
"note" : "Data is very simple because we're demonstrating only the mechanism."
}
}

32
web/src/static/site.css Normal file
View File

@@ -0,0 +1,32 @@
.message {
font-weight: 600;
color: blue;
}
.navbar {
background-color: lightslategray;
font-size: 1em;
font-family: 'Trebuchet MS', 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans', Arial, sans-serif;
color: white;
padding: 8px 5px 8px 5px;
}
.navbar a {
text-decoration: none;
color: inherit;
}
.navbar-brand {
font-size: 1.2em;
font-weight: 600;
}
.navbar-item {
font-variant: small-caps;
margin-left: 30px;
}
.body-content {
padding: 5px;
font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

View File

@@ -0,0 +1,7 @@
{% extends "layout.html" %}
{% block title %}
About us
{% endblock %}
{% block content %}
<p>About page for the Visual Studio Code Flask tutorial.</p>
{% endblock %}

View File

@@ -0,0 +1,7 @@
{% extends "layout.html" %}
{% block title %}
Contact us
{% endblock %}
{% block content %}
<p>Contact page for the Visual Studio Code Flask tutorial.</p>
{% endblock %}

View File

@@ -0,0 +1,16 @@
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<link rel="stylesheet" type="text/css" href="{{ url_for('static', filename='site.css') }}" />
<title>Hello, Flask</title>
</head>
<body>
{%if name %}
<span class="message">Hello there, {{ name }}!</span> It's {{ date.strftime("%A, %d %B, %Y at %X") }}.
{% else %}
<span class="message">What's your name? Provide it after /hello/ in the URL.</span>
{% endif %}
</body>
</html>
<!-- The above syntax makes use of jinja and it's documentation can be found over here http://jinja.pocoo.org/docs/2.10/templates/ -->

View File

@@ -0,0 +1,7 @@
{% extends "layout.html" %}
{% block title %}
Home
{% endblock %}
{% block content %}
<p>Home page for the Visual Studio Code Flask tutorial.</p>
{% endblock %}

View File

@@ -0,0 +1,25 @@
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>{% block title %}{% endblock %}</title>
<link rel="stylesheet" type="text/css" href="{{ url_for('static', filename='site.css') }}" />
</head>
<body>
<div class="navbar">
<a href="{{ url_for('home') }}" class="navbar-brand">Home</a>
<a href="{{ url_for('about') }}" class="navbar-item">About</a>
<a href="{{ url_for('contact') }}" class="navbar-item">Contact</a>
</div>
<div class="body-content">
{% block content %}
{% endblock %}
<hr/>
<footer>
<p>&copy; 2018</p>
</footer>
</div>
</body>
</html>

48
web/src/views.py Normal file
View File

@@ -0,0 +1,48 @@
from datetime import datetime
from flask import Flask, render_template,request
from . import app, client
@app.route("/")
def home():
return render_template("home.html")
@app.route("/about/")
def about():
return render_template("about.html")
@app.route("/contact/")
def contact():
return render_template("contact.html")
@app.route("/hello/")
@app.route("/hello/<name>")
def hello_there(name = None):
return render_template(
"hello_there.html",
name=name,
date=datetime.now()
)
@app.route("/api/data")
def get_data():
return app.send_static_file("data.json")
CMD = "web2mqtt/command"
@app.route("/cmnd")
def command():
opts = ""
command = CMD
if request.args.get('cmnd'):
command += "/" + request.args.get('cmnd')
if request.args.get('opts'):
opts = request.args.get('opts')
if not client.is_connected():
print("reconnection to mqtt server...")
client.connect("192.168.178.36",1884,keepalive=60)
client.publish(command,opts)
content = f"Command: {command} triggered with opts: {opts}"
return content

7
web/src/webapp.py Normal file
View File

@@ -0,0 +1,7 @@
# Entry point for the application.
import gunicorn
from . import app # For application discovery by the 'flask' command.
from . import views # For import side-effects of setting up routes.
# Time-saver: output a URL to the VS Code terminal so you can easily Ctrl+click to open a browser
# print('http://127.0.0.1:5000/hello/VSCode')

1
web/update_reqs.sh Executable file
View File

@@ -0,0 +1 @@
pipreqs . --force