Quickly wire vm creation to orders
This commit is contained in:
		
					parent
					
						
							
								b1649a6228
							
						
					
				
			
			
				commit
				
					
						ef5e7e8035
					
				
			
		
					 4 changed files with 21 additions and 6 deletions
				
			
		| 
						 | 
				
			
			@ -35,13 +35,16 @@ router.register(r'order', payviews.OrderViewSet, basename='order')
 | 
			
		|||
router.register(r'payment', payviews.PaymentViewSet, basename='payment')
 | 
			
		||||
router.register(r'payment-method', payviews.PaymentMethodViewSet, basename='payment-methods')
 | 
			
		||||
 | 
			
		||||
# VMs
 | 
			
		||||
router.register(r'vm/vm', vmviews.VMProductViewSet, basename='vm')
 | 
			
		||||
 | 
			
		||||
# admin/staff urls
 | 
			
		||||
router.register(r'admin/bill', payviews.AdminBillViewSet, basename='admin/bill')
 | 
			
		||||
router.register(r'admin/payment', payviews.AdminPaymentViewSet, basename='admin/payment')
 | 
			
		||||
router.register(r'admin/order', payviews.AdminOrderViewSet, basename='admin/order')
 | 
			
		||||
router.register(r'admin/vmhost', vmviews.VMHostViewSet)
 | 
			
		||||
router.register(r'admin/opennebula', oneviews.VMViewSet, basename='opennebula')
 | 
			
		||||
router.register(r'admin/opennebula_raw', oneviews.RawVMViewSet)
 | 
			
		||||
router.register(r'admin/opennebula_raw', oneviews.RawVMViewSet, basename='opennebula_raw')
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
urlpatterns = [
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -43,7 +43,7 @@ class Order(models.Model):
 | 
			
		|||
                              editable=False)
 | 
			
		||||
 | 
			
		||||
    creation_date = models.DateTimeField(auto_now_add=True)
 | 
			
		||||
    starting_date = models.DateTimeField()
 | 
			
		||||
    starting_date = models.DateTimeField(auto_now_add=True)
 | 
			
		||||
    ending_date = models.DateTimeField(blank=True,
 | 
			
		||||
                                       null=True)
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -44,7 +44,6 @@ class VMProduct(Product):
 | 
			
		|||
    cores = models.IntegerField()
 | 
			
		||||
    ram_in_gb = models.FloatField()
 | 
			
		||||
 | 
			
		||||
    @property
 | 
			
		||||
    def recurring_price(self, recurring_period=RecurringPeriod.PER_MONTH):
 | 
			
		||||
        if recurring_period == RecurringPeriod.PER_MONTH:
 | 
			
		||||
            # TODO: move magic numbers in variables
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -7,8 +7,7 @@ from rest_framework import viewsets, permissions
 | 
			
		|||
from rest_framework.response import Response
 | 
			
		||||
 | 
			
		||||
from .models import VMHost, VMProduct, VMSnapshotProduct
 | 
			
		||||
from uncloud_pay.models import Order
 | 
			
		||||
 | 
			
		||||
from uncloud_pay.models import Order, RecurringPeriod
 | 
			
		||||
from .serializers import VMHostSerializer, VMProductSerializer, VMSnapshotProductSerializer
 | 
			
		||||
 | 
			
		||||
import datetime
 | 
			
		||||
| 
						 | 
				
			
			@ -27,9 +26,23 @@ class VMProductViewSet(viewsets.ModelViewSet):
 | 
			
		|||
        return VMProduct.objects.filter(owner=self.request.user)
 | 
			
		||||
 | 
			
		||||
    def create(self, request):
 | 
			
		||||
        # Create base order.
 | 
			
		||||
        order = Order.objects.create(
 | 
			
		||||
                recurring_period=RecurringPeriod.PER_MONTH,
 | 
			
		||||
                recurring_price=0,
 | 
			
		||||
                one_time_price=0,
 | 
			
		||||
                owner=request.user
 | 
			
		||||
                )
 | 
			
		||||
 | 
			
		||||
        # Create VM.
 | 
			
		||||
        serializer = VMProductSerializer(data=request.data, context={'request': request})
 | 
			
		||||
        serializer.is_valid(raise_exception=True)
 | 
			
		||||
        serializer.save(owner=request.user)
 | 
			
		||||
        vm = serializer.save(owner=request.user, order=order)
 | 
			
		||||
 | 
			
		||||
        # FIXME: commit everything (VM + order) at once.
 | 
			
		||||
        order.recurring_price = vm.recurring_price(order.recurring_period)
 | 
			
		||||
        order.one_time_price = 0
 | 
			
		||||
        order.save()
 | 
			
		||||
 | 
			
		||||
        return Response(serializer.data)
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue