Add simple support for PGP keys
This commit is contained in:
parent
0e3ef423d2
commit
75f2575c30
4 changed files with 56 additions and 1 deletions
|
@ -7,6 +7,14 @@
|
||||||
<h4 class="card-title p-name">
|
<h4 class="card-title p-name">
|
||||||
<span class="p-given-name">{{ user.first_name }}</span> <span class="p-family-name">{{ user.last_name }}</span>
|
<span class="p-given-name">{{ user.first_name }}</span> <span class="p-family-name">{{ user.last_name }}</span>
|
||||||
</h4>
|
</h4>
|
||||||
|
{% for key in user.keys.all %}
|
||||||
|
<h6 class="card-subtitle">
|
||||||
|
<a class="u-key" href="{{ key.file.url }}">
|
||||||
|
<i class="fa fa-key"></i>
|
||||||
|
{{ key.pretty_print }}
|
||||||
|
</a>
|
||||||
|
</h6>
|
||||||
|
{% endfor %}
|
||||||
{% if user.note %}<p class="card-text p-note">{{ user.note }}</p>{% endif %}
|
{% if user.note %}<p class="card-text p-note">{{ user.note }}</p>{% endif %}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
|
@ -1,12 +1,20 @@
|
||||||
from django.contrib import admin
|
from django.contrib import admin
|
||||||
from django.contrib.auth.admin import UserAdmin as BaseUserAdmin
|
from django.contrib.auth.admin import UserAdmin as BaseUserAdmin
|
||||||
from .models import User
|
from .models import Key, User
|
||||||
|
|
||||||
|
|
||||||
|
class KeyInline(admin.TabularInline):
|
||||||
|
model = Key
|
||||||
|
extra = 1
|
||||||
|
|
||||||
|
|
||||||
class UserAdmin(BaseUserAdmin):
|
class UserAdmin(BaseUserAdmin):
|
||||||
fieldsets = BaseUserAdmin.fieldsets + (
|
fieldsets = BaseUserAdmin.fieldsets + (
|
||||||
('Profile', {'fields': ('avatar', 'note')}),
|
('Profile', {'fields': ('avatar', 'note')}),
|
||||||
)
|
)
|
||||||
|
inlines = (
|
||||||
|
KeyInline,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
admin.site.register(User, UserAdmin)
|
admin.site.register(User, UserAdmin)
|
||||||
|
|
26
users/migrations/0003_key.py
Normal file
26
users/migrations/0003_key.py
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# Generated by Django 1.11.6 on 2017-10-23 01:25
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
from django.conf import settings
|
||||||
|
from django.db import migrations, models
|
||||||
|
import django.db.models.deletion
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('users', '0002_auto_20171023_0109'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Key',
|
||||||
|
fields=[
|
||||||
|
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('fingerprint', models.CharField(max_length=40)),
|
||||||
|
('file', models.FileField(upload_to='keys')),
|
||||||
|
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='keys', to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
]
|
|
@ -9,3 +9,16 @@ def avatar_path(instance, name):
|
||||||
class User(AbstractUser):
|
class User(AbstractUser):
|
||||||
avatar = models.ImageField(upload_to=avatar_path)
|
avatar = models.ImageField(upload_to=avatar_path)
|
||||||
note = models.TextField(blank=True)
|
note = models.TextField(blank=True)
|
||||||
|
|
||||||
|
|
||||||
|
class Key(models.Model):
|
||||||
|
user = models.ForeignKey(
|
||||||
|
User,
|
||||||
|
related_name='keys',
|
||||||
|
on_delete=models.CASCADE
|
||||||
|
)
|
||||||
|
fingerprint = models.CharField(max_length=40)
|
||||||
|
file = models.FileField(upload_to='keys')
|
||||||
|
|
||||||
|
def pretty_print(self):
|
||||||
|
return " ".join(self.fingerprint[i:i+4] for i in range(0, 40, 4))
|
||||||
|
|
Loading…
Reference in a new issue