5050//! }
5151//! ```
5252
53+ use crate :: include_png_as_base64;
5354use crate :: visualization:: oxide_auth:: { authorize, authorize_consent, refresh, token} ;
5455use include_dir:: { include_dir, Dir } ;
5556use rocket:: fairing:: { Fairing , Info , Kind } ;
@@ -58,7 +59,7 @@ use rocket::http::{ContentType, Header};
5859use rocket:: response:: { Redirect , Responder } ;
5960use rocket:: { async_trait, get, options, routes, uri, Build , Rocket } ;
6061use rocket:: { Request , Response } ;
61- use rocket_okapi:: { openapi, openapi_get_routes} ;
62+ use rocket_okapi:: { openapi, openapi_get_routes, rapidoc :: * , settings :: UrlObject } ;
6263use std:: env;
6364use std:: io:: Cursor ;
6465use std:: path:: PathBuf ;
@@ -232,12 +233,11 @@ pub async fn build_rocket(figment: Figment, hmac_secret: &str) -> Rocket<Build>
232233 . attach ( CORS )
233234 . mount (
234235 "/" ,
235- openapi_get_routes ! [ webclient_index, webclient_index_html, ] ,
236+ openapi_get_routes ! [ webclient_index, webclient_index_html, options ] ,
236237 )
237238 . mount (
238239 "/" ,
239240 routes ! [
240- options,
241241 favicon,
242242 webclient,
243243 authorize,
@@ -251,6 +251,31 @@ pub async fn build_rocket(figment: Figment, hmac_secret: &str) -> Rocket<Build>
251251 "/api" ,
252252 routes ! [ super :: api_auth:: get_profile, super :: api_auth:: get_data, ] ,
253253 )
254+ . mount (
255+ "/api/doc/" ,
256+ make_rapidoc ( & RapiDocConfig {
257+ title : Some ( "SCTG rust-photoacoustic API Doc" . to_owned ( ) ) ,
258+ custom_html : Some ( include_str ! ( "../../resources/rapidoc/index.html" ) . to_owned ( ) ) ,
259+ slots : SlotsConfig {
260+ logo : Some ( include_png_as_base64 ! ( "../../resources/rapidoc/logo.png" ) ) ,
261+ footer : Some ( r#"© 2025 <a style="color: #ffffff; text-decoration: none;" href='https://sctg.eu.org/'>SCTG</a>. All rights reserved. <a style="color: #ffffff; text-decoration: none;" href="https://github.com/sctg-development/sctgdesk-server">sctgdesk-server <svg style="height:1.25em" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 496 512"><path d="M165.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3 .3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6zm-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5 .3-6.2 2.3zm44.2-1.7c-2.9 .7-4.9 2.6-4.6 4.9 .3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9zM244.8 8C106.1 8 0 113.3 0 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C428.2 457.8 496 362.9 496 252 496 113.3 383.5 8 244.8 8zM97.2 352.9c-1.3 1-1 3.3 .7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1zm-10.8-8.1c-.7 1.3 .3 2.9 2.3 3.9 1.6 1 3.6 .7 4.3-.7 .7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3 .7zm32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3 .7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1zm-11.4-14.7c-1.6 1-1.6 3.6 0 5.9 1.6 2.3 4.3 3.3 5.6 2.3 1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2z"/></svg></a>"# . to_owned ( ) ) ,
262+ ..Default :: default ( )
263+ } ,
264+ general : GeneralConfig {
265+ spec_urls : vec ! [ UrlObject :: new( "General" , "../../openapi.json" ) ] ,
266+ ..Default :: default ( )
267+ } ,
268+ hide_show : HideShowConfig {
269+ allow_spec_url_load : false ,
270+ allow_spec_file_load : false ,
271+ allow_spec_file_download : true ,
272+ show_curl_before_try : true ,
273+ ..Default :: default ( )
274+ } ,
275+ ..Default :: default ( )
276+ } ) ,
277+ )
278+ . mount ( "/api/doc/" , routes ! [ helper_min_js] )
254279 . manage ( oxide_state)
255280 . manage ( jwt_validator)
256281}
@@ -476,3 +501,13 @@ async fn favicon() -> Option<StaticFileResponse> {
476501 } ) ;
477502 file
478503}
504+
505+
506+ /// Serve the helper.min.js file for rapidoc
507+ #[ get( "/helper.min.js" ) ]
508+ async fn helper_min_js ( ) -> Option < StaticFileResponse > {
509+ let file_content = include_str ! ( "../../resources/rapidoc/helper.min.js" ) ;
510+ let content_type = ContentType :: JavaScript ;
511+ let response = StaticFileResponse ( file_content. as_bytes ( ) . to_vec ( ) , content_type) ;
512+ Some ( response)
513+ }
0 commit comments