8 Commits

Author SHA1 Message Date
4d2e419018 dragdrop 2026-06-03 18:55:28 +00:00
91d5883885 dots 2026-05-31 13:19:05 +05:00
4203b1e9f8 ssh port 2026-05-31 00:34:53 +05:00
658a95877c improved the nginx section 2026-05-31 00:16:17 +05:00
3ce62f13e2 small fixes 2026-05-30 22:19:02 +05:00
1361f8cd5e corners 2026-05-30 16:58:45 +00:00
323beeb886 headers 2026-05-30 21:48:37 +05:00
9378f022b4 instruction 2026-05-30 21:45:50 +05:00
3 changed files with 59 additions and 4 deletions

View File

@@ -1,2 +1,51 @@
# pechatalka
Chat-robot constructor for the Svoboda typography
# Pechatalka
Site and chat-robot constructor for the Svoboda typography
# Installation
Before process any command think about **what it does** and whether the **paths** are specified correctly<br>
## NGINX
### Create the NGINX server
You can copy an example of the server file from here: `/examples/nginx/pechatalka.conf`<br>
<small><i>I prefer to rename nginx config files to domain names. For example: `pechatalka.kodorvan.tech`</i></small><br>
<i>The file will be half commented out specifically to start the server for generating the TLS/SSL certificate</i><br>
1. `cd /examples/nginx`<br>
2. `sudo cp pechatalka.conf /etc/nginx/sites-avaiable/pechatalka.conf`<br>
3. `sudo nvim /etc/nginx/sites-avaiable/pechatalka.conf`<br>
<small>3.1. <i>Customize the file according to your requirements</i></small><br>
4. `sudo ln -s /etc/nginx/sites-avaiable/pechatalka.conf /etc/nginx/sites-enabled/pechatalka.conf`<br>
5. `sudo nginx -t`<br>
<small>5.1. <i>Make sure that <b>NGINX does not throw errors</b>, otherwise proceed to the instructions for generate a TLS/SSL certificate</i></small><br>
6. `sudo service nginx restart`<br>
### Add mime-type recognition for javascript modules
<small>Edit the file: `/etc/nginx/mime.types`</small><br>
**From:** `application/javascript js;`<br>
**To:** `application/javascript js mjs;`
### Generate a TLS/SSL sertificate (via [certbot](http://certbot.eff.org/) for [ubuntu](https://ubuntu.com/))
1. `sudo apt install certbot python3-certbot-nginx`<br>
2. `sudo certbot certonly --nginx`<br>
<small><i>The **domain** must already be **bound** to the **IP-address** of the server by `CNAME`, `A` or `AAAA` record</i></small><br>
3. Uncomment and reconfigure the nginx server file
4. `sudo nginx -t`<br>
<small>4.1. <i>Make sure that <b>NGINX does not throw errors</b></i></small><br>
5. `sudo service nginx restart`
### Set up firewall rules for HTTP and HTTPS requests (for [ubuntu](https://ubuntu.com/))
1. `sudo ufw allow "NGINX Full"`<br>
<small>1.1. <i>Make sure that the <b>port for SSH connection</b> is open</i></small><br>
2. `sudo ufw allow 22`<br>
<small>2.1. <i>Use your SSH port instead of 22</i></small><br>
3. `sudo ufw enable`
## SystemD (or any alternative you like)
You can copy an example of the systemd file from here: `/examples/systemd/arming.service`<br>
1. `cd examples/systemd`<br>
2. `sudo cp pechatalka.service /etc/systemd/system/pechatalka.service && sudo chmod +x /etc/systemd/system/pechatalka.service`<br>
3. `sudo nvim /etc/systemd/system/pechatalka.service`<br>
<small>3.1. <i>Customize the file according to your requirements</i></small><br>
4. `sudo systemctl daemon-reload`<br>
3. `sudo systemctl enable pechatalka`<br>

View File

@@ -156,7 +156,13 @@ final class paper extends core
// Resizing the layer image
$image->adaptiveResizeImage((int) round($blank['width'] * $layer['scale']), 0);
$image->roundCornersImage($layer['corners'], $layer['corners']);
if (!empty($layer['corners'])) {
// Received the layer image corners
// Masking the layer image with corners
$image->roundCornersImage($layer['corners'], $layer['corners']);
}
// Calculating the layer image coordinates by the layer image mask
$vertical = $blank['height'] - $before;

View File

@@ -1,5 +1,5 @@
{% block js %}
<script src="https://telegram.org/js/telegram-web-app.js"></script>
<!-- <script src="https://telegram.org/js/telegram-web-app.js"></script> -->
<script src="/js/modules/damper.mjs" type="module"></script>
<script src="/js/core.js"></script>
<script src="/js/modules/telegram.mjs" type="module"></script>