-
Notifications
You must be signed in to change notification settings - Fork 168
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Application usage statistics #2387
base: master
Are you sure you want to change the base?
Conversation
|
||
@Controller | ||
@Path("/statistic/") | ||
@ConditionalOnProperty(value = "audit.trail.enabled", havingValue = "true") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If Audit Trail feature is not enabled the Controller is not efficient
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is the intent here to make the /statistic/
end-point available based on the audit.trail.enabled
property? Seems a little confusing to make an endpoint conditional vs. having it always available and to have it return based on the status of the configuration of the application.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I personally see no problem that some of the endpoints are not available if an appropriate configuration is not at place
private StatisticService service; | ||
|
||
public enum ResponseFormat { | ||
CSV, JSON |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Both CSV and JSON output formats should be supported
src/main/java/org/ohdsi/webapi/statistic/controller/StatisticController.java
Show resolved
Hide resolved
} | ||
} | ||
|
||
private void updateExecutionStatisticsHeader(boolean showUserInformation) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Both methods to be replaced by extra two static constants!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
When will this be replaced?
private String sourceName; | ||
private String executionName; | ||
private String executionDate; | ||
private String userID; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
userId
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
When do you plan to change this?
protected final Logger LOG = LoggerFactory.getLogger(getClass()); | ||
|
||
@Value("${audit.trail.log.file}") | ||
// TODO remove value |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To be configured via properties
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So will you remove this then?
@@ -0,0 +1,2 @@ | |||
UPDATE ${ohdsiSchema}.sec_permission SET value='statistic:executions:post' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We may combine both scripts into one
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, please do and make sure the prefix of the file is v2.15...
|
||
@Controller | ||
@Path("/statistic/") | ||
@ConditionalOnProperty(value = "audit.trail.enabled", havingValue = "true") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is the intent here to make the /statistic/
end-point available based on the audit.trail.enabled
property? Seems a little confusing to make an endpoint conditional vs. having it always available and to have it return based on the status of the configuration of the application.
src/main/java/org/ohdsi/webapi/statistic/controller/StatisticController.java
Show resolved
Hide resolved
} | ||
} | ||
|
||
private void updateExecutionStatisticsHeader(boolean showUserInformation) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
When will this be replaced?
private String sourceName; | ||
private String executionName; | ||
private String executionDate; | ||
private String userID; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
When do you plan to change this?
protected final Logger LOG = LoggerFactory.getLogger(getClass()); | ||
|
||
@Value("${audit.trail.log.file}") | ||
// TODO remove value |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So will you remove this then?
@@ -0,0 +1,2 @@ | |||
UPDATE ${ohdsiSchema}.sec_permission SET value='statistic:executions:post' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, please do and make sure the prefix of the file is v2.15...
…der collections are stateless, hard-coded constants deleted relying on the application configuration file Migration scripts combined
Addressing #2329
Business logic is based on parsing Audit Trail log entries. As some of the Analysis Execution entries were identified as duplicates a filter has been introduced to count each Analysis Execution precisely once
Usage examples (for the second one {} is used in the 'urlPattern' parameter to indicated a dynamic part of the URL):