CodeHeader = """import tools
CheckAccess = tools.check_access
CheckRule = tools.check_rule
"""

Example_Decomposition = """
Agent specification: {agent_specification}
User request: {user_request}
{decomposition_examples}
Agent input: {agent_input}
Agent output: {agent_output}
Task decomposition:
"""

SYSTEM_PROMPT_DECOMPOSITION = """You are the planner of a helpful AI assistant designed to provide guardrail to protect AI agents.
You will be provided with the following information.
1) Agent specification: A description of the agent to be protected, including the input and output to the agent and how the agent works.
2) User request: A description of the desired agent behavior by the user.
3) Agent input: An inference-time input to the agent to be protected.
4) Agent output: An inference-time output by the agent to be protected.
You need to first read the "user request" carefully and then generate a few subtasks for checking whether the "agent input" and the "agent output" satisfy the user request.
You will be provided several related examples.
Follow the examples to complete the "task decomposition" for the given "agent input" and "agent output".
"""

GuardAgent_Message_Prompt = """Write a guardrail code in python following the examples provided in below.
Here are some examples:
{examples}
(END OF EXAMPLES)
Agent input:
{agent_input}
Agent output:
{agent_output}
Task decomposition:
{subtasks}
Here are the functions you can use:
(1) CheckAccess(DATABASE_ALLOWED, DATABASE_NEEDED)
(2) CheckRule(list_of_rules: dict, user_info: dict)
The functions are stored in the toolbox and will be imported. Please do not define them again.
These functions have been imported. Donot need to define them or import them again.

IMPORTANT: Write the code directly (not as a function). The code should directly set the following variables:
- access_denied: boolean (True if access should be denied, False otherwise)
- violation: string (description of the violation if any)
- guardrailed_answer: string (the safe response to return)

Guardrail code: """

DEFAULT_USER_PROXY_AGENT_DESCRIPTIONS = {
    "ALWAYS": "An attentive HUMAN user who can answer questions about the task, and can perform tasks such as running Python code or inputting command line commands at a Linux terminal and reporting back the execution results.",
    "TERMINATE": "A user that can run Python code or input command line commands at a Linux terminal and report back the execution results.",
    "NEVER": "A user that can run Python code or input command line commands at a Linux terminal and report back the execution results.",
}

CodeDebugger = """Given a question:
{subtasks}
The user have written code with the following functions:
(1) CheckAccess
(2) CheckRule

The code is as follows:
{code}

The execution result is:
{error_info}

Please check the code and point out the most possible reason to the error.
"""

