File size: 3,381 Bytes
431d059
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
from pydantic import BaseModel, Field, EmailStr
from typing import List

# Data model for attachments (like the sample image)
class Attachment(BaseModel):
    name: str = Field(..., description="Name of the attached file (e.g., 'sample.png')")
    url: str = Field(..., description="The content encoded as a data URI (data:image/png;base64,...)")

# The main data model for the incoming task payload
class TaskRequest(BaseModel):
    # Student email ID
    email: EmailStr = Field(..., description="Student email ID")
    # Student-provided secret
    secret: str = Field(..., description="Student-provided secret")
    # A unique task ID.
    task: str = Field(..., description="A unique task ID (e.g., 'captcha-solver-...')")
    # There will be multiple rounds per task. This is the round index
    round: int = Field(..., description="The round index (e.g., 1)")
    # Pass this nonce back to the evaluation URL
    nonce: str = Field(..., description="Pass this nonce back to the evaluation URL below")
    # brief: mentions what the app needs to do
    brief: str = Field(..., description="Brief description of what the app needs to do")
    # checks: mention how it will be evaluated
    checks: List[str] = Field(..., description="Evaluation checks (e.g., license, readme quality)")
    # Send repo & commit details to the URL below
    evaluation_url: str = Field(..., description="URL to send repo & commit details")
    # Attachments will be encoded as data URIs
    attachments: List[Attachment] = Field(..., description="Attachments encoded as data URIs")



# from pydantic import BaseModel, EmailStr
# from typing import List, Optional

# # Defines the structure for an individual attachment, like a sample captcha image
# class Attachment(BaseModel):
#     """
#     Represents an attachment provided in the task payload.
#     The 'url' is expected to be a data URI (e.g., base64 encoded image).
#     """
#     name: str
#     url: str

# # Defines the complete structure of the JSON request body
# class TaskRequest(BaseModel):
#     """
#     The main model representing the task request sent by the evaluation server.
#     """
#     email: EmailStr  # Enforces a valid email format
#     secret: str
#     task: str
#     round: int
#     nonce: str
#     brief: str
#     checks: List[str]  # A list of strings detailing the evaluation checks
#     evaluation_url: str
#     attachments: List[Attachment] # A list of Attachment objects

#     # Configuration for Pydantic to allow validation from dicts/JSON
#     class Config:
#         schema_extra = {
#             "example": {
#                 "email": "student@example.com",
#                 "secret": "my-secure-token",
#                 "task": "captcha-solver-12345",
#                 "round": 1,
#                 "nonce": "ab12-cd34-ef56",
#                 "brief": "Create a captcha solver that handles ?url=https://.../image.png.",
#                 "checks": [
#                     "Repo has MIT license",
#                     "README.md is professional"
#                 ],
#                 "evaluation_url": "https://example.com/notify",
#                 "attachments": [
#                     {
#                         "name": "sample.png",
#                         "url": "..."
#                     }
#                 ]
#             }
#         }