Created a base template for login / signup, Fixed some html design issues on login / signup pages, Added Billing Address Form to payment page, Handle Billing Address Form validation, Created VirtualMachinePlan model in order to store user purchased VM, Create method in order to create a stripe plan , Investigated about stripe payment workflows
This commit is contained in:
commit
5456c4c341
17 changed files with 573 additions and 415 deletions
|
|
@ -8,11 +8,10 @@ from django.http import HttpResponseRedirect
|
|||
from django.contrib.auth import authenticate, login
|
||||
from django.conf import settings
|
||||
|
||||
|
||||
|
||||
from membership.forms import PaymentForm
|
||||
from membership.models import CustomUser
|
||||
from .models import RailsBetaUser, VirtualMachineType
|
||||
from utils.forms import BillingAddressForm
|
||||
from .models import VirtualMachineType, VirtualMachinePlan
|
||||
from .forms import HostingUserSignupForm, HostingUserLoginForm
|
||||
from .mixins import ProcessVMSelectionMixin
|
||||
|
||||
|
|
@ -32,7 +31,9 @@ class DjangoHostingView(ProcessVMSelectionMixin, View):
|
|||
return context
|
||||
|
||||
def get(self, request, *args, **kwargs):
|
||||
|
||||
context = self.get_context_data()
|
||||
|
||||
return render(request, self.template_name, context)
|
||||
|
||||
|
||||
|
|
@ -70,7 +71,9 @@ class NodeJSHostingView(ProcessVMSelectionMixin, View):
|
|||
return context
|
||||
|
||||
def get(self, request, *args, **kwargs):
|
||||
|
||||
context = self.get_context_data()
|
||||
|
||||
return render(request, self.template_name, context)
|
||||
|
||||
|
||||
|
|
@ -89,23 +92,28 @@ class IndexView(View):
|
|||
return context
|
||||
|
||||
def get(self, request, *args, **kwargs):
|
||||
|
||||
context = self.get_context_data()
|
||||
|
||||
return render(request, self.template_name, context)
|
||||
|
||||
|
||||
class LoginView(FormView):
|
||||
template_name = 'hosting/login.html'
|
||||
success_url = reverse_lazy('hosting:login')
|
||||
form_class = HostingUserLoginForm
|
||||
moodel = CustomUser
|
||||
success_url = reverse_lazy('hosting:login')
|
||||
|
||||
def form_valid(self, form):
|
||||
email = form.cleaned_data.get('email')
|
||||
password = form.cleaned_data.get('password')
|
||||
auth_user = authenticate(email=email, password=password)
|
||||
|
||||
if auth_user:
|
||||
|
||||
login(self.request, auth_user)
|
||||
return HttpResponseRedirect(self.get_success_url())
|
||||
|
||||
return HttpResponseRedirect(self.get_success_url())
|
||||
|
||||
|
||||
|
|
@ -118,18 +126,21 @@ class SignupView(CreateView):
|
|||
return reverse_lazy('hosting:signup')
|
||||
|
||||
def form_valid(self, form):
|
||||
|
||||
name = form.cleaned_data.get('name')
|
||||
email = form.cleaned_data.get('email')
|
||||
password = form.cleaned_data.get('password')
|
||||
|
||||
CustomUser.register(name, password, email)
|
||||
auth_user = authenticate(email=email, password=password)
|
||||
login(self.request, auth_user)
|
||||
|
||||
return HttpResponseRedirect(self.get_success_url())
|
||||
|
||||
|
||||
class PaymentVMView(FormView):
|
||||
template_name = 'hosting/payment.html'
|
||||
form_class = PaymentForm
|
||||
form_class = BillingAddressForm
|
||||
|
||||
def get_context_data(self, **kwargs):
|
||||
context = super(PaymentVMView, self).get_context_data(**kwargs)
|
||||
|
|
@ -138,39 +149,29 @@ class PaymentVMView(FormView):
|
|||
})
|
||||
return context
|
||||
|
||||
# moodel = CustomUser
|
||||
def post(self, request, *args, **kwargs):
|
||||
form = self.get_form()
|
||||
|
||||
# def get(self, request, *args, **kwargs):
|
||||
if form.is_valid():
|
||||
|
||||
# return render(request, self.template_name, self.context)
|
||||
specifications = request.session.get('vm_specs')
|
||||
vm_type = specifications.get('hosting_company')
|
||||
vm = VirtualMachineType.objects.get(hosting_company=vm_type)
|
||||
|
||||
# class RailsBetaUserForm(ModelForm):
|
||||
# required_css_class = 'form-control'
|
||||
# class Meta:
|
||||
# model = RailsBetaUser
|
||||
# fields = [ 'email' ]
|
||||
plan_data = {
|
||||
'vm_type': vm,
|
||||
'cores': specifications.get('cores'),
|
||||
'memory': specifications.get('memory'),
|
||||
'disk_size': specifications.get('disk_size'),
|
||||
'price': vm.calculate_price(specifications)
|
||||
}
|
||||
|
||||
# def hosting(request, context):
|
||||
# email = RailsBetaUser(received_date=datetime.datetime.now())
|
||||
# Stripe payment goes here
|
||||
|
||||
# if request.method == 'POST':
|
||||
# context['form'] = RailsBetaUserForm(request.POST, instance=email)
|
||||
# if context['form'].is_valid():
|
||||
# context['form'].save()
|
||||
# email = context['form'].cleaned_data['email']
|
||||
# subject = "%shosting request" % context['hosting']
|
||||
# message = "Request for beta by: %s" % email
|
||||
# Billing Address should be store here
|
||||
|
||||
# mail_managers(subject, message)
|
||||
VirtualMachinePlan.create(plan_data, request.user)
|
||||
|
||||
# return HttpResponseRedirect(reverse("hosting:beta"))
|
||||
# else:
|
||||
# context['form'] = RailsBetaUserForm()
|
||||
# context['error_message'] = "a problem"
|
||||
|
||||
# page = "hosting/%s.html" % context['hosting']
|
||||
|
||||
# return render(request, page, context)
|
||||
|
||||
# def beta(request):
|
||||
# return render(request, 'hosting/beta.html')
|
||||
return HttpResponseRedirect(reverse('hosting:payment'))
|
||||
else:
|
||||
return self.form_invalid(form)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue