Skip to content
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

feat(jans-lock): lock should collect MAU and MAC based on log entries… #10328

Merged
merged 18 commits into from
Jan 6, 2025

Conversation

yurem
Copy link
Contributor

@yurem yurem commented Dec 3, 2024

  • I confirm that there is no impact on the docs due to the code changes in this PR.

Closes #10327,

@mo-auto mo-auto added comp-jans-auth-server Component affected by issue or PR comp-jans-bom Component affected by issue or PR comp-jans-linux-setup Component affected by issue or PR comp-jans-lock kind-feature Issue or PR is a new feature request labels Dec 3, 2024
Copy link

dryrunsecurity bot commented Dec 3, 2024

DryRun Security Summary

The pull request introduces comprehensive updates to the Jans Lock application, focusing on enhancing statistics and monitoring capabilities through new data types, configuration settings, REST services, and event handling, while also providing recommendations for maintaining application security.

Expand for full summary

Summary:

The code changes in this pull request cover a wide range of updates and additions to the Jans Lock application, primarily focused on improving the application's statistics and monitoring capabilities. The changes introduce new data types, configuration settings, REST web services, and event handling related to statistics collection and reporting.

From an application security perspective, the changes do not appear to introduce any immediate security vulnerabilities. However, there are several areas that should be reviewed and addressed to ensure the ongoing security and integrity of the application:

  1. Input Validation and Sanitization: Ensure that all user input and external data are properly validated and sanitized to prevent common web application vulnerabilities, such as SQL injection and cross-site scripting (XSS).
  2. Sensitive Data Handling: Review the application's handling of sensitive data, such as user IDs, access tokens, and configuration details, to ensure that appropriate security measures are in place to protect this information.
  3. Access Control and Authorization: Verify that the access control and authorization mechanisms, such as the @ProtectedApi annotation, are properly implemented and configured to restrict access to sensitive functionality and data.
  4. Logging and Monitoring: Ensure that the application's logging and monitoring capabilities are robust and secure, allowing for the detection and investigation of potential security incidents.
  5. Dependency Management: Regularly review the application's dependencies, including third-party libraries, to identify and address any known security vulnerabilities.

Overall, the code changes appear to be focused on enhancing the application's functionality and monitoring capabilities, which can be beneficial from a security perspective. However, it's crucial to review the implementation details and the broader context of the application to ensure that the changes do not introduce any unintended security risks.

Files Changed:

  1. jans-linux-setup/jans_setup/static/rdbm/sql_data_types.json: This file has been updated to add a new data type called "clntDat" of type "TEXT" in the MySQL database.
  2. jans-bom/pom.xml: The dependencies in this file have been updated, including the addition of new dependencies for Prometheus and HyperLogLog, as well as version updates for several existing dependencies.
  3. jans-linux-setup/jans_setup/schema/jans_schema.json: A new attribute called "clntDat" and a new objectclass called "jansLockStatEntry" have been added to the Jans schema.
  4. jans-linux-setup/jans_setup/templates/jans-lock/errors.json: New error codes and descriptions have been added to the existing "common" section and a new "stat" section.
  5. jans-lock/lock-server/model/src/main/java/io/jans/lock/model/config/BaseDnConfiguration.java: A new field called "stat" has been added to this class.
  6. jans-lock/lock-server/model/src/main/java/io/jans/lock/model/config/AppConfiguration.java: Two new configuration properties, "statEnabled" and "statTimerIntervalInSeconds", have been added.
  7. jans-linux-setup/jans_setup/templates/jans-lock/static-conf.json: A new base DN for "lock" and "stat" has been added under the "o=jans" organization.
  8. jans-lock/lock-server/model/src/main/java/io/jans/lock/model/config/ErrorMessages.java: New XML annotations have been added to this class.
  9. jans-lock/lock-server/service/pom.xml: Dependencies have been updated, including the addition of new libraries for working with Prometheus and HyperLogLog.
  10. jans-lock/lock-server/service/src/main/java/io/jans/lock/model/Stat.java: A new class called "Stat" has been added to represent statistical information.
  11. jans-lock/lock-server/service/src/main/java/io/jans/lock/model/StatEntry.java: A new class called "StatEntry" has been added to store and manage statistical data.
  12. jans-lock/lock-server/service/src/main/java/io/jans/lock/model/error/CommonErrorResponseType.java: Two new error types, "INVALID_REQUEST" and "UNKNOWN_ERROR", have been added.

Code Analysis

We ran 9 analyzers against 30 files and 1 analyzer had findings. 8 analyzers had no findings.

Analyzer Findings
Sensitive Files Analyzer 3 findings

View PR in the DryRun Dashboard.

@mo-auto
Copy link
Member

mo-auto commented Dec 3, 2024

Error: Hi @yurem, You did not reference an open issue in your PR. I attempted to create an issue for you.
Please update that issues' title and body and make sure I correctly referenced it in the above PRs body.

Copy link

