diff --git a/README.md b/README.md index 111f7bd..61df052 100644 --- a/README.md +++ b/README.md @@ -278,6 +278,8 @@ The template supports the following environment variables: - `MU_SPARQL_ENDPOINT`: SPARQL endpoint URL. Default: `http://database:8890/sparql` - `MU_SPARQL_TIMEOUT`: timeout (in seconds) for SPARQL queries. Default: 60 seconds. +- `ALLOW_MU_AUTH_SUDO`: Allow sudo queries when the service requests it. +- `DEFAULT_MU_AUTH_SCOPE`: Default mu-auth-scope to use for calls. - `LOG_LEVEL`: the level of logging (default: `info`, values: `debug`, `info`, `warn`, `error`, `fatal`). - `USE_LEGACY_UTILS`: when enabled (using `"true"` or `"yes"`) legacy utils from v2 will be included in the root file so they can be used as before (e.g. `query` instead of `Mu::query`). Default: `"true"` - `PRINT_DEPRECATION_WARNINGS`: Deprecation warnings will be printed for each usage of a legacy util. Default: `"true"`. diff --git a/mu.rb b/mu.rb index 8ee5c4a..42d55b3 100644 --- a/mu.rb +++ b/mu.rb @@ -26,13 +26,25 @@ def log @log end - def query(query) + def query(query, **options) log.info "Executing query: #{query}" - sparql_client.query query + @sparql_client = sparql_client(**options) + @sparql_client.query query end - def sparql_client - options = {} + def sparql_client(**options) + if Mu::truthy? options[:sudo] + if Mu::truthy? ENV['ALLOW_MU_AUTH_SUDO'] + options[:headers] = { 'mu-auth-sudo': 'true' } + else + log.error "Error, sudo request but service lacks ALLOW_MU_AUTH_SUDO header" + end + end + if options[:scope] + options[:headers] = { 'mu-auth-scope': options[:scope] } + elsif ENV['DEFAULT_MU_AUTH_SCOPE'] + options[:headers] = { 'mu-auth-scope': ENV['DEFAULT_MU_AUTH_SCOPE'] } + end if ENV['MU_SPARQL_TIMEOUT'] options[:read_timeout] = ENV['MU_SPARQL_TIMEOUT'].to_i end @@ -71,9 +83,10 @@ def truthy? value ["true", "yes", "1"].include?(value && value.to_s.downcase) end - def update(query) + def update(query, **options) log.info "Executing query: #{query}" - sparql_client.update query + @sparql_client = sparql_client(**options) + @sparql_client.update query end def update_modified(subject, modified = DateTime.now)