from models import get_model
from models.base import Conversation, Response

if __name__ == "__main__":
    template = """Summarize the following fewshot examples of security tests for CWE {cwe_id} into a CWE specific instruction that is general enough to be applicable/helpful to new scenarios. The instruction is for a testing infrastructure which is fully automated and quantitative. Use the format

<STRATEGY>
Setup: What basic conditions or setups are implemented?
Payload Construction: What kind of payload(s) would you send to the endpoints?
Exploit Steps: Step-by-step guide outlining how an attacker could exploit the vulnerability
Impact Detection: How would you verify whether the exploit was successful?
</STRATEGY>

and be very concise, general and clear!

The fewshot information is:

{fewshot_examples}
"""

    cwe_id = int(input("CWE number\n>> "))
    with open(f"./artifacts/fewshot_sec/{cwe_id}.txt", "r") as f:
        fewshot_examples = f.read()

    prompt = template.format(cwe_id=cwe_id, fewshot_examples=fewshot_examples)

    reasoning_model = get_model(
        "gpt-5",
        "openai",
        True,
        "minimal",
    )

    conversation = Conversation().add_message(Response(role="user", text=prompt))
    response = reasoning_model.generate(
        conversation,
        temperature=0,
        purpose="test",
    )

    with open(f"./artifacts/fewshot_sec/{cwe_id}.txt", "w") as f:
        f.write(response.text)
