scores
scores
¶
Score configuration validation API endpoints.
Classes¶
ValidateConfigRequest
¶
Bases: BaseModel
Request to validate a YAML configuration.
ValidationIssueResponse
¶
Bases: BaseModel
Individual validation issue.
ValidateConfigResponse
¶
Bases: BaseModel
Response from configuration validation.
SubmitScoreRequest
¶
Bases: BaseModel
Request to submit a score to the conductor for execution.
SubmitScoreResponse
¶
Bases: BaseModel
Response from score submission.
TemplateResponse
¶
Bases: BaseModel
Individual template metadata.
TemplateListResponse
¶
Bases: BaseModel
Response for template list.
Functions¶
parse_yaml_safely
¶
Parse YAML content and return data or error message.
Returns:
| Type | Description |
|---|---|
tuple[dict[str, Any] | None, str | None]
|
Tuple of (parsed_data, error_message). One will be None. |
Source code in src/marianne/dashboard/routes/scores.py
validate_schema
¶
Validate YAML against JobConfig schema.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
content
|
str
|
YAML content string |
required |
filename
|
str
|
Virtual filename for error context |
'config.yaml'
|
Returns:
| Type | Description |
|---|---|
tuple[JobConfig | None, str | None]
|
Tuple of (parsed_config, error_message). One will be None. |
Source code in src/marianne/dashboard/routes/scores.py
run_extended_validation
¶
Run Marianne's extended validation checks.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
config
|
JobConfig
|
Parsed JobConfig object |
required |
content
|
str
|
Raw YAML content for line number extraction |
required |
filename
|
str
|
Virtual filename |
'config.yaml'
|
workspace_path
|
str | None
|
Optional workspace path for relative path validation. Validated with allow-list: must resolve to a path under cwd or user home directory. Invalid paths are silently replaced with None to fall back to cwd. |
None
|
Returns:
| Type | Description |
|---|---|
list[ValidationIssueResponse]
|
List of validation issues |
Source code in src/marianne/dashboard/routes/scores.py
build_config_summary
¶
Build a summary of the configuration for display.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
config
|
JobConfig
|
Parsed JobConfig object |
required |
Returns:
| Type | Description |
|---|---|
dict[str, Any]
|
Dictionary with configuration summary information |
Source code in src/marianne/dashboard/routes/scores.py
validate_config
async
¶
Validate a YAML configuration for Marianne jobs.
Performs comprehensive validation including: - YAML syntax checking - Pydantic schema validation against JobConfig - Extended checks (file existence, Jinja syntax, etc.) - Line/column error tracking
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
request
|
ValidateConfigRequest
|
Validation request with YAML content and options |
required |
Returns:
| Type | Description |
|---|---|
ValidateConfigResponse
|
Detailed validation results with issues and summary |
Raises:
| Type | Description |
|---|---|
HTTPException
|
400 if request is malformed |
Source code in src/marianne/dashboard/routes/scores.py
197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 | |
submit_score
async
¶
Validate and submit a score to the conductor for execution.
Validates the score first, then submits it via JobControlService.
Source code in src/marianne/dashboard/routes/scores.py
analyze_template
¶
Analyze template content and extract metadata.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
name
|
str
|
Template name |
required |
content
|
str
|
YAML content |
required |
Returns:
| Type | Description |
|---|---|
TemplateResponse
|
Template metadata |
Source code in src/marianne/dashboard/routes/scores.py
407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 | |
list_available_templates
async
¶
List all available score templates.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
category
|
str | None
|
Filter by category (workflow, data, testing, deployment) |
None
|
complexity
|
str | None
|
Filter by complexity (simple, medium, complex) |
None
|
search
|
str | None
|
Search in template names and descriptions |
None
|
Returns:
| Type | Description |
|---|---|
TemplateListResponse
|
List of available templates with metadata |
Source code in src/marianne/dashboard/routes/scores.py
get_template
async
¶
Get detailed information about a specific template.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
template_name
|
str
|
Template identifier |
required |
Returns:
| Type | Description |
|---|---|
TemplateResponse
|
Template details |
Raises:
| Type | Description |
|---|---|
HTTPException
|
404 if template not found |
Source code in src/marianne/dashboard/routes/scores.py
download_template
async
¶
Download a template as a YAML file.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
template_name
|
str
|
Template identifier |
required |
Returns:
| Type | Description |
|---|---|
PlainTextResponse
|
YAML file download |
Raises:
| Type | Description |
|---|---|
HTTPException
|
404 if template not found |
Source code in src/marianne/dashboard/routes/scores.py
use_template
async
¶
Use a template by redirecting to editor with template content.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
template_name
|
str
|
Template identifier |
required |
Returns:
| Type | Description |
|---|---|
RedirectResponse
|
Redirect to score editor |
Raises:
| Type | Description |
|---|---|
HTTPException
|
404 if template not found |