main
parent
b3c9924e41
commit
9c10835f28
@ -0,0 +1,19 @@
|
||||
import os
|
||||
import json
|
||||
|
||||
if not os.path.exists('domains.json'):
|
||||
db = {}
|
||||
js = json.dumps(db, indent=2)
|
||||
with open("domains.json", "w") as outfile:
|
||||
outfile.write(js)
|
||||
print('Created new domains.json')
|
||||
|
||||
def read(file = 'domains.json'):
|
||||
with open(file, "r", encoding="utf-8") as openfile:
|
||||
db = json.load(openfile)
|
||||
return db
|
||||
|
||||
def write(db, file = 'domains.json'):
|
||||
js = json.dumps(db, indent=2, ensure_ascii=False)
|
||||
with open(file, "w", encoding="utf-8") as outfile:
|
||||
outfile.write(js)
|
@ -0,0 +1,23 @@
|
||||
from re import compile, sub
|
||||
domains = ['jet', 'mirror', 'org', 'info', 'news', 'me']
|
||||
|
||||
def domain_ok(domain):
|
||||
global domains
|
||||
if domain.count('.') == 1:
|
||||
if domain.split('.')[1] in domains:
|
||||
# ../some => some
|
||||
# Защита от проверки папок выше, чем нужно и др.
|
||||
regex = compile('[^a-z0-9.-]')
|
||||
c_domain = regex.sub('', domain)
|
||||
if domain == c_domain:
|
||||
return domain
|
||||
|
||||
return False
|
||||
|
||||
def domain_list():
|
||||
global domains
|
||||
out = ''
|
||||
for i in domains:
|
||||
out += f'{i}, '
|
||||
out = out[:-2]
|
||||
return out
|
@ -0,0 +1,52 @@
|
||||
from fastapi import FastAPI, HTTPException
|
||||
from uuid import uuid4
|
||||
app = FastAPI()
|
||||
|
||||
# If you don't need domain check (jetwork):
|
||||
# --- comment
|
||||
# multi-comments uncomment
|
||||
|
||||
from db import *
|
||||
from domain_check import *
|
||||
|
||||
def set_nginx(url: str, port: int):
|
||||
f = open('/etc/nginx/nginx.conf')
|
||||
|
||||
|
||||
@app.post('/api/create/{domain}/{port}')
|
||||
def create(domain: str, port: int):
|
||||
# ---
|
||||
if domain_ok(domain):
|
||||
db = read()
|
||||
if domain not in db:
|
||||
token = str(uuid4())
|
||||
db[domain] = token
|
||||
write(db)
|
||||
return {'token': token}
|
||||
else:
|
||||
raise HTTPException(status_code=400, detail="Domain exist")
|
||||
else:
|
||||
raise HTTPException(status_code=400, detail="Bad domain")
|
||||
# ---
|
||||
'''
|
||||
db = read()
|
||||
if domain not in db:
|
||||
token = str(uuid4())
|
||||
db[domain] = token
|
||||
write(db)
|
||||
return {'token': token}
|
||||
else:
|
||||
raise HTTPException(status_code=400, detail="Domain exist")
|
||||
'''
|
||||
|
||||
@app.post('/api/set/{domain}/{port}/{token}')
|
||||
def set(domain: str, port: int, token: str):
|
||||
return 200
|
||||
|
||||
@app.post('/api/del/{domain}/{port}/{token}')
|
||||
def set(domain: str, port: int, token: str):
|
||||
return 200
|
||||
|
||||
if __name__ == '__main__':
|
||||
import uvicorn
|
||||
uvicorn.run(app, host='127.0.0.1', port=8000)
|
@ -0,0 +1,38 @@
|
||||
user www-data;
|
||||
worker_processes auto;
|
||||
pid /run/nginx.pid;
|
||||
error_log /var/log/nginx/error.log;
|
||||
include /etc/nginx/modules-enabled/*.conf;
|
||||
events {
|
||||
worker_connections 768;
|
||||
}
|
||||
http {
|
||||
sendfile on;
|
||||
tcp_nopush on;
|
||||
types_hash_max_size 2048;
|
||||
include /etc/nginx/mime.types;
|
||||
default_type application/octet-stream;
|
||||
ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3; # Dropping SSLv3, ref: POODLE
|
||||
ssl_prefer_server_ciphers on;
|
||||
access_log /var/log/nginx/access.log;
|
||||
gzip on;
|
||||
include /etc/nginx/conf.d/*.conf;
|
||||
include /etc/nginx/sites-enabled/*;
|
||||
|
||||
|
||||
server
|
||||
{
|
||||
listen 80;
|
||||
server_name jet-d.del.pw;
|
||||
server_name_in_redirect off;
|
||||
proxy_set_header Host $host:$server_port;
|
||||
|
||||
location / {
|
||||
proxy_set_header X-Real-IP $remote_addr;
|
||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||
proxy_pass http://127.0.0.1:8000;
|
||||
}}
|
||||
|
||||
|
||||
|
||||
}
|
Loading…
Reference in new issue