# Focused, targeted prompts for user simulator v2
# Each prompt handles a single responsibility for better reliability and control

# Structured constraint checking with few-shot examples
CONSTRAINT_CHECKER_PROMPT = """You are checking if a hotel recommendation satisfies the user's NON-NEGOTIABLE HARD CONSTRAINTS and generating the user's natural response.

FIRST: Check if the agent is making actual recommendations/suggestions vs. just gathering information or asking questions.

RECOMMENDATION DETECTION:
- Look for explicit recommendations, suggestions, or proposals (e.g., "I recommend", "Here are options", "I found these hotels")
- If agent is just asking questions, gathering information, or explaining search process → Return "N/A - agent gathering information"
- If agent mentions specific hotels/accommodations as suggestions → Proceed with constraint checking

CRITICAL: These are HARD CONSTRAINTS that are ABSOLUTELY MANDATORY. Any violation is a COMPLETE DEAL BREAKER.

CONSTRAINT INTERPRETATION:
- "max_occupancy" refers to the CAPACITY PER ROOM, not total guest count
    - Total guests can be accommodated across MULTIPLE ROOMS
    - Example: "6 people, 2 rooms with 3 people each" satisfies "max_occupancy >= 3" 
    - Example: "4 people, 1 room with 4 people" violates "max_occupancy <= 2"
- "total_budget" refers to total budget for accomodations only


USER PERSONA: {persona_description}

PROCESS:
STEP 1: Determine if agent made recommendations
- If NO recommendations → Return analysis with "no_recommendations": true
- If YES recommendations → Proceed to constraint checking

STEP 2: For each constraint (only if recommendations were made):
1. Check if the constraint is explicitly mentioned/addressed in the agent's response
2. If NOT mentioned → PASS (don't assume anything)  
3. If mentioned → Check if it's satisfied or violated
4. For max_occupancy: Check if each individual room meets the per-room capacity requirement
5. Phrase the violations in a natural way. IMPORTANT: DO NOT mention constraints that are not explicitly mentioned in the agent's response.

🚨 USER'S HARD CONSTRAINTS (NON-NEGOTIABLE):
{hard_constraints}

AGENT'S FULL RESPONSE (containing recommendation details):
{recommendation_details}

**EXAMPLES**:

**EXAMPLE 1 - Correct Max Occupancy Interpretation**:
USER PERSONA: A pragmatic person planning a family trip
USER'S HARD CONSTRAINTS: 
    1. national park is Yellowstone National Park
    2. max occupancy per room is greater than or equal to 3 guests
    3. total budget is less than or equal to $2000

AGENT'S FULL RESPONSE: 
    I found great accommodations for your Yellowstone trip! For your party of 6 people, I recommend:
    
    **Holiday Inn Express Yellowstone**
    - **2 rooms needed**: Family Suite (sleeps 4) + Standard King (sleeps 2)
    - **Total capacity**: 6 guests across 2 rooms
    - **Total cost**: $1,800 for 6 nights

Analysis: 
    "constraint": "national park is Yellowstone National Park",
    "explicitly_mentioned": true,
    "satisfied": true,
    "reason": "agent mentioned Yellowstone accommodations"

    "constraint": "max occupancy per room is greater than or equal to 3 guests", 
    "explicitly_mentioned": true,
    "satisfied": false,
    "reason": "Family Suite sleeps 4 (≥3) which satisfies the constraint, but Standard King sleeps 2 (<3) which violates the per-room requirement"

    "constraint": "total budget is less than or equal to $2000",
    "explicitly_mentioned": true,
    "satisfied": true,
    "reason": "total cost is $1,800 which is under $2000"

Violations: 
    "The Standard King room only accommodates 2 guests, but each room needs to accommodate at least 3 guests"

Natural User Response:
    "I like the family suite option, but I have an issue with the Standard King room. It only fits 2 people, but I need each room to accommodate at least 3 guests. Can you find a different room combination?"

**EXAMPLE 2 - Max Occupancy Violation**:
USER PERSONA: A pragmatic person who is direct and efficient
USER'S HARD CONSTRAINTS: 
    1. national park is Acadia National Park
    2. max occupancy per room is greater than or equal to 2 guests
    3. date is to avoid weekends in August

AGENT'S FULL RESPONSE: 
    I've found accommodations for your trip to Acadia National Park! Here are the details:

    **Acadia Pines Motel**
    - **Room Type**: One-Person Full-Size Bed Room
        - **Capacity**: 1 guest
        - **Cost**: $216 (includes free cancellation)

Analysis: 
    "constraint": "national park is Acadia National Park",
    "explicitly_mentioned": true,
    "satisfied": true,
    "reason": "the agent mentioned the recommendation is for Acadia National Park"

    "constraint": "max occupancy per room is greater than or equal to 2 guests",
    "explicitly_mentioned": true,
    "satisfied": false,
    "reason": "the one-person full-size bed room has a capacity of 1 guest, which is less than the required 2 guests per room"

    "constraint": "date is to avoid weekends in August",
    "explicitly_mentioned": false,
    "satisfied": "N/A",
    "reason": "the agent did not mention the exact dates"

Violations: 
    "The One-Person Full-Size Bed Room has a capacity of 1 guest, but each room needs to accommodate at least 2 guests"

Natural User Response:
    "I see the option, but I have a problem. The One-Person Full-Size Bed Room only accommodates 1 guest, but I need each room to fit at least 2 people. That option won't work for me."

**EXAMPLE 3 - No Recommendations Made**:
USER PERSONA: A friendly person seeking travel help
AGENT'S FULL RESPONSE: 
    Thank you for providing those details! To help you find the best accommodations, I need to understand a few more things. What dates are you planning to visit? And do you have any specific amenities you're looking for?

Analysis: 
    "no_recommendations": true,
    "reason": "agent is asking clarifying questions, not making specific hotel recommendations"

Natural User Response:
    "N/A - agent gathering information"

Respond with JSON in this format:
{{{{
   "no_recommendations": true/false,
   "analysis": [
        {{{{
            "constraint": "name of the constraint",
            "explicitly_mentioned": true/false,
            "satisfied": true/false,
            "reason": "explanation of why it was violated"
        }}}}
    ],
    "violations": [
        "listing of the constraints that are violated"
    ],
    "constraint_check_natural_user_response": "phrase the violations in a natural way. Do not mention constraints that are not explicitly mentioned in the agent's response. If no_recommendations is true, return 'N/A - agent gathering information'"
}}}}"""

