Launchlab / guardrails /guardrails_input_function.py
Muhammad Saad
Add application file
8770644
import traceback
from agents import RunContextWrapper, Runner, GuardrailFunctionOutput, input_guardrail
from guardrails.input_guardrails import guardrail_agent
@input_guardrail
async def guardrail_input_function(ctx: RunContextWrapper, agent, user_input: str):
try:
result = await Runner.run(
guardrail_agent,
input=user_input,
context=ctx.context
)
# Check if result has the expected structure
if not result or not hasattr(result, 'final_output'):
print(f"Warning: Guardrail agent returned unexpected result: {result}")
# Allow the query to proceed if guardrail fails
return GuardrailFunctionOutput(
output_info=None,
tripwire_triggered=False
)
final_output = result.final_output
# Check if final_output has the expected attribute
if not hasattr(final_output, 'is_query_about_launchlabs'):
print(f"Warning: Guardrail output missing is_query_about_launchlabs attribute: {final_output}")
return GuardrailFunctionOutput(
output_info=final_output,
tripwire_triggered=False
)
return GuardrailFunctionOutput(
output_info=final_output,
tripwire_triggered=not final_output.is_query_about_launchlabs
)
except Exception as e:
print(f"Error in guardrail_input_function: {e}")
print(traceback.format_exc())
# Allow the query to proceed if guardrail fails
return GuardrailFunctionOutput(
output_info=None,
tripwire_triggered=False
)