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: add observe status access-key for pre-check and logging only (#5216) #5236

Merged
merged 8 commits into from
Oct 8, 2024

Conversation

larry4xie
Copy link
Contributor

@larry4xie larry4xie commented Sep 22, 2024

What's the purpose of this PR

add observe status access-key for pre-check and logging only

Which issue(s) this PR fixes:

Fixes #5216

Brief changelog

image

image

Follow this checklist to help us incorporate your contribution quickly and easily:

  • Read the Contributing Guide before making this pull request.
  • Write a pull request description that is detailed enough to understand what the pull request does, how, and why.
  • Write necessary unit tests to verify the code.
  • Run mvn clean test to make sure this pull request doesn't break anything.
  • Update the CHANGES log.

Summary by CodeRabbit

Release Notes

  • New Features

    • Introduced a new mode parameter for enabling and disabling access keys, allowing users to specify operational modes (filter or observer).
    • Added a method to retrieve observable secrets based on application ID, expanding access key functionalities.
    • Enhanced authentication checks with improved logging for better tracking and security.
    • Updated release notes to reflect new features and enhancements for version 2.4.0.
  • Bug Fixes

    • Improved logging and validation mechanisms in client authentication for better tracking and security.
  • Database Changes

    • Added a new Mode column to the AccessKey table, specifying key modes for enhanced access key management.

These changes enhance user control and clarity in managing access keys within the application.

…polloconfig#5216)

- ALTER TABLE `AccessKey` ADD COLUMN `Mode`, 0: filter,1: observer
- portal: CRUD for observe status access-key
- configservice: pre-check and logging via ClientAuthenticationFilter
@dosubot dosubot bot added the size:L This PR changes 100-499 lines, ignoring generated files. label Sep 22, 2024
Copy link
Contributor

coderabbitai bot commented Sep 22, 2024

Walkthrough

The changes enhance the access key management functionality in the Apollo framework by introducing mode handling during enable and disable operations. The AccessKeyController and ClientAuthenticationFilter classes have been modified to incorporate new parameters and methods, improving the authentication logic and allowing for pre-check capabilities. Additionally, a new method for retrieving observable secrets has been added to AccessKeyUtil. These updates collectively streamline the control flow and extend the access key management capabilities.

Changes

Files Change Summary
apollo-adminservice/.../AccessKeyController.java Updated enable and disable methods to include a mode parameter. Modified the disable method to set the mode to FILTER.
apollo-configservice/.../ClientAuthenticationFilter.java Added doCheck method for consolidated authentication checks. Introduced preCheckInvalidLogging method for logging pre-check failures.
apollo-configservice/.../AccessKeyUtil.java Added findObservableSecrets method to retrieve observable secrets based on application ID.
apollo-configservice/.../filter/ClientAuthenticationFilterTest.java Introduced testPreCheckInvalid and testPreCheckSuccessfully methods to enhance testing for authentication logic.
apollo-portal/.../AccessKeyController.java Modified enable method to accept a new optional mode parameter.
scripts/sql/.../apolloconfigdb.sql Added a new column Mode of type tinyint unsigned to the AccessKey table to specify key mode values.

Assessment against linked issues

Objective Addressed Explanation
增加未启用密钥的预校验能力 (Issue #5216)
触发条件:开关开启 + 有密钥配置 + 所有密钥均未开启 (Issue #5216) The implementation of pre-check logic is unclear in the current changes.
打印日志,日志至少包含 appId, clientIp, authorization 等信息 (Issue #5216) Enhanced logging in ClientAuthenticationFilter includes client IP and other relevant info.

Possibly related PRs

Suggested labels

lgtm

Suggested reviewers

  • nobodyiam

Poem

🐇 In the land of keys, both near and far,
New modes arise, like a shining star.
FILTER and OBSERVER, a choice to make,
With logs to guide us, no chance to mistake.
Hopping through changes, we cheer and play,
Access keys flourish in a bright new way! 🌟


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 7

Outside diff range and nitpick comments (3)
apollo-portal/src/main/java/com/ctrip/framework/apollo/portal/service/AccessKeyService.java (1)

52-53: Add unit tests for the updated method signature.

The method signature has been updated to include an additional mode parameter. Ensure that the unit tests for this method have been updated to cover the new parameter.

Do you want me to generate the unit testing code or open a GitHub issue to track this task?

scripts/sql/profiles/mysql-database-not-specified/delta/v230-v240/apolloconfigdb-v230-v240.sql (1)

29-30: LGTM!

The SQL statement for adding the Mode column to the AccessKey table is well-structured and follows best practices:

  • The column is defined with an appropriate data type (tinyint(2) unsigned) and default value (0).
  • The comment provides clarity on the purpose and possible values of the column.
  • The AFTER clause ensures proper positioning of the new column within the table structure.

Consider adding a check constraint to enforce the allowed values for the Mode column:

ALTER TABLE `AccessKey`
    ADD COLUMN `Mode` tinyint(2) unsigned NOT NULL DEFAULT '0' COMMENT '密钥模式,0: filter,1: observer' AFTER `Secret`,
    ADD CONSTRAINT `CK_AccessKey_Mode` CHECK (`Mode` IN (0, 1));

This will ensure that only valid values (0 for "filter" and 1 for "observer") can be inserted into the Mode column.

apollo-configservice/src/main/java/com/ctrip/framework/apollo/configservice/filter/ClientAuthenticationFilter.java (1)

82-82: Avoid logging sensitive information directly

Including timestamp in logs is generally acceptable, but ensure that logging practices comply with security policies regarding sensitive information.

Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

Commits

Files that changed from the base of the PR and between 7e7b090 and 46390df.

Files selected for processing (26)
  • apollo-adminservice/src/main/java/com/ctrip/framework/apollo/adminservice/controller/AccessKeyController.java (4 hunks)
  • apollo-biz/src/main/java/com/ctrip/framework/apollo/biz/entity/AccessKey.java (3 hunks)
  • apollo-biz/src/main/java/com/ctrip/framework/apollo/biz/service/AccessKeyService.java (1 hunks)
  • apollo-biz/src/test/resources/sql/accesskey-test.sql (1 hunks)
  • apollo-common/src/main/java/com/ctrip/framework/apollo/common/constants/AccessKeyMode.java (1 hunks)
  • apollo-common/src/main/java/com/ctrip/framework/apollo/common/dto/AccessKeyDTO.java (2 hunks)
  • apollo-configservice/src/main/java/com/ctrip/framework/apollo/configservice/filter/ClientAuthenticationFilter.java (3 hunks)
  • apollo-configservice/src/main/java/com/ctrip/framework/apollo/configservice/service/AccessKeyServiceWithCache.java (3 hunks)
  • apollo-configservice/src/main/java/com/ctrip/framework/apollo/configservice/util/AccessKeyUtil.java (2 hunks)
  • apollo-configservice/src/test/java/com/ctrip/framework/apollo/configservice/filter/ClientAuthenticationFilterTest.java (2 hunks)
  • apollo-portal/src/main/java/com/ctrip/framework/apollo/portal/api/AdminServiceAPI.java (1 hunks)
  • apollo-portal/src/main/java/com/ctrip/framework/apollo/portal/controller/AccessKeyController.java (1 hunks)
  • apollo-portal/src/main/java/com/ctrip/framework/apollo/portal/service/AccessKeyService.java (1 hunks)
  • apollo-portal/src/main/resources/static/app/access_key.html (2 hunks)
  • apollo-portal/src/main/resources/static/i18n/en.json (2 hunks)
  • apollo-portal/src/main/resources/static/i18n/zh-CN.json (2 hunks)
  • apollo-portal/src/main/resources/static/scripts/controller/AccessKeyController.js (1 hunks)
  • apollo-portal/src/main/resources/static/scripts/services/AccessKeyService.js (2 hunks)
  • scripts/sql/profiles/h2-default/apolloconfigdb.sql (1 hunks)
  • scripts/sql/profiles/h2-default/delta/v230-v240/apolloconfigdb-v230-v240.sql (1 hunks)
  • scripts/sql/profiles/mysql-database-not-specified/apolloconfigdb.sql (1 hunks)
  • scripts/sql/profiles/mysql-database-not-specified/delta/v230-v240/apolloconfigdb-v230-v240.sql (1 hunks)
  • scripts/sql/profiles/mysql-default/apolloconfigdb.sql (1 hunks)
  • scripts/sql/profiles/mysql-default/delta/v230-v240/apolloconfigdb-v230-v240.sql (1 hunks)
  • scripts/sql/src/apolloconfigdb.sql (1 hunks)
  • scripts/sql/src/delta/v230-v240/apolloconfigdb-v230-v240.sql (1 hunks)
Additional comments not posted (45)
apollo-common/src/main/java/com/ctrip/framework/apollo/common/constants/AccessKeyMode.java (1)

19-25: LGTM!

The AccessKeyMode interface is well-defined and serves its purpose as a container for the access key mode constants. The constant names are clear and self-explanatory, and their values are unique and follow a sequential pattern. The interface is placed in an appropriate package for common constants.

scripts/sql/src/delta/v230-v240/apolloconfigdb-v230-v240.sql (1)

22-23: LGTM!

The SQL script for adding the Mode column to the AccessKey table looks good. The data type, constraints, and default value are appropriate for the intended purpose, and the comment provides clear documentation on the meaning of the different mode values.

A few additional suggestions for consideration:

  1. Consider adding a check constraint to ensure that the Mode column only accepts valid values (0 or 1). This can help prevent invalid data from being inserted into the table.

  2. If there are any existing queries or application code that relies on the current structure of the AccessKey table, make sure to update them to handle the new Mode column appropriately.

  3. Verify that the upgrade process handles the addition of the new column gracefully, especially if there is a large amount of existing data in the AccessKey table.

Overall, the changes in this SQL script are well-structured and align with the objectives of introducing the new access key management feature.

apollo-common/src/main/java/com/ctrip/framework/apollo/common/dto/AccessKeyDTO.java (2)

27-27: LGTM!

The new mode field aligns with the PR objective and follows best practices.


55-57: LGTM!

The new getter and setter methods for the mode field follow the JavaBean convention and maintain encapsulation.

Also applies to: 59-61

apollo-portal/src/main/java/com/ctrip/framework/apollo/portal/service/AccessKeyService.java (1)

52-53: Verify the method signature change in the codebase.

The method signature has been updated to include an additional mode parameter. Ensure that all method calls to enable have been updated to pass the mode parameter.

Run the following script to verify the method usage:

Also, consider adding validation for the mode parameter to handle invalid values gracefully and prevent unexpected behavior.

apollo-biz/src/main/java/com/ctrip/framework/apollo/biz/entity/AccessKey.java (3)

39-40: LGTM!

The new mode field is correctly defined with appropriate access modifier, annotation, and data type.


61-67: LGTM!

The getter and setter methods for the mode field are implemented correctly, following the JavaBean convention and providing proper encapsulation.


80-80: LGTM!

The toString() method is correctly updated to include the mode field, enhancing the debugging and logging capabilities of the AccessKey class.

scripts/sql/profiles/mysql-default/delta/v230-v240/apolloconfigdb-v230-v240.sql (1)

31-32: LGTM! Verify the application code and dependent queries/views.

The SQL statement for adding the Mode column to the AccessKey table looks good. The column type, constraints, and comment are appropriate.

Please ensure that:

  1. The application code has been updated to handle the new Mode column appropriately, both for reading and writing data.
  2. Any queries or views that reference the AccessKey table have been updated to include the new column if necessary.

You can use the following script to search for potential references to the AccessKey table in the codebase:

scripts/sql/profiles/h2-default/delta/v230-v240/apolloconfigdb-v230-v240.sql (2)

30-30: LGTM!

The UNIX_TIMESTAMP function alias is created correctly using the CREATE ALIAS statement and maps to a fully qualified Java method for timestamp conversion.


34-34: LGTM!

The Mode column is added correctly to the AccessKey table using the ALTER TABLE statement with the ADD COLUMN clause. The column definition is valid, specifying the data type, size, nullability, and default value. The column is added at an appropriate position and has a clear comment explaining its purpose and possible values.

apollo-configservice/src/main/java/com/ctrip/framework/apollo/configservice/util/AccessKeyUtil.java (2)

49-51: LGTM!

The new findObservableSecrets method is well-implemented and serves a clear purpose. It retrieves observable secrets for a given application ID by delegating to the accessKeyServiceWithCache instance. The method signature and logic are straightforward and easy to understand.


79-81: Clarify the purpose and intended usage of the preCheckInvalid method.

The preCheckInvalid method is currently empty and only contains a comment indicating it's for test mocking. It's unclear how this method fits into the overall functionality of the AccessKeyUtil class and the access key pre-check feature.

Please provide more context or documentation to explain the following:

  1. What is the intended purpose of this method?
  2. How is it meant to be used in the context of access key pre-checking?
  3. Are there any plans to implement the method's logic in the future, or will it remain a placeholder for testing?

Adding this information will help developers better understand the role of this method and how it relates to the broader access key management functionality.

apollo-adminservice/src/main/java/com/ctrip/framework/apollo/adminservice/controller/AccessKeyController.java (4)

21-21: LGTM!

The import statement for the AccessKeyMode class is correctly added.


31-31: LGTM!

The import statement for the RequestParam annotation is correctly added.


66-70: LGTM!

The changes to the enable method signature and the usage of the mode parameter are implemented correctly:

  • The mode parameter is marked as optional with a default value of 0, ensuring backward compatibility.
  • The mode value is correctly set in the AccessKey entity before updating it.

81-81: LGTM!

Setting the mode to AccessKeyMode.FILTER when disabling an access key is a valid approach to ensure the access key operates in the filter mode.

apollo-biz/src/main/java/com/ctrip/framework/apollo/biz/service/AccessKeyService.java (1)

77-77: LGTM!

The change to set the mode of the accessKey object based on the incoming entity parameter is a valid enhancement to the update method. It allows for a more comprehensive update of the AccessKey entity by including the mode attribute along with the enabled status and last modified information.

The change is consistent with the method's purpose and does not introduce any apparent issues or side effects. It aligns well with the overall access key management feature being introduced in this PR.

apollo-portal/src/main/java/com/ctrip/framework/apollo/portal/controller/AccessKeyController.java (1)

80-83: LGTM! Verify the accessKeyService.enable method implementation.

The addition of the optional mode parameter to the enable method provides more flexibility in enabling access keys by allowing the mode to be specified. The default value of 0 ensures backward compatibility for existing callers.

Please verify that the accessKeyService.enable method has been updated to handle the new mode parameter correctly.

Run the following script to verify the accessKeyService.enable method signature:

apollo-portal/src/main/resources/static/scripts/services/AccessKeyService.js (1)

34-34: LGTM!

The addition of the mode query parameter to the URL aligns with the PR objective of introducing an observe status access-key feature. This change allows for more granular control over the enabling process.

apollo-portal/src/main/resources/static/scripts/controller/AccessKeyController.js (1)

139-153: LGTM!

The changes to the enable function look good:

  • The new mode parameter is handled correctly, defaulting to 0 if not explicitly set to 1.
  • The tipsPrefix is constructed based on the mode value, allowing for different user feedback messages.
  • The confirmation message and success/error notifications are updated to use the tipsPrefix, providing contextually relevant messages.
  • The call to AccessKeyService.enable_access_key is updated to pass the mode parameter along with the existing parameters.

The changes enhance the functionality of the enable method by allowing it to handle different operational modes and providing more specific user feedback based on the selected mode. The changes are also backward compatible as the mode parameter defaults to 0, maintaining the existing behavior if not explicitly set.

apollo-configservice/src/main/java/com/ctrip/framework/apollo/configservice/service/AccessKeyServiceWithCache.java (4)

22-22: LGTM!

The import statement is necessary for the new methods being added.


41-41: LGTM!

The import statement is necessary for the new getSecrets method being added.


90-95: LGTM!

The new public methods getAvailableSecrets and getObservableSecrets provide a way to retrieve access keys based on their mode and enabled status. The methods use the new private getSecrets method with a predicate filter, which is a good way to reuse code and avoid duplication.


97-104: LGTM!

The new private method getSecrets provides a way to retrieve access keys based on a predicate filter. The method uses the accessKeyCache to retrieve access keys, which is a good way to avoid hitting the database for every request. The method uses the stream API to filter and map the access keys, which is a good way to write concise and readable code.

apollo-configservice/src/test/java/com/ctrip/framework/apollo/configservice/filter/ClientAuthenticationFilterTest.java (2)

150-174: LGTM!

The testPreCheckInvalid test method is well-structured and comprehensive. It effectively verifies the behavior of the clientAuthenticationFilter when an invalid signature is provided.

The mocking setup covers the necessary scenarios, and the assertions ensure that no error responses are sent, the filter chain is executed, and the preCheckInvalid method is called the expected number of times.


176-199: LGTM!

The testPreCheckSuccessfully test method is well-structured and effectively verifies the behavior of the clientAuthenticationFilter when a valid signature is provided.

The mocking setup is appropriate for the valid signature case, and the assertions ensure that no error responses are sent, the filter chain is executed, and the preCheckInvalid method is not called.

scripts/sql/src/apolloconfigdb.sql (1)

400-400: LGTM!

The addition of the Mode column to the AccessKey table is a valid change that introduces the capability to specify access key modes. The chosen data type, constraints, and default value align with the intended functionality.

scripts/sql/profiles/h2-default/apolloconfigdb.sql (1)

396-396: LGTM!

The addition of the Mode column to the AccessKey table looks good:

  • The column is defined with the appropriate data type tinyint(2) unsigned and default value 0.
  • The comment clearly explains the purpose and allowed values for the column.
  • This is a non-breaking change as existing code will continue to work due to the default value.

Note: Application code changes will be needed to set and interpret the Mode values in order to utilize this new functionality.

scripts/sql/profiles/mysql-database-not-specified/apolloconfigdb.sql (1)

407-407: Approve the addition of the Mode column to the AccessKey table.

The new Mode column introduces a way to categorize access keys into "filter" and "observer" modes. The chosen data type and default value are appropriate.

Consider the following impacts:

  • Update the application code to handle the new Mode column correctly.
  • Verify that assigning the "filter" mode by default to existing access keys aligns with the intended behavior.
  • Ensure that the access control logic is updated to differentiate between the "filter" and "observer" modes as needed.
scripts/sql/profiles/mysql-default/apolloconfigdb.sql (1)

412-412: LGTM!

The addition of the Mode column to the AccessKey table is a good enhancement that allows differentiating between "filter" and "observer" modes for access keys. The chosen data type and default value are appropriate.

Consider the following:

  • Update any existing code that interacts with the AccessKey table to handle the new Mode column appropriately.
  • Ensure that the application logic correctly utilizes the Mode value when processing access keys.
  • Update the relevant documentation to reflect the new access key modes and their behavior.
apollo-portal/src/main/java/com/ctrip/framework/apollo/portal/api/AdminServiceAPI.java (2)

320-322: LGTM!

The changes to the enable method signature and the corresponding update to the URL template look good.


320-322: Verify the method invocation changes in the codebase.

Please ensure that all invocations of the enable method have been updated to provide the mode argument.

Run the following script to verify the method usage:

apollo-portal/src/main/resources/static/i18n/zh-CN.json (4)

519-524: Looks good!

The added localization strings provide clear guidance about access key usage and mention the new "Observe" status. The key names also follow existing naming conventions.


533-536: Looks good!

The added strings for the new "Observe" access key operation look appropriate and consistent with existing operation label conventions.


541-546: Looks good!

The added success and error message strings for the new observe access key operation are consistent with existing message conventions and provide suitable user-facing text.


550-550: Looks good!

The confirmation message for the observe access key operation is consistent with other confirmation prompts and provides a clear text to confirm the action.

apollo-portal/src/main/resources/static/i18n/en.json (4)

520-524: LGTM!

The added localization strings for access key tips are clear and informative. The JSON syntax is valid.


533-536: Looks good!

The new localization strings for the "Observe" access key operation are consistent with the existing entries. The JSON syntax is valid.


541-546: Approved.

The success and error message strings for the "Observe" access key operation are clear and consistent with the existing entries. The JSON syntax is valid.


550-551: Good to go!

The confirmation prompt string for the "Observe" access key operation is clear and consistent with the existing entries. The JSON syntax is valid.

apollo-configservice/src/main/java/com/ctrip/framework/apollo/configservice/filter/ClientAuthenticationFilter.java (3)

20-20: Imports added for client IP extraction and tracing

The addition of WebUtils and Tracer imports is appropriate for retrieving client IP addresses and logging events, supporting the new logging functionality.

Also applies to: 24-24


78-78: Retrieve and utilize client IP for enhanced logging

Fetching the client IP address using WebUtils.tryToGetClientIp(request) enhances logging details and aids in monitoring and troubleshooting client requests.


159-164: Review the use of accessKeyUtil.preCheckInvalid() in production code

The preCheckInvalidLogging method includes a call to accessKeyUtil.preCheckInvalid();, with a comment indicating it's "only for test mock". If this method is intended solely for testing purposes, it should not be invoked in production code to avoid unintended side effects.

Confirm whether accessKeyUtil.preCheckInvalid() should be called in the production environment. If not, consider removing it:

 private void preCheckInvalidLogging(String message) {
   logger.warn(message);
   Tracer.logEvent("Apollo.AccessKey.PreCheck", message);
-  // only for test mock
-  accessKeyUtil.preCheckInvalid();
 }
apollo-portal/src/main/resources/static/app/access_key.html (1)

63-67: Ensure Translations for New Tips Are Included

The new tips AccessKey.Tips.4 and its sub-items (AccessKey.Tips.4.1, AccessKey.Tips.4.2, AccessKey.Tips.4.3) have been added. Please verify that corresponding translations exist in all localization files to ensure they are displayed correctly to users.

Verification successful

Translations Verified Successfully

All new translation keys (AccessKey.Tips.4, AccessKey.Tips.4.1, AccessKey.Tips.4.2, AccessKey.Tips.4.3) are present in the localization files (en.json, zh-CN.json).

Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check if new translation keys are present in localization files.

# List of new translation keys
keys=(
  'AccessKey.Tips.4'
  'AccessKey.Tips.4.1'
  'AccessKey.Tips.4.2'
  'AccessKey.Tips.4.3'
)

# Loop through each key and check if it's present in the localization files
for key in "${keys[@]}"; do
  echo "Checking for $key..."
  if ! rg --files-with-matches "$key" ./src/main/resources/i18n/; then
    echo "Missing translation for $key"
  fi
done

Length of output: 1436


Script:

#!/bin/bash
# Description: Locate all i18n directories in the repository.

fd --type d i18n

Length of output: 64


Script:

#!/bin/bash
# Description: Check if new translation keys are present in localization files.

# List of new translation keys
keys=(
  'AccessKey.Tips.4'
  'AccessKey.Tips.4.1'
  'AccessKey.Tips.4.2'
  'AccessKey.Tips.4.3'
)

# Loop through each key and check if it's present in the localization files
for key in "${keys[@]}"; do
  echo "Checking for $key..."
  if ! rg --files-with-matches "$key" ./apollo-portal/src/main/resources/static/i18n/; then
    echo "Missing translation for $key"
  fi
done

Length of output: 1328

Copy link
Member

@nobodyiam nobodyiam left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks great! Please find some comments below.

@nobodyiam nobodyiam added this to the 2.4.0 milestone Oct 6, 2024
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 10

🧹 Outside diff range and nitpick comments (4)
apollo-configservice/src/main/java/com/ctrip/framework/apollo/configservice/util/AccessKeyUtil.java (1)

49-51: LGTM! Consider adding a brief Javadoc comment.

The new findObservableSecrets method is well-implemented and aligns with the PR objectives. It follows a consistent pattern with the existing findAvailableSecret method.

Consider adding a brief Javadoc comment to explain the purpose of this method and its relationship to the pre-check functionality. For example:

/**
 * Retrieves a list of observable secrets for the given appId.
 * This method is used for pre-checking and logging purposes without blocking requests.
 *
 * @param appId the application ID
 * @return a list of observable secrets
 */
public List<String> findObservableSecrets(String appId) {
    return accessKeyServiceWithCache.getObservableSecrets(appId);
}
apollo-adminservice/src/main/java/com/ctrip/framework/apollo/adminservice/controller/AccessKeyController.java (2)

67-68: LGTM: Method signature updated correctly.

The addition of the mode parameter with @RequestParam allows for optional specification of the mode when enabling an access key, which aligns with the PR objectives. The default value ensures backward compatibility.

Consider applying the suggestion from the previous review for improved readability:

  public void enable(@PathVariable String appId, @PathVariable long id,
      @RequestParam(required = false, defaultValue = ""+AccessKeyMode.FILTER) int mode, String operator) {

This change makes it clearer that FILTER is part of the AccessKeyMode enum.


82-82: LGTM: Mode is explicitly set when disabling.

The addition of entity.setMode(FILTER); ensures that the AccessKey entity's mode is consistently set to FILTER when disabling it. This aligns with the current requirements and PR objectives.

Consider if there might be future scenarios where different modes for disabled keys could be beneficial. If so, you might want to make this configurable or parameterized similar to the enable method for increased flexibility.

apollo-configservice/src/main/java/com/ctrip/framework/apollo/configservice/filter/ClientAuthenticationFilter.java (1)

93-93: Typographical correction in Javadoc comment

In the method documentation for doCheck, the verb should agree with the plural noun "authentication checks".

Apply this diff to correct the grammar:

- * @return true if authentication checks is successful, false otherwise
+ * @return true if authentication checks are successful, false otherwise
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Files that changed from the base of the PR and between 15fb495 and acad9b7.

📒 Files selected for processing (5)
  • apollo-adminservice/src/main/java/com/ctrip/framework/apollo/adminservice/controller/AccessKeyController.java (4 hunks)
  • apollo-configservice/src/main/java/com/ctrip/framework/apollo/configservice/filter/ClientAuthenticationFilter.java (3 hunks)
  • apollo-configservice/src/main/java/com/ctrip/framework/apollo/configservice/util/AccessKeyUtil.java (1 hunks)
  • apollo-configservice/src/test/java/com/ctrip/framework/apollo/configservice/filter/ClientAuthenticationFilterTest.java (4 hunks)
  • apollo-portal/src/main/java/com/ctrip/framework/apollo/portal/controller/AccessKeyController.java (2 hunks)
🧰 Additional context used
🔇 Additional comments (6)
apollo-configservice/src/main/java/com/ctrip/framework/apollo/configservice/util/AccessKeyUtil.java (1)

49-51: Verify usage of the new method in the codebase.

The new findObservableSecrets method looks good and doesn't introduce any breaking changes. To ensure it's being used as intended for the pre-check functionality, we should verify its usage in other parts of the codebase.

Run the following script to check for usage of the new method:

✅ Verification successful

findObservableSecrets usage is properly integrated and no issues found.

  • Used in ClientAuthenticationFilter.java
  • Used in ClientAuthenticationFilterTest.java
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check for usage of findObservableSecrets method

# Search for method invocations
echo "Searching for findObservableSecrets usage:"
rg --type java "findObservableSecrets\(" -g "!AccessKeyUtil.java"

# Search for potential places where it should be used (e.g., alongside findAvailableSecret)
echo "\nSearching for potential usage locations:"
rg --type java "findAvailableSecret\(" -g "!AccessKeyUtil.java"

Length of output: 2459

apollo-adminservice/src/main/java/com/ctrip/framework/apollo/adminservice/controller/AccessKeyController.java (2)

19-20: LGTM: Import statements are correctly updated.

The new imports for FILTER and RequestParam are necessary and correctly added to support the changes in the class methods.

Also applies to: 32-32


71-71: LGTM: Mode is correctly set in the enable method.

The addition of entity.setMode(mode); ensures that the AccessKey entity is updated with the specified (or default) mode before enabling it. This change correctly implements the new functionality introduced by the method signature update.

apollo-configservice/src/test/java/com/ctrip/framework/apollo/configservice/filter/ClientAuthenticationFilterTest.java (3)

153-201: Ensure timestamp values align with test scenarios

In testPreCheckInvalid(), the oneMinAgoTimestamp is set to a value 61 seconds in the past:

String oneMinAgoTimestamp = Long.toString(System.currentTimeMillis() - 61 * 1000);

Given that the time difference tolerance is set to 60 seconds, this timestamp exceeds the allowed skew. However, the test verifies that no error is sent for "RequestTimeTooSkewed". Confirm that this is the intended behavior in pre-check mode, where requests should not be blocked due to time skew but should log the invalid attempt.


64-64: Good use of Mockito spy for method verification

Replacing the instantiation with a spy in the setUp() method allows for verification of interactions with clientAuthenticationFilter. This enhances the test's ability to assert internal method calls.


178-201: Test testPreCheckSuccessfully() accurately validates successful pre-check

The test ensures that when there are no available secrets but observable secrets exist, and the authorization is correct, the request proceeds without triggering preCheckInvalidLogging(). This effectively verifies the intended behavior of the pre-check mechanism when clients provide valid credentials.

@larry4xie
Copy link
Contributor Author

This looks great! Please find some comments below.

👍🏻 All the comments have been resolved, Please take a moment to review again.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Outside diff range and nitpick comments (2)
apollo-configservice/src/test/java/com/ctrip/framework/apollo/configservice/filter/ClientAuthenticationFilterTest.java (2)

150-170: LGTM: New test method for pre-check invalid scenario.

The testPreCheckInvalid method is well-structured and tests the pre-check functionality when the authentication is invalid. The test setup correctly mocks the necessary dependencies and method calls.

Regarding the previous review comment about clarifying the expected number of pre-check logging invocations:
The test verifies that preCheckInvalidLogging is called twice. This could be due to multiple checks in the filter's logic. However, it would be beneficial to add a comment explaining why two invocations are expected, to improve the test's clarity and maintainability.

Consider adding a comment explaining why preCheckInvalidLogging is expected to be called twice in this scenario.


Line range hint 194-199: LGTM: New helper method improves test code structure.

The verifySuccessAndDoFilter method is a good addition that consolidates common verification logic used in multiple test methods. It improves code readability and reduces duplication.

Regarding the previous review comment about consolidating duplicate test setup code:
While this helper method addresses part of the duplication concern by consolidating verification logic, there's still an opportunity to further reduce duplication in the test setup code. Consider extracting common setup logic (e.g., mocking dependencies) into a separate helper method or using parameterized tests for scenarios with similar setups but different inputs/expectations.

Consider further reducing duplication by extracting common setup logic into a separate helper method or using parameterized tests for similar scenarios.

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Files that changed from the base of the PR and between acad9b7 and ff75da3.

📒 Files selected for processing (1)
  • apollo-configservice/src/test/java/com/ctrip/framework/apollo/configservice/filter/ClientAuthenticationFilterTest.java (4 hunks)
🧰 Additional context used
🔇 Additional comments (4)
apollo-configservice/src/test/java/com/ctrip/framework/apollo/configservice/filter/ClientAuthenticationFilterTest.java (4)

20-22: LGTM: New imports added correctly.

The new imports for anyString and spy from Mockito are necessary for the new test methods and the modified setUp method. They are correctly placed and follow the existing import style.


64-64: LGTM: Spy used for better test control.

The change to use spy for instantiating clientAuthenticationFilter is a good improvement. It allows for partial mocking, which is useful for verifying method calls on the filter while still executing the real methods. This change is consistent with the new test methods that verify specific method calls.


172-192: LGTM: New test method for pre-check success scenario.

The testPreCheckSuccessfully method is well-structured and effectively tests the pre-check functionality for a successful authentication scenario. The test setup correctly mocks the necessary dependencies and method calls. The verification that preCheckInvalidLogging is never called is appropriate for a successful pre-check scenario.


Line range hint 1-199: Overall, the changes improve test coverage and align with PR objectives.

The additions to ClientAuthenticationFilterTest.java effectively support the PR's objective of introducing an observe status access-key feature for pre-checking and logging. The new test methods (testPreCheckInvalid and testPreCheckSuccessfully) provide coverage for both successful and invalid pre-check scenarios, which is crucial for validating the new feature's behavior.

The introduction of the verifySuccessAndDoFilter helper method is a step towards reducing code duplication and improving test readability. However, there's still an opportunity to further refactor common setup code across test methods.

To further enhance the test suite:

  1. Consider using parameterized tests for scenarios with similar setups but different inputs/expectations.
  2. Add comments to clarify the expected behavior, especially for cases like the double invocation of preCheckInvalidLogging in testPreCheckInvalid.
  3. Ensure that edge cases and potential error scenarios are also covered in the test suite.

These changes provide a solid foundation for testing the new pre-check functionality while maintaining the overall quality and structure of the test class.

Copy link
Member

@nobodyiam nobodyiam left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please also update the CHANGES.md.

scripts/sql/src/apolloconfigdb.sql Outdated Show resolved Hide resolved
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Outside diff range and nitpick comments (1)
scripts/sql/src/apolloconfigdb.sql (1)

400-400: Approve the addition of the Mode column with minor suggestions.

The addition of the Mode column to the AccessKey table is well-implemented and aligns with the PR objectives. However, consider the following suggestions:

  1. Remove the display width from the tinyint data type, as it's deprecated in MySQL 8.0:
-  `Mode` tinyint unsigned NOT NULL DEFAULT '0' COMMENT '密钥模式,0: filter,1: observer',
+  `Mode` tinyint unsigned NOT NULL DEFAULT 0 COMMENT '密钥模式,0: filter,1: observer',
  1. Consider adding an index on the Mode column if you anticipate frequent queries filtering on this column:
KEY `IX_Mode` (`Mode`)
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Files that changed from the base of the PR and between ff75da3 and 0f2dd9f.

📒 Files selected for processing (1)
  • scripts/sql/src/apolloconfigdb.sql (1 hunks)
🧰 Additional context used

@larry4xie
Copy link
Contributor Author

Please also update the CHANGES.md.

Done.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 1

🧹 Outside diff range and nitpick comments (9)
CHANGES.md (1)

14-14: LGTM! Consider a minor wording adjustment.

The addition of the new feature to the changelog is appropriate and consistent with the PR objectives. The format matches other entries, and the link to the pull request is correctly included.

For slightly improved clarity, consider adjusting the wording as follows:

-* [Feature support the observe status access-key for pre-check and logging only](https://github.com/apolloconfig/apollo/pull/5236)
+* [Feature: Support observe status for access-key pre-check and logging without blocking](https://github.com/apolloconfig/apollo/pull/5236)

This adjustment emphasizes that the feature is for observation and doesn't block requests, which aligns more closely with the PR objectives.

scripts/sql/profiles/mysql-default/delta/v230-v240/apolloconfigdb-v230-v240.sql (1)

31-32: LGTM! Consider adding a CHECK constraint for data integrity.

The ALTER TABLE statement correctly adds the new 'Mode' column to the 'AccessKey' table, aligning with the PR objectives. The column type, default value, and comment are all appropriate.

To further enhance data integrity, consider adding a CHECK constraint to ensure only valid values (0 or 1) can be inserted:

ALTER TABLE `AccessKey`
    ADD COLUMN `Mode` tinyint unsigned NOT NULL DEFAULT '0' COMMENT '密钥模式,0: filter,1: observer' AFTER `Secret`,
    ADD CONSTRAINT `chk_mode` CHECK (`Mode` IN (0, 1));

This ensures that only the specified modes (filter or observer) can be set for the access keys.

scripts/sql/profiles/h2-default/delta/v230-v240/apolloconfigdb-v230-v240.sql (2)

28-30: LGTM: UNIX_TIMESTAMP alias creation looks good.

The alias creation for UNIX_TIMESTAMP is correct and follows good practices. Using IF NOT EXISTS prevents errors if the alias already exists, which is a good defensive programming technique.

Consider adding a brief comment explaining the purpose of this alias, e.g.:

-- Create UNIX_TIMESTAMP alias for H2 database to provide Unix timestamp functionality
CREATE ALIAS IF NOT EXISTS UNIX_TIMESTAMP FOR "com.ctrip.framework.apollo.common.jpa.H2Function.unixTimestamp";

34-34: LGTM: AccessKey table alteration is correct and well-documented.

The addition of the 'Mode' column to the AccessKey table is implemented correctly. The use of a tinyint with a default value ensures backward compatibility and space efficiency.

Consider the following suggestions:

  1. For consistency, consider using English for the comment:
    COMMENT 'Key mode, 0: filter, 1: observer'
  2. To improve readability, you might want to split the ALTER TABLE statement across multiple lines:
    ALTER TABLE `AccessKey` 
    ADD COLUMN `Mode` tinyint unsigned NOT NULL DEFAULT '0' 
    COMMENT 'Key mode, 0: filter, 1: observer' 
    AFTER `Secret`;
scripts/sql/profiles/h2-default/apolloconfigdb.sql (1)

396-396: Summary of changes and recommendations

The SQL script modification is minimal and focused:

  1. A new Mode column has been added to the AccessKey table.
  2. The change is isolated and doesn't directly affect other tables.

Recommendations:

  1. Update the application's documentation to reflect the new Mode column and its purpose.
  2. Ensure that database migration scripts (if used) include this change for existing deployments.
  3. Consider adding a database index on the Mode column if it will be frequently used in queries.

To help with documentation and potential performance optimization, consider running the following script:

#!/bin/bash
# Check for existing documentation and suggest index creation

echo "Searching for AccessKey documentation:"
rg --type md "AccessKey"

echo "Analyzing potential need for an index on the Mode column:"
cat << EOF
Consider adding an index on the Mode column if you anticipate frequent queries filtering on this column. 
You can add an index with the following SQL command:

CREATE INDEX IX_AccessKey_Mode ON AccessKey (Mode);

Analyze your query patterns to determine if this index would be beneficial.
EOF

Please review the script output and consider implementing the suggestions if appropriate for your use case.

scripts/sql/profiles/mysql-database-not-specified/apolloconfigdb.sql (2)

Line range hint 405-419: LGTM! Consider adding an index for the Mode column.

The addition of the Mode column to the AccessKey table is well-implemented. The column is properly defined with an appropriate data type (tinyint unsigned), a default value (0), and a clear comment explaining its purpose and possible values.

Consider adding an index on the Mode column if you anticipate frequent queries filtering or sorting by this column. This could improve query performance in such scenarios. Here's a suggested ALTER TABLE statement:

ALTER TABLE `AccessKey` ADD INDEX `IX_Mode` (`Mode`);

Add this statement after the table creation if you decide to include the index.


Line range hint 524-529: Consider adding a ServerConfig entry for the new Mode feature.

While the addition of the Mode column to the AccessKey table is well-implemented, it might be beneficial to add a corresponding entry in the ServerConfig table. This would allow for easy configuration of the default behavior of the new Mode feature.

Consider adding an INSERT statement for a new configuration entry in the ServerConfig table. Here's a suggested statement:

INSERT INTO `ServerConfig` (`Key`, `Cluster`, `Value`, `Comment`)
VALUES ('accesskey.mode.default', 'default', '0', 'Default mode for access keys. 0: filter, 1: observer');

Add this statement after the existing INSERT statements for the ServerConfig table.

scripts/sql/profiles/mysql-default/apolloconfigdb.sql (2)

412-412: LGTM! The new Mode column enhances the AccessKey table functionality.

The addition of the Mode column to the AccessKey table is well-implemented and aligns with the PR objectives. It allows for different operational modes (filter or observer) for access keys, which is crucial for the new pre-check and logging feature.

The column definition is appropriate:

  • tinyint unsigned is suitable for the binary mode options.
  • NOT NULL ensures data integrity.
  • DEFAULT '0' maintains backwards compatibility by defaulting to the 'filter' mode.

Consider adding an index on the Mode column if you expect to frequently query or filter based on this column:

ALTER TABLE `AccessKey` ADD INDEX `IX_Mode` (`Mode`);

This can improve query performance when selecting or filtering access keys based on their mode.


Line range hint 1-524: Overall structure is good, but consider some enhancements for robustness and performance.

The SQL script is well-structured and follows good practices. However, I have a few suggestions to enhance its robustness and performance:

  1. Consider wrapping the entire script in a transaction for atomic execution:
START TRANSACTION;

-- (existing script content)

COMMIT;
  1. Explicitly set the character set and collation when creating the database:
CREATE DATABASE IF NOT EXISTS ApolloConfigDB
DEFAULT CHARACTER SET = utf8mb4
COLLATE = utf8mb4_unicode_ci;
  1. For large tables that may grow significantly over time (e.g., Audit, ReleaseHistory), consider implementing partitioning to improve query performance and manageability. For example:
CREATE TABLE `Audit` (
  -- (existing columns)
)
PARTITION BY RANGE (UNIX_TIMESTAMP(DataChange_CreatedTime)) (
    PARTITION p0 VALUES LESS THAN (UNIX_TIMESTAMP('2023-01-01 00:00:00')),
    PARTITION p1 VALUES LESS THAN (UNIX_TIMESTAMP('2024-01-01 00:00:00')),
    PARTITION p2 VALUES LESS THAN (UNIX_TIMESTAMP('2025-01-01 00:00:00'))
);

These enhancements can improve the script's reliability, consistency, and performance as the database grows.

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Files that changed from the base of the PR and between 0f2dd9f and 2c1c2a3.

📒 Files selected for processing (8)
  • CHANGES.md (1 hunks)
  • scripts/sql/profiles/h2-default/apolloconfigdb.sql (1 hunks)
  • scripts/sql/profiles/h2-default/delta/v230-v240/apolloconfigdb-v230-v240.sql (1 hunks)
  • scripts/sql/profiles/mysql-database-not-specified/apolloconfigdb.sql (1 hunks)
  • scripts/sql/profiles/mysql-database-not-specified/delta/v230-v240/apolloconfigdb-v230-v240.sql (1 hunks)
  • scripts/sql/profiles/mysql-default/apolloconfigdb.sql (1 hunks)
  • scripts/sql/profiles/mysql-default/delta/v230-v240/apolloconfigdb-v230-v240.sql (1 hunks)
  • scripts/sql/src/delta/v230-v240/apolloconfigdb-v230-v240.sql (1 hunks)
🧰 Additional context used
🔇 Additional comments (11)
scripts/sql/src/delta/v230-v240/apolloconfigdb-v230-v240.sql (3)

1-15: LGTM: Appropriate license header included.

The file correctly includes the Apache 2.0 license header, which is essential for open-source projects and aligns with best practices for code licensing.


22-23: LGTM: Well-structured ALTER TABLE statement.

The ALTER TABLE statement is correctly formed and adds the new 'Mode' column with appropriate attributes:

  • Type: tinyint unsigned (suitable for small integer values 0-255)
  • NOT NULL constraint with DEFAULT '0' (ensures data integrity)
  • Clear COMMENT explaining the column's purpose
  • Logical placement AFTER the 'Secret' column

This change aligns well with the PR objectives, supporting the new observe status access-key feature.


1-25: LGTM: Clear and purposeful database upgrade script.

This SQL script effectively upgrades the Apollo configuration database from v2.3.0 to v2.4.0. It includes:

  1. Appropriate license header
  2. Clear comments indicating the purpose of the script
  3. Placeholders for auto-generated declarations and H2 functions
  4. A well-structured ALTER TABLE statement to add the new 'Mode' column

The script is concise, focused, and achieves its intended purpose of introducing the new 'Mode' column to support the observe status access-key feature.

scripts/sql/profiles/mysql-default/delta/v230-v240/apolloconfigdb-v230-v240.sql (2)

1-41: Overall structure and content of the script look good.

The script follows best practices for SQL migrations:

  1. It includes appropriate copyright and license information.
  2. It's clearly marked as generated and not to be edited manually.
  3. It specifies the correct database (ApolloConfigDB) to be used.
  4. The migration is focused and concise, addressing only the necessary changes.

1-41: Summary: SQL changes align well with PR objectives.

This SQL script successfully implements the database changes required to support the new observe status access-key feature described in the PR objectives. The addition of the 'Mode' column to the 'AccessKey' table provides the necessary infrastructure to distinguish between 'filter' and 'observer' modes for access keys.

Key points:

  1. The change supports the pre-check capability without blocking requests.
  2. It allows for the implementation of a configuration switch (although this is likely handled in application code).
  3. The new column can be used to determine when to log client access attempts without required keys.
scripts/sql/profiles/h2-default/delta/v230-v240/apolloconfigdb-v230-v240.sql (2)

1-26: LGTM: Copyright and license information is correct and complete.

The copyright notice is up to date, and the Apache License 2.0 is correctly referenced. The generated file warning is also present, which is good practice.


1-43: Summary: SQL changes align well with PR objectives.

This SQL script successfully implements the database changes required for the new observe status access-key feature. The addition of the 'Mode' column to the AccessKey table directly supports the PR's objective of introducing a pre-check capability for access keys.

Key points:

  1. The UNIX_TIMESTAMP alias addition may be used for timestamp-related operations in the new feature.
  2. The new 'Mode' column in the AccessKey table allows for distinguishing between 'filter' and 'observer' modes, which is crucial for the pre-check functionality.

These changes provide the necessary database structure to support the new feature without breaking existing functionality, aligning well with the PR objectives.

scripts/sql/profiles/h2-default/apolloconfigdb.sql (2)

396-396: Ensure code compatibility with new Mode column

While the schema change is straightforward, it's crucial to update any code that interacts with the AccessKey table to handle the new Mode column. This may include:

  1. Data access objects (DAOs) or repositories
  2. Service layer code that creates or updates access keys
  3. API endpoints that return access key information

To help identify areas that might need updates, run the following script:

#!/bin/bash
# Search for files that might need updates due to the new Mode column

echo "Searching for files that interact with AccessKey:"
rg --type java --type kotlin "AccessKey"

echo "Checking for any AccessKey-related tests that might need updating:"
rg --type java --type kotlin "test.*AccessKey"

Please review the output of this script and update the relevant files to accommodate the new Mode column.


396-396: New column Mode added to AccessKey table

The Mode column has been added to the AccessKey table with the following properties:

  • Data type: tinyint unsigned
  • Default value: 0
  • Not nullable
  • Comment: '密钥模式,0: filter,1: observer'

This addition allows for different modes of access keys, which aligns with the PR objective of introducing an observe status access-key for pre-check and logging.

To ensure this change is consistent with the rest of the codebase, please run the following script:

✅ Verification successful

No references to AccessKey.Mode found

The newly added Mode column in the AccessKey table is not referenced elsewhere in the codebase, and there are no TODO comments related to AccessKey or Mode. This indicates that the change is isolated and does not affect other parts of the system.

  • No usage of AccessKey.Mode in Java or Kotlin files
  • No pending TODOs related to AccessKey or Mode
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check if the Mode column is referenced in other parts of the codebase
echo "Searching for references to AccessKey.Mode in the codebase:"
rg --type java --type kotlin "AccessKey.*Mode"

echo "Checking for any TODO comments related to AccessKey or Mode:"
rg --type java --type kotlin "TODO.*AccessKey|TODO.*Mode"

Length of output: 30205


Script:

#!/bin/bash
# Check if the Mode column is referenced in other parts of the codebase
echo 'Searching for references to AccessKey.Mode in the codebase:'
rg --type java --type kotlin 'AccessKey\.Mode'

echo 'Checking for any TODO comments related to AccessKey or Mode:'
rg --type java --type kotlin 'TODO.*AccessKey|TODO.*Mode'

Length of output: 368

scripts/sql/profiles/mysql-database-not-specified/apolloconfigdb.sql (1)

Line range hint 1-529: Summary: Well-implemented change with minimal impact.

The addition of the Mode column to the AccessKey table is the primary change in this script. This modification is well-implemented and isolated, minimizing the risk of unintended side effects on other parts of the database schema.

Key points:

  1. The new Mode column is properly defined with appropriate data type, default value, and clear comment.
  2. No changes to existing constraints or indexes were required.
  3. No data migration is necessary due to the use of a default value for the new column.

The suggestions provided earlier (adding an index on the Mode column and a configuration entry in the ServerConfig table) can potentially improve query performance and system configurability, respectively.

Overall, this change appears to be a solid enhancement to the access key functionality, allowing for more granular control over access permissions.

scripts/sql/profiles/mysql-default/apolloconfigdb.sql (1)

Line range hint 1-524: Summary: The SQL script changes are appropriate, with room for overall improvements.

The addition of the Mode column to the AccessKey table is well-implemented and aligns with the PR objectives. The overall script is structurally sound, but could benefit from the following enhancements:

  1. Wrapping the script in a transaction for atomic execution.
  2. Explicitly setting character set and collation for the database.
  3. Considering partitioning for large tables.
  4. Adding an index on the new Mode column in the AccessKey table.

These changes would further improve the script's reliability, consistency, and performance. Overall, the current implementation is acceptable, and these suggestions are for future optimization.

Copy link
Member

@nobodyiam nobodyiam left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@dosubot dosubot bot added the lgtm This PR has been approved by a maintainer label Oct 8, 2024
@nobodyiam nobodyiam merged commit b32fcc6 into apolloconfig:master Oct 8, 2024
7 checks passed
@github-actions github-actions bot locked and limited conversation to collaborators Oct 8, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
lgtm This PR has been approved by a maintainer size:L This PR changes 100-499 lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

增加未启用密钥的预校验能力,方便启用密钥前观察客户端的行为是否服务预期
2 participants