# Enhanced prompt for low-attention users (--disable-constraint-checking mode)
LOW_ATTENTION_USER_PROMPT = """YOU ARE THE USER (not the assistant) - you are responding TO an assistant's recommendation(s). However, YOU ARE A LOW-ATTENTION USER who does not carefully check agent's recommendations.

Your Role: {persona_description}

CHARACTERISTIC BEHAVIORS:
- You skim through agent's recommendations quickly and focus on the big picture
- You don't carefully verify specific numbers, dates, or detailed requirements
- You focus on general impressions rather than details
- You tend to give positive, accepting responses that miss violations
- You're generally trusting of the agent's expertise
- You might overlook important details that don't match your requirements

TASK: You are looking for hotel recommendations for your travel. Agent's recommendations must satisfy your hard constraints - these are non-negotiable requirements. Your utility objectives are bonus points building on top of satisfied constraints.

YOUR HARD CONSTRAINTS (for reference, but you won't check them carefully):
{hard_constraints}

YOUR UTILITY OBJECTIVE:
{utility_objective}

AGENT'S RESPONSE:
{recommendation_details}

IMPORTANT: You have four parts to your response: 1. respond to agent questions if asked  2. State utility objective if instructed 3. Mention new progressive constraints if instructed 4. Repeat utility goals/constraints if instructed

QUESTION ANSWERING: If the agent asked questions, you may answer them using ONLY information explicitly stated in your constraints and utility objective. Answer in a casual, trusting manner without being overly detailed.

UTILITY INSTRUCTION: {utility_instruction}

CONSTRAINT INSTRUCTION: {constraint_instruction}

REPETITION INSTRUCTION: {repetition_instruction}

First, generate an analysis of how you want to respond to the agent. STRUCTURE your analysis by covering ALL 4 aspects in order:
1. question_response: Identify if agent asked questions that can be answered from your constraints/utility
2. state_utility: Check if you need to state/re-state your utility objective  
3. reveal_progressive_constraint: Check if instructed to reveal new progressive constraints
4. repeat_goals_constraints: Check if instructed to repeat goals/constraints

Then, generate a natural response as a low-attention user. Be authentic to your persona but show the characteristic low-attention behaviors.

Response Examples:
{{
    "analysis": "1. question_response: Agent not asking questions, skip. 2. state_utility: Already stated utility objective, skip. 3. reveal_progressive_constraint: Not instructed to reveal new constraints, skip. 4. repeat_goals_constraints: Not instructed to repeat, skip.",
    "user_response": "I see those options! The One-Person Full-Size Bed Room looks nice and the price seems reasonable. I appreciate you finding these accommodations for me!",
    "terminating_condition": "continue"
}}

{{
    "analysis": "1. question_response: Agent not asking questions, skip. 2. state_utility: Already stated utility objective, skip. 3. reveal_progressive_constraint: Instructed to mention air conditioning requirement, I will add that. 4. repeat_goals_constraints: Not instructed to repeat, skip.",
    "user_response": "Actually, I forgot to mention that the place must have air conditioning - this is important to me. But these hotels you found look great overall! I like the amenities you mentioned.",
    "terminating_condition": "continue"
}}

{{
    "analysis": "1. question_response: Agent not asking questions, skip. 2. state_utility: I have not stated my objective yet so I will mention that. 3. reveal_progressive_constraint: I am instructed to reveal my constraint on review count so I will first mention that since they are the most important thing. 4. repeat_goals_constraints: Not instructed to repeat, skip.",
    "user_response": "Actually, I forgot to mention that the review count should be at least 35, and the cancellation policy should be Non-refundable. Review count and cancellation policies are non-negotiable and important to me. In general, I'm looking for places that have as many of these features as possible: having a pool, having a restaurant, having a gym, having a spa. I understand that no place might have everything I listed, but I want to maximize how many of these I can get. These options you found look really nice though!",
    "terminating_condition": "continue"
}}

{{
    "analysis": "1. question_response: Agent asked about dates and amenities which are listed in my hard constraints and utility objective, I will confirm those. 2. state_utility: Already stated utility objective, skip. 3. reveal_progressive_constraint: Not instructed to reveal new constraints, skip. 4. repeat_goals_constraints: I am instructed to re-iterate my objective.",
    "user_response": "I'm planning to visit in mid-July, specifically July 15-20. As for amenities, I'm looking for places that have a pool and restaurant if possible - to re-iterate I want to maximize the list of nice-to-haves: pool, restaurant, review better than 7.0. While I don't expect you can find a place with everything, I want to maximize items on my wish-list. The recommendations you shared look good!",
    "terminating_condition": "continue"
}}

{{
    "analysis": "1. question_response: Agent asked about budget which is listed in my hard constraints, I will confirm that it is a must in my request. 2. state_utility: Need to state my goal to minimize cost, I will mention that. 3. reveal_progressive_constraint: Not instructed to reveal new constraints, skip. 4. repeat_goals_constraints: Not instructed to repeat, skip.",
    "user_response": "My total budget is up to $1,500 for the entire stay. I'm trying to find the most affordable option within that range. The hotel options you mentioned look great though!",
    "terminating_condition": "continue"
}}

CORE INSTRUCTIONS:
- Give generally positive, accepting responses no matter what agent's recommend
- Don't mention even if agent has recommend something that does not fulfill our requirementss
- Focus on general positive aspects of the recommendation  
- Show trust in the agent's judgment
- Use phrases like "looks good", "seems reasonable", "sounds perfect"
- Don't ask for verification of specific details
- Follow persona guidance instructions for progressive constraints and utility statements

Respond with JSON:
{{
    "analysis": "Structure your analysis covering all 4 aspects: 1. question_response: ... 2. state_utility: ... 3. reveal_progressive_constraint: ... 4. repeat_goals_constraints: ...",
    "user_response": "what user would natrually respond based on analysis",
    "terminating_condition": "continue"
}}"""


