From d1d0ccc3115e5d54ca16c7361d53ba45f7bf2763 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mateusz=20Gruszczy=C5=84ski?= Date: Mon, 24 Feb 2025 23:08:03 +0100 Subject: [PATCH] refactor --- README.md | 99 ++++++- app.py | 2 +- templates/backups.html | 178 ++----------- templates/base.html | 203 ++++++++++++++ templates/change_password.html | 70 +---- templates/clear_hosts.html | 48 ++-- templates/dashboard.html | 356 +++++-------------------- templates/deploy_hosts_file.html | 56 ++-- templates/edit_host.html | 106 ++++---- templates/edit_hosts.html | 51 +--- templates/edit_local_hosts.html | 12 + templates/hosts.html | 209 ++++++--------- templates/hosts_files.html | 74 ++--- templates/import_hosts.html | 43 +-- templates/list_regex_hosts.html | 160 +++-------- templates/login.html | 83 ++---- templates/new_edit_hosts_file.html | 51 ++-- templates/new_edit_regex_host.html | 142 +++------- templates/register.html | 77 ++---- templates/settings.html | 150 ++--------- templates/view_backup.html | 53 ++-- templates_old/backups.html | 149 +++++++++++ templates_old/change_password.html | 58 ++++ templates_old/clear_hosts.html | 32 +++ templates_old/dashboard.html | 297 +++++++++++++++++++++ templates_old/deploy_hosts_file.html | 41 +++ templates_old/edit_host.html | 62 +++++ templates_old/edit_hosts.html | 41 +++ templates_old/hosts.html | 160 +++++++++++ templates_old/hosts_files.html | 48 ++++ templates_old/import_hosts.html | 31 +++ templates_old/list_regex_hosts.html | 121 +++++++++ templates_old/login.html | 60 +++++ templates_old/new_edit_hosts_file.html | 35 +++ templates_old/new_edit_regex_host.html | 106 ++++++++ templates_old/register.html | 60 +++++ templates_old/settings.html | 122 +++++++++ templates_old/view_backup.html | 33 +++ 38 files changed, 2251 insertions(+), 1428 deletions(-) create mode 100644 templates/base.html create mode 100644 templates/edit_local_hosts.html create mode 100644 templates_old/backups.html create mode 100644 templates_old/change_password.html create mode 100644 templates_old/clear_hosts.html create mode 100644 templates_old/dashboard.html create mode 100644 templates_old/deploy_hosts_file.html create mode 100644 templates_old/edit_host.html create mode 100644 templates_old/edit_hosts.html create mode 100644 templates_old/hosts.html create mode 100644 templates_old/hosts_files.html create mode 100644 templates_old/import_hosts.html create mode 100644 templates_old/list_regex_hosts.html create mode 100644 templates_old/login.html create mode 100644 templates_old/new_edit_hosts_file.html create mode 100644 templates_old/new_edit_regex_host.html create mode 100644 templates_old/register.html create mode 100644 templates_old/settings.html create mode 100644 templates_old/view_backup.html diff --git a/README.md b/README.md index bc3f90c..5d5d789 100644 --- a/README.md +++ b/README.md @@ -1,21 +1,92 @@ -# RouterOS backup system +/etc/hosts Manager to aplikacja webowa do zarządzania plikami hosts na zdalnych serwerach, napisana przy użyciu Flask, SQLAlchemy oraz APScheduler. Aplikacja umożliwia dodawanie, edycję, usuwanie hostów, import/eksport konfiguracji, tworzenie backupów oraz automatyczne wdrażanie zmian. -# Instalation: - - clone (to ex. /opt/hosts_app) - - create venv - - install requirements via pip - - copy systemd service (hosts_app.service) +Wymagania +--------- +- Python 3.7 lub nowszy +- Pakiety: + - Flask + - Flask-SQLAlchemy + - APScheduler + - paramiko + - waitress -# Start - - edit gunicorn_config.py and set listen IP - - systemctl start hosts_app.service - - go to http://IPADDRESS:8888 +Możesz zainstalować wszystkie zależności za pomocą polecenia: -# Register, Login + pip install -r requirements.txt -# Configure devices, /etc/hosts +Przykładowa zawartość pliku requirements.txt: +----------------------------------------------- +Flask +Flask-SQLAlchemy +APScheduler +paramiko +waitress +Uruchamianie Aplikacji +---------------------- +Tryb developerski +----------------- +Aplikację można uruchomić lokalnie, korzystając z wbudowanego serwera Flask: -# Authors + python app.py -- [@linuxiarz.pl] +Aplikacja będzie dostępna domyślnie pod adresem: http://0.0.0.0:8888 + +Uruchomienie z Waitress +----------------------- +Aby uruchomić aplikację w trybie produkcyjnym przy użyciu serwera Waitress, użyj pliku run_waitress.py: + + python run_waitress.py + +Aplikacja będzie dostępna pod adresem: http://0.0.0.0:5580 + + - Port: 5580 + - Liczba wątków: 4 + +Harmonogramy +------------ +Aplikacja wykorzystuje APScheduler do automatycznych zadań: +- Automatyczne wdrożenia co 5 minut (jeśli włączone w ustawieniach użytkownika). +- Automatyczne tworzenie backupów co 60 minut. +- Czyszczenie starych backupów co 24 godziny. + +Harmonogramy działają w tle w ramach kontekstu aplikacji i są uruchamiane przy starcie aplikacji. + +Struktura Katalogów +------------------- +- app.py – główny plik aplikacji Flask. +- run_waitress.py – plik do uruchamiania aplikacji z serwerem Waitress. +- templates/ – katalog z szablonami HTML. +- static/ – katalog na zasoby statyczne (CSS, JS, obrazy). + +Dodatkowe Informacje +-------------------- +- Aplikacja ukrywa nagłówki serwera dzięki ustawieniom w app.py. +- Interfejs został zmodernizowany przy użyciu Bootstrapa 5, z możliwością przełączania trybu jasnego i ciemnego. +- Tooltipy są używane do dynamicznego wyświetlania rozwiązywanych nazw hostów przy najechaniu myszką. +- Automatyczne zadania i harmonogramy działają w tle, dzięki czemu aplikacja wykonuje regularne wdrożenia i backupy. + +Instalacja środowiska wirtualnego (venv) +----------------------------------------- +Aby utworzyć środowisko wirtualne w Pythonie, wykonaj poniższe kroki: + +1. Utwórz środowisko: + + python -m venv venv + +2. Aktywuj środowisko: + - W systemach Unix/Linux/macOS: + + source venv/bin/activate + + - W systemie Windows: + + venv\Scripts\activate + +3. Zainstaluj wymagane pakiety: + + pip install -r requirements.txt + +Kontakt +------- +@linuxiarz.pl diff --git a/app.py b/app.py index a116b83..feb0565 100644 --- a/app.py +++ b/app.py @@ -1077,6 +1077,6 @@ if __name__ == '__main__': db.create_all() app.run( host='0.0.0.0', - port=8888, + port=5580, use_reloader=False, ) diff --git a/templates/backups.html b/templates/backups.html index 38e8f05..1824ef6 100644 --- a/templates/backups.html +++ b/templates/backups.html @@ -1,149 +1,29 @@ - - - - - Backups - - - -
-

