-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathUploadResults.R
104 lines (96 loc) · 3.89 KB
/
UploadResults.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
################################################################################
# INSTRUCTIONS: The code below assumes you have access to a PostgreSQL database
# and permissions to insert data into tables created by running the
# CreateResultsDataModel.R script. This script will loop over all of the
# directories found under the "results" folder and upload the results.
#
# This script also contains some commented out code for
# setting read-only permissions for a user account on the results schema.
# This is used when setting up a read-only user for use with a Shiny results
# viewer. Additionally, there is commented out code that will allow you to run
# ANALYZE on each results table to ensure the database is performant.
#
# See the Working with results section
# of the UsingThisTemplate.md for more details.
#
# More information about working with results produced by running Strategus
# is found at:
# https://ohdsi.github.io/Strategus/articles/WorkingWithResults.html
# ##############################################################################
# Code for uploading results to a Postgres database
resultsDatabaseSchema <- "results"
analysisSpecifications <- ParallelLogger::loadSettingsFromJson(
fileName = "inst/sampleStudy/sampleStudyAnalysisSpecification.json"
)
resultsDatabaseConnectionDetails <- DatabaseConnector::createConnectionDetails(
dbms = "postgresql",
server = Sys.getenv("OHDSI_RESULTS_DATABASE_SERVER"),
user = Sys.getenv("OHDSI_RESULTS_DATABASE_USER"),
password = Sys.getenv("OHDSI_RESULTS_DATABASE_PASSWORD")
)
# Setup logging ----------------------------------------------------------------
ParallelLogger::clearLoggers()
ParallelLogger::addDefaultFileLogger(
fileName = "upload-log.txt",
name = "RESULTS_FILE_LOGGER"
)
ParallelLogger::addDefaultErrorReportLogger(
fileName = "upload-errorReport.txt",
name = "RESULTS_ERROR_LOGGER"
)
# Upload Results ---------------------------------------------------------------
for (resultFolder in list.dirs(path = "results", full.names = T, recursive = F)) {
resultsDataModelSettings <- Strategus::createResultsDataModelSettings(
resultsDatabaseSchema = resultsDatabaseSchema,
resultsFolder = file.path(resultFolder, "strategusOutput"),
)
Strategus::uploadResults(
analysisSpecifications = analysisSpecifications,
resultsDataModelSettings = resultsDataModelSettings,
resultsConnectionDetails = resultsDatabaseConnectionDetails
)
}
connection <- DatabaseConnector::connect(
connectionDetails = resultsDatabaseConnectionDetails
)
# Optional scripts to set permissions and to analyze tables ------------------
# # Grant read only permissions to all tables
# sql <- "GRANT USAGE ON SCHEMA @schema TO @results_user;
# GRANT SELECT ON ALL TABLES IN SCHEMA @schema TO @results_user;
# GRANT EXECUTE ON ALL FUNCTIONS IN SCHEMA @schema TO @results_user;"
#
# message("Setting permissions for results schema")
# sql <- SqlRender::render(
# sql = sql,
# schema = resultsDatabaseSchema,
# results_user = 'shinyproxy'
# )
# DatabaseConnector::executeSql(
# connection = connection,
# sql = sql,
# progressBar = FALSE,
# reportOverallTime = FALSE
# )
#
# # Analyze all tables in the results schema
# message("Analyzing all tables in results schema")
# sql <- "ANALYZE @schema.@table_name;"
# tableList <- DatabaseConnector::getTableNames(
# connection = connection,
# databaseSchema = resultsDatabaseSchema
# )
# for (i in 1:length(tableList)) {
# DatabaseConnector::renderTranslateExecuteSql(
# connection = connection,
# sql = sql,
# schema = resultsDatabaseSchema,
# table_name = tableList[i],
# progressBar = FALSE,
# reportOverallTime = FALSE
# )
# }
#
# DatabaseConnector::disconnect(connection)
# Unregister loggers -----------------------------------------------------------
ParallelLogger::unregisterLogger("RESULTS_FILE_LOGGER")
ParallelLogger::unregisterLogger("RESULTS_ERROR_LOGGER")