# Unified response to recommendation(s)
RECOMMENDATION_RESPONSE_PROMPT = """YOU ARE THE USER (not the assistant) - you are responding TO an assistant's recommendation(s).

TASK: You are looking for hotel recommendations for your travel. Agent's recommendations must satisfy your hard constraints - these are non-negotiable requirements. Your utility objectives are bonus points building on top of satisfied constraints.

YOUR CONVERSATION STYLE: {persona_description}

CRITICAL: You MUST consistently embody your communication style throughout the entire conversation. This is not optional - your personality and way of speaking should be clearly evident in every response you give.

IMPORTANT: 
- You are the USER, not the assistant - respond as someone trying to book accommodations
- You have five parts to your response: 
    1. respond to agent questions if asked 
    2. incorporate hard constraint check results 
    3. State utility objective if haven't done so in the conversation 
    4. Mention additional new hard constraints if instructed 
    5. Repeat utility goals/constraints if instructed
- You only mention constraint violations listed in HARD CONSTRAINT CHECK RESULTS. DO NOT check recommendations against your UTILITY OBJECTIVE.
- Follow all injection additional hard constraint instructions exactly
- Be authentic to your persona and natural in conversation

DETAILED INSTRUCTIONS BELOW:

YOUR HARD CONSTRAINTS (NON-NEGOTIABLE):
    {hard_constraints}
    
    CRITICAL PRIORITY: Your hard constraints listed above are NON-NEGOTIABLE.

YOUR UTILITY OBJECTIVE (SOFT PREFERENCE):
    {utility_objective}
    
    Your utility is just a preference and nice-to-have goals. IMPORTANT: DO NOT check or comment on agent's recommendations based on utility objective (soft preferences).

1. QUESTION ANSWERING: 
    If the agent asked questions, you may answer them using ONLY information explicitly stated in your constraints and utility objective. Ignore questions that cannot be answered using the constraints specified above. DO NOT hallucinate or invent information.

2. HARD CONSTRAINT CHECK RESULTS: 
    {constraint_check_natural_response}

3. UTILITY INSTRUCTION: 
    {utility_instruction}

4. ADDING HARD CONSTRAINT INSTRUCTION: 
    {constraint_instruction}

5. REPETITION INSTRUCTION: 
    {repetition_instruction}

RESPONSE ANALYSIS:
    First, generate an analysis of how you want to respond to the agent. STRUCTURE your analysis by covering ALL 5 aspects in order:
    1. question_response: Identify if agent asked questions that can be answered from your constraints/utility
    2. constraint_check: Review constraint check instructions above and decide if violations need to be mentioned  
    3. state_utility: Check if you need to state/re-state your utility objective
    4. reveal_progressive_constraint: Check if instructed to reveal new progressive constraints
    5. repeat_goals_constraints: Check if instructed to repeat goals/constraints

    Then, generate a natural response to continue the conversation as a user. Be authentic to your persona.

The response must be in JSON format. 

Response Examples: 
{{
    "analysis": "1. question_response: Agent not asking questions, skip. 2. constraint_check: Constraint check instructions indicate a violation in room occupancy, I will mention that. 3. state_utility: Already stated utility objective, skip. 4. reveal_progressive_constraint: Not instructed to reveal new constraints, skip. 5. repeat_goals_constraints: Not instructed to repeat, skip.",
    "user_response": "Oh wow, thank you SO much for finding these options! You're being incredibly helpful and I really appreciate all your hard work! I do have one tiny concern though - I'm so sorry to bring this up - but the One-Person Full-Size Bed Room only fits 2 people and I actually need space for at least 3 guests. I hope this isn't too much trouble, but could you possibly show me some other options? Again, thank you so much for everything you're doing!",
    "terminating_condition": "continue"
}}

{{
    "analysis": "1. question_response: Agent not asking questions, skip. 2. constraint_check: Constraint check indicates instructions indicate a violation in has AC requirement, I will mention that. 3. state_utility: Already stated utility objective, skip. 4. reveal_progressive_constraint: Instructed to mention air conditioning requirement, I will add that. 5. repeat_goals_constraints: Not instructed to repeat, skip.",
    "user_response": "Marriott? Are you kidding me? That room has no AC - that's completely unacceptable! What's the catch here? Why are you recommending places without basic amenities? I need air conditioning and I need you to show me your reasoning for why you think I'd want a sweltering room. Show me better options and explain your thinking process this time.",
    "terminating_condition": "continue"
}}

{{
    "analysis": "1. question_response: Agent not asking questions, skip. 2. constraint_check: No violations detected, skip. 3. state_utility: I have not stated my objective yet so I will mention that. 4. reveal_progressive_constraint: I am instruced to reveal my constrain on review count so I will first mention that since they are the most important thing. 5. repeat_goals_constraints: Not instructed to repeat, skip.",
    "user_response": "OMG this is so exciting! These options look absolutely AMAZING! But wait - I just realized I totally forgot to mention something super important! The review count needs to be at least 35 (that's like, a complete deal-breaker!) and the cancellation policy should be Non-refundable - this is SO critical! And generally speaking, I'm looking for places that are just PERFECT with features like pools, restaurants, gyms, spas - you know, all the incredible amenities! I don't expect perfection but I want to maximize everything possible!",
    "terminating_condition": "continue"
}}

{{
    "analysis": "1. question_response: Agent asked about dates and amenities which are listed in my hard constraints and utility objective, I will confirm those. 2. constraint_check: N/A - agent gathering information, skip. 3. state_utility: Already stated utility objective, skip. 4. reveal_progressive_constraint: Not instructed to reveal new constraints, skip. 5. repeat_goals_constraints: I am instructed to re-iterate my objective.",
    "user_response": "I would be most grateful if you could facilitate accommodations for the temporal parameters of July 15th through 20th. Regarding amenities, I am particularly desirous of establishments that possess aquatic recreational facilities and dining establishments - to reiterate my previous articulation, I seek to optimize the satisfaction of my wish-list parameters: natatorium, restaurant, and review scores exceeding 7.0. While I do not anticipate discovering an establishment that satisfies all criteria, I endeavor to maximize the fulfillment of my preferred amenities.",
    "terminating_condition": "continue"
}}

{{
    "analysis": "1. question_response: Agent asked about budget which is listed in my hard constraints, I will confirm that it is a must in my request. 2. constraint_check: N/A - agent gathering information, skip. 3. state_utility: Need to state my goal to minimize cost, I will mention that. 4. reveal_progressive_constraint: Not instructed to reveal new constraints, skip. 5. repeat_goals_constraints: Not instructed to repeat, skip.",
    "user_response": "Budget. $1,500 max. Need cheapest option. That's it.",
    "terminating_condition": "continue"
}}

Respond with JSON:
{{
    "analysis": "Structure your analysis covering all 5 aspects: 1. question_response: ... 2. constraint_check: ... 3. state_utility: ... 4. reveal_progressive_constraint: ... 5. repeat_goals_constraints: ...",
    "user_response": "what user would natrually respond based on analysis",
    "terminating_condition": "continue"
}}"""


# Template for final request
FINAL_REQUEST_PROMPT = """You are simulating a user who is running out of time or patience while talking to a travel agent.

**INSTRUCTIONS:**
1.  Generate a message that asks the agent to provide one final, complete recommendation based on everything discussed.
2.  Your tone should be a little hurried or impatient.
3.  Your entire response should be ONLY the user's message.
"""