maps-service/openapi.yaml

807 lines
20 KiB
YAML
Raw Normal View History

2024-11-25 20:45:06 -08:00
openapi: 3.1.0
2024-11-25 17:22:45 -08:00
info:
2024-11-25 21:56:55 -08:00
title: StrafesNET Submissions - OpenAPI 3.1
2024-12-09 17:34:46 -08:00
description: Browse and manage map submissions.
2024-11-25 17:22:45 -08:00
version: 0.1.0
servers:
2024-11-25 21:56:55 -08:00
- url: https://submissions.strafes.net/v1
2024-11-25 17:22:45 -08:00
tags:
2024-11-25 21:56:55 -08:00
- name: Submissions
description: Submission operations
2024-12-03 19:29:59 -08:00
- name: Scripts
description: Script operations
2024-12-05 16:32:48 -08:00
- name: ScriptPolicy
description: Script policy operations
security:
- cookieAuth: []
2024-11-25 17:22:45 -08:00
paths:
2024-11-25 21:56:55 -08:00
/submissions:
2024-11-25 17:22:45 -08:00
get:
2024-11-25 21:18:11 -08:00
summary: Get list of submissions
2024-11-25 21:56:55 -08:00
operationId: listSubmissions
2024-11-25 17:22:45 -08:00
tags:
2024-11-25 21:56:55 -08:00
- Submissions
2024-12-17 21:33:09 -08:00
parameters:
- $ref: "#/components/parameters/Page"
- $ref: "#/components/parameters/Limit"
- name: DisplayName
in: query
schema:
type: string
maxLength: 128
- name: Creator
in: query
schema:
type: string
maxLength: 128
- name: GameID
in: query
schema:
type: integer
format: int32
- name: Sort
in: query
schema:
type: integer
format: int32
2024-11-25 17:22:45 -08:00
responses:
"200":
description: Successful response
content:
application/json:
schema:
type: array
items:
2024-11-25 21:56:55 -08:00
$ref: "#/components/schemas/Submission"
2024-11-25 17:22:45 -08:00
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
2024-11-25 21:18:11 -08:00
post:
summary: Create new submission
2024-11-25 21:56:55 -08:00
operationId: createSubmission
2024-11-25 21:18:11 -08:00
tags:
2024-11-25 21:56:55 -08:00
- Submissions
2024-11-27 15:38:17 -08:00
requestBody:
2024-12-05 18:48:26 -08:00
required: true
2024-11-27 15:38:17 -08:00
content:
application/json:
schema:
$ref: '#/components/schemas/SubmissionCreate'
2024-11-25 21:18:11 -08:00
responses:
"201":
2024-11-25 21:18:11 -08:00
description: Successful response
content:
application/json:
schema:
2024-11-27 16:13:43 -08:00
$ref: "#/components/schemas/Id"
2024-11-25 21:18:11 -08:00
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
2024-11-25 21:56:55 -08:00
/submissions/{SubmissionID}:
2024-11-25 17:22:45 -08:00
get:
2024-11-25 20:45:06 -08:00
summary: Retrieve map with ID
2024-11-25 21:56:55 -08:00
operationId: getSubmission
2024-11-25 17:22:45 -08:00
tags:
2024-11-25 21:56:55 -08:00
- Submissions
2024-11-25 17:22:45 -08:00
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/SubmissionID'
2024-11-25 17:22:45 -08:00
responses:
"200":
description: Successful response
content:
application/json:
schema:
2024-11-25 21:56:55 -08:00
$ref: "#/components/schemas/Submission"
2024-11-25 17:22:45 -08:00
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
2024-11-25 21:57:19 -08:00
/submissions/{SubmissionID}/model:
2024-12-09 21:57:35 -08:00
post:
2024-11-25 21:57:19 -08:00
summary: Update model following role restrictions
2024-12-09 21:57:35 -08:00
operationId: updateSubmissionModel
2024-11-25 21:57:19 -08:00
tags:
- Submissions
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/SubmissionID'
2024-11-25 21:57:19 -08:00
- name: ModelID
in: query
required: true
schema:
type: integer
format: int64
- name: VersionID
in: query
required: true
schema:
type: integer
format: int64
responses:
"204":
2024-11-25 21:57:19 -08:00
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
/submissions/{SubmissionID}/completed:
2024-12-09 21:57:35 -08:00
post:
2024-11-25 21:57:19 -08:00
summary: Retrieve map with ID
2024-12-09 21:57:35 -08:00
operationId: setSubmissionCompleted
2024-11-25 21:57:19 -08:00
tags:
- Submissions
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/SubmissionID'
2024-11-25 21:57:19 -08:00
responses:
"204":
2024-11-25 21:57:19 -08:00
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
2024-11-27 17:44:20 -08:00
/submissions/{SubmissionID}/status/submit:
2024-12-09 21:57:35 -08:00
post:
2024-11-27 17:44:20 -08:00
summary: Role Submitter changes status from UnderConstruction|ChangesRequested -> Submitted
operationId: actionSubmissionSubmit
2024-11-25 21:57:19 -08:00
tags:
- Submissions
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/SubmissionID'
2024-11-25 21:57:19 -08:00
responses:
"204":
2024-11-25 21:57:19 -08:00
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
2024-11-27 17:44:30 -08:00
/submissions/{SubmissionID}/status/revoke:
2024-12-09 21:57:35 -08:00
post:
2024-11-27 17:44:30 -08:00
summary: Role Submitter changes status from Submitted|ChangesRequested -> UnderConstruction
operationId: actionSubmissionRevoke
tags:
- Submissions
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/SubmissionID'
2024-11-27 17:44:30 -08:00
responses:
"204":
2024-11-27 17:44:30 -08:00
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
/submissions/{SubmissionID}/status/trigger-validate:
2024-12-09 21:57:35 -08:00
post:
2024-11-27 17:44:30 -08:00
summary: Role Reviewer triggers validation and changes status from Submitted|Accepted -> Validating
operationId: actionSubmissionTriggerValidate
tags:
- Submissions
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/SubmissionID'
2024-11-27 17:44:30 -08:00
responses:
"204":
2024-11-27 17:44:30 -08:00
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
/submissions/{SubmissionID}/status/reject:
2024-12-09 21:57:35 -08:00
post:
2024-11-27 17:44:30 -08:00
summary: Role Reviewer changes status from Submitted -> Rejected
operationId: actionSubmissionReject
tags:
- Submissions
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/SubmissionID'
2024-11-27 17:44:30 -08:00
responses:
"204":
2024-11-27 17:44:30 -08:00
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
/submissions/{SubmissionID}/status/request-changes:
2024-12-09 21:57:35 -08:00
post:
2024-11-27 17:44:30 -08:00
summary: Role Reviewer changes status from Validated|Accepted|Submitted -> ChangesRequested
operationId: actionSubmissionRequestChanges
tags:
- Submissions
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/SubmissionID'
2024-11-27 17:44:30 -08:00
responses:
"204":
2024-11-27 17:44:30 -08:00
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
/submissions/{SubmissionID}/status/trigger-upload:
2024-12-09 21:57:35 -08:00
post:
summary: Role Admin changes status from Validated -> Uploading
operationId: actionSubmissionTriggerUpload
2024-11-27 17:44:30 -08:00
tags:
- Submissions
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/SubmissionID'
2024-11-27 17:44:30 -08:00
responses:
"204":
2024-11-27 17:44:30 -08:00
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
/release-submissions:
post:
summary: Release a set of uploaded maps
operationId: releaseSubmissions
tags:
- Submissions
requestBody:
required: true
content:
application/json:
schema:
type: array
minItems: 1
maxItems: 255
items:
$ref: '#/components/schemas/ReleaseInfo'
responses:
"201":
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
2024-12-05 16:32:48 -08:00
/script-policy:
get:
summary: Get list of script policies
operationId: listScriptPolicy
tags:
- ScriptPolicy
2024-12-17 21:33:09 -08:00
parameters:
- $ref: "#/components/parameters/Page"
- $ref: "#/components/parameters/Limit"
- name: FromScriptHash
in: query
schema:
type: string
minLength: 16
maxLength: 16
- name: ToScriptID
in: query
schema:
type: integer
format: int64
- name: Policy
in: query
schema:
type: integer
format: int32
responses:
"200":
description: Successful response
content:
application/json:
schema:
type: array
items:
$ref: "#/components/schemas/ScriptPolicy"
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
2024-12-05 16:32:48 -08:00
post:
summary: Create a new script policy
operationId: createScriptPolicy
tags:
- ScriptPolicy
requestBody:
2024-12-05 18:48:26 -08:00
required: true
2024-12-05 16:32:48 -08:00
content:
application/json:
schema:
$ref: '#/components/schemas/ScriptPolicyCreate'
responses:
"201":
2024-12-05 16:32:48 -08:00
description: Successful response
content:
application/json:
schema:
$ref: "#/components/schemas/Id"
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
/script-policy/{ScriptPolicyID}:
2024-12-05 16:32:48 -08:00
get:
summary: Get the specified script policy by ID
operationId: getScriptPolicy
tags:
- ScriptPolicy
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/ScriptPolicyID'
2024-12-05 16:32:48 -08:00
responses:
"200":
description: Successful response
content:
application/json:
schema:
$ref: "#/components/schemas/ScriptPolicy"
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
2024-12-09 21:57:35 -08:00
post:
2024-12-05 16:32:48 -08:00
summary: Update the specified script policy by ID
operationId: updateScriptPolicy
tags:
- ScriptPolicy
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/ScriptPolicyID'
2024-12-05 16:32:48 -08:00
requestBody:
2024-12-05 18:48:26 -08:00
required: true
2024-12-05 16:32:48 -08:00
content:
application/json:
schema:
$ref: '#/components/schemas/ScriptPolicyUpdate'
responses:
"204":
2024-12-05 16:32:48 -08:00
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
delete:
summary: Delete the specified script policy by ID
operationId: deleteScriptPolicy
tags:
- ScriptPolicy
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/ScriptPolicyID'
2024-12-05 16:32:48 -08:00
responses:
"204":
2024-12-05 16:32:48 -08:00
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
/scripts:
get:
summary: Get list of scripts
operationId: listScripts
tags:
- Script
parameters:
- $ref: "#/components/parameters/Page"
- $ref: "#/components/parameters/Limit"
- name: Hash
in: query
schema:
type: string
minLength: 16
maxLength: 16
- name: Name
in: query
schema:
type: string
maxLength: 128
- name: Source
in: query
schema:
type: string
maxLength: 1048576
- name: SubmissionID
in: query
schema:
type: integer
format: int64
responses:
"200":
description: Successful response
content:
application/json:
schema:
type: array
items:
$ref: "#/components/schemas/Script"
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
2024-12-05 16:32:48 -08:00
post:
summary: Create a new script
operationId: createScript
tags:
- Scripts
requestBody:
2024-12-05 18:48:26 -08:00
required: true
2024-12-05 16:32:48 -08:00
content:
application/json:
schema:
$ref: '#/components/schemas/ScriptCreate'
responses:
"201":
2024-12-05 16:32:48 -08:00
description: Successful response
content:
application/json:
schema:
$ref: "#/components/schemas/Id"
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
2024-12-04 17:27:32 -08:00
/scripts/{ScriptID}:
get:
summary: Get the specified script by ID
operationId: getScript
tags:
- Scripts
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/ScriptID'
2024-12-04 17:27:32 -08:00
responses:
"200":
description: Successful response
content:
application/json:
schema:
$ref: "#/components/schemas/Script"
2024-12-03 19:29:59 -08:00
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
2024-12-09 21:57:35 -08:00
post:
2024-12-05 16:32:48 -08:00
summary: Update the specified script by ID
operationId: updateScript
tags:
- Scripts
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/ScriptID'
2024-12-05 16:32:48 -08:00
requestBody:
2024-12-05 18:48:26 -08:00
required: true
2024-12-05 16:32:48 -08:00
content:
application/json:
schema:
$ref: '#/components/schemas/ScriptUpdate'
responses:
"204":
2024-12-05 16:32:48 -08:00
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
delete:
summary: Delete the specified script by ID
operationId: deleteScript
tags:
- Scripts
parameters:
2024-12-09 22:05:47 -08:00
- $ref: '#/components/parameters/ScriptID'
2024-12-05 16:32:48 -08:00
responses:
"204":
2024-12-05 16:32:48 -08:00
description: Successful response
default:
description: General Error
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
2024-11-25 17:22:45 -08:00
components:
2024-11-29 14:33:48 -08:00
securitySchemes:
cookieAuth:
type: apiKey
in: cookie
2024-12-09 19:32:47 -08:00
name: session_id
2024-12-09 22:05:47 -08:00
parameters:
SubmissionID:
name: SubmissionID
in: path
required: true
description: The unique identifier for a submission.
schema:
type: integer
format: int64
ScriptID:
name: ScriptID
in: path
required: true
description: The unique identifier for a script.
schema:
type: integer
format: int64
ScriptPolicyID:
name: ScriptPolicyID
in: path
required: true
description: The unique identifier for a script policy.
schema:
type: integer
format: int64
2024-12-17 21:33:09 -08:00
Page:
name: Page
in: query
required: true
schema:
type: integer
format: int32
minimum: 1
Limit:
name: Limit
in: query
required: true
schema:
type: integer
format: int32
minimum: 1
maximum: 100
2024-11-25 17:22:45 -08:00
schemas:
2024-11-27 16:13:43 -08:00
Id:
2024-12-05 16:32:48 -08:00
required:
- ID
2024-11-27 16:13:43 -08:00
type: object
properties:
ID:
type: integer
format: int64
2024-11-25 21:56:55 -08:00
Submission:
2024-12-05 16:32:48 -08:00
required:
- ID
- DisplayName
- Creator
- GameID
2024-12-09 22:27:52 -08:00
- CreatedAt
- UpdatedAt
2024-12-05 16:32:48 -08:00
- Submitter
- AssetID
- AssetVersion
- Completed
- SubmissionType
# - TargetAssetID
- StatusID
2024-11-25 17:22:45 -08:00
type: object
properties:
ID:
type: integer
format: int64
DisplayName:
type: string
maxLength: 128
2024-11-25 17:22:45 -08:00
Creator:
type: string
maxLength: 128
2024-11-25 17:22:45 -08:00
GameID:
type: integer
format: int32
2024-12-09 22:27:52 -08:00
CreatedAt:
type: integer
format: int64
UpdatedAt:
2024-11-25 17:22:45 -08:00
type: integer
format: int64
2024-11-26 14:42:22 -08:00
Submitter:
type: integer
format: int64
AssetID:
type: integer
format: int64
AssetVersion:
type: integer
format: int64
Completed:
type: boolean
SubmissionType:
type: integer
format: int32
TargetAssetID:
type: integer
format: int64
StatusID:
type: integer
format: int32
2024-11-27 15:38:17 -08:00
SubmissionCreate:
2024-12-05 16:32:48 -08:00
required:
- DisplayName
- Creator
- GameID
- AssetID
- AssetVersion
# - TargetAssetID
2024-11-27 15:38:17 -08:00
type: object
properties:
DisplayName:
type: string
maxLength: 128
2024-11-27 15:38:17 -08:00
Creator:
type: string
maxLength: 128
2024-11-27 15:38:17 -08:00
GameID:
type: integer
format: int32
AssetID:
type: integer
format: int64
AssetVersion:
type: integer
format: int64
TargetAssetID:
type: integer
format: int64
ReleaseInfo:
required:
- SubmissionID
- Date
type: object
properties:
SubmissionID:
type: integer
format: int64
Date:
type: string
format: date-time
2024-12-04 17:27:32 -08:00
Script:
2024-12-05 16:32:48 -08:00
required:
- ID
2024-12-14 12:31:31 -08:00
- Name
2024-12-05 16:32:48 -08:00
- Hash
- Source
- SubmissionID
2024-12-04 17:27:32 -08:00
type: object
properties:
ID:
type: integer
format: int64
2024-12-14 12:31:31 -08:00
Name:
type: string
maxLength: 128
2024-12-04 17:27:32 -08:00
Hash:
type: string
minLength: 16
maxLength: 16
2024-12-04 17:27:32 -08:00
Source:
type: string
maxLength: 1048576
2024-12-04 17:27:32 -08:00
SubmissionID:
type: integer
format: int64
2024-12-05 16:32:48 -08:00
ScriptCreate:
required:
2024-12-14 12:31:31 -08:00
- Name
2024-12-05 16:32:48 -08:00
- Source
# - SubmissionID
type: object
properties:
2024-12-14 12:31:31 -08:00
Name:
type: string
maxLength: 128
2024-12-05 16:32:48 -08:00
Source:
type: string
maxLength: 1048576
2024-12-05 16:32:48 -08:00
SubmissionID:
type: integer
format: int64
ScriptUpdate:
required:
- ID
type: object
properties:
ID:
type: integer
format: int64
2024-12-14 12:31:31 -08:00
Name:
type: string
maxLength: 128
2024-12-05 16:32:48 -08:00
Source:
type: string
maxLength: 1048576
2024-12-05 16:32:48 -08:00
SubmissionID:
type: integer
format: int64
2024-12-04 17:27:32 -08:00
ScriptPolicy:
2024-12-05 16:32:48 -08:00
required:
- ID
- FromScriptHash
- ToScriptID
- Policy
2024-12-04 17:27:32 -08:00
type: object
properties:
ID:
type: integer
format: int64
2024-12-05 16:32:48 -08:00
FromScriptHash:
2024-12-04 17:27:32 -08:00
type: string
minLength: 16
maxLength: 16
2024-12-05 16:32:48 -08:00
ToScriptID:
type: integer
format: int64
Policy:
type: integer
format: int32
ScriptPolicyCreate:
required:
- FromScriptID
- ToScriptID
- Policy
type: object
properties:
FromScriptID:
type: integer
format: int64
ToScriptID:
type: integer
format: int64
Policy:
type: integer
format: int32
ScriptPolicyUpdate:
required:
- ID
type: object
properties:
ID:
type: integer
format: int64
FromScriptID:
type: integer
format: int64
ToScriptID:
2024-12-04 17:27:32 -08:00
type: integer
format: int64
Policy:
type: integer
format: int32
2024-11-25 17:22:45 -08:00
Error:
description: Represents error object
type: object
properties:
code:
type: integer
format: int64
message:
type: string
required:
- code
2024-11-25 19:06:12 -08:00
- message