Skip to content

Commit

Permalink
Merge pull request #575 from Sage-Bionetworks/FDS-1215-refactor-config
Browse files Browse the repository at this point in the history
FDS-1215 refactor DCC config
  • Loading branch information
afwillia authored Nov 28, 2023
2 parents 10286e8 + 38ed6dd commit 9552104
Show file tree
Hide file tree
Showing 7 changed files with 168 additions and 88 deletions.
3 changes: 2 additions & 1 deletion DESCRIPTION
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ Authors: Rongrong Chai, Xengie Doan, Milen Nikolov, Sujay Patil, Robert Allaway,
License: file LICENSE
Encoding: UTF-8
Roxygen: list(markdown = TRUE)
RoxygenNote: 7.2.1
RoxygenNote: 7.2.3
Imports: httr, dplyr, jsonlite
Suggests:
covr
8 changes: 8 additions & 0 deletions NAMESPACE
Original file line number Diff line number Diff line change
@@ -1,6 +1,11 @@
# Generated by roxygen2: do not edit by hand

export(create_dca_template_config)
export(create_template_config)
export(format_edge_type)
export(get_asset_view_table)
export(get_display_names)
export(graph_by_edge_type)
export(manifest_download)
export(manifest_generate)
export(manifest_populate)
Expand All @@ -14,3 +19,6 @@ export(synapse_access)
export(synapse_get)
export(synapse_is_certified)
export(synapse_user_profile)
export(write_dca_template_config)
importFrom(httr,GET)
importFrom(httr,content)
14 changes: 14 additions & 0 deletions R/schematic_rest_api.R
Original file line number Diff line number Diff line change
Expand Up @@ -314,3 +314,17 @@ get_asset_view_table <- function(url="http://localhost:3001/v1/storage/assets/ta

}

#' @param url URL of schematic API endpoint
#' @param schema_url URL of data model
#' @param relationship Argument to schematic graph_by_edge_type
#' @export
#' @importFrom httr GET content
graph_by_edge_type <- function(url = "https://schematic-dev.api.sagebionetworks.org/v1/schemas/get/graph_by_edge_type",
schema_url, relationship = "requiresDependency") {
req <- httr::GET(url = url,
query = list(
schema_url = schema_url,
relationship = relationship
))
httr::content(req)
}
63 changes: 63 additions & 0 deletions R/template_config.R
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
#' @export
format_edge_type <- function(edge_types) {
et <- dplyr::bind_rows(lapply(edge_types, function(x) data.frame(value = x[[2]], schema_name = x[[1]])))
components <- et |>
dplyr::filter(tolower(value) == "component") |>
dplyr::pull(schema_name)
et |>
dplyr::filter(value %in% c("Component", "Filename")) |>
dplyr::group_by(schema_name) |>
dplyr::summarise(file_based = "Filename" %in% value) |>
dplyr::filter(schema_name %in% components)
}

#' @export
get_display_names <- function(qlist) {
if (!"schema_url" %in% names(qlist)) stop("qlist needs element named `schema_url`")
if (!"node_list" %in% names(qlist)) stop("qlist needs at least one element named `node_list`")
httr::GET(
url = "https://schematic-dev.api.sagebionetworks.org/v1/schemas/get_nodes_display_names",
query = qlist
)
}

#' @export
create_template_config <- function(data_model, include_schemas = NULL, exclude_schemas = NULL) {
if (!is.null(include_schemas) && !is.null(exclude_schemas)) stop("include_schemas and exclude_schemas cannot both have values")
edges <- graph_by_edge_type(schema_url = data_model)
schema_names <- format_edge_type(edges)
nl <- setNames(as.list(schema_names$schema_name), rep("node_list", length(schema_names$schema_name)))
dnames <- get_display_names(c(schema_url = data_model, nl)) |> httr::content()
config <- data.frame(display_name = unlist(dnames), schema_name = unlist(nl)) |>
dplyr::left_join(schema_names, by = "schema_name") |>
dplyr::mutate(type = ifelse(file_based, "file", "record")) |>
dplyr::select(-file_based)
if (!is.null(include_schemas)) {
if (any(length(x <- setdiff(include_schemas, config$schema_name)))) stop(sprintf("%s is not a schema name in the data model", x))
config <- dplyr::filter(config, schema_name %in% include_schemas)
}
if (!is.null(exclude_schemas)) {
if (any(length(y <- setdiff(exclude_schemas, config$schema_name)))) stop(sprintf("%s is not a schema name in the data model", y))
config <- dplyr::filter(config, !schema_name %in% exclude_schemas)
}
config
}

#' @export
create_dca_template_config <- function(data_model, include_schemas = NULL, exclude_schemas = NULL) {
df <- create_template_config(data_model, include_schemas, exclude_schemas)
schematic_version <- httr::GET("https://schematic-dev.api.sagebionetworks.org/v1/version") |>
httr::content()
list(
manifest_schemas = df,
service_version = schematic_version,
schema_version = ""
)
}

#' @export
#' @description Create a DCA-specific template generation function
write_dca_template_config <- function(data_model, file, include_schemas = NULL, exclude_schemas = NULL) {
df <- create_dca_template_config(data_model, include_schemas, exclude_schemas)
jsonlite::write_json(df, file, pretty = TRUE, auto_unbox = TRUE)
}
11 changes: 4 additions & 7 deletions global.R
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,10 @@ options(shiny.maxRequestSize=32*1024^2)
source_files <- list.files(c("functions", "modules"), pattern = "*\\.R$", recursive = TRUE, full.names = TRUE)
sapply(source_files, FUN = source)

dcc_config_file <- Sys.getenv("DCA_DCC_CONFIG")
dcc_config <- read_csv(dcc_config_file, show_col_types = FALSE)
if (Sys.getenv("DCA_DCC_CONFIG") == "") stop("missing DCA_DCC_CONFIG environment variable")
dca_dcc_config <- read_json(Sys.getenv("DCA_DCC_CONFIG"), simplifyVector = TRUE)
tenants_config <- dca_dcc_config$tenants
config_dir <- dirname(Sys.getenv("DCA_DCC_CONFIG"))

## Set Up OAuth
client_id <- Sys.getenv("DCA_CLIENT_ID")
Expand Down Expand Up @@ -127,11 +129,6 @@ api <- oauth_endpoint(
# The 'openid' scope is required by the protocol for retrieving user information.
scope <- "openid view download modify"

template_config_files <- setNames(dcc_config$template_menu_config_file,
dcc_config$synapse_asset_view)
if (dca_schematic_api == "offline") template_config_files <- setNames("www/template_config/config_offline.json",
"synXXXXXX")

## Set Up Virtual Environment
# ShinyAppys has a limit of 7000 files which this app' grossly exceeds
# due to its Python dependencies. To get around the limit we zip up
Expand Down
Loading

0 comments on commit 9552104

Please sign in to comment.