Files
OutFleet/templates/clients.html

171 lines
7.2 KiB
HTML
Raw Normal View History

2023-09-25 03:53:08 +03:00
{% extends "base.html" %}
{% block content %}
2023-09-27 22:42:32 +03:00
<div id="list" class="pure-u-1-3" xmlns="http://www.w3.org/1999/html" xmlns="http://www.w3.org/1999/html">
2023-09-25 03:53:08 +03:00
<div class="server-item pure-g">
<h1 class="server-content-title">Clients</h1>
</div>
{% for client, values in CLIENTS.items() %}
<div class="server-item server-item-{% if client == selected_client %}unread{% else %}selected{% endif %} pure-g">
<div class="pure-u-3-4" onclick="location.href='/clients?selected_client={{ client }}';">
<h5 class="server-name">{{ values["name"] }}</h5>
<h4 class="server-info">Allowed {{ values["servers"]|length }} server{% if values["servers"]|length >1 %}s{%endif%}</h4>
</div>
</div>
{% endfor %}
<div onclick="location.href='/clients?add_client=True';" class="server-item server-add pure-g">
<div class="pure-u-1">
+
</div>
</div>
</div>
{% if add_client %}
<div class="pure-u-1-3">
<div class="server-content-header pure-g">
<div class="pure-u-1-2">
<h1 class="server-content-title">Add new client</h1>
</div>
</div>
<div class="server-content-body">
<form action="/add_client" class="pure-form pure-form-stacked" method="POST">
<fieldset>
<div class="pure-g">
<div class="pure-u-1 pure-u-md-1-3">
<input type="text" class="pure-u-23-24" name="name" required placeholder="Name"/>
</div>
<div class="pure-u-1 pure-u-md-1-3">
<input type="text" class="pure-u-23-24" name="comment" placeholder="Comment"/>
</div>
<div class="pure-checkbox">
{% for server in SERVERS %}
<label class="pure-checkbox" for="option{{loop.index0}}">{{server.info()["name"]}}
<input type="checkbox" id="option{{loop.index0}}" name="servers" value="{{server.info()['server_id']}}"></label>
{% endfor %}
</div>
</div>
<button type="submit" class="pure-button pure-input-1 pure-button-primary">Add</button>
</fieldset>
</form>
</div>
</div>
{% endif %}
{% if selected_client and not add_client %}
{% set client = CLIENTS[selected_client] %}
2023-09-25 20:22:44 +03:00
<div class="pure-u-1-2">
2023-09-25 03:53:08 +03:00
<div class="server-content-header pure-g">
<div class="pure-u-1-2">
<h1 class="server-content-title">{{client['name']}}</h1>
<h4 class="server-info">{{ client['comment'] }}</h4>
<h4 class="server-info">id {{ selected_client }}</h4>
</div>
</div>
<div class="server-content-body">
<form action="/add_client" class="pure-form pure-form-stacked" method="POST">
<fieldset>
<div class="pure-g">
<div class="pure-u-1 pure-u-md-1-3">
2023-09-25 20:22:44 +03:00
<input type="text" class="pure-u-1" name="name" required value="{{client['name']}}"/>
<input type="hidden" class="pure-u-1" name="old_name" required value="{{client['name']}}"/>
2023-09-25 03:53:08 +03:00
</div>
<div class="pure-u-1 pure-u-md-1-3">
2023-09-25 20:22:44 +03:00
<input type="text" class="pure-u-1" name="comment" value="{{client['comment']}}"/>
2023-09-25 03:53:08 +03:00
</div>
2023-09-25 20:22:44 +03:00
<input type="hidden" class="pure-u-1" name="user_id" value="{{selected_client}}"/>
2023-09-25 03:53:08 +03:00
<div class="pure-checkbox">
{% for server in SERVERS %}
<label class="pure-checkbox" for="option{{loop.index0}}">{{server.info()["name"]}}
<input
{% if server.info()['server_id'] in client['servers'] %}checked{%endif%}
type="checkbox" id="option{{loop.index0}}" name="servers" value="{{server.info()['server_id']}}"></label>
{% endfor %}
</div>
</div>
2023-09-26 00:55:02 +03:00
<button type="submit" class="pure-button pure-input-1 pure-button-primary">Save and apply</button>
2023-09-25 03:53:08 +03:00
</fieldset>
</form>
2023-09-25 20:22:44 +03:00
2023-09-27 22:42:32 +03:00
<div>
<h3>Invite text</h3><hr>
<p>Install OutLine VPN. Copy and paste below keys to OutLine client.</p>
{% for server in SERVERS %}
{% if server.info()['server_id'] in client['servers'] %}
<b>{{server.info()['name']}}</b></br>
<code>{% for key in server.data["keys"] %}{% if key.name == client['name'] %}ssconf://{{ dynamic_hostname }}/dynamic/{{server.info()['name']}}/{{selected_client}}#{{server.info()['comment']}}{% endif %}{% endfor %}</code></br></br>
{% endif %}
{% endfor %}
</div>
<hr>
2023-09-25 20:22:44 +03:00
<div style="padding-top: 15px; padding-bottom: 15px">
2023-09-27 22:42:32 +03:00
<div class="pure-u-1">
<h3>Dynamic Access Keys</h3>
2023-09-25 20:22:44 +03:00
<table class="pure-table">
<thead>
<tr>
<th>Server</th>
2023-09-27 22:42:32 +03:00
<th>Dynamic</th>
2023-09-25 20:22:44 +03:00
</tr>
</thead>
<tbody>
{% for server in SERVERS %}
{% if server.info()['server_id'] in client['servers'] %}
<tr>
<td>{{ server.info()['name'] }}</td>
<td>
2023-09-27 22:42:32 +03:00
<p style="font-size: 10pt">{% for key in server.data["keys"] %}{% if key.name == client['name'] %}ssconf://{{ dynamic_hostname }}/dynamic/{{server.info()['name']}}/{{selected_client}}#{{server.info()['comment']}}{% endif %}{% endfor %}</p>
2023-09-25 20:22:44 +03:00
</td>
</tr>
{% endif %}
{% endfor %}
</tbody>
</table>
2023-09-25 03:53:08 +03:00
</div>
2023-09-27 22:42:32 +03:00
<div class="pure-u-1 pure-u-md-1">
<h3>SS Links</h3>
2023-09-25 20:22:44 +03:00
<table class="pure-table">
<thead>
<tr>
<th>Server</th>
2023-09-27 22:42:32 +03:00
<th>SSlink</th>
2023-09-25 20:22:44 +03:00
</tr>
</thead>
<tbody>
{% for server in SERVERS %}
{% if server.info()['server_id'] in client['servers'] %}
<tr>
<td>{{ server.info()['name'] }}</td>
<td>
2023-09-27 22:42:32 +03:00
<pre style="font-size: 10pt">{% for key in server.data["keys"] %}{% if key.name == client['name'] %}{{ key.access_url }}{% endif %}{% endfor %}</pre>
2023-09-25 20:22:44 +03:00
</td>
</tr>
{% endif %}
{% endfor %}
</tbody>
</table>
</div>
2023-09-27 22:42:32 +03:00
<hr>
2023-09-25 20:22:44 +03:00
</div>
<form action="/del_client" class="pure-form pure-form-stacked" method="POST">
<input type="hidden" class="pure-u-1" name="name" required value="{{client['name']}}"/>
<input type="hidden" class="pure-u-1" name="user_id" value="{{selected_client}}"/>
<button type="submit" class="pure-button button-error pure-input-1 ">Delete</button>
</form>
2023-09-25 03:53:08 +03:00
</div>
2023-09-25 20:22:44 +03:00
</div>
2023-09-25 03:53:08 +03:00
{% endif %}
{% endblock %}