diff --git a/.gitignore b/.gitignore
index 3b3dce87a8756480bcb5ad7666bef3e2f5fdf2c6..52b9cfece2ee24e884cd5915db58575c82d93689 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,5 +1,5 @@
 # Local app configuration
-.env.local
+.env
 # Ide shit
 .idea/*
 # Session shit
diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml
index 9c4dcb84e7e45785a07e81263364a4b83d29314c..4067891801ebc0d6f266087829e0ac992af568b0 100644
--- a/.gitlab-ci.yml
+++ b/.gitlab-ci.yml
@@ -16,4 +16,3 @@ deploy:
     - bots-deployer
   script:
     - sh deploy.sh
-
diff --git a/deploy.sh b/deploy.sh
index 6b24245895fb6dc134dcca8907dd565160688996..02d222796ad6efed132864f531336d9555b94673 100644
--- a/deploy.sh
+++ b/deploy.sh
@@ -8,9 +8,11 @@ TELEGRAM_APP_ID="${TELEGRM_APP_ID_MASKED//a/}"
 } >>.env
 
 # Store some info in app.info file
-printf "Maintainer: \`win10@list.ru\`\n" >app.info
-printf "Repo url: \`%s\`\n" "$CI_PROJECT_URL" >>app.info
-printf "Last commit: \`\`\`\n%s \`\`\`\n" "$(git log -1 --pretty=%B)" >>app.info
+{
+printf "Maintainer: \`win10@list.ru\`\n"
+printf "Repo url: \`%s\`\n" "$CI_PROJECT_URL"
+printf "Last commit: \`\`\`\n%s \`\`\`\n" "$(git log -1 --pretty=%B)"
+} > ./static_messages/app.info
 
 sed -i "s#WorkingDirectory=.*#WorkingDirectory=${APP_DIR:?}#" -i ./systemd/bot_s3rius_san.service
 
diff --git a/src/actions/fun.py b/src/actions/fun.py
index df62df9fc1d13c2bd889c1bd379d357e4dbe2645..83a4fe08e25031cc7ce172a0d48cc066bc639732 100644
--- a/src/actions/fun.py
+++ b/src/actions/fun.py
@@ -17,7 +17,7 @@ swearing = [
     "(П|п)издуй на хуй",
     "(С|с)ъеби нахуй",
     "(С|с)ъеби на хуй",
-    "(С|с)соси хуй",
+    "(С|с)оси хуй",
     "(Х|х)уй соси",
     "(С|с)осать",
 ]
diff --git a/src/config.py b/src/config.py
index c4f14d15166c84a04a91fac222a01405e914dfcc..3ed8fd8f29f0a4ff1443e4c4add5fc9439c5a62e 100644
--- a/src/config.py
+++ b/src/config.py
@@ -22,8 +22,6 @@ class Config(BaseSettings):
 
     flask_port: str = Field(name="flask_port", default="8080", env="FLASK_PORT")
 
-    telegram_token: str = None
-
     telegram_client: TelegramClient = None
 
 
diff --git a/src/initializator.py b/src/initializator.py
index 483df6702e4d198e766888317f579e49dc2c56f9..f0448a2db9d3e323f847df47db651035a6c2bd23 100644
--- a/src/initializator.py
+++ b/src/initializator.py
@@ -1,4 +1,6 @@
+import asyncio
 import logging
+from multiprocessing import Process, Manager
 
 from telethon import TelegramClient
 
@@ -15,10 +17,15 @@ def setup_logging():
     logging.getLogger("telethon").setLevel(logging.WARNING)
 
 
-async def get_code_from_web():
-    create_web_app()
-    logger.info("Token received!")
-    return config.telegram_token
+def get_code_from_web(token):
+    async def waiter():
+        while token.value is None:
+            logger.debug("Waiting for token")
+            await asyncio.sleep(1)
+        logger.info("Token received!")
+        return token.value
+
+    return waiter
 
 
 def init():
@@ -27,9 +34,13 @@ def init():
     client = TelegramClient(
         "bot_session", config.telegram_app_id, config.telegram_api_hash
     )
-    client.start(phone=config.telegram_account_phone, code_callback=get_code_from_web)
+    manager = Manager()
+    token = manager.Value('s', None)
+    web_app = Process(target=create_web_app, args=(token,))
+    web_app.start()
+    client.start(phone=config.telegram_account_phone, code_callback=get_code_from_web(token))
     config.telegram_client = client
     from src.actions import finish
-
     finish()
+
     return client
diff --git a/src/server_app.py b/src/server_app.py
index a3f192578d06036918d523296fa487f0c6fff35e..cb9c2629ad33ba0c81097d1b32d8d34f17690ac9 100644
--- a/src/server_app.py
+++ b/src/server_app.py
@@ -1,41 +1,48 @@
 import logging
 import random
 
-from flask import Flask, redirect, render_template, request, send_file
+from flask import Flask, render_template, request, send_file, current_app
 
 from src.config import config
 
-app = Flask(__name__)
 logger = logging.getLogger(__name__)
 
 
-def shutdown_server():
-    func = request.environ.get("werkzeug.server.shutdown")
-    if func is None:
-        raise RuntimeError("Not running with the Werkzeug Server")
-    func()
-
-
-@app.route("/")
 def form_template():
-    return render_template("index.html")
+    return render_template("index.html", activated=current_app.activated)
 
 
-@app.route("/girl.png")
 def girl_image():
     num = random.randint(1, 3)
     return send_file(f"./templates/static/girl_{num}.png", mimetype="image/png")
 
 
-@app.route("/code", methods=["POST"])
 def get_code():
     code = request.form.get("code", None)
     if code is not None:
-        logger.debug("Code found. Stopping server!")
-        config.telegram_token = code
-        shutdown_server()
-    return redirect("/", code=302)
+        logger.debug("Updating token!")
+        current_app.update_token(code)
+    return "Ok"
+
+
+class MyServer(Flask):
+
+    def __init__(self, token_value, *args, **kwargs):
+        super(MyServer, self).__init__(*args, **kwargs)
+        self.token_value = token_value
+        self.activated = False
+        self.init_routes()
+
+    def init_routes(self):
+        self.add_url_rule("/", None, form_template)
+        self.add_url_rule("/girl.png", None, girl_image)
+        self.add_url_rule("/code", None, get_code, methods=["POST"])
+
+    def update_token(self, new_val):
+        self.token_value.value = new_val
+        self.activated = True
 
 
-def create_web_app():
+def create_web_app(token):
+    app = MyServer(token, __name__)
     app.run("0.0.0.0", config.flask_port)
diff --git a/src/templates/index.html b/src/templates/index.html
index e7c74e65eb24bcf471ec6e1bb1ff49291723808c..15963c0f3fedca9e4892225e0dc75d71ea44e2da 100644
--- a/src/templates/index.html
+++ b/src/templates/index.html
@@ -56,14 +56,21 @@
         .nes-input {
             cursor: url(), auto;
         }
+
+        .mtr-2 {
+            margin-top: 2rem;
+        }
     </style>
     <title>Bot code</title>
 </head>
 <body>
+
+{% if not activated %}
 <div class="h-center">
     Welcome back, s3rius!
 </div>
-<form action="/code" method="post" class="center" autocomplete="off">
+
+<form id="code_form" action="/code" method="post" class="center" autocomplete="off">
     <div class="nes-field is-inline">
         <label for="inline_field">Verification code</label>
         <input type="text" id="inline_field" class="nes-input is-success" name="code" placeholder="Your code">
@@ -72,6 +79,42 @@
         <input type="submit" class="nes-input is-success" value="Submit code">
     </div>
 </form>
+{%else%}
+<div class="center">
+    Hi, there! The bot is running.
+</div>
+<div class="center mtr-2">
+    Just write a message to <a href="tg://resolve?domain=s3rius_san">@s3rius_san</a> in telegram.
+</div>
+{% endif %}
 <img src="/girl.png" alt="" class="at_bottom">
 </body>
+<script>
+    function sendData() {
+        const XHR = new XMLHttpRequest();
+        // Bind the FormData object and the form element
+        const FD = new FormData(form);
+        // Define what happens on successful data submission
+        XHR.addEventListener("load", function (event) {
+            location.reload()
+        });
+        // Define what happens in case of error
+        XHR.addEventListener("error", function (event) {
+            location.reload()
+        });
+        // Set up our request
+        XHR.open("POST", "/code");
+        // The data sent is what the user provided in the form
+        XHR.send(FD);
+    }
+
+    const form = document.getElementById("code_form");
+
+    // ...and take over its submit event.
+    form.addEventListener("submit", function (event) {
+        event.preventDefault();
+
+        sendData();
+    });
+</script>
 </html>