Readur/src/swagger.rs

211 lines
9.9 KiB
Rust

use utoipa::{OpenApi, Modify};
use utoipa::openapi::security::{SecurityScheme, HttpAuthScheme, Http};
use utoipa_swagger_ui::SwaggerUi;
use axum::Router;
use std::sync::Arc;
use crate::{
models::{
CreateUser, LoginRequest, LoginResponse, UserResponse, UpdateUser,
DocumentResponse, SearchRequest, SearchResponse, EnhancedDocumentResponse,
SettingsResponse, UpdateSettings, SearchMode, SearchSnippet, HighlightRange,
FacetItem, SearchFacetsResponse, Notification, NotificationSummary, CreateNotification,
Source, SourceResponse, CreateSource, UpdateSource, SourceWithStats,
WebDAVSourceConfig, LocalFolderSourceConfig, S3SourceConfig,
ProcessedImage, CreateProcessedImage, IgnoredFileResponse, IgnoredFilesQuery,
DocumentListResponse, DocumentOcrResponse, DocumentOperationResponse,
BulkDeleteResponse, PaginationInfo, DocumentDuplicatesResponse
},
models::source::{
WebDAVCrawlEstimate, WebDAVTestConnection, WebDAVConnectionResult, WebDAVSyncStatus,
},
routes::{
metrics::{
SystemMetrics, DatabaseMetrics, OcrMetrics, DocumentMetrics, UserMetrics, GeneralSystemMetrics
},
labels::{
Label, CreateLabel, UpdateLabel, LabelAssignment, LabelQuery, BulkUpdateRequest as LabelBulkUpdateRequest
},
documents::BulkDeleteRequest
},
AppState,
};
#[derive(OpenApi)]
#[openapi(
paths(
// Auth endpoints
crate::routes::auth::register,
crate::routes::auth::login,
crate::routes::auth::me,
crate::routes::auth::oidc_login,
crate::routes::auth::oidc_callback,
// Document endpoints
crate::routes::documents::crud::upload_document,
crate::routes::documents::crud::list_documents,
crate::routes::documents::crud::get_document_by_id,
crate::routes::documents::crud::delete_document,
crate::routes::documents::bulk::bulk_delete_documents,
crate::routes::documents::crud::download_document,
crate::routes::documents::crud::view_document,
crate::routes::documents::debug::get_document_thumbnail,
crate::routes::documents::ocr::get_document_ocr,
crate::routes::documents::debug::get_processed_image,
crate::routes::documents::ocr::retry_ocr,
crate::routes::documents::debug::get_document_debug_info,
crate::routes::documents::failed::get_failed_ocr_documents,
crate::routes::documents::failed::view_failed_document,
crate::routes::documents::bulk::delete_low_confidence_documents,
crate::routes::documents::bulk::delete_failed_ocr_documents,
crate::routes::documents::crud::get_user_duplicates,
// Labels endpoints
crate::routes::labels::get_labels,
crate::routes::labels::create_label,
crate::routes::labels::get_label,
crate::routes::labels::update_label,
crate::routes::labels::delete_label,
crate::routes::labels::get_document_labels,
crate::routes::labels::update_document_labels,
crate::routes::labels::add_document_label,
crate::routes::labels::remove_document_label,
crate::routes::labels::bulk_update_document_labels,
// Search endpoints
crate::routes::search::search_documents,
crate::routes::search::enhanced_search_documents,
crate::routes::search::get_search_facets,
// Settings endpoints
crate::routes::settings::get_settings,
crate::routes::settings::update_settings,
// User endpoints
crate::routes::users::list_users,
crate::routes::users::create_user,
crate::routes::users::get_user,
crate::routes::users::update_user,
crate::routes::users::delete_user,
// Queue endpoints
crate::routes::queue::get_queue_stats,
crate::routes::queue::requeue_failed,
crate::routes::queue::enqueue_pending_documents,
crate::routes::queue::get_ocr_status,
crate::routes::queue::pause_ocr_processing,
crate::routes::queue::resume_ocr_processing,
// Metrics endpoints
crate::routes::metrics::get_system_metrics,
crate::routes::prometheus_metrics::get_prometheus_metrics,
// Notifications endpoints
crate::routes::notifications::get_notifications,
crate::routes::notifications::get_notification_summary,
crate::routes::notifications::mark_notification_read,
crate::routes::notifications::mark_all_notifications_read,
crate::routes::notifications::delete_notification,
// Sources endpoints
crate::routes::sources::crud::list_sources,
crate::routes::sources::crud::create_source,
crate::routes::sources::crud::get_source,
crate::routes::sources::crud::update_source,
crate::routes::sources::crud::delete_source,
crate::routes::sources::sync::trigger_sync,
crate::routes::sources::sync::stop_sync,
crate::routes::sources::sync::trigger_deep_scan,
crate::routes::sources::sync::sync_progress_websocket,
crate::routes::sources::sync::get_sync_status,
crate::routes::sources::validation::test_connection,
crate::routes::sources::validation::validate_source,
crate::routes::sources::estimation::estimate_crawl,
crate::routes::sources::estimation::estimate_crawl_with_config,
crate::routes::sources::validation::test_connection_with_config,
// WebDAV endpoints
crate::routes::webdav::start_webdav_sync,
crate::routes::webdav::cancel_webdav_sync,
crate::routes::webdav::get_webdav_sync_status,
crate::routes::webdav::test_webdav_connection,
crate::routes::webdav::estimate_webdav_crawl,
// OCR endpoints
crate::routes::ocr::get_available_languages,
crate::ocr::api::health_check,
crate::ocr::api::perform_ocr,
// Ignored files endpoints
crate::routes::ignored_files::list_ignored_files,
crate::routes::ignored_files::get_ignored_file,
crate::routes::ignored_files::delete_ignored_file,
crate::routes::ignored_files::bulk_delete_ignored_files,
crate::routes::ignored_files::get_ignored_files_stats,
// Health check
crate::health_check,
),
components(
schemas(
CreateUser, LoginRequest, LoginResponse, UserResponse, UpdateUser,
DocumentResponse, SearchRequest, SearchResponse, EnhancedDocumentResponse,
SettingsResponse, UpdateSettings, SearchMode, SearchSnippet, HighlightRange,
FacetItem, SearchFacetsResponse, Notification, NotificationSummary, CreateNotification,
Source, SourceResponse, CreateSource, UpdateSource, SourceWithStats,
WebDAVSourceConfig, LocalFolderSourceConfig, S3SourceConfig,
WebDAVCrawlEstimate, WebDAVTestConnection, WebDAVConnectionResult, WebDAVSyncStatus,
ProcessedImage, CreateProcessedImage, IgnoredFileResponse, IgnoredFilesQuery,
crate::routes::ignored_files::BulkDeleteIgnoredFilesRequest,
crate::routes::ignored_files::IgnoredFilesStats,
crate::routes::ignored_files::SourceTypeCount,
SystemMetrics, DatabaseMetrics, OcrMetrics, DocumentMetrics, UserMetrics, GeneralSystemMetrics,
// Labels schemas
Label, CreateLabel, UpdateLabel, LabelAssignment, LabelQuery, LabelBulkUpdateRequest,
// Document schemas
BulkDeleteRequest, DocumentListResponse, DocumentOcrResponse, DocumentOperationResponse,
BulkDeleteResponse, PaginationInfo, DocumentDuplicatesResponse, crate::routes::documents::RetryOcrRequest,
// OCR schemas
crate::routes::ocr::AvailableLanguagesResponse, crate::routes::ocr::LanguageInfo,
crate::ocr::api::OcrHealthResponse, crate::ocr::api::OcrErrorResponse, crate::ocr::api::OcrRequest,
// Sync progress schemas
crate::services::sync_progress_tracker::SyncProgressInfo
)
),
tags(
(name = "auth", description = "Authentication endpoints"),
(name = "documents", description = "Document management endpoints"),
(name = "labels", description = "Document labeling and categorization endpoints"),
(name = "search", description = "Document search endpoints"),
(name = "settings", description = "User settings endpoints"),
(name = "users", description = "User management endpoints"),
(name = "queue", description = "OCR queue management endpoints"),
(name = "metrics", description = "System metrics and monitoring endpoints"),
(name = "notifications", description = "User notification endpoints"),
(name = "sources", description = "Document source management endpoints"),
(name = "webdav", description = "WebDAV synchronization endpoints"),
(name = "ignored_files", description = "Ignored files management endpoints"),
(name = "ocr", description = "OCR service management endpoints"),
(name = "health", description = "Health check endpoint"),
),
modifiers(&SecurityAddon),
info(
title = "Readur API",
version = "2.5.3",
description = "Document management and OCR processing API",
contact(
name = "Readur Team",
email = "support@readur.dev"
)
),
servers(
(url = "/api", description = "API base path")
)
)]
pub struct ApiDoc;
struct SecurityAddon;
impl Modify for SecurityAddon {
fn modify(&self, openapi: &mut utoipa::openapi::OpenApi) {
if let Some(components) = openapi.components.as_mut() {
components.add_security_scheme(
"bearer_auth",
SecurityScheme::Http(Http::new(HttpAuthScheme::Bearer))
)
}
}
}
pub fn create_swagger_router() -> Router<Arc<AppState>> {
SwaggerUi::new("/swagger-ui")
.url("/api-docs/openapi.json", ApiDoc::openapi())
.into()
}