Compare commits
	
		
			1 Commits
		
	
	
		
			1.0.3
			...
			7764881574
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 7764881574 | 
							
								
								
									
										38
									
								
								moneymgr_backend/Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										38
									
								
								moneymgr_backend/Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -724,9 +724,9 @@ dependencies = [ | ||||
|  | ||||
| [[package]] | ||||
| name = "clap" | ||||
| version = "4.5.40" | ||||
| version = "4.5.38" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "40b6887a1d8685cebccf115538db5c0efe625ccac9696ad45c409d96566e910f" | ||||
| checksum = "ed93b9805f8ba930df42c2590f05453d5ec36cbb85d018868a5b24d31f6ac000" | ||||
| dependencies = [ | ||||
|  "clap_builder", | ||||
|  "clap_derive", | ||||
| @@ -734,9 +734,9 @@ dependencies = [ | ||||
|  | ||||
| [[package]] | ||||
| name = "clap_builder" | ||||
| version = "4.5.40" | ||||
| version = "4.5.38" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "e0c66c08ce9f0c698cbce5c0279d0bb6ac936d8674174fe48f736533b964f59e" | ||||
| checksum = "379026ff283facf611b0ea629334361c4211d1b12ee01024eec1591133b04120" | ||||
| dependencies = [ | ||||
|  "anstream", | ||||
|  "anstyle", | ||||
| @@ -746,9 +746,9 @@ dependencies = [ | ||||
|  | ||||
| [[package]] | ||||
| name = "clap_derive" | ||||
| version = "4.5.40" | ||||
| version = "4.5.32" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "d2c7947ae4cc3d851207c1adb5b5e260ff0cca11446b1d6d1423788e442257ce" | ||||
| checksum = "09176aae279615badda0765c0c0b3f6ed53f4709118af73cf4655d85d1530cd7" | ||||
| dependencies = [ | ||||
|  "heck", | ||||
|  "proc-macro2", | ||||
| @@ -948,9 +948,9 @@ dependencies = [ | ||||
|  | ||||
| [[package]] | ||||
| name = "crypto-common" | ||||
| version = "0.2.0-rc.3" | ||||
| version = "0.2.0-rc.2" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "8a23fa214dea9efd4dacee5a5614646b30216ae0f05d4bb51bafb50e9da1c5be" | ||||
| checksum = "170d71b5b14dec99db7739f6fc7d6ec2db80b78c3acb77db48392ccc3d8a9ea0" | ||||
| dependencies = [ | ||||
|  "hybrid-array", | ||||
| ] | ||||
| @@ -1100,9 +1100,9 @@ dependencies = [ | ||||
|  | ||||
| [[package]] | ||||
| name = "diesel" | ||||
| version = "2.2.11" | ||||
| version = "2.2.10" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "a917a9209950404d5be011c81d081a2692a822f73c3d6af586f0cab5ff50f614" | ||||
| checksum = "ff3e1edb1f37b4953dd5176916347289ed43d7119cc2e6c7c3f7849ff44ea506" | ||||
| dependencies = [ | ||||
|  "bitflags", | ||||
|  "byteorder", | ||||
| @@ -1159,13 +1159,13 @@ dependencies = [ | ||||
|  | ||||
| [[package]] | ||||
| name = "digest" | ||||
| version = "0.11.0-rc.0" | ||||
| version = "0.11.0-pre.10" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "460dd7f37e4950526b54a5a6b1f41b6c8e763c58eb9a8fc8fc05ba5c2f44ca7b" | ||||
| checksum = "6c478574b20020306f98d61c8ca3322d762e1ff08117422ac6106438605ea516" | ||||
| dependencies = [ | ||||
|  "block-buffer 0.11.0-rc.4", | ||||
|  "const-oid 0.10.1", | ||||
|  "crypto-common 0.2.0-rc.3", | ||||
|  "crypto-common 0.2.0-rc.2", | ||||
| ] | ||||
|  | ||||
| [[package]] | ||||
| @@ -2304,7 +2304,7 @@ dependencies = [ | ||||
|  "rust_xlsxwriter", | ||||
|  "serde", | ||||
|  "serde_json", | ||||
|  "sha2 0.11.0-rc.0", | ||||
|  "sha2 0.11.0-pre.5", | ||||
|  "tempfile", | ||||
|  "thiserror 2.0.12", | ||||
|  "tokio", | ||||
| @@ -3296,13 +3296,13 @@ dependencies = [ | ||||
|  | ||||
| [[package]] | ||||
| name = "sha2" | ||||
| version = "0.11.0-rc.0" | ||||
| version = "0.11.0-pre.5" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "aa1d2e6b3cc4e43a8258a9a3b17aa5dfd2cc5186c7024bba8a64aa65b2c71a59" | ||||
| checksum = "19b4241d1a56954dce82cecda5c8e9c794eef6f53abe5e5216bac0a0ea71ffa7" | ||||
| dependencies = [ | ||||
|  "cfg-if", | ||||
|  "cpufeatures", | ||||
|  "digest 0.11.0-rc.0", | ||||
|  "digest 0.11.0-pre.10", | ||||
| ] | ||||
|  | ||||
| [[package]] | ||||
| @@ -3571,9 +3571,9 @@ dependencies = [ | ||||
|  | ||||
| [[package]] | ||||
| name = "tokio" | ||||
| version = "1.45.1" | ||||
| version = "1.45.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "75ef51a33ef1da925cea3e4eb122833cb377c61439ca401b770f54902b806779" | ||||
| checksum = "2513ca694ef9ede0fb23fe71a4ee4107cb102b9dc1930f6d0fd77aae068ae165" | ||||
| dependencies = [ | ||||
|  "backtrace", | ||||
|  "bytes", | ||||
|   | ||||
| @@ -6,9 +6,9 @@ edition = "2024" | ||||
| [dependencies] | ||||
| env_logger = "0.11.8" | ||||
| log = "0.4.27" | ||||
| diesel = { version = "2.2.11", features = ["postgres", "r2d2"] } | ||||
| diesel = { version = "2.2.10", features = ["postgres", "r2d2"] } | ||||
| diesel_migrations = "2.2.0" | ||||
| clap = { version = "4.5.40", features = ["env", "derive"] } | ||||
| clap = { version = "4.5.38", features = ["env", "derive"] } | ||||
| actix-web = "4.11.0" | ||||
| actix-cors = "0.7.1" | ||||
| actix-multipart = "0.7.2" | ||||
| @@ -20,7 +20,7 @@ anyhow = "1.0.98" | ||||
| serde = { version = "1.0.219", features = ["derive"] } | ||||
| rust-s3 = "0.36.0-beta.2" | ||||
| thiserror = "2.0.12" | ||||
| tokio = "1.45.1" | ||||
| tokio = "1.45.0" | ||||
| futures-util = "0.3.31" | ||||
| serde_json = "1.0.140" | ||||
| light-openid = "1.0.4" | ||||
| @@ -30,7 +30,7 @@ lazy-regex = "3.4.1" | ||||
| jwt-simple = { version = "0.12.12", default-features = false, features = ["pure-rust"] } | ||||
| mime_guess = "2.0.5" | ||||
| rust-embed = { version = "8.7.2" } | ||||
| sha2 = "0.11.0-rc.0" | ||||
| sha2 = "0.11.0-pre.5" | ||||
| base16ct = "0.2.0" | ||||
| httpdate = "1.0.3" | ||||
| chrono = "0.4.41" | ||||
|   | ||||
| @@ -30,7 +30,7 @@ pub async fn create_bucket_if_required() -> anyhow::Result<()> { | ||||
|             log::warn!("The bucket does not seem to exists, trying to create it!") | ||||
|         } | ||||
|         Err(e) => { | ||||
|             log::error!("Got unexpected error when querying bucket info: {e}"); | ||||
|             log::error!("Got unexpected error when querying bucket info: {}", e); | ||||
|             return Err(BucketServiceError::FailedFetchBucketInfo.into()); | ||||
|         } | ||||
|     } | ||||
|   | ||||
| @@ -50,7 +50,7 @@ impl FromRequest for AccountInPath { | ||||
|             Self::load_account_from_path(&auth, account_id) | ||||
|                 .await | ||||
|                 .map_err(|e| { | ||||
|                     log::error!("Failed to extract account ID from URL! {e}"); | ||||
|                     log::error!("Failed to extract account ID from URL! {}", e); | ||||
|                     actix_web::error::ErrorNotFound("Could not fetch account information!") | ||||
|                 }) | ||||
|         }) | ||||
|   | ||||
| @@ -165,13 +165,13 @@ impl FromRequest for AuthExtractor { | ||||
|                 // Update last use (if needed) | ||||
|                 if token.shall_update_time_used() { | ||||
|                     if let Err(e) = tokens_service::update_time_used(&token).await { | ||||
|                         log::error!("Failed to refresh last usage of token! {e}"); | ||||
|                         log::error!("Failed to refresh last usage of token! {}", e); | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|                 // Handle tokens expiration | ||||
|                 if token.is_expired() { | ||||
|                     log::error!("Attempted to use expired token! {token:?}"); | ||||
|                     log::error!("Attempted to use expired token! {:?}", token); | ||||
|                     return Err(actix_web::error::ErrorBadRequest("Token has expired!")); | ||||
|                 } | ||||
|  | ||||
|   | ||||
| @@ -47,7 +47,7 @@ impl FromRequest for FileIdExtractor { | ||||
|             Self::load_file_from_path(&auth, file_id) | ||||
|                 .await | ||||
|                 .map_err(|e| { | ||||
|                     log::error!("Failed to extract file ID from URL! {e}"); | ||||
|                     log::error!("Failed to extract file ID from URL! {}", e); | ||||
|                     actix_web::error::ErrorNotFound("Could not fetch file information!") | ||||
|                 }) | ||||
|         }) | ||||
|   | ||||
| @@ -50,7 +50,7 @@ impl FromRequest for InboxEntryInPath { | ||||
|             Self::load_inbox_entry_from_path(&auth, entry_id) | ||||
|                 .await | ||||
|                 .map_err(|e| { | ||||
|                     log::error!("Failed to extract inbox entry ID from URL! {e}"); | ||||
|                     log::error!("Failed to extract inbox entry ID from URL! {}", e); | ||||
|                     actix_web::error::ErrorNotFound("Could not fetch inbox entry information!") | ||||
|                 }) | ||||
|         }) | ||||
|   | ||||
| @@ -57,7 +57,7 @@ impl FromRequest for MovementInPath { | ||||
|             Self::load_movement_from_path(&auth, account_id) | ||||
|                 .await | ||||
|                 .map_err(|e| { | ||||
|                     log::error!("Failed to extract movement ID from URL! {e}"); | ||||
|                     log::error!("Failed to extract movement ID from URL! {}", e); | ||||
|                     actix_web::error::ErrorNotFound("Could not fetch movement information!") | ||||
|                 }) | ||||
|         }) | ||||
|   | ||||
							
								
								
									
										699
									
								
								moneymgr_web/package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										699
									
								
								moneymgr_web/package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -12,36 +12,36 @@ | ||||
|   "dependencies": { | ||||
|     "@emotion/react": "^11.14.0", | ||||
|     "@emotion/styled": "^11.14.0", | ||||
|     "@fontsource/roboto": "^5.2.6", | ||||
|     "@fontsource/roboto": "^5.2.5", | ||||
|     "@jsonjoy.com/base64": "^1.1.2", | ||||
|     "@mdi/js": "^7.4.47", | ||||
|     "@mdi/react": "^1.6.1", | ||||
|     "@mui/icons-material": "^7.1.2", | ||||
|     "@mui/material": "^7.1.2", | ||||
|     "@mui/x-charts": "^8.5.3", | ||||
|     "@mui/x-data-grid": "^8.5.3", | ||||
|     "@mui/x-date-pickers": "^8.5.3", | ||||
|     "@mui/icons-material": "^7.1.0", | ||||
|     "@mui/material": "^7.1.0", | ||||
|     "@mui/x-charts": "^8.3.1", | ||||
|     "@mui/x-data-grid": "^8.4.0", | ||||
|     "@mui/x-date-pickers": "^8.3.1", | ||||
|     "date-and-time": "^3.6.0", | ||||
|     "dayjs": "^1.11.13", | ||||
|     "filesize": "^10.1.6", | ||||
|     "qrcode.react": "^4.2.0", | ||||
|     "react": "^19.1.0", | ||||
|     "react-dom": "^19.1.0", | ||||
|     "react-router": "^7.6.2", | ||||
|     "react-router-dom": "^7.6.2", | ||||
|     "react-router": "^7.6.0", | ||||
|     "react-router-dom": "^7.6.0", | ||||
|     "ts-pattern": "^5.7.1" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "@eslint/js": "^9.29.0", | ||||
|     "@types/react": "^19.1.8", | ||||
|     "@types/react-dom": "^19.1.6", | ||||
|     "@vitejs/plugin-react": "^4.6.0", | ||||
|     "@eslint/js": "^9.27.0", | ||||
|     "@types/react": "^19.1.5", | ||||
|     "@types/react-dom": "^19.1.5", | ||||
|     "@vitejs/plugin-react": "^4.4.1", | ||||
|     "eslint": "^9.26.0", | ||||
|     "eslint-plugin-react-dom": "^1.49.0", | ||||
|     "eslint-plugin-react-hooks": "^5.2.0", | ||||
|     "eslint-plugin-react-refresh": "^00.4.20", | ||||
|     "eslint-plugin-react-x": "^1.52.2", | ||||
|     "globals": "^16.2.0", | ||||
|     "eslint-plugin-react-x": "^1.49.0", | ||||
|     "globals": "^16.1.0", | ||||
|     "typescript": "~5.8.3", | ||||
|     "typescript-eslint": "^8.32.1", | ||||
|     "vite": "^6.3.5" | ||||
|   | ||||
| @@ -31,21 +31,12 @@ export class APIClient { | ||||
|     return URL; | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Get the full URL at which the backend can be contacted | ||||
|    */ | ||||
|   static ActualBackendURL(): string { | ||||
|     const backendURL = this.backendURL(); | ||||
|     if (backendURL.startsWith("/")) return `${location.origin}${backendURL}`; | ||||
|     else return backendURL; | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Check out whether the backend is accessed through | ||||
|    * HTTPS or not | ||||
|    */ | ||||
|   static IsBackendSecure(): boolean { | ||||
|     return this.ActualBackendURL().startsWith("https"); | ||||
|     return this.backendURL().startsWith("https"); | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|   | ||||
| @@ -268,7 +268,7 @@ function CreatedToken(p: { token: TokenWithSecret }): React.ReactElement { | ||||
|           <div style={{ padding: "15px", backgroundColor: "white" }}> | ||||
|             <QRCodeCanvas | ||||
|               value={`moneymgr://api=${encodeURIComponent( | ||||
|                 APIClient.ActualBackendURL() | ||||
|                 APIClient.backendURL() | ||||
|               )}&id=${p.token.id}&secret=${p.token.token}`} | ||||
|             /> | ||||
|           </div> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user