dynamicweb/hosting/forms.py

132 lines
4.5 KiB
Python
Raw Normal View History

import datetime
2017-08-31 07:23:00 +00:00
import logging
2017-09-12 21:03:21 +00:00
import os
import subprocess
import tempfile
2017-08-31 19:28:30 +00:00
from django import forms
from django.contrib.auth import authenticate
from django.utils.translation import ugettext_lazy as _
2017-08-31 07:23:00 +00:00
from membership.models import CustomUser
from .models import UserHostingKey
2017-08-31 07:23:00 +00:00
logger = logging.getLogger(__name__)
def generate_ssh_key_name():
return 'dcl-generated-key-' + datetime.datetime.now().strftime(
'%m%d%y%H%M')
class HostingUserLoginForm(forms.Form):
email = forms.CharField(widget=forms.EmailInput())
password = forms.CharField(widget=forms.PasswordInput())
class Meta:
fields = ['email', 'password']
def clean(self):
email = self.cleaned_data.get('email')
password = self.cleaned_data.get('password')
is_auth = authenticate(email=email, password=password)
if not is_auth:
2017-07-29 12:49:10 +00:00
raise forms.ValidationError(
2017-08-03 16:30:41 +00:00
_("Your username and/or password were incorrect."))
elif is_auth.validated == 0:
2017-07-29 12:49:10 +00:00
raise forms.ValidationError(
_("Your account is not activated yet."))
return self.cleaned_data
def clean_email(self):
email = self.cleaned_data.get('email')
try:
CustomUser.objects.get(email=email)
return email
except CustomUser.DoesNotExist:
2017-08-31 07:23:00 +00:00
raise forms.ValidationError(_("User does not exist"))
class HostingUserSignupForm(forms.ModelForm):
confirm_password = forms.CharField(widget=forms.PasswordInput())
password = forms.CharField(widget=forms.PasswordInput())
class Meta:
model = CustomUser
fields = ['name', 'email', 'password']
widgets = {
2017-08-31 07:23:00 +00:00
'name': forms.TextInput(
attrs={'placeholder': 'Enter your name or company name'}),
}
def clean_confirm_password(self):
password = self.cleaned_data.get('password')
confirm_password = self.cleaned_data.get('confirm_password')
if not confirm_password == password:
raise forms.ValidationError("Passwords don't match")
return confirm_password
class UserHostingKeyForm(forms.ModelForm):
private_key = forms.CharField(widget=forms.HiddenInput(), required=False)
public_key = forms.CharField(widget=forms.Textarea(
2017-08-31 07:23:00 +00:00
attrs={'class': 'form_public_key',
'placeholder': _('Paste here your public key')}),
required=False,
)
user = forms.models.ModelChoiceField(queryset=CustomUser.objects.all(),
2017-08-31 07:23:00 +00:00
required=False,
widget=forms.HiddenInput())
name = forms.CharField(required=False, widget=forms.TextInput(
2017-08-31 07:23:00 +00:00
attrs={'class': 'form_key_name',
'placeholder': _('Give a name to your key')}))
def __init__(self, *args, **kwargs):
self.request = kwargs.pop("request")
super(UserHostingKeyForm, self).__init__(*args, **kwargs)
2017-07-31 14:13:15 +00:00
self.fields['name'].label = _('Key name')
2017-08-31 07:23:00 +00:00
def clean_public_key(self):
"""
A function that validates a public ssh key using sshpubkeys module
2017-08-31 07:23:00 +00:00
:return:
"""
if 'generate' in self.request.POST:
return self.data.get('public_key')
2017-08-31 07:23:00 +00:00
KEY_ERROR_MESSAGE = _("Please input a proper SSH key")
openssh_pubkey_str = self.data.get('public_key')
with tempfile.NamedTemporaryFile(delete=True) as tmp_public_key_file:
2017-09-12 21:01:19 +00:00
tmp_public_key_file.write(openssh_pubkey_str.encode('utf-8'))
tmp_public_key_file.flush()
try:
out = subprocess.check_output(
['ssh-keygen', '-lf', tmp_public_key_file.name])
except subprocess.CalledProcessError as cpe:
logger.debug(
2017-09-12 21:03:21 +00:00
"Not a correct ssh format {error}".format(error=str(cpe)))
raise forms.ValidationError(KEY_ERROR_MESSAGE)
return openssh_pubkey_str
2017-08-31 07:23:00 +00:00
def clean_name(self):
return self.data.get('name')
def clean_user(self):
return self.request.user
def clean(self):
cleaned_data = self.cleaned_data
if 'generate' in self.request.POST:
self.cleaned_data['name'] = generate_ssh_key_name()
private_key, public_key = UserHostingKey.generate_keys()
cleaned_data.update({
'private_key': private_key,
'public_key': public_key
})
return cleaned_data
class Meta:
model = UserHostingKey
fields = ['user', 'name', 'public_key']