-
Notifications
You must be signed in to change notification settings - Fork 392
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
[#6078] feat(core): Support model event to Gravitino server #6129
base: main
Are you sure you want to change the base?
Conversation
core/src/main/java/org/apache/gravitino/listener/api/event/GetModelVersionEvent.java
Outdated
Show resolved
Hide resolved
core/src/main/java/org/apache/gravitino/listener/api/info/ModelInfo.java
Outdated
Show resolved
Hide resolved
Support model event to Gravitino server. Add list, get, create and delete events to both model and model version.
Fix some class comments.
799df18
to
cd86b6a
Compare
Will review the PR these days. |
…on details page (apache#6167) ### What changes were proposed in this pull request? Reload tree data after refreshing the version details page <img width="1352" alt="image" src="https://github.com/user-attachments/assets/80bc7370-0052-4be8-9b6d-efbe6d97e945" /> ### Why are the changes needed? N/A Fix: apache#6166 ### Does this PR introduce _any_ user-facing change? N/A ### How was this patch tested? manually
…apache#6159) ### What changes were proposed in this pull request? 1. Refactor catalog commands and Base class in Gavitino CLI. 2. Add test case. ### Why are the changes needed? Fix: apache#6143 ### Does this PR introduce _any_ user-facing change? No ### How was this patch tested? local test.
…pache#6161) ### What changes were proposed in this pull request? Refactor table commands in Gavitino CLI and Base class. ### Why are the changes needed? Fix: apache#6145 ### Does this PR introduce _any_ user-facing change? No ### How was this patch tested? local test
…pache#6162) ### What changes were proposed in this pull request? Refactor model commands and Base class in Gavitino CLI. ### Why are the changes needed? Fix: apache#6148 ### Does this PR introduce _any_ user-facing change? No ### How was this patch tested? local test
…eset catalog with cloud storage (apache#5974) ### What changes were proposed in this pull request? Support dynamic credential in obtaining cloud storage fileset. ### Why are the changes needed? Static key are not very safe, we need to optimize it. Fix: apache#5973 ### Does this PR introduce _any_ user-facing change? N/A ### How was this patch tested? ITs
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 noticed that this PR includes commits from other PRs. It seems like those are unrelated to the feature in this PR. Could you please clean up the commit history to ensure only relevant changes are included?
### What changes were proposed in this pull request? Added LICENSE and NOTICE file for the Trino connector. ### Why are the changes needed? to comply with ASF policy Fix: apache#6173 ### Does this PR introduce _any_ user-facing change? No. ### How was this patch tested? Tested locally.
### What changes were proposed in this pull request? Update year as we are going to make a new release. ### Why are the changes needed? ASF/legal policy. Fix: #N/A ### Does this PR introduce _any_ user-facing change? No ### How was this patch tested? N/A
Bumps [nanoid](https://github.com/ai/nanoid) from 3.3.7 to 3.3.8. <details> <summary>Changelog</summary> <p><em>Sourced from <a href="https://github.com/ai/nanoid/blob/main/CHANGELOG.md">nanoid's changelog</a>.</em></p> <blockquote> <h2>3.3.8</h2> <ul> <li>Fixed a way to break Nano ID by passing non-integer size (by <a href="https://github.com/myndzi"><code>@myndzi</code></a>).</li> </ul> </blockquote> </details> <details> <summary>Commits</summary> <ul> <li><a href="https://github.com/ai/nanoid/commit/3044cd5e73f4cf31795f61f6e6b961c8c0a5c744"><code>3044cd5</code></a> Release 3.3.8 version</li> <li><a href="https://github.com/ai/nanoid/commit/4fe34959c34e5b3573889ed4f24fe91d1d3e7231"><code>4fe3495</code></a> Update size limit</li> <li><a href="https://github.com/ai/nanoid/commit/d643045f40d6dc8afa000a644d857da1436ed08c"><code>d643045</code></a> Fix pool pollution, infinite loop (<a href="https://redirect.github.com/ai/nanoid/issues/510">#510</a>)</li> <li>See full diff in <a href="https://github.com/ai/nanoid/compare/3.3.7...3.3.8">compare view</a></li> </ul> </details> <br /> [![Dependabot compatibility score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=nanoid&package-manager=npm_and_yarn&previous-version=3.3.7&new-version=3.3.8)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores) Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting `@dependabot rebase`. [//]: # (dependabot-automerge-start) [//]: # (dependabot-automerge-end) --- <details> <summary>Dependabot commands and options</summary> <br /> You can trigger Dependabot actions by commenting on this PR: - `@dependabot rebase` will rebase this PR - `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `@dependabot merge` will merge this PR after your CI passes on it - `@dependabot squash and merge` will squash and merge this PR after your CI passes on it - `@dependabot cancel merge` will cancel a previously requested merge and block automerging - `@dependabot reopen` will reopen this PR if it is closed - `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually - `@dependabot show <dependency name> ignore conditions` will show all of the ignore conditions of the specified dependency - `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself) You can disable automated security fix PRs for this repo from the [Security Alerts page](https://github.com/apache/gravitino/network/alerts). </details> Signed-off-by: dependabot[bot] <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
…pache#6174) ### What changes were proposed in this pull request? Refactor topic commands in Gavitino CLI ### Why are the changes needed? Fix: apache#6146 ### Does this PR introduce _any_ user-facing change? No ### How was this patch tested? local test.
…pache#6175) ### What changes were proposed in this pull request? Refactor group commands in Gavitino CLI. ### Why are the changes needed? Fix: apache#6151 ### Does this PR introduce _any_ user-facing change? No ### How was this patch tested? local test.
…ages for Iceberg REST server (apache#6168) ### What changes were proposed in this pull request? 1. use Gravitino cloud jar without hadoop packages for Iceberg REST server credential vending in test and document 2. For OSS, use Gravitino Aliyun bundle jar in test and docker image because Iceberg doesn't provide Iceberg Aliyun bundle jar ### Why are the changes needed? Fix: apache#6165 ### Does this PR introduce _any_ user-facing change? no ### How was this patch tested? test S3 OSS GCS ADLS Iceberg REST test in local
…operations (apache#6141) ### What changes were proposed in this pull request? 1. for resource path like `a/b`, add "a", "a/", "a/b" read permission for GCS connector 2. replace `storage.legacyBucketReader` with `storage.insightsCollectorService`, because `storage.legacyBucketReader` provides extra list permission for the bucket. ### Why are the changes needed? Fix: apache#6054 ### Does this PR introduce _any_ user-facing change? no ### How was this patch tested? Iceberg GCS IT and fileset GCS credential IT
…apache#6115) ### What changes were proposed in this pull request? Add document for chain authorization plugin ### Why are the changes needed? Fix: apache#6110 ### Does this PR introduce _any_ user-facing change? Just document. ### How was this patch tested? No need. --------- Co-authored-by: Xun <[email protected]> Co-authored-by: Qiming Teng <[email protected]>
…apache#6178) ### What changes were proposed in this pull request? Refactor schema commands in Gravitino CLI. ### Why are the changes needed? Fix: apache#6144 ### Does this PR introduce _any_ user-facing change? No ### How was this patch tested? Local test
### What changes were proposed in this pull request? Remove the unused protobuf dependency. ### Why are the changes needed? Since we already removed the KV storage support, so protobuf dependency is not required any more. Fix: apache#6184 ### Does this PR introduce _any_ user-facing change? No. ### How was this patch tested? Existing tests.
…e#6170) ### What changes were proposed in this pull request? Break up role commands in Gravitino command line class ### Why are the changes needed? For readability and maintainability. ### Fix: apache#6153 ### Does this PR introduce any user-facing change? None. ### How was this patch tested? Tested locally.
Hi @orenccl , I’ve finished updating the code. Please take a look at the PR again when you have time. |
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.
According to #6078, I think we also need to generate event in ModelEventDispatcher
and add unit test.
I didn’t see them included in this PR. Could you check?
@orenccl Thank you! This PR primarily aims to ensure that my design and implementation approach is correct. because this feature is split into 4 issue, If there are no errors, I will add test cases in #6075, WDYT |
In my opinion, I would prefer to handle #6075 and #6078 in the same PR. Currently, I am busy with my family as my father is in the hospital's intensive care unit (ICU). I can only perform some simple checks for now. Please reach out to others for help with the review. Thank you! |
@orenccl Thank you for sharing your thoughts . I appreciate you taking the time to provide feedback despite everything you're going through.Wishing your father a smooth and speedy recovery. I will add Take care!! |
+1 for handle #6075 and #6078 in the same PR. I hope your father is back to healthy soon, Good luck! |
…CLI (apache#6188) ### What changes were proposed in this pull request? Refactor ownership commands in Gravitino CLI. ### Why are the changes needed? Fix: apache#6177 ### Does this PR introduce _any_ user-facing change? No ### How was this patch tested? local test.
…pache#6190) ### What changes were proposed in this pull request? Refactor column commands CLI ### Why are the changes needed? Fix: apache#6149 ### Does this PR introduce _any_ user-facing change? None ### How was this patch tested? Tested locally
…pache#6193) ### What changes were proposed in this pull request? Refactor user commands and Base class in Gavitino CLI. ### Why are the changes needed? Fix: apache#6150 ### Does this PR introduce any user-facing change? No ### How was this patch tested? local test.
### What changes were proposed in this pull request? bump version to 0.9.0-incubating-snapshot ### Why are the changes needed? change project version after cut branch-0.8 ### Does this PR introduce _any_ user-facing change? no ### How was this patch tested? no, just change version
## What changes were proposed in this pull request? Add license and notice files. ### Why are the changes needed? As the release's content is different to that of Gravitino. Fix: apache#6194 ### Does this PR introduce _any_ user-facing change? No ### How was this patch tested? Tested locally.
### What changes were proposed in this pull request? Fix the wrong document information about revoke roles from role ### Why are the changes needed? Fix: apache#6069 ### Does this PR introduce _any_ user-facing change? No ### How was this patch tested? local test.
…utOfBoundsException when execute COMMENT COLUMN command (apache#6182) ### What changes were proposed in this pull request? Fix the exception of ArrayIndexOutOfBoundsException when handle error message of IllegalArgumentException ### Why are the changes needed? Fix: apache#5533 ### Does this PR introduce _any_ user-facing change? No ### How was this patch tested? IT
…pache#6137) ### What changes were proposed in this pull request? Update command usage and add usage tracker ### Why are the changes needed? So everything is up to date and we can see many many people look up the CLI docs. Fix: # N/A ### Does this PR introduce _any_ user-facing change? No. ### How was this patch tested? Tested locally.
### What changes were proposed in this pull request? This PR fixes the glossary docs. ### Why are the changes needed? The glossary is reordered for quick reference. ### Does this PR introduce _any_ user-facing change? No. ### How was this patch tested? N/A
Fix some error and add ModelEventDispatcher to Gravitino server.
…pache#6202) ### What changes were proposed in this pull request? Add Docker image details for 0.8.0 ### Why are the changes needed? Fix: apache#6200 ### Does this PR introduce _any_ user-facing change? Add doc. ### How was this patch tested? No need.
…oris table properties. (apache#6186) ### What changes were proposed in this pull request? Modify table properties SQL in alter table sentence to support setting table properties. ### Why are the changes needed? It's a bug. Fix: apache#5545 ### Does this PR introduce _any_ user-facing change? N/A. ### How was this patch tested? IT.
…ion in unique index (apache#6183) ### What changes were proposed in this pull request? add column not null limitation in unique index ### Why are the changes needed? mysql will automatically change the null column in unique index to not null, so we add the limitation at creation Fix: apache#5721 ### Does this PR introduce _any_ user-facing change? yes, limitation for mysql unique index is more strict ### How was this patch tested? tests added
…ngine type of MySQL catalog (apache#6209) ### What changes were proposed in this pull request? Add more details about the usage of engine type for MySQL catalog. ### Why are the changes needed? The value of engine type may be influenced by many factors like MySQL version, configurations and so on, we need to clarify it. Fix: apache#5100 ### Does this PR introduce _any_ user-facing change? N/A ### How was this patch tested? N/A
…tion DDL for paimon-catalog (apache#5818) ### What changes were proposed in this pull request? Support Catalog Operation DDL for paimon-catalog ### Why are the changes needed? Fix apache#5192 apache#5193 ### Does this PR introduce _any_ user-facing change? None ### How was this patch tested? org.apache.gravitino.flink.connector.paimon.TestPaimonPropertiesConverter org.apache.gravitino.flink.connector.integration.test.paimon.FlinkPaimonCatalogIT
### What changes were proposed in this pull request? The Gravitino command line class is a little large and could be broken up. ### Why are the changes needed? For readability and maintainability. Fix: apache#6139 ### Does this PR introduce _any_ user-facing change? None. ### How was this patch tested? Tested locally. --------- Co-authored-by: Shaofeng Shi <[email protected]>
apache#6191) ### What changes were proposed in this pull request? Refactor fileset commands in cli client ### Why are the changes needed? Fix: apache#6147 ### Does this PR introduce _any_ user-facing change? None ### How was this patch tested? Tested locally
…e#6192) ### What changes were proposed in this pull request? Reduce complexity in `GravitinoCommandLine` ### Why are the changes needed? For readability and maintainability. Fix: apache#6152 ### Does this PR introduce _any_ user-facing change? (Please list the user-facing changes introduced by your change, including None. ### How was this patch tested? Tested locally. --------- Co-authored-by: Justin Mclean <[email protected]>
@FANNG1 @shaofengshi I’ve finished updating the code. Please take a look at the PR again when you have time. |
throws NoSuchModelException, ModelVersionAliasesAlreadyExistException { | ||
// TODO: preEvent | ||
try { | ||
Model model = dispatcher.getModel(ident); |
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 this seems will do another call to get the model, is it necessary just for generating event?
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.
@jerryshao thank you, this Just for generating event, IMHO, I think the behavior of preEvent
is actually replaced by event
and failureEvent
, but other entities define preEvent
, so should we be consistent with them?
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.
Same question with Jerry, seems expensive to do an IO operation to get model to generate event.
core/src/main/java/org/apache/gravitino/listener/api/event/DropModelEvent.java
Outdated
Show resolved
Hide resolved
…t been refactored rename drop event and operation type.
// TODO: preEvent | ||
try { | ||
NameIdentifier[] models = dispatcher.listModels(namespace); | ||
eventBus.dispatchEvent(new ListModelEvent(PrincipalUtils.getCurrentUserName(), namespace)); |
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.
ListModelsEvent?
Map<String, String> properties) | ||
throws NoSuchSchemaException, ModelAlreadyExistsException, | ||
ModelVersionAliasesAlreadyExistException { | ||
return dispatcher.registerModel(ident, uri, aliases, comment, 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.
missing event here?
try { | ||
boolean isExists = dispatcher.deleteModelVersion(ident, version); | ||
eventBus.dispatchEvent( | ||
new DeleteModelVersionEvent(PrincipalUtils.getCurrentUserName(), ident, isExists)); |
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.
better put version
or alias
to DeleteModelVersionEvent
try { | ||
int[] versions = dispatcher.listModelVersions(ident); | ||
Model model = dispatcher.getModel(ident); | ||
ModelInfo modelInfo = new ModelInfo(model); |
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.
no need to place modelInfo
to the listModelVersionsEvent
throws NoSuchModelException, ModelVersionAliasesAlreadyExistException { | ||
// TODO: preEvent | ||
try { | ||
Model model = dispatcher.getModel(ident); |
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.
Same question with Jerry, seems expensive to do an IO operation to get model to generate event.
What changes were proposed in this pull request?
Support model event to Gravitino server. Add
list
,get
,create
anddelete
events to both model and model version.test case will add after EventDispatcher merged.
ModelInfo, ModelVersionInfo
Event
RegisterModelEvent
REGISTER_MODEL
registerModel
GetModelEvent
LOAD_MODEL
getModel
DeleteModelEvent
Delete_MODEL
deleteModel
ListModelEvent
LIST_MODEL
listModels
LinkModelVersionEvent
LINK_MODEL_VERSION
linkModelVersion
GetModelVersionEvent
GET_MODEL_VERSION
getModelVersion
DeleteModelVersionEvent
Delete_MODEL_VERSION
deleteModelVersion
ListModelVersionsEvent
LIST_MODEL_VERSIONS
listModelVersions
ModelEventDispatcher
Why are the changes needed?
Fix: #6078
Does this PR introduce any user-facing change?
no
How was this patch tested?
Model Event
testRegisterModelEvent
testGetModelEvent
testDeleteExistsModelEvent
testDeleteNotExistsModelEvent
testListModelEvent
Model Version Event
testLinkModelVersionEvent
testGetModelVersionEventViaVersion
testGetModelVersionEventViaAlias
testDeleteModelVersionEventViaVersion
testDeleteModelVersionEventViaAlias
testDeleteModelVersionEventViaVersionNotExists
testListModelVersionsEvent