Backups

- - - - - - - - - - - - {% for backup in backups %} - - - - - - - - {% endfor %} -
IDHostCreated AtDescriptionActions
{{ backup.id }}{{ backup.host.hostname if backup.host else 'Default Configuration' }}{{ backup.created_at }}{{ backup.description or '' }} - - View - - - Restore - - -
- -
-
- -
- - +{% extends "base.html" %} +{% block title %}Backups - /etc/hosts Manager{% endblock %} +{% block content %} +

Backups

+Backup All + + + + + + + + + + {% for backup in backups %} + + + + + + {% endfor %} + +
Data utworzeniaOpisAkcje
{{ backup.created_at.strftime("%Y-%m-%d %H:%M:%S") }}{{ backup.description }} + Podgląd +
+ +
+
+{% endblock %} diff --git a/templates/base.html b/templates/base.html new file mode 100644 index 0000000..a44542e --- /dev/null +++ b/templates/base.html @@ -0,0 +1,203 @@ + + + + + + {% block title %}/etc/hosts Manager{% endblock %} + + + + + {% block extra_css %} + + {% endblock %} + + + + + + +
+ {% with messages = get_flashed_messages(with_categories=true) %} + {% if messages %} + {% for category, message in messages %} + + {% endfor %} + {% endif %} + {% endwith %} + + {% block content %} + {% endblock %} +
+ + + + + + + {% block extra_js %} + + {% endblock %} + + diff --git a/templates/change_password.html b/templates/change_password.html index f035ffd..53489ef 100644 --- a/templates/change_password.html +++ b/templates/change_password.html @@ -1,58 +1,16 @@ - - - - - Change Password - - - -
-

