| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- {% extends 'users/base.html' %}
- {% load helpers %}
- {% block title %}API Tokens{% endblock %}
- {% block content %}
- <div class="row">
- <div class="col col-md-10 offset-md-1">
- {% for token in tokens %}
- <div class="card{% if token.is_expired %} bg-danger{% endif %}">
- <div class="card-header">
- <div class="float-end noprint">
- <a class="m-1 btn btn-sm btn-success copy-token" data-clipboard-target="#token_{{ token.pk }}">Copy</a>
- <a href="{% url 'user:token_edit' pk=token.pk %}" class="m-1 btn btn-sm btn-warning">Edit</a>
- <a href="{% url 'user:token_delete' pk=token.pk %}" class="m-1 btn btn-sm btn-danger">Delete</a>
- </div>
- <i class="mdi mdi-key"></i>
- <samp><span id="token_{{ token.pk }}">{{ token.key }}</span></samp>
- {% if token.is_expired %}
- <span class="badge bg-danger">Expired</span>
- {% endif %}
- </div>
- <div class="card-body">
- <div class="row">
- <div class="col col-md-3">
- <small class="text-muted">Created</small><br />
- {{ token.created|annotated_date }}
- </div>
- <div class="col col-md-3">
- <small class="text-muted">Expires</small><br />
- {% if token.expires %}
- {{ token.expires|annotated_date }}
- {% else %}
- <span>Never</span>
- {% endif %}
- </div>
- <div class="col col-md-3">
- <small class="text-muted">Create/Edit/Delete Operations</small><br />
- {% if token.write_enabled %}
- <span class="badge bg-success">Enabled</span>
- {% else %}
- <span class="badge bg-danger">Disabled</span>
- {% endif %}
- </div>
- <div class="col col-md-3">
- <small class="text-muted">Allowed Source IPs</small><br />
- {% if token.allowed_ips %}
- {{ token.allowed_ips|join:', ' }}
- {% else %}
- <span>Any</span>
- {% endif %}
- </div> </div>
- {% if token.description %}
- <br /><span>{{ token.description }}</span>
- {% endif %}
- </div>
- </div>
- {% empty %}
- <h6><i class="mdi mdi-information"></i> You do not have any API tokens.</h6>
- <p>Tokens are used to authenticate REST and GraphQL API requests.</p>
- {% endfor %}
- <div class="text-end">
- <a href="{% url 'user:token_add' %}" class="btn btn-sm btn-primary my-3">
- <span class="mdi mdi-plus-thick" aria-hidden="true"></span>
- Add a Token
- </a>
- </div>
- </div>
- </div>
- {% endblock %}
|