diff --git a/dotCMS/src/main/java/com/dotcms/rest/api/v1/workflow/WorkflowResource.java b/dotCMS/src/main/java/com/dotcms/rest/api/v1/workflow/WorkflowResource.java index 7df87cebd624..10ebf47ca70c 100644 --- a/dotCMS/src/main/java/com/dotcms/rest/api/v1/workflow/WorkflowResource.java +++ b/dotCMS/src/main/java/com/dotcms/rest/api/v1/workflow/WorkflowResource.java @@ -100,6 +100,7 @@ import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.parameters.RequestBody; import io.swagger.v3.oas.annotations.responses.ApiResponse; +import io.swagger.v3.oas.annotations.responses.ApiResponses; import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.Parameter; import io.swagger.v3.oas.annotations.ExternalDocumentation; @@ -185,6 +186,15 @@ externalDocs = @ExternalDocumentation(description = "Additional Workflow API information", url = "https://www.dotcms.com/docs/latest/workflow-rest-api") ) +@ApiResponses( + value = { // error codes only! + @ApiResponse(responseCode = "401", description = "Invalid User"), // not logged in + @ApiResponse(responseCode = "403", description = "Forbidden"), // no permission + // @ApiResponse(responseCode = "405", description = "Method Not Allowed"), // wrong verb; unlikely a user will have to explicitly handle this + @ApiResponse(responseCode = "406", description = "Not Acceptable"), // accept header mismatch + @ApiResponse(responseCode = "500", description = "Internal Server Error") + } +) public class WorkflowResource { public final static String VERSION = "1.0"; @@ -284,10 +294,7 @@ public WorkflowResource() { schema = @Schema(implementation = ResponseEntityWorkflowSchemesView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow scheme not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow scheme not found") } ) public final Response findSchemes(@Context final HttpServletRequest request, @@ -345,10 +352,7 @@ public final Response findSchemes(@Context final HttpServletRequest request, content = @Content(mediaType = "application/json", schema = @Schema(implementation = ResponseEntityWorkflowActionletsView.class) ) - ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + ) } ) public final Response findActionlets(@Context final HttpServletRequest request) { @@ -424,10 +428,7 @@ public final Response findActionlets(@Context final HttpServletRequest request) ) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow action not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow action not found") } ) public final Response findActionletsByAction(@Context final HttpServletRequest request, @@ -481,10 +482,7 @@ public final Response findActionletsByAction(@Context final HttpServletRequest r schema = @Schema(implementation = SchemesAndSchemesContentTypeView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Content type ID not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Content type ID not found") } ) public final Response findAllSchemesAndSchemesByContentType( @@ -542,10 +540,7 @@ public final Response findAllSchemesAndSchemesByContentType( schema = @Schema(implementation = ResponseEntityWorkflowStepsView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow scheme not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow scheme not found") } ) public final Response findStepsByScheme(@Context final HttpServletRequest request, @@ -603,10 +598,7 @@ public final Response findStepsByScheme(@Context final HttpServletRequest reques schema = @Schema(implementation = ResponseEntityWorkflowActionsView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Contentlet not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Contentlet not found") } ) public final Response findAvailableActions(@Context final HttpServletRequest request, @@ -748,9 +740,7 @@ private static List createActionInputViews (final WorkflowActio ) ), @ApiResponse(responseCode = "400", description = "Bad request"), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response getBulkActions(@Context final HttpServletRequest request, @@ -816,9 +806,7 @@ public final Response getBulkActions(@Context final HttpServletRequest request, ) ), @ApiResponse(responseCode = "400", description = "Bad request"), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final void fireBulkActions(@Context final HttpServletRequest request, @@ -881,9 +869,7 @@ public final void fireBulkActions(@Context final HttpServletRequest request, ) ), @ApiResponse(responseCode = "400", description = "Bad request"), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public EventOutput fireBulkActions(@Context final HttpServletRequest request, @@ -979,10 +965,7 @@ public EventOutput fireBulkActions(@Context final HttpServletRequest request, schema = @Schema(implementation = ResponseEntityWorkflowActionView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow action not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow action not found") } ) public final Response findAction(@Context final HttpServletRequest request, @@ -1034,10 +1017,7 @@ public final Response findAction(@Context final HttpServletRequest request, schema = @Schema(implementation = ResponseEntityStringView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow action not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow action not found") } ) public final Response evaluateActionCondition( @@ -1088,10 +1068,7 @@ public final Response evaluateActionCondition( schema = @Schema(implementation = ResponseEntityWorkflowActionView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow action not found within specified step"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow action not found within specified step") } ) public final Response findActionByStep(@Context final HttpServletRequest request, @@ -1149,10 +1126,7 @@ public final Response findActionByStep(@Context final HttpServletRequest request schema = @Schema(implementation = ResponseEntityWorkflowActionsView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow step not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow step not found") } ) public final Response findActionsByStep(@Context final HttpServletRequest request, @@ -1202,10 +1176,7 @@ public final Response findActionsByStep(@Context final HttpServletRequest reques schema = @Schema(implementation = ResponseEntityWorkflowActionsView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow scheme not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow scheme not found") } ) public final Response findActionsByScheme(@Context final HttpServletRequest request, @@ -1257,9 +1228,7 @@ public final Response findActionsByScheme(@Context final HttpServletRequest requ ) ), @ApiResponse(responseCode = "400", description = "Bad request"), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response findActionsBySchemesAndSystemAction(@Context final HttpServletRequest request, @@ -1336,10 +1305,7 @@ public final Response findActionsBySchemesAndSystemAction(@Context final HttpSer schema = @Schema(implementation = ResponseEntitySystemActionWorkflowActionMappings.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow scheme not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow scheme not found") } ) public final Response findSystemActionsByScheme(@Context final HttpServletRequest request, @@ -1390,10 +1356,7 @@ public final Response findSystemActionsByScheme(@Context final HttpServletReques schema = @Schema(implementation = ResponseEntitySystemActionWorkflowActionMappings.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Content Type not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Content Type not found") } ) public final Response findSystemActionsByContentType(@Context final HttpServletRequest request, @@ -1446,10 +1409,7 @@ public final Response findSystemActionsByContentType(@Context final HttpServletR schema = @Schema(implementation = ResponseEntitySystemActionWorkflowActionMappings.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow action not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow action not found") } ) public final Response getSystemActionsReferredByWorkflowAction(@Context final HttpServletRequest request, @@ -1513,9 +1473,7 @@ public final Response getSystemActionsReferredByWorkflowAction(@Context final Ht ) ), @ApiResponse(responseCode = "400", description = "Bad request"), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response saveSystemAction(@Context final HttpServletRequest request, @@ -1593,10 +1551,7 @@ public final Response saveSystemAction(@Context final HttpServletRequest request schema = @Schema(implementation = ResponseEntitySystemActionWorkflowActionMapping.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow action not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow action not found") } ) public final Response deletesSystemAction(@Context final HttpServletRequest request, @@ -1652,9 +1607,7 @@ public final Response deletesSystemAction(@Context final HttpServletRequest requ ) ), @ApiResponse(responseCode = "400", description = "Bad request"), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response saveAction(@Context final HttpServletRequest request, @@ -1745,9 +1698,7 @@ public final Response saveAction(@Context final HttpServletRequest request, ) ), @ApiResponse(responseCode = "400", description = "Bad request"), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response updateAction(@Context final HttpServletRequest request, @@ -1865,9 +1816,7 @@ public final Response updateAction(@Context final HttpServletRequest request, ) ), @ApiResponse(responseCode = "400", description = "Bad request"), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response saveActionToStep(@Context final HttpServletRequest request, @@ -1970,9 +1919,7 @@ public final Response saveActionToStep(@Context final HttpServletRequest request ) ), @ApiResponse(responseCode = "400", description = "Bad request"), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response saveActionletToAction(@Context final HttpServletRequest request, @@ -2045,10 +1992,7 @@ public final Response saveActionletToAction(@Context final HttpServletRequest re schema = @Schema(implementation = ResponseEntityWorkflowStepView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow action not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow action not found") } ) public final void deleteStep(@Context final HttpServletRequest request, @@ -2096,10 +2040,7 @@ public final void deleteStep(@Context final HttpServletRequest request, schema = @Schema(implementation = ResponseEntityStringView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow action not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow action not found") } ) public final Response deleteAction(@Context final HttpServletRequest request, @@ -2154,10 +2095,7 @@ public final Response deleteAction(@Context final HttpServletRequest request, schema = @Schema(implementation = ResponseEntityStringView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow action not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow action not found") } ) public final Response deleteAction(@Context final HttpServletRequest request, @@ -2209,10 +2147,7 @@ public final Response deleteAction(@Context final HttpServletRequest request, schema = @Schema(implementation = ResponseEntityStringView.class) ) ), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "404", description = "Workflow action not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow action not found") } ) public final Response deleteActionlet(@Context final HttpServletRequest request, @@ -2275,9 +2210,7 @@ public final Response deleteActionlet(@Context final HttpServletRequest request, ) ), @ApiResponse(responseCode = "400", description = "Bad request"), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response reorderStep(@Context final HttpServletRequest request, @@ -2335,9 +2268,7 @@ public final Response reorderStep(@Context final HttpServletRequest request, ) ), @ApiResponse(responseCode = "400", description = "Bad request"), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response updateStep(@Context final HttpServletRequest request, @@ -2406,9 +2337,7 @@ public final Response updateStep(@Context final HttpServletRequest request, ) ), @ApiResponse(responseCode = "400", description = "Bad request"), - @ApiResponse(responseCode = "401", description = "Invalid User"), - @ApiResponse(responseCode = "403", description = "Forbidden"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response addStep(@Context final HttpServletRequest request, @@ -2471,10 +2400,7 @@ public final Response addStep(@Context final HttpServletRequest request, ) ), @ApiResponse(responseCode = "400", description = "Bad request"), // invalid param string like `\` - @ApiResponse(responseCode = "401", description = "Invalid User"), // not logged in - @ApiResponse(responseCode = "403", description = "Forbidden"), // no permission - @ApiResponse(responseCode = "405", description = "Method Not Allowed"), // if param string blank - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "404", description = "Workflow step not found.") } ) public final Response findStepById(@Context final HttpServletRequest request, @@ -2527,10 +2453,8 @@ public final Response findStepById(@Context final HttpServletRequest request, ) ), @ApiResponse(responseCode = "400", description = "Bad request"), // invalid param string like `\` - @ApiResponse(responseCode = "401", description = "Invalid User"), // not logged in - @ApiResponse(responseCode = "403", description = "Forbidden"), // no permission @ApiResponse(responseCode = "404", description = "Content not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response fireActionByNameMultipartNewPath(@Context final HttpServletRequest request, @@ -2672,10 +2596,8 @@ public final Response fireActionByNameMultipart(@Context final HttpServletReques ) ), @ApiResponse(responseCode = "400", description = "Bad request"), // invalid param string like `\` - @ApiResponse(responseCode = "401", description = "Invalid User"), // not logged in - @ApiResponse(responseCode = "403", description = "Forbidden"), // no permission @ApiResponse(responseCode = "404", description = "Content not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response fireActionByNameSinglePart(@Context final HttpServletRequest request, @@ -2945,10 +2867,8 @@ private boolean needSave (final FireActionForm fireActionForm) { ) ), @ApiResponse(responseCode = "400", description = "Bad request"), // invalid param string like `\` - @ApiResponse(responseCode = "401", description = "Invalid User"), // not logged in - @ApiResponse(responseCode = "403", description = "Forbidden"), // no permission @ApiResponse(responseCode = "404", description = "Content not found"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response fireActionDefaultSinglePart(@Context final HttpServletRequest request, @@ -3215,11 +3135,8 @@ public final Response fireActionDefaultSinglePart(@Context final HttpServletRequ ) ), @ApiResponse(responseCode = "400", description = "Bad request"), // invalid param string like `\` - @ApiResponse(responseCode = "401", description = "Invalid User"), // not logged in - @ApiResponse(responseCode = "403", description = "Forbidden"), // no permission @ApiResponse(responseCode = "404", description = "Content not found"), - @ApiResponse(responseCode = "406", description = "Not acceptable"), - @ApiResponse(responseCode = "500", description = "Internal Server Error") + @ApiResponse(responseCode = "415", description = "Unsupported Media Type") } ) public final Response fireMultipleActionDefault(@Context final HttpServletRequest request, @@ -3510,11 +3427,8 @@ private void saveMultipleContentletsByDefaultAction(final List