Change Password

- {% with messages = get_flashed_messages(category_filter=["danger","success","info"]) %} - {% if messages %} -
- {% for message in messages %} -

{{ message }}

- {% endfor %} -
- {% endif %} - {% endwith %} -
- - - +{% extends "base.html" %} +{% block title %}Zmiana hasła - /etc/hosts Manager{% endblock %} +{% block content %} +
+
+

Zmień hasło

+ +
+ + +
+ -
- - +
+{% endblock %} diff --git a/templates/clear_hosts.html b/templates/clear_hosts.html index 8d36877..a0cb69a 100644 --- a/templates/clear_hosts.html +++ b/templates/clear_hosts.html @@ -1,32 +1,16 @@ - - - - - Clear Hosts Files - - - -
-

Clear /etc/hosts* Files

-
-

Select which types of hosts to clear:

-
-
- -

* - or MikroTik Router

-
- -
- - +{% extends "base.html" %} +{% block title %}Wyczyść Hosts - /etc/hosts Manager{% endblock %} +{% block content %} +

Wyczyść Hosts

+
+
+ + +
+
+ + +
+ +
+{% endblock %} diff --git a/templates/dashboard.html b/templates/dashboard.html index 173bd16..d716f58 100644 --- a/templates/dashboard.html +++ b/templates/dashboard.html @@ -1,297 +1,65 @@ - - - - - /etc/hosts file manager - - - - - - -
-

/etc/hosts file manager

- {% with messages = get_flashed_messages(with_categories=true) %} - {% if messages %} -
- {% for category, message in messages %} -

{{ message }}

- {% endfor %} +{% extends "base.html" %} +{% block title %}Dashboard - /etc/hosts Manager{% endblock %} +{% block content %} +

Dashboard

+
+ +
+
+
+
Liczba hostów
+

{{ stats.host_count }}

- {% endif %} - {% endwith %} - - - - - - -
-

Statistics

-
    -
  • Number of managed server: {{ stats.host_count }}
  • -
  • Total deployments: {{ stats.total_deployments }}
  • -
  • Successful deployments: {{ stats.successful_deployments }}
  • -
  • Failed deployments: {{ stats.failed_deployments }}
  • -
-
-
-

Deployment Success Rate

-
-
- {{ stats.successful_deployments }} Successful -
-
- {{ stats.failed_deployments }} Failed -
-
-
-
-

Recent Deploy Logs

- {% if logs %} - {% for log in logs %} -
- {{ log.timestamp.strftime('%Y-%m-%d %H:%M:%S') }} -

{{ log.details }}

-
- {% endfor %} - {% else %} -

No deployment logs available yet.

- {% endif %}
- - +
+
+
+
Łącznie wdrożeń
+

{{ stats.total_deployments }}

+
+
+
+
+
+
+
Udane wdrożenia
+

{{ stats.successful_deployments }}

+
+
+
+
+
+
+
Nieudane wdrożenia
+

{{ stats.failed_deployments }}

+
+
+
+
+ + +
+
+

Ostatnie logi

+
+ + + + + + + + + {% for log in logs %} + + + + + {% endfor %} + +
CzasWiadomość
{{ log.timestamp.strftime("%Y-%m-%d %H:%M:%S") }}{{ log.details }}
+
+
+
+{% endblock %} diff --git a/templates/deploy_hosts_file.html b/templates/deploy_hosts_file.html index 9714865..8b9c258 100644 --- a/templates/deploy_hosts_file.html +++ b/templates/deploy_hosts_file.html @@ -1,41 +1,17 @@ - - - - - Deploy /etc/hosts File - {{ file.title }} - - - -
-

Deploy "{{ file.title }}"

-

Select the hosts to which you want to deploy this file:

-
-
- {% for host in hosts %} -
- -
- {% endfor %} -
- -
- + + +{% endblock %} diff --git a/templates/edit_host.html b/templates/edit_host.html index fbf12e6..c6c86ee 100644 --- a/templates/edit_host.html +++ b/templates/edit_host.html @@ -1,62 +1,46 @@ - - - - - Edit server {{ host.hostname }} - - - -
-

