From bcca364021fbe54f2404de9664072c23ecd78aa0 Mon Sep 17 00:00:00 2001 From: sultanofdisco Date: Sun, 29 Jun 2025 22:37:36 +0900 Subject: [PATCH] =?UTF-8?q?[ADD]apple=20=ED=94=84=EB=A1=AC=ED=94=84?= =?UTF-8?q?=ED=8A=B8=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/lib/llm/prompt/apple/__init__.py | 2 + src/lib/llm/prompt/apple/model.py | 6 +++ src/lib/llm/prompt/apple/prompt.py | 58 ++++++++++++++++++++++++++++ 3 files changed, 66 insertions(+) create mode 100644 src/lib/llm/prompt/apple/__init__.py create mode 100644 src/lib/llm/prompt/apple/model.py create mode 100644 src/lib/llm/prompt/apple/prompt.py diff --git a/src/lib/llm/prompt/apple/__init__.py b/src/lib/llm/prompt/apple/__init__.py new file mode 100644 index 0000000..ccd832f --- /dev/null +++ b/src/lib/llm/prompt/apple/__init__.py @@ -0,0 +1,2 @@ +from lib.llm.prompt.apple.prompt import prompt +from lib.llm.prompt.apple.model import model diff --git a/src/lib/llm/prompt/apple/model.py b/src/lib/llm/prompt/apple/model.py new file mode 100644 index 0000000..773f3a7 --- /dev/null +++ b/src/lib/llm/prompt/apple/model.py @@ -0,0 +1,6 @@ +from pydantic import BaseModel + +class model(BaseModel): + msg: str | None = None + status: str | None = None # "success", "mfa_required", "apple_blocked", "sso_not_found", "login_page_not_found", "invalid_credentials" + final_url: str | None = None diff --git a/src/lib/llm/prompt/apple/prompt.py b/src/lib/llm/prompt/apple/prompt.py new file mode 100644 index 0000000..99a6b96 --- /dev/null +++ b/src/lib/llm/prompt/apple/prompt.py @@ -0,0 +1,58 @@ +import os + +# Extended planner prompt +prompt = f""" +You are a web automation agent. + +Your task is to visit the given domain and perform a full login via the **Apple SSO button**, following all steps strictly as described below. + +▶ Target: Find a login page inside this domain that allows "Sign in with Apple", and use it to complete login via Apple. + +Instructions: + +1. If any cookie or privacy popups appear, dismiss or accept them. +2. Navigate through the site's UI to find the **login or sign-in page** (e.g., via buttons like "Log In", "Sign In", "Get Started"). + - Only follow links within the same domain. +3. On the login page, look for a clearly labeled **Apple SSO button** — typically labeled as: + - "Continue with Apple" + - "Sign in with Apple" + - or a button with the Apple icon +4. Click the **Apple login button**. + - ⚠️ The Apple login flow MUST open in a **new browser tab** (not a new window or popup). + - ❌ If the login opens in a new **window** or **popup**, do NOT continue. Immediately stop and return the appropriate status. +5. Check if the user is **already logged in to Apple and immediately redirected back to the original site** without showing a Apple login screen. + - ✅ If so, treat the login as successful and return immediately. +6. If redirected to the Apple login page: + - If a **CAPTCHA**, **MFA prompt**, or a request for **ID/password entry** appears, do NOT proceed. + - Immediately stop and return the appropriate status. +7. If login proceeds without interruptions, wait for redirection back to the original site and record the final URL. + +Credentials to use for Apple login: +- Email: {os.getenv("APPLE_EMAIL", "")} +- Password: {os.getenv("APPLE_PASSWORD", "")} + +Constraints: +- Do NOT use search engines or guess URLs. +- Do NOT use autofill, saved sessions, or cookies. +- Do NOT proceed with login if: + - The login opens in a new window (only tabs are allowed) + - CAPTCHA or MFA appears + - ID/password input is required +- If the user is already logged in to Apple and redirected back automatically, stop there and report success. +- If the login page cannot be found, return "login_page_not_found". +- If the Apple login button is not found, return "sso_not_found". +- If a page such as a sign-up page appears, consider it a successful login and terminate immediately. + +Final Output: +Return the result in the following format only: + +```json +{{ + "msg": "Apple login completed", + "status": "success" | "already_logged_in" | "mfa_required" | "captcha_triggered" | "window_blocked" | "idpw_required" | "apple_blocked" | "sso_not_found" | "login_page_not_found", + "final_url": "" +}} +``` + +- Return ONLY the JSON object. Do NOT include any explanation, logging, or extra output. +""" \ No newline at end of file