Compare commits
8 Commits
files.nata
...
main
Author | SHA1 | Date | |
---|---|---|---|
|
9e4c8ba3df | ||
|
9669e09448 | ||
|
cf2fa1f0c0 | ||
|
2661e44e78 | ||
|
33807314f4 | ||
|
81429ec7cb | ||
|
e8d333e399 | ||
|
2793325c50 |
@ -8,11 +8,11 @@ class Headers:
|
|||||||
def has(self, key: str) -> bool:
|
def has(self, key: str) -> bool:
|
||||||
return key in self.headers.keys()
|
return key in self.headers.keys()
|
||||||
|
|
||||||
def get(self, key: str) -> str | None:
|
def get(self, key: str) -> str:
|
||||||
if self.has(key):
|
if self.has(key):
|
||||||
return self.headers[key]
|
return self.headers[key]
|
||||||
|
|
||||||
return None
|
return ''
|
||||||
|
|
||||||
def add(self, key, value) -> None:
|
def add(self, key, value) -> None:
|
||||||
self.headers[key] = value
|
self.headers[key] = value
|
||||||
|
@ -47,6 +47,20 @@ def uwuify_text(text):
|
|||||||
|
|
||||||
return '. '.join(uwuified_sentences)
|
return '. '.join(uwuified_sentences)
|
||||||
|
|
||||||
|
def apply_url_params(body, params: str):
|
||||||
|
body = body.decode('utf-8')
|
||||||
|
soup = BeautifulSoup(body, 'html.parser')
|
||||||
|
|
||||||
|
for a_tag in soup.find_all('a', href=True):
|
||||||
|
original_href = a_tag['href']
|
||||||
|
if '?' in original_href:
|
||||||
|
new_href = f"{original_href}&{params}"
|
||||||
|
else:
|
||||||
|
new_href = f"{original_href}?{params}"
|
||||||
|
a_tag['href'] = new_href
|
||||||
|
|
||||||
|
return str(soup)
|
||||||
|
|
||||||
def uwuify(body):
|
def uwuify(body):
|
||||||
body = body.decode('utf-8')
|
body = body.decode('utf-8')
|
||||||
soup = BeautifulSoup(body, 'html.parser')
|
soup = BeautifulSoup(body, 'html.parser')
|
||||||
@ -90,6 +104,17 @@ patchers: List[Patcher] = [
|
|||||||
lambda response, request: Response(
|
lambda response, request: Response(
|
||||||
response.code,
|
response.code,
|
||||||
response.headers,
|
response.headers,
|
||||||
re.sub(r'sludge', lambda match: 'sludge' + ' (/slʌd͡ʒ/)' if random.randint(0, 5) < 1 else 'sludge', response.body.decode('utf-8')).encode('utf-8')
|
re.sub(r'sludge', lambda match: 'sludge' + ' (/slʌd͡ʒ/)' if random.randint(0, 5) < 1 else 'sludge', response.body.decode()).encode('utf-8')
|
||||||
) if 'text/html' in response.headers.values() else response
|
) if 'text/html' in response.headers.values() else response,
|
||||||
|
lambda response, request: Response(
|
||||||
|
response.code,
|
||||||
|
response.headers,
|
||||||
|
apply_url_params(response.body.replace(b'<head>', b'<head><style>:root,body,body>main>section{animation:swing 180s infinite ease-in-out;transform-origin:center}@keyframes swing{0%{transform:rotate(0deg)}50%{transform:rotate(-1deg)}100%{transform:rotate(1deg)}}</style>'), 'swing=true').encode('utf-8')
|
||||||
|
) if 'text/html' in response.headers.values() and (random.randint(0, 100) < 1 or is_subdict({'swing': 'true'}, request.path.params)) else response,
|
||||||
|
# spiin!
|
||||||
|
lambda response, request: Response(
|
||||||
|
response.code,
|
||||||
|
response.headers,
|
||||||
|
apply_url_params(response.body.replace(b'<head>', b'<head><style>:root,body,body>main>section,body>main>section>flex-grid>flex-grid-item{animation:spiin 480s infinite ease-in-out;transform-origin:center}@keyframes spiin{0%{transform:rotate(0deg)}50%{transform:rotate(180)}100%{transform:rotate(360deg)}}</style>'), 'spiin=true').encode('utf-8')
|
||||||
|
) if 'text/html' in response.headers.values() and (random.randint(0, 1000) < 1 or is_subdict({'spiin': 'true'}, request.path.params)) else response
|
||||||
]
|
]
|
||||||
|
@ -44,7 +44,9 @@ class Request:
|
|||||||
body_start = request_str.find('\r\n\r\n') + 4
|
body_start = request_str.find('\r\n\r\n') + 4
|
||||||
body = Body(request_bytes[body_start:], headers.get('Content-Type') or 'text/plain')
|
body = Body(request_bytes[body_start:], headers.get('Content-Type') or 'text/plain')
|
||||||
|
|
||||||
|
if not 'Nim httpclient' in headers.get('user-agent'):
|
||||||
log.info(f'received request for {path.path} from {headers.get('X-Real-IP')}')
|
log.info(f'received request for {path.path} from {headers.get('X-Real-IP')}')
|
||||||
|
|
||||||
return cls(method, path, version, headers, body)
|
return cls(method, path, version, headers, body)
|
||||||
|
|
||||||
def match(self):
|
def match(self):
|
||||||
|
@ -30,7 +30,7 @@ class Route:
|
|||||||
return response
|
return response
|
||||||
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
log.error(traceback.format_exc)
|
log.error(traceback.format_exc())
|
||||||
return error_page(500)
|
return error_page(500)
|
||||||
|
|
||||||
def matches(self, request: 'Request') -> bool:
|
def matches(self, request: 'Request') -> bool:
|
||||||
@ -52,7 +52,7 @@ routes = [
|
|||||||
lambda request, *_: Response(
|
lambda request, *_: Response(
|
||||||
ResponseCode.OK,
|
ResponseCode.OK,
|
||||||
{'Content-Type': 'text/html'},
|
{'Content-Type': 'text/html'},
|
||||||
(parse_file('./home.html', dict(prev='\\/')).encode('utf-8') if request.method == Method.GET else (
|
((parse_file('./home.html', dict(prev='\\/')).encode('utf-8') if not 'Nim httpclient' in request.headers.get('user-agent') else error_page(200).body) if request.method == Method.GET else (
|
||||||
[
|
[
|
||||||
(lambda form_data: (
|
(lambda form_data: (
|
||||||
(lambda time: (
|
(lambda time: (
|
||||||
@ -83,20 +83,28 @@ routes = [
|
|||||||
Route(
|
Route(
|
||||||
lambda path: os.path.isfile('.' + path.path) and path.path.startswith('/html/') and (path.path.endswith('.html') or '/thoughts/' in path.path),
|
lambda path: os.path.isfile('.' + path.path) and path.path.startswith('/html/') and (path.path.endswith('.html') or '/thoughts/' in path.path),
|
||||||
[Method.GET],
|
[Method.GET],
|
||||||
lambda request, *_: Response(
|
lambda request, *_: [print(request.path), Response(
|
||||||
ResponseCode.OK,
|
ResponseCode.OK,
|
||||||
{'Content-Type': 'text/html'},
|
{'Content-Type': 'text/html'},
|
||||||
parse_file('.' + request.path.path, dict(prev=request.headers.get('Referer').replace('/', '\\/') if request.headers.has('Referer') else '')).encode('utf-8')
|
parse_file('.' + request.path.path, dict((k, v.replace('\'', '')) for k, v in map(lambda item: (item[0], item[1]), request.path.params.items()))).encode('utf-8')
|
||||||
)
|
)][-1]
|
||||||
),
|
),
|
||||||
Route(
|
Route(
|
||||||
lambda path: os.path.isfile('.' + path.path) and (path.path.startswith('/font/') or path.path.startswith('/files/')),
|
lambda path: os.path.isfile('.' + path.path) and (path.path.startswith('/font/') or path.path.startswith('/files/') or path.path.startswith('/.well-known/')),
|
||||||
[Method.GET],
|
[Method.GET],
|
||||||
lambda request, *_: Response(
|
lambda request, *_: Response(
|
||||||
ResponseCode.OK,
|
ResponseCode.OK,
|
||||||
*raw_file_contents('.' + request.path.path)
|
*raw_file_contents('.' + request.path.path)
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
Route(
|
||||||
|
lambda request: request.path == '/robots.txt',
|
||||||
|
[Method.GET],
|
||||||
|
lambda *_: Response(
|
||||||
|
ResponseCode.OK,
|
||||||
|
*raw_file_contents('./robots.txt')
|
||||||
|
)
|
||||||
|
),
|
||||||
Route(
|
Route(
|
||||||
lambda request: request.path == '/status',
|
lambda request: request.path == '/status',
|
||||||
[Method.GET],
|
[Method.GET],
|
||||||
|
@ -25,7 +25,7 @@ def handle_client(client: socket.socket, addr: Tuple[str, int]) -> None:
|
|||||||
.execute(request, client, addr) \
|
.execute(request, client, addr) \
|
||||||
.send(client)
|
.send(client)
|
||||||
|
|
||||||
log.info('destroy thread')
|
log.debug('destroy thread')
|
||||||
|
|
||||||
def main() -> None:
|
def main() -> None:
|
||||||
http_thread = threading.Thread(name='http', target=serve, args=('0.0.0.0', config['http-port'], handle_client))
|
http_thread = threading.Thread(name='http', target=serve, args=('0.0.0.0', config['http-port'], handle_client))
|
||||||
|
Loading…
Reference in New Issue
Block a user