Edit server {{ host.hostname }}

- {% with messages = get_flashed_messages(category_filter=["danger","success","info"]) %} - {% if messages %} -
- {% for message in messages %} -

{{ message }}

- {% endfor %} -
- {% endif %} - {% endwith %} -
- - - - - - - - - - - - - - - - - -
- +{% extends "base.html" %} +{% block title %}Edytuj host - /etc/hosts Manager{% endblock %} +{% block content %} +

Edytuj host

+
+
+ +
- - +
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+ +
+{% endblock %} diff --git a/templates/edit_hosts.html b/templates/edit_hosts.html index dfafdcf..1d13568 100644 --- a/templates/edit_hosts.html +++ b/templates/edit_hosts.html @@ -1,41 +1,12 @@ - - - - - Edit Global /etc/hosts File - - - -
-

Edit Global /etc/hosts File

- {% with messages = get_flashed_messages(category_filter=["danger","success","info"]) %} - {% if messages %} -
- {% for message in messages %} -

{{ message }}

- {% endfor %} -
- {% endif %} - {% endwith %} -
- -
- -
- +{% extends "base.html" %} +{% block title %}Edytuj lokalny Hosts - /etc/hosts Manager{% endblock %} +{% block content %} +

Edytuj lokalny Hosts

+
+
+ +
- - + +
+{% endblock %} diff --git a/templates/edit_local_hosts.html b/templates/edit_local_hosts.html new file mode 100644 index 0000000..90446ea --- /dev/null +++ b/templates/edit_local_hosts.html @@ -0,0 +1,12 @@ +{% extends "base.html" %} +{% block title %}Edytuj lokalny Hosts - /etc/hosts Manager{% endblock %} +{% block content %} +

Edytuj lokalny Hosts

+
+
+ + +
+ +
+{% endblock %} diff --git a/templates/hosts.html b/templates/hosts.html index 3925999..68b12dc 100644 --- a/templates/hosts.html +++ b/templates/hosts.html @@ -1,160 +1,111 @@ - - - - - Remote server management +{% extends "base.html" %} +{% block title %}Hosty - /etc/hosts Manager{% endblock %} +{% block extra_css %} + {{ super() }} - - -
-

Remote server management

- {% with messages = get_flashed_messages(category_filter=["danger","success","info"]) %} - {% if messages %} -
- {% for message in messages %} -

{{ message }}

- {% endfor %} -
- {% endif %} - {% endwith %} -
-

Add new server

-
- - - - - - - - - - +
+
+ + +
+
+ + +
+
+ + +
+
+ + - - + + - - - - - - -
- + +
+ + +
+
+ + +
+ + + + + +
+
+

Lista hostów

+
+
+
- - + + - - - + + + {% for h in hosts %} - - {% endfor %}
IDHostnameSSH UserNazwa hostaUżytkownik SSH PortTypeAuth MethodActionsTypMetoda uwierzytelnianiaAkcje
{{ h.id }} - {{ h.hostname }} -
- {{ h.resolved_hostname }} +
+ {{ h.hostname }} {{ h.username }} {{ h.port }} {{ h.type }} {{ h.auth_method }} - Edit - Test - Backup + Edytuj + Testuj + Backup
- +
-
- - +
+ + +{% endblock %} diff --git a/templates/hosts_files.html b/templates/hosts_files.html index f8f74f8..c454b30 100644 --- a/templates/hosts_files.html +++ b/templates/hosts_files.html @@ -1,48 +1,26 @@ - - - - - /etc/hosts Files Management - - - -
-

Your /etc/hosts Files

- - - - - - - - - - {% for file in files %} - - - - - - {% endfor %} - -
IDTitleActions
{{ file.id }}{{ file.title }} - Edit | - Deploy | - Delete -
- -
- - +{% extends "base.html" %} +{% block title %}Hosts Files - /etc/hosts Manager{% endblock %} +{% block content %} +

Hosts Files

+Utwórz nowy Hosts File + + + + + + + + + {% for file in files %} + + + + + {% endfor %} + +
TytułAkcje
{{ file.title }} + Edytuj + Usuń + Deploy +
+{% endblock %} diff --git a/templates/import_hosts.html b/templates/import_hosts.html index 0329a91..994fce9 100644 --- a/templates/import_hosts.html +++ b/templates/import_hosts.html @@ -1,31 +1,12 @@ - - - - - Import Hosts - - - -
-

Import Hosts

-
- - -
- -
- - +{% extends "base.html" %} +{% block title %}Import Hosts - /etc/hosts Manager{% endblock %} +{% block content %} +

Import Hosts

+
+
+ + +
+ +
+{% endblock %} diff --git a/templates/list_regex_hosts.html b/templates/list_regex_hosts.html index d585021..7ea02cd 100644 --- a/templates/list_regex_hosts.html +++ b/templates/list_regex_hosts.html @@ -1,121 +1,39 @@ - - - - - Regex /etc/hosts Entries - - - -
-

Regex (CIDR) for /etc/hosts Entries

- - - - - - - - - - - - {% for e in entries %} - - - - - - - - - {% endfor %} - -
IDDomainCIDR RangeCommentActions
{{ e.id }}{{ e.domain_suffix }}{{ e.cidr_range }}{{ e.comment }} - Edit -
- -
-
-
Add New Entry
- - -
- - +{% extends "base.html" %} +{% block title %}Lista Regex Hosts - /etc/hosts Manager{% endblock %} +{% block content %} +

Lista Regex Hosts

+Dodaj nowy Regex Host + + + + + + + + + + + + + + + {% for entry in entries %} + + + + + + + + + + + {% endfor %} + +
CIDRGateway IPGateway HostnameDomain SuffixHost PrefixUżyj Gateway IPKomentarzAkcje
{{ entry.cidr_range }}{{ entry.gateway_ip }}{{ entry.gateway_hostname }}{{ entry.domain_suffix }}{{ entry.host_prefix }}{{ entry.use_gateway_ip }}{{ entry.comment }} + Edytuj +
+ +
+
+{% endblock %} diff --git a/templates/login.html b/templates/login.html index acb9ca3..7140035 100644 --- a/templates/login.html +++ b/templates/login.html @@ -1,60 +1,27 @@ - - - - - Login - - - -
-

Login

- {% with messages = get_flashed_messages(category_filter=["danger","success","info"]) %} - {% if messages %} -
- {% for message in messages %} -

{{ message }}

- {% endfor %} -
- {% endif %} - {% endwith %} -
- - - - - +{% extends "base.html" %} +{% block title %}Logowanie - /etc/hosts Manager{% endblock %} +{% block extra_css %} + +{% endblock %} +{% block content %} +
+
+

Logowanie

+ +
+ + +
+
+ + +
+ - +

Nie masz konta? Zarejestruj się.

- - +
+{% endblock %} +{% block extra_js %} + +{% endblock %} diff --git a/templates/new_edit_hosts_file.html b/templates/new_edit_hosts_file.html index 6ddb66d..1a7114f 100644 --- a/templates/new_edit_hosts_file.html +++ b/templates/new_edit_hosts_file.html @@ -1,35 +1,16 @@ - - - - - {% if file %}Edit /etc/hosts File{% else %}New /etc/hosts File{% endif %} - - - -
-

{% if file %}Edit /etc/hosts File{% else %}New /etc/hosts File{% endif %}

-
- - - - - -
- -
- - +{% extends "base.html" %} +{% block title %}{% if file %}Edytuj Hosts File{% else %}Nowy Hosts File{% endif %} - /etc/hosts Manager{% endblock %} +{% block content %} +

{% if file %}Edytuj Hosts File{% else %}Nowy Hosts File{% endif %}

+
+
+ + +
+
+ + +
+ +
+{% endblock %} diff --git a/templates/new_edit_regex_host.html b/templates/new_edit_regex_host.html index 9e8a0af..e0275ea 100644 --- a/templates/new_edit_regex_host.html +++ b/templates/new_edit_regex_host.html @@ -1,106 +1,36 @@ - - - - - {% if entry %}Edit{% else %}New{% endif %} Regex/CIDR Entry - - - -
-

{% if entry %}Edit{% else %}New{% endif %} CIDR Entry

-
- - - - - - - - - - - - - - -
- -
- - +{% extends "base.html" %} +{% block title %}{% if entry %}Edytuj Regex Host{% else %}Nowy Regex Host{% endif %} - /etc/hosts Manager{% endblock %} +{% block content %} +

