From a46d92fa0248e890e96d7306c108a4c6772852ca Mon Sep 17 00:00:00 2001 From: Dilum Aluthge Date: Tue, 28 Feb 2023 00:42:33 -0500 Subject: [PATCH] Fix the constructor for BaseURL when the argument is a string (#123) * Fix the constructor for `BaseURL` when the argument is a string * Bump the version from "2.0.0" to "2.0.1" * Fix a typo * Add more tests * Fix some mistakes * Fix the tests * Fix the tests --- Project.toml | 2 +- src/types.jl | 37 +++++++++++++++++++++++++------------ test/unit/types.jl | 19 ++++++++++++++++--- 3 files changed, 42 insertions(+), 16 deletions(-) diff --git a/Project.toml b/Project.toml index 33270b9..34e3752 100644 --- a/Project.toml +++ b/Project.toml @@ -1,7 +1,7 @@ name = "FHIRClient" uuid = "b44d2ca2-8176-4fa9-8684-826e17b2a2da" authors = ["Dilum Aluthge", "Rhode Island Quality Institute", "contributors"] -version = "2.0.0" +version = "2.0.1" [deps] Base64 = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f" diff --git a/src/types.jl b/src/types.jl index c76711e..04bbcc9 100644 --- a/src/types.jl +++ b/src/types.jl @@ -17,11 +17,11 @@ abstract type FHIRVersion <: Any abstract type FHIRVersion end -function _uses_https(url_str::AbstractString) +@inline function _uses_https(url_str::AbstractString) return startswith(lowercase(strip(url_str)), "https://") end -function _uses_https(uri::HTTP.URI) +@inline function _uses_https(uri::HTTP.URI) return _uses_https(Base.string(uri)) end @@ -38,6 +38,7 @@ struct BaseURL <: Any """ struct BaseURL uri::HTTP.URI + function BaseURL(uri::HTTP.URI; require_https::Bool = true) this_uri_uses_https = _uses_https(uri) if !this_uri_uses_https @@ -51,22 +52,34 @@ struct BaseURL end return new(uri) end + + @doc """ + BaseURL(base_url::AbstractString) + + Construct a `BaseURL` object given the base URL. + + The base URL is also called the "Service Root URL" + """ + function BaseURL(uri::AbstractString; require_https::Bool = true) + this_uri_uses_https = _uses_https(uri) + if !this_uri_uses_https + msg = "The following FHIR Base URL does not use HTTPS: $(uri)" + if require_https + throw(ArgumentError(msg)) + else + @warn "`require_https` is set to `false` - we strongly recommend setting it to `true`" + @warn msg + end + end + return new(HTTP.URI(uri)) + end end + _get_http_uri(base_url::BaseURL) = base_url.uri function _get_http_uri_string(uri::HTTP.URI)::String return Base.string(uri) end -""" - BaseURL(base_url::AbstractString) - -Construct a `BaseURL` object given the base URL. - -The base URL is also called the "Service Root URL" -""" -BaseURL(base_url::AbstractString) = BaseURL(HTTP.URI(base_url)) - - """ A FHIR client. diff --git a/test/unit/types.jl b/test/unit/types.jl index bce1c15..c41059e 100644 --- a/test/unit/types.jl +++ b/test/unit/types.jl @@ -1,3 +1,16 @@ -@test_throws Exception FHIRClient.BaseURL(HTTP.URI("http://example.com"); require_https = true) -@test FHIRClient.BaseURL(HTTP.URI("http://example.com"); require_https = false) isa FHIRClient.BaseURL -@test_logs (:warn,) match_mode=:any FHIRClient.BaseURL(HTTP.URI("http://example.com"); require_https = false) +@testset "BaseURL constructor" begin + https_uris = ["https://example.com", HTTP.URI("https://example.com")] + @testset for uri in https_uris + @test FHIRClient.BaseURL(uri) isa FHIRClient.BaseURL + @test FHIRClient.BaseURL(uri; require_https = true) isa FHIRClient.BaseURL + @test FHIRClient.BaseURL(uri; require_https = false) isa FHIRClient.BaseURL + end + + http_uris = ["http://example.com", HTTP.URI("http://example.com")] + @testset for uri in http_uris + @test_throws Exception FHIRClient.BaseURL(uri) + @test_throws Exception FHIRClient.BaseURL(uri; require_https = true) + @test FHIRClient.BaseURL(uri; require_https = false) isa FHIRClient.BaseURL + @test_logs (:warn,) match_mode=:any FHIRClient.BaseURL(uri; require_https = false) + end +end