 0e0898c3cf
			
		
	
	0e0898c3cf
	
	
	
		
			
			* stages/*: Add SerializerModel as base model, implement serializer property * flows: add initial flow exporter and importer * policies/*: implement .serializer for all policies * root: fix missing dacite requirement
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """passbook expression Policy Models"""
 | ||
| from typing import Type
 | ||
| 
 | ||
| from django.db import models
 | ||
| from django.forms import ModelForm
 | ||
| from django.utils.translation import gettext as _
 | ||
| from rest_framework.serializers import BaseSerializer
 | ||
| 
 | ||
| from passbook.policies.expression.evaluator import PolicyEvaluator
 | ||
| from passbook.policies.models import Policy
 | ||
| from passbook.policies.types import PolicyRequest, PolicyResult
 | ||
| 
 | ||
| 
 | ||
| class ExpressionPolicy(Policy):
 | ||
|     """Execute arbitrary Python code to implement custom checks and validation."""
 | ||
| 
 | ||
|     expression = models.TextField()
 | ||
| 
 | ||
|     @property
 | ||
|     def serializer(self) -> BaseSerializer:
 | ||
|         from passbook.policies.expression.api import ExpressionPolicySerializer
 | ||
| 
 | ||
|         return ExpressionPolicySerializer
 | ||
| 
 | ||
|     def form(self) -> Type[ModelForm]:
 | ||
|         from passbook.policies.expression.forms import ExpressionPolicyForm
 | ||
| 
 | ||
|         return ExpressionPolicyForm
 | ||
| 
 | ||
|     def passes(self, request: PolicyRequest) -> PolicyResult:
 | ||
|         """Evaluate and render expression. Returns PolicyResult(false) on error."""
 | ||
|         evaluator = PolicyEvaluator(self.name)
 | ||
|         evaluator.set_policy_request(request)
 | ||
|         return evaluator.evaluate(self.expression)
 | ||
| 
 | ||
|     def save(self, *args, **kwargs):
 | ||
|         PolicyEvaluator(self.name).validate(self.expression)
 | ||
|         return super().save(*args, **kwargs)
 | ||
| 
 | ||
|     class Meta:
 | ||
| 
 | ||
|         verbose_name = _("Expression Policy")
 | ||
|         verbose_name_plural = _("Expression Policies")
 |