38 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
"""Dummy policy"""
 | 
						|
from random import SystemRandom
 | 
						|
from time import sleep
 | 
						|
 | 
						|
from django.db import models
 | 
						|
from django.utils.translation import gettext_lazy as _
 | 
						|
from structlog import get_logger
 | 
						|
 | 
						|
from passbook.policies.models import Policy
 | 
						|
from passbook.policies.types import PolicyRequest, PolicyResult
 | 
						|
 | 
						|
LOGGER = get_logger()
 | 
						|
 | 
						|
 | 
						|
class DummyPolicy(Policy):
 | 
						|
    """Policy used for debugging the PolicyEngine. Returns a fixed result,
 | 
						|
    but takes a random time to process."""
 | 
						|
 | 
						|
    __debug_only__ = True
 | 
						|
 | 
						|
    result = models.BooleanField(default=False)
 | 
						|
    wait_min = models.IntegerField(default=5)
 | 
						|
    wait_max = models.IntegerField(default=30)
 | 
						|
 | 
						|
    form = "passbook.policies.dummy.forms.DummyPolicyForm"
 | 
						|
 | 
						|
    def passes(self, request: PolicyRequest) -> PolicyResult:
 | 
						|
        """Wait random time then return result"""
 | 
						|
        wait = SystemRandom().randrange(self.wait_min, self.wait_max)
 | 
						|
        LOGGER.debug("Policy waiting", policy=self, delay=wait)
 | 
						|
        sleep(wait)
 | 
						|
        return PolicyResult(self.result, "dummy")
 | 
						|
 | 
						|
    class Meta:
 | 
						|
 | 
						|
        verbose_name = _("Dummy Policy")
 | 
						|
        verbose_name_plural = _("Dummy Policies")
 |