@moabu moabu force-pushed the main branch 2 times, most recently from 5126af2 to aa1b2ed Compare December 27, 2024 04:55
Copy link

sonarqubecloud bot commented Jan 2, 2025

Copy link

sonarqubecloud bot commented Jan 2, 2025

Copy link

sonarqubecloud bot commented Jan 3, 2025

@yurem yurem marked this pull request as ready for review January 3, 2025 18:11
Copy link

sonarqubecloud bot commented Jan 3, 2025

Copy link

sonarqubecloud bot commented Jan 3, 2025

@yuremm yuremm enabled auto-merge (squash) January 3, 2025 20:41
yuremm
yuremm previously approved these changes Jan 3, 2025
Copy link

sonarqubecloud bot commented Jan 3, 2025

yuriyz
yuriyz previously approved these changes Jan 3, 2025
devrimyatar
devrimyatar previously approved these changes Jan 4, 2025
yuriyzz
yuriyzz previously approved these changes Jan 4, 2025
@yurem yurem dismissed stale reviews from yuriyzz, devrimyatar, yuriyz, and yuremm via a2ca2a7 January 5, 2025 06:49
@moabu moabu disabled auto-merge January 6, 2025 05:44
@moabu moabu merged commit b8a7e1a into main Jan 6, 2025
21 of 22 checks passed
@moabu moabu deleted the stat_user_client branch January 6, 2025 05:47
olehbozhok pushed a commit that referenced this pull request Jan 9, 2025
#10328)

* feat(jans-lock): lock should collect MAU and MAC based on log entries requests

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): add sse/config endpoints protection

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): add configurable error response types support

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): add table for lock stat entries

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): increase clnData size

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): fix errorResponseFactory dependecy

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): enable stats by default

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): update protection api to allow use annotations defined in interfaces

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): define lock SSE scope in installer to pre-create it

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-linux-setup): create jans-lock scopes

Signed-off-by: Mustafa Baser <[email protected]>

* feat(jans-lock): add lock scopes

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): use same scopes namespace

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-bom): remove artifact duplicates

Signed-off-by: Yuriy Movchan <[email protected]>

---------

Signed-off-by: Yuriy Movchan <[email protected]>
Signed-off-by: Mustafa Baser <[email protected]>
Co-authored-by: Mustafa Baser <[email protected]>
Co-authored-by: Yuriy M. <[email protected]>
Signed-off-by: Oleh Bohzok <[email protected]>
olehbozhok pushed a commit that referenced this pull request Jan 9, 2025
#10328)

* feat(jans-lock): lock should collect MAU and MAC based on log entries requests

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): add sse/config endpoints protection

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): add configurable error response types support

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): add table for lock stat entries

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): increase clnData size

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): fix errorResponseFactory dependecy

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): enable stats by default

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): update protection api to allow use annotations defined in interfaces

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): define lock SSE scope in installer to pre-create it

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-linux-setup): create jans-lock scopes

Signed-off-by: Mustafa Baser <[email protected]>

* feat(jans-lock): add lock scopes

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): use same scopes namespace

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-bom): remove artifact duplicates

Signed-off-by: Yuriy Movchan <[email protected]>

---------

Signed-off-by: Yuriy Movchan <[email protected]>
Signed-off-by: Mustafa Baser <[email protected]>
Co-authored-by: Mustafa Baser <[email protected]>
Co-authored-by: Yuriy M. <[email protected]>
Signed-off-by: Oleh Bohzok <[email protected]>
olehbozhok pushed a commit that referenced this pull request Jan 9, 2025
#10328)

* feat(jans-lock): lock should collect MAU and MAC based on log entries requests

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): add sse/config endpoints protection

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): add configurable error response types support

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): add table for lock stat entries

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): increase clnData size

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): fix errorResponseFactory dependecy

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): enable stats by default

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): update protection api to allow use annotations defined in interfaces

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): define lock SSE scope in installer to pre-create it

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-linux-setup): create jans-lock scopes

Signed-off-by: Mustafa Baser <[email protected]>

* feat(jans-lock): add lock scopes

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-lock): use same scopes namespace

Signed-off-by: Yuriy Movchan <[email protected]>

* feat(jans-bom): remove artifact duplicates

Signed-off-by: Yuriy Movchan <[email protected]>

---------

Signed-off-by: Yuriy Movchan <[email protected]>
Signed-off-by: Mustafa Baser <[email protected]>
Co-authored-by: Mustafa Baser <[email protected]>
Co-authored-by: Yuriy M. <[email protected]>
Signed-off-by: Oleh Bohzok <[email protected]>
Signed-off-by: Oleh Bohzok <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
comp-jans-auth-server Component affected by issue or PR comp-jans-bom Component affected by issue or PR comp-jans-linux-setup Component affected by issue or PR comp-jans-lock kind-feature Issue or PR is a new feature request
Projects
None yet
Development

Successfully merging this pull request may close these issues.

feat(jans-lock): lock should collect MAU and MAC based on log entries requests
7 participants