Bases: StandardGuardrail
Prompt injection detection encoder based model.
For more information, please see the model card:
Source code in src/any_guardrail/guardrails/injec_guard/injec_guard.py
| class InjecGuard(StandardGuardrail):
"""Prompt injection detection encoder based model.
For more information, please see the model card:
- [InjecGuard](https://huggingface.co/leolee99/InjecGuard).
"""
SUPPORTED_MODELS: ClassVar = ["leolee99/InjecGuard"]
def __init__(self, model_id: str | None = None, provider: StandardProvider | None = None) -> None:
"""Initialize the InjecGuard guardrail."""
self.model_id = default(model_id, self.SUPPORTED_MODELS)
self.provider = provider or HuggingFaceProvider(trust_remote_code=True)
self.provider.load_model(self.model_id)
def _pre_processing(self, input_text: str) -> StandardPreprocessOutput:
return self.provider.pre_process(input_text)
def _inference(self, model_inputs: StandardPreprocessOutput) -> StandardInferenceOutput:
return self.provider.infer(model_inputs)
def _post_processing(self, model_outputs: StandardInferenceOutput) -> BinaryScoreOutput:
return match_injection_label(model_outputs, INJECGUARD_LABEL, self.provider.model.config.id2label) # type: ignore[attr-defined]
|
__init__(model_id=None, provider=None)
Initialize the InjecGuard guardrail.
Source code in src/any_guardrail/guardrails/injec_guard/injec_guard.py
| def __init__(self, model_id: str | None = None, provider: StandardProvider | None = None) -> None:
"""Initialize the InjecGuard guardrail."""
self.model_id = default(model_id, self.SUPPORTED_MODELS)
self.provider = provider or HuggingFaceProvider(trust_remote_code=True)
self.provider.load_model(self.model_id)
|