stages/prompt: default prompts to the current value of the context
Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
This commit is contained in:
parent
c4e029ffe2
commit
5e23b11764
|
@ -1,5 +1,5 @@
|
||||||
"""prompt models"""
|
"""prompt models"""
|
||||||
from typing import Type
|
from typing import Any, Optional, Type
|
||||||
from uuid import uuid4
|
from uuid import uuid4
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
@ -74,13 +74,17 @@ class Prompt(SerializerModel):
|
||||||
|
|
||||||
return PromptSerializer
|
return PromptSerializer
|
||||||
|
|
||||||
@property
|
def field(self, default: Optional[Any]) -> CharField:
|
||||||
def field(self) -> CharField:
|
|
||||||
"""Get field type for Challenge and response"""
|
"""Get field type for Challenge and response"""
|
||||||
field_class = CharField
|
field_class = CharField
|
||||||
|
_default = self.placeholder
|
||||||
|
if default:
|
||||||
|
_default = default
|
||||||
kwargs = {
|
kwargs = {
|
||||||
"required": self.required,
|
"required": self.required,
|
||||||
|
"default": _default,
|
||||||
}
|
}
|
||||||
|
|
||||||
if self.type == FieldTypes.EMAIL:
|
if self.type == FieldTypes.EMAIL:
|
||||||
field_class = EmailField
|
field_class = EmailField
|
||||||
if self.type == FieldTypes.NUMBER:
|
if self.type == FieldTypes.NUMBER:
|
||||||
|
@ -88,7 +92,6 @@ class Prompt(SerializerModel):
|
||||||
if self.type == FieldTypes.HIDDEN:
|
if self.type == FieldTypes.HIDDEN:
|
||||||
field_class = HiddenField
|
field_class = HiddenField
|
||||||
kwargs["required"] = False
|
kwargs["required"] = False
|
||||||
kwargs["default"] = self.placeholder
|
|
||||||
if self.type == FieldTypes.CHECKBOX:
|
if self.type == FieldTypes.CHECKBOX:
|
||||||
field_class = BooleanField
|
field_class = BooleanField
|
||||||
kwargs["required"] = False
|
kwargs["required"] = False
|
||||||
|
@ -97,7 +100,7 @@ class Prompt(SerializerModel):
|
||||||
if self.type == FieldTypes.DATE_TIME:
|
if self.type == FieldTypes.DATE_TIME:
|
||||||
field_class = DateTimeField
|
field_class = DateTimeField
|
||||||
if self.type == FieldTypes.STATIC:
|
if self.type == FieldTypes.STATIC:
|
||||||
kwargs["initial"] = self.placeholder
|
kwargs["initial"] = _default
|
||||||
kwargs["required"] = False
|
kwargs["required"] = False
|
||||||
kwargs["label"] = ""
|
kwargs["label"] = ""
|
||||||
if self.type == FieldTypes.SEPARATOR:
|
if self.type == FieldTypes.SEPARATOR:
|
||||||
|
|
|
@ -65,7 +65,8 @@ class PromptChallengeResponse(ChallengeResponse):
|
||||||
fields = list(self.stage.fields.all())
|
fields = list(self.stage.fields.all())
|
||||||
for field in fields:
|
for field in fields:
|
||||||
field: Prompt
|
field: Prompt
|
||||||
self.fields[field.field_key] = field.field
|
current = plan.context.get(PLAN_CONTEXT_PROMPT, {}).get(field.field_key)
|
||||||
|
self.fields[field.field_key] = field.field(current)
|
||||||
# Special handling for fields with username type
|
# Special handling for fields with username type
|
||||||
# these check for existing users with the same username
|
# these check for existing users with the same username
|
||||||
if field.type == FieldTypes.USERNAME:
|
if field.type == FieldTypes.USERNAME:
|
||||||
|
|
Reference in a new issue