2024-03-16 00:08:47 +01:00
|
|
|
import std/strutils, regex, stew/results
|
2023-06-22 11:27:40 +02:00
|
|
|
|
|
|
|
proc validateDbUrl*(dbUrl: string): Result[string, string] =
|
|
|
|
## dbUrl mimics SQLAlchemy Database URL schema
|
|
|
|
## See: https://docs.sqlalchemy.org/en/14/core/engines.html#database-urls
|
2024-05-16 22:29:11 +02:00
|
|
|
let regex = re2"^\w+:\/\/.+:.+@[\w*-.]+:[0-9]+\/[\w*-.]+$"
|
2023-06-22 11:27:40 +02:00
|
|
|
let dbUrl = dbUrl.strip()
|
2023-09-26 13:59:54 +02:00
|
|
|
if "sqlite" in dbUrl or dbUrl == "" or dbUrl == "none" or dbUrl.match(regex):
|
2023-06-22 11:27:40 +02:00
|
|
|
return ok(dbUrl)
|
|
|
|
else:
|
2024-05-23 18:37:04 -04:00
|
|
|
return err("invalid 'db url' option format")
|
2023-06-22 11:27:40 +02:00
|
|
|
|
|
|
|
proc getDbEngine*(dbUrl: string): Result[string, string] =
|
|
|
|
let dbUrlParts = dbUrl.split("://", 1)
|
|
|
|
|
|
|
|
if dbUrlParts.len != 2:
|
2024-05-23 18:37:04 -04:00
|
|
|
return err("Incorrect dbUrl")
|
2023-06-22 11:27:40 +02:00
|
|
|
|
|
|
|
let engine = dbUrlParts[0]
|
|
|
|
return ok(engine)
|
|
|
|
|
|
|
|
proc getDbPath*(dbUrl: string): Result[string, string] =
|
|
|
|
let dbUrlParts = dbUrl.split("://", 1)
|
|
|
|
|
|
|
|
if dbUrlParts.len != 2:
|
2024-05-23 18:37:04 -04:00
|
|
|
return err("Incorrect dbUrl")
|
2023-06-22 11:27:40 +02:00
|
|
|
|
|
|
|
let path = dbUrlParts[1]
|
|
|
|
return ok(path)
|