{% if entry %}Edytuj Regex Host{% else %}Nowy Regex Host{% endif %}

+
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+ +
+{% endblock %} diff --git a/templates/register.html b/templates/register.html index 487fcb9..b164a4a 100644 --- a/templates/register.html +++ b/templates/register.html @@ -1,60 +1,21 @@ - - - - - Register - - - -
-

Register

- {% with messages = get_flashed_messages(category_filter=["danger","success","info"]) %} - {% if messages %} -
- {% for message in messages %} -

{{ message }}

- {% endfor %} -
- {% endif %} - {% endwith %} -
- - - - - +{% extends "base.html" %} +{% block title %}Rejestracja - /etc/hosts Manager{% endblock %} +{% block content %} +
+
+

Rejestracja

+ +
+ + +
+
+ + +
+ - +

Masz już konto? Zaloguj się.

- - +
+{% endblock %} diff --git a/templates/settings.html b/templates/settings.html index 03ba6f2..43c4b85 100644 --- a/templates/settings.html +++ b/templates/settings.html @@ -1,122 +1,28 @@ - - - - - Settings - - - -
-

Settings

-
-
- -
-
- -
-
- -
-
- -
-
- - Include CIDR-based entries in final /etc/hosts deploy -
- -
- -
- - +{% extends "base.html" %} +{% block title %}Ustawienia - /etc/hosts Manager{% endblock %} +{% block content %} +

Ustawienia

+
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+ +
+{% endblock %} diff --git a/templates/view_backup.html b/templates/view_backup.html index a152908..5381bd8 100644 --- a/templates/view_backup.html +++ b/templates/view_backup.html @@ -1,33 +1,20 @@ - - - - - View Backup - - - -
-

Backup Preview

- {% if host %} -

Host: {{ host.hostname }} ({{ host.type }})

- {% else %} -

Default configuration

- {% endif %} -

Description: {{ backup.description }}

-

Created at: {{ backup.created_at }}

-

Content:

-
{{ backup.content }}
- -
- - +{% extends "base.html" %} +{% block title %}Podgląd Backupu - /etc/hosts Manager{% endblock %} +{% block extra_css %} + {{ super() }} + + +{% endblock %} +{% block content %} +

Podgląd Backupu

+

Data: {{ backup.created_at.strftime("%Y-%m-%d %H:%M:%S") }}

+

Opis: {{ backup.description }}

+
{{ backup.content | e }}
+Powrót do listy backupów +{% endblock %} +{% block extra_js %} + {{ super() }} + + + +{% endblock %} diff --git a/templates_old/backups.html b/templates_old/backups.html new file mode 100644 index 0000000..38e8f05 --- /dev/null +++ b/templates_old/backups.html @@ -0,0 +1,149 @@ + + + + + Backups + + + +
+

Backups

+ + + + + + + + + + + + {% for backup in backups %} + + + + + + + + {% endfor %} +
IDHostCreated AtDescriptionActions
{{ backup.id }}{{ backup.host.hostname if backup.host else 'Default Configuration' }}{{ backup.created_at }}{{ backup.description or '' }} + + View + + + Restore + + +
+ +
+
+ +
+ + diff --git a/templates_old/change_password.html b/templates_old/change_password.html new file mode 100644 index 0000000..f035ffd --- /dev/null +++ b/templates_old/change_password.html @@ -0,0 +1,58 @@ + + + + + Change Password + + + +
+

Change Password

+ {% with messages = get_flashed_messages(category_filter=["danger","success","info"]) %} + {% if messages %} +
+ {% for message in messages %} +

{{ message }}

+ {% endfor %} +
+ {% endif %} + {% endwith %} +
+ + + +
+ +
+ + diff --git a/templates_old/clear_hosts.html b/templates_old/clear_hosts.html new file mode 100644 index 0000000..8d36877 --- /dev/null +++ b/templates_old/clear_hosts.html @@ -0,0 +1,32 @@ + + + + + Clear Hosts Files + + + +
+

Clear /etc/hosts* Files

+
+

Select which types of hosts to clear:

+
+
+ +

* - or MikroTik Router

+
+ +
+ + diff --git a/templates_old/dashboard.html b/templates_old/dashboard.html new file mode 100644 index 0000000..173bd16 --- /dev/null +++ b/templates_old/dashboard.html @@ -0,0 +1,297 @@ + + + + + /etc/hosts file manager + + + + + + +
+

/etc/hosts file manager

+ {% with messages = get_flashed_messages(with_categories=true) %} + {% if messages %} +
+ {% for category, message in messages %} +

{{ message }}

+ {% endfor %} +
+ {% endif %} + {% endwith %} + + + + + + +
+

Statistics

+
    +
  • Number of managed server: {{ stats.host_count }}
  • +
  • Total deployments: {{ stats.total_deployments }}
  • +
  • Successful deployments: {{ stats.successful_deployments }}
  • +
  • Failed deployments: {{ stats.failed_deployments }}
  • +
+
+
+

Deployment Success Rate

+
+
+ {{ stats.successful_deployments }} Successful +
+
+ {{ stats.failed_deployments }} Failed +
+
+
+
+

Recent Deploy Logs

+ {% if logs %} + {% for log in logs %} +
+ {{ log.timestamp.strftime('%Y-%m-%d %H:%M:%S') }} +

{{ log.details }}

+
+ {% endfor %} + {% else %} +

No deployment logs available yet.

+ {% endif %} +
+
+ + diff --git a/templates_old/deploy_hosts_file.html b/templates_old/deploy_hosts_file.html new file mode 100644 index 0000000..9714865 --- /dev/null +++ b/templates_old/deploy_hosts_file.html @@ -0,0 +1,41 @@ + + + + + Deploy /etc/hosts File - {{ file.title }} + + + +
+

Deploy "{{ file.title }}"

+

Select the hosts to which you want to deploy this file:

+
+
+ {% for host in hosts %} +
+ +
+ {% endfor %} +
+ +
+ +
+ + diff --git a/templates_old/edit_host.html b/templates_old/edit_host.html new file mode 100644 index 0000000..fbf12e6 --- /dev/null +++ b/templates_old/edit_host.html @@ -0,0 +1,62 @@ + + + + + Edit server {{ host.hostname }} + + + +
+

Edit server {{ host.hostname }}

+ {% with messages = get_flashed_messages(category_filter=["danger","success","info"]) %} + {% if messages %} +
+ {% for message in messages %} +

{{ message }}

+ {% endfor %} +
+ {% endif %} + {% endwith %} +
+ + + + + + + + + + + + + + + + + +
+ +
+ + diff --git a/templates_old/edit_hosts.html b/templates_old/edit_hosts.html new file mode 100644 index 0000000..dfafdcf --- /dev/null +++ b/templates_old/edit_hosts.html @@ -0,0 +1,41 @@ + + + + + Edit Global /etc/hosts File + + + +
+

Edit Global /etc/hosts File

+ {% with messages = get_flashed_messages(category_filter=["danger","success","info"]) %} + {% if messages %} +
+ {% for message in messages %} +

{{ message }}

+ {% endfor %} +
+ {% endif %} + {% endwith %} +
+ +
+ +
+ +
+ + diff --git a/templates_old/hosts.html b/templates_old/hosts.html new file mode 100644 index 0000000..3925999 --- /dev/null +++ b/templates_old/hosts.html @@ -0,0 +1,160 @@ + + + + + Remote server management + + + +
+

Remote server management

+ {% with messages = get_flashed_messages(category_filter=["danger","success","info"]) %} + {% if messages %} +
+ {% for message in messages %} +

{{ message }}

+ {% endfor %} +
+ {% endif %} + {% endwith %} +
+

Add new server

+
+ + + + + + + + + + + + + + + + + +
+
+ + + + + + + + + + + + + + {% for h in hosts %} + + + + + + + + + + + {% endfor %} + +
IDHostnameSSH UserPortTypeAuth MethodActions
{{ h.id }} + {{ h.hostname }} +
+ {{ h.resolved_hostname }} +
{{ h.username }}{{ h.port }}{{ h.type }}{{ h.auth_method }} + Edit + Test + Backup +
+ +
+
+ +
+ + diff --git a/templates_old/hosts_files.html b/templates_old/hosts_files.html new file mode 100644 index 0000000..f8f74f8 --- /dev/null +++ b/templates_old/hosts_files.html @@ -0,0 +1,48 @@ + + + + + /etc/hosts Files Management + + + +
+

Your /etc/hosts Files

+ + + + + + + + + + {% for file in files %} + + + + + + {% endfor %} + +
IDTitleActions
{{ file.id }}{{ file.title }} + Edit | + Deploy | + Delete +
+ +
+ + diff --git a/templates_old/import_hosts.html b/templates_old/import_hosts.html new file mode 100644 index 0000000..0329a91 --- /dev/null +++ b/templates_old/import_hosts.html @@ -0,0 +1,31 @@ + + + + + Import Hosts + + + +
+

Import Hosts

+
+ + +
+ +
+ + diff --git a/templates_old/list_regex_hosts.html b/templates_old/list_regex_hosts.html new file mode 100644 index 0000000..d585021 --- /dev/null +++ b/templates_old/list_regex_hosts.html @@ -0,0 +1,121 @@ + + + + + Regex /etc/hosts Entries + + + +
+

Regex (CIDR) for /etc/hosts Entries

+ + + + + + + + + + + + {% for e in entries %} + + + + + + + + + {% endfor %} + +
IDDomainCIDR RangeCommentActions
{{ e.id }}{{ e.domain_suffix }}{{ e.cidr_range }}{{ e.comment }} + Edit +
+ +
+
+
Add New Entry
+ + +
+ + diff --git a/templates_old/login.html b/templates_old/login.html new file mode 100644 index 0000000..acb9ca3 --- /dev/null +++ b/templates_old/login.html @@ -0,0 +1,60 @@ + + + + + Login + + + +
+

Login

+ {% with messages = get_flashed_messages(category_filter=["danger","success","info"]) %} + {% if messages %} +
+ {% for message in messages %} +

{{ message }}

+ {% endfor %} +
+ {% endif %} + {% endwith %} +
+ + + + + +
+ +
+ + diff --git a/templates_old/new_edit_hosts_file.html b/templates_old/new_edit_hosts_file.html new file mode 100644 index 0000000..6ddb66d --- /dev/null +++ b/templates_old/new_edit_hosts_file.html @@ -0,0 +1,35 @@ + + + + + {% if file %}Edit /etc/hosts File{% else %}New /etc/hosts File{% endif %} + + + +
+

{% if file %}Edit /etc/hosts File{% else %}New /etc/hosts File{% endif %}

+
+ + + + + +
+ +
+ + diff --git a/templates_old/new_edit_regex_host.html b/templates_old/new_edit_regex_host.html new file mode 100644 index 0000000..9e8a0af --- /dev/null +++ b/templates_old/new_edit_regex_host.html @@ -0,0 +1,106 @@ + + + + + {% if entry %}Edit{% else %}New{% endif %} Regex/CIDR Entry + + + +
+

{% if entry %}Edit{% else %}New{% endif %} CIDR Entry

+
+ + + + + + + + + + + + + + +
+ +
+ + diff --git a/templates_old/register.html b/templates_old/register.html new file mode 100644 index 0000000..487fcb9 --- /dev/null +++ b/templates_old/register.html @@ -0,0 +1,60 @@ + + + + + Register + + + +
+

Register

+ {% with messages = get_flashed_messages(category_filter=["danger","success","info"]) %} + {% if messages %} +
+ {% for message in messages %} +

{{ message }}

+ {% endfor %} +
+ {% endif %} + {% endwith %} +
+ + + + + +
+ +
+ + diff --git a/templates_old/settings.html b/templates_old/settings.html new file mode 100644 index 0000000..03ba6f2 --- /dev/null +++ b/templates_old/settings.html @@ -0,0 +1,122 @@ + + + + + Settings + + + +
+

Settings

+
+
+ +
+
+ +
+
+ +
+
+ +
+
+ + Include CIDR-based entries in final /etc/hosts deploy +
+ +
+ +
+ + diff --git a/templates_old/view_backup.html b/templates_old/view_backup.html new file mode 100644 index 0000000..a152908 --- /dev/null +++ b/templates_old/view_backup.html @@ -0,0 +1,33 @@ + + + + + View Backup + + + +
+

Backup Preview

+ {% if host %} +

Host: {{ host.hostname }} ({{ host.type }})

+ {% else %} +

Default configuration

+ {% endif %} +

Description: {{ backup.description }}

+

Created at: {{ backup.created_at }}

+

Content:

+
{{ backup.content }}
+ +
+ +