This is an automated email from the ASF dual-hosted git repository.
github-bot pushed a change to branch
dependabot/github_actions/actions/checkout-5
in repository https://gitbox.apache.org/repos/asf/gravitino.git
omit c60ecec64a build(deps): bump actions/checkout from 3 to 5
add 6ec2f29423 [#5199] feat(client-python): add partition DTO serdes
(#8128)
add 6019ae10bb [#8285] Fix redundant operation parameter in LOG.warn call
(#8289)
add b6bdf8bc1f [#7788] fix(core): fix duplicate column when load table
(#7789)
add 1ff0802039 [#7744] improvement(core): allow nested SqlSession call
(#8242)
add be24d340a9 [#8157]Improvement: exception handling in RoleDetails for
Unknown Role (#8191)
add 0b1faba298 [#8206] fix: NPE by initializing lastRecordDropEventTime in
AsyncQueueListener (#8259)
add bce78de47b Fix incorrect name/comment assignment in
TestModelMetaService tests (#8296)
add 9bcdeead8d [MINOR](docs): Refine docs about StarRocks catalog. (#8295)
add 7aa79ded0a [#8284] fix(trino-connector): Correct misspelled package
name 'storedprocdure' (#8292)
add 83de7c61f9 [#7437] feat(client): Java/Python clients and CLI support
model version with multiple URIs (#8267)
add 474de4a098 [#7987] feat(core): Add Lance Storage for partition
statistics (#8228)
add 258b4c03b5 [#8219] feat(catalog): Throw exception when failed (#8222)
add 1f0ae44905 [#8112] feat(mcp): Support Gravitino MCP server docker
image (#8139)
add c67a81ba9e [#8101] Improvement(authz): Remove
AuthorizationMetadataPrivileges (#8104)
add 5d8fd86f20 [#8266] feat(authz): support list file Authorization (#8294)
add 6a0acc92c0 [#6791] improvement(authz): Add IT for metadata
authorization and use spark connector (#8100)
add 9e99701438 [#8318] improvement(docs): Add docs about list file
operation Authorization (#8319)
add 891035d773 [#8316] fix(iceberg): add namespace&view&table exists
endpoint for config response (#8315)
add 85bee783a9 [#8299] fix: validate null/blank prefix in
RandomNameUtils.genRandomName (#8317)
add 522748b436 [#7572] improvement(gvfs): add fileset cache in GVFS (#8254)
add 40855b357b [#8283] improvement(cli): Exit with error when both
--comment and --rename are missing in fileset update (#8324)
add eeb0db55e9 [#8198] Improvement(trino-connector): prevent NPE in
GravitinoConnector (#8246)
add 7bf378d974 [#8113] Improvement to only notify the user when a role
deletion succeeds (#8120)
add 4ceea55014 [#8301] Improvement: Improve ParseType.parseBasicType so it
accepts whitespace around numeric parameters (#8328)
add 4590dadbf7 [Improvement] Support multiple Accept header values in
VersioningFilter (#8133)
add 0f2a9fd378 [#8291] In OwnerDetails.java exit if entity type is null
(#8320)
add dc4cad8b41 [#8302] fix(cli): Fix potential NPE in ListTables (#8325)
add 4c20574bf3 [#8280]Improvement(GCSTokenProvider): handle empty uri path
(#8326)
add 9ee4099743 [#8287] feat(spark-common): support varchar/char partition
values in SparkPartitionUtils (#8338)
add be3f7a39a1 [#8346] fix(server): fix misleading log message in catalog
drop operation (#8351)
add 997feb6511 [#7273] docs: Add documents for statistics (#8229)
add d2d76c797e [#8307] fix(backend): fix Postgresql SQL syntax error
(#8355)
add f4aa8bddcf [#8349] Correct entity type in ModelMetaService.java error
message (#8352)
add 6d283f75df [#8341] improvement(config): ake sure ConfigBuilder
params with leading/trailing spaces are parsed correctly (#8359)
add 5fef3314e6 [#8306] Avoid rollback when autocommit is true in
ScriptRunner.java (#8332)
add 4d36ab191e [#8340][Improvement]Remove the redundant
content().validate() (#8365)
add 40b1253265 [Imp] Exit with correct error message in CreateCatalog.java
(#8364)
add e450f70fa1 [#8343] fix: correct invalid exception handling in
GroupDetails (#8362)
add d2c6136034 [#8281]Improvement(PolicyOperation): handle policy
exception parameters (#8334)
add 74051e5bea Added a simple getting started to help newcomers (#8321)
add c347a08d6c [#7438] subtask(UI): Web UI supports model version with
multiple URIs (#8331)
add 26068c1a55 feat: thrown a TrinoException if catalog-backend is missing
#1 (#8360)
add e1cc3e2bc6 [MINOR] docs(iceberg): polish Iceberg REST server document
(#8358)
add 14f59b05e5 [#7439] minor(doc): Update docs for usage of model version
with multiple URIs (#8329)
add 7b5c80ca3d [#8251][#8249] fix(fileset-catalog): Fix OOM problem for
fileset catalog (#8252)
add a2ef24a533 [#7370] fix(iceberag,paimon): Fix OOM problem for Iceberg
and Paimon catalog (#8271)
add 005bbd874c [#7395] fix(iceberg): add default catalog for dynamic
config proivder for IRC (#8327)
add 90d724350e Add super.validate() call in OAuth2TokenResponse.validate()
method (#8376)
add ffadbfcf26 [#8322] improvement: fix sort direction parsing bug and add
test case (#8366)
add 5c00ae7418 [#7908] improvement(python-client): Support passing custom
configuration for python GVFS client. (#8333)
add d184eee45e [#6403] improvement(trino-connector): Support SQL
UPDATE/DELETE with jdbc catalog (#8188)
add a4c8ccf101 [#4707] fix (client): Fix the Gravitino client-side version
verification to ignore patch version numbers (#8389)
add cf8c5ee7c6 [#8390] fix(api): remove premature String.format in
AuthorizationPluginException (#8396)
add c11384a838 [#8391] fix(docs): Fix error in documents about how to use
bundle jars for Azure Blob Storage and GCS (#8392)
add 6fdeaecf6e [#8367] improvement(core): Remove duplicate setOwner call
in TestOwnerMetaService.testDeleteMetadataObject (#8378)
add 7b196b5574 [MINOR] Add github action to auto-cherrypick to branch-1.0
(#8397)
add 9d88c4bdd0 build(deps): bump actions/checkout from 3 to 5
This update added new revisions after undoing existing revisions.
That is to say, some revisions that were in the old version of the
branch are not in the new version. This situation occurs
when a user --force pushes a change and generates a repository
containing something like this:
* -- * -- B -- O -- O -- O (c60ecec64a)
\
N -- N -- N
refs/heads/dependabot/github_actions/actions/checkout-5 (9d88c4bdd0)
You should already have received notification emails for all of the O
revisions, and so the following emails describe only the N revisions
from the common base, B.
Any revisions marked "omit" are not gone; other references still
refer to them. Any revisions marked "discard" are gone forever.
No new revisions were added by this update.
Summary of changes:
.github/workflows/auto-cherry-pick.yml | 20 +-
.../workflows/backend-integration-test-action.yml | 5 +
.github/workflows/build.yml | 5 +
.github/workflows/docker-image.yml | 4 +
GETTING_STARTED.md | 113 +++++
.../exceptions/AuthorizationPluginException.java | 2 +-
.../org/apache/gravitino/model/ModelCatalog.java | 18 +-
.../org/apache/gravitino/model/ModelVersion.java | 4 +-
.../ranger/integration/test/RangerHiveE2EIT.java | 32 ++
build.gradle.kts | 1 +
bundles/azure-bundle/build.gradle.kts | 7 +-
bundles/gcp-bundle/build.gradle.kts | 5 +-
.../gravitino/gcs/credential/GCSTokenProvider.java | 3 +
.../gcs/credential/TestGCSTokenProvider.java | 4 +-
.../lakehouse/iceberg/IcebergConstants.java | 1 +
.../utils/ClassLoaderResourceCleanerUtils.java | 303 ++++++++++++
.../fileset/SecureFilesetCatalogOperations.java | 3 +
.../iceberg/IcebergCatalogOperations.java | 2 +
.../lakehouse/paimon/PaimonCatalogOperations.java | 2 +
.../integration/test/ModelCatalogOperationsIT.java | 262 +++++++++++
.../hive/converter/HiveTableConverter.java | 9 +
.../hive/converter/TestHiveTableConverter.java | 212 +++++++++
.../apache/gravitino/hive/hms/ScriptRunner.java | 8 +-
.../org/apache/gravitino/cli/ErrorMessages.java | 3 +-
.../gravitino/cli/FilesetCommandHandler.java | 5 +
.../org/apache/gravitino/cli/GravitinoOptions.java | 4 +-
.../apache/gravitino/cli/ModelCommandHandler.java | 35 +-
.../java/org/apache/gravitino/cli/ParseType.java | 2 +-
.../apache/gravitino/cli/TestableCommandLine.java | 4 +-
.../gravitino/cli/commands/CreateCatalog.java | 2 +-
.../gravitino/cli/commands/GroupDetails.java | 4 +-
.../apache/gravitino/cli/commands/LinkModel.java | 16 +-
.../apache/gravitino/cli/commands/ListTables.java | 12 +-
.../gravitino/cli/commands/OwnerDetails.java | 4 +
.../apache/gravitino/cli/commands/RoleDetails.java | 6 +-
.../apache/gravitino/cli/TestFilesetCommands.java | 20 +
.../apache/gravitino/cli/TestModelCommands.java | 38 +-
.../org/apache/gravitino/cli/TestParseType.java | 15 +
.../org/apache/gravitino/cli/TestRoleCommands.java | 25 +
.../org/apache/gravitino/client/ErrorHandlers.java | 5 +
.../gravitino/client/GenericModelCatalog.java | 50 +-
.../gravitino/client/GenericModelVersion.java | 4 +-
.../gravitino/client/GravitinoClientBase.java | 2 +-
.../apache/gravitino/client/GravitinoVersion.java | 5 +-
.../gravitino/client/TestGenericModelCatalog.java | 248 +++++++++-
.../gravitino/client/TestGravitinoVersion.java | 10 +-
.../test/authorization/FilesetAuthorizationIT.java | 109 +++++
.../gravitino/api/model_version_change.py | 143 +++++-
.../gravitino/api/types/json_serdes/base.py | 3 +-
.../gravitino/client/generic_model_catalog.py | 91 +++-
.../gravitino/client/generic_model_version.py | 3 -
.../gravitino/client/gravitino_client_base.py | 2 +-
.../gravitino/client/gravitino_version.py | 2 +-
.../gravitino/dto/model_version_dto.py | 7 +-
.../rel/partitions/json_serdes}/__init__.py | 0
.../partitions/json_serdes/_helper}/__init__.py | 0
.../partitions/json_serdes/_helper/serdes_utils.py | 168 +++++++
.../json_serdes/partition_dto_serdes.py} | 15 +-
.../gravitino/dto/rel/partitions/partition_dto.py | 5 +-
.../dto/requests/model_version_link_request.py | 16 +-
.../dto/requests/model_version_update_request.py | 87 +++-
.../dto/responses/model_version_list_response.py | 2 +-
.../dto/responses/model_version_response.py | 2 +-
...n_response.py => model_version_uri_response.py} | 16 +-
clients/client-python/gravitino/filesystem/gvfs.py | 2 +
.../gravitino/filesystem/gvfs_base_operations.py | 65 ++-
.../gravitino/filesystem/gvfs_config.py | 5 +
clients/client-python/gravitino/utils/serdes.py | 1 +
.../tests/integration/test_gvfs_with_s3.py | 11 +-
.../tests/integration/test_model_catalog.py | 193 ++++++++
.../unittests/dto/rel/test_partition_dto_serdes.py | 483 ++++++++++++++++++++
.../tests/unittests/test_gravitino_version.py | 10 +-
.../tests/unittests/test_model_catalog_api.py | 79 +++-
.../tests/unittests/test_responses.py | 34 +-
.../filesystem/hadoop/BaseGVFSOperations.java | 73 +--
...CatalogCache.java => FilesetMetadataCache.java} | 58 ++-
.../hadoop/GravitinoVirtualFileSystem.java | 2 +-
.../GravitinoVirtualFileSystemConfiguration.java | 15 +
.../org/apache/gravitino/config/ConfigBuilder.java | 16 +-
.../org/apache/gravitino/dto/file/FileInfoDTO.java | 3 +-
.../dto/responses/OAuth2TokenResponse.java | 3 +
.../apache/gravitino/utils/RandomNameUtils.java | 4 +
.../gravitino/utils/TestRandomNameUtils.java | 26 +-
core/build.gradle.kts | 1 +
.../main/java/org/apache/gravitino/Configs.java | 5 +-
.../hook/AccessControlHookDispatcher.java | 2 +-
.../gravitino/hook/CatalogHookDispatcher.java | 1 +
.../gravitino/listener/AsyncQueueListener.java | 2 +-
.../org/apache/gravitino/meta/PolicyEntity.java | 1 -
.../apache/gravitino/stats/StatisticManager.java | 2 +-
.../storage/LancePartitionStatisticStorage.java | 429 +++++++++++++++++
.../LancePartitionStatisticStorageFactory.java | 11 +-
.../FilesetVersionPostgreSQLProvider.java | 4 +-
.../PolicyVersionPostgreSQLProvider.java | 4 +-
.../relational/service/GroupMetaService.java | 4 +-
.../relational/service/JobTemplateMetaService.java | 2 +-
.../relational/service/ModelMetaService.java | 4 +-
.../service/ModelVersionMetaService.java | 10 +-
.../relational/service/PolicyMetaService.java | 8 +-
.../relational/service/RoleMetaService.java | 8 +-
.../relational/service/TableColumnMetaService.java | 2 +-
.../relational/service/TableMetaService.java | 4 +-
.../storage/relational/service/TagMetaService.java | 12 +-
.../relational/service/UserMetaService.java | 4 +-
.../storage/relational/session/SqlSessions.java | 83 ++--
.../storage/relational/utils/SessionUtils.java | 135 ++----
.../test/java/org/apache/gravitino/TestConfig.java | 23 +
.../TestLancePartitionStatisticStorage.java | 243 ++++++++++
.../relational/service/TestModelMetaService.java | 6 +-
.../relational/service/TestOwnerMetaService.java | 4 +-
.../storage/relational/session/TestSqlSession.java | 6 +
dev/docker/build-docker.sh | 4 +-
dev/docker/{gravitino => mcp-server}/Dockerfile | 20 +-
.../mcp-server-dependency.sh} | 24 +-
.../docker/mcp-server/start-mcp-server.sh | 5 +-
docs/cli.md | 94 +++-
docs/docker-image-details.md | 16 +
docs/fileset-catalog-with-adls.md | 27 +-
docs/fileset-catalog-with-gcs.md | 22 +-
docs/gravitino-mcp-server.md | 4 +
docs/how-to-use-gvfs.md | 3 +-
docs/iceberg-rest-service.md | 238 +++++-----
docs/index.md | 9 +
docs/manage-model-metadata-using-gravitino.md | 280 +++++++++++-
docs/manage-relational-metadata-using-gravitino.md | 8 +
docs/manage-statistics-in-gravitino.md | 299 ++++++++++++
docs/model-catalog.md | 8 +-
docs/open-api/openapi.yaml | 12 +
docs/open-api/statistics.yaml | 508 +++++++++++++++++++++
docs/security/access-control.md | 1 +
docs/trino-connector/catalog-hive.md | 8 +
docs/trino-connector/catalog-iceberg.md | 10 +-
docs/trino-connector/catalog-mysql.md | 21 +
docs/trino-connector/catalog-postgresql.md | 21 +
docs/trino-connector/sql-support.md | 2 +
gradle/libs.versions.toml | 2 +
.../provider/DynamicIcebergConfigProvider.java | 22 +-
.../service/rest/IcebergConfigOperations.java | 3 +
.../AuthorizationMetadataPrivileges.java | 49 --
.../authorization/annotations/TestAnnotations.java | 23 -
.../gravitino/server/web/VersioningFilter.java | 2 +-
.../server/web/rest/CatalogOperations.java | 3 +-
.../server/web/rest/FilesetOperations.java | 12 +-
.../server/web/rest/PolicyOperations.java | 2 +-
.../gravitino/server/web/TestVersioningFilter.java | 42 ++
.../spark/connector/utils/SparkPartitionUtils.java | 4 +
.../test/authorization/SparkAuthorizationIT.java | 283 ++++++++++++
.../connector/utils/TestSparkPartitionUtils.java | 19 +-
.../test/authorization/SparkAuthorizationIT33.java | 8 +-
.../test/authorization/SparkAuthorizationIT34.java | 8 +-
.../test/authorization/SparkAuthorizationIT35.java | 8 +-
.../testsets/jdbc-mysql/00012_update_table.sql | 22 +
.../testsets/jdbc-mysql/00012_update_table.txt | 22 +
.../testsets/jdbc-mysql/00013_delete_table.sql | 26 ++
.../testsets/jdbc-mysql/00013_delete_table.txt | 28 ++
.../jdbc-postgresql/00008_update_table.sql | 22 +
.../jdbc-postgresql/00008_update_table.txt | 22 +
.../jdbc-postgresql/00009_delete_table.sql | 26 ++
.../jdbc-postgresql/00009_delete_table.txt | 28 ++
.../trino/connector/GravitinoConnector.java | 3 +-
.../trino/connector/GravitinoConnectorFactory.java | 2 +-
.../trino/connector/GravitinoMetadata.java | 62 ++-
.../connector/catalog/iceberg/ExpressionUtil.java | 2 +-
.../iceberg/IcebergCatalogPropertyConverter.java | 4 +
.../connector/system/GravitinoSystemConnector.java | 2 +-
.../AlterCatalogStoredProcedure.java | 2 +-
.../CreateCatalogStoredProcedure.java | 2 +-
.../DropCatalogStoredProcedure.java | 2 +-
.../GravitinoStoredProcedure.java | 2 +-
.../GravitinoStoredProcedureFactory.java | 2 +-
.../TestGravitinoConnectorNullChecks.java | 56 +++
.../catalog/iceberg/TestExpressionUtil.java | 5 +
.../metalake/rightContent/LinkVersionDialog.js | 193 ++++++--
.../tabsContent/detailsView/DetailsView.js | 51 +++
web/web/src/components/DetailsDrawer.js | 51 +++
web/web/src/lib/utils/index.js | 33 ++
176 files changed, 6435 insertions(+), 687 deletions(-)
create mode 100644 GETTING_STARTED.md
create mode 100644
catalogs/catalog-common/src/main/java/org/apache/gravitino/utils/ClassLoaderResourceCleanerUtils.java
create mode 100644
catalogs/hive-metastore-common/src/test/java/org/apache/gravitino/hive/converter/TestHiveTableConverter.java
copy clients/client-python/gravitino/{api =>
dto/rel/partitions/json_serdes}/__init__.py (100%)
copy clients/client-python/gravitino/{api =>
dto/rel/partitions/json_serdes/_helper}/__init__.py (100%)
create mode 100644
clients/client-python/gravitino/dto/rel/partitions/json_serdes/_helper/serdes_utils.py
copy clients/client-python/gravitino/{api/types/json_serdes/__init__.py =>
dto/rel/partitions/json_serdes/partition_dto_serdes.py} (62%)
copy clients/client-python/gravitino/dto/responses/{file_location_response.py
=> model_version_uri_response.py} (71%)
create mode 100644
clients/client-python/tests/unittests/dto/rel/test_partition_dto_serdes.py
rename
clients/filesystem-hadoop3/src/main/java/org/apache/gravitino/filesystem/hadoop/{FilesetCatalogCache.java
=> FilesetMetadataCache.java} (60%)
copy
api/src/test/java/org/apache/gravitino/rel/expressions/TestFunctionExpression.java
=> common/src/test/java/org/apache/gravitino/utils/TestRandomNameUtils.java
(58%)
create mode 100644
core/src/main/java/org/apache/gravitino/stats/storage/LancePartitionStatisticStorage.java
copy web/web/postcss.config.js =>
core/src/main/java/org/apache/gravitino/stats/storage/LancePartitionStatisticStorageFactory.java
(72%)
create mode 100644
core/src/test/java/org/apache/gravitino/stats/storage/TestLancePartitionStatisticStorage.java
copy dev/docker/{gravitino => mcp-server}/Dockerfile (75%)
copy dev/docker/{hive/check-status.sh => mcp-server/mcp-server-dependency.sh}
(67%)
copy core/src/test/resources/common.sh =>
dev/docker/mcp-server/start-mcp-server.sh (94%)
mode change 100755 => 100644
create mode 100644 docs/manage-statistics-in-gravitino.md
create mode 100644 docs/open-api/statistics.yaml
delete mode 100644
server-common/src/main/java/org/apache/gravitino/server/authorization/annotations/AuthorizationMetadataPrivileges.java
create mode 100644
spark-connector/spark-common/src/test/java/org/apache/gravitino/spark/connector/integration/test/authorization/SparkAuthorizationIT.java
copy
bundles/aliyun/src/main/java/org/apache/gravitino/oss/credential/policy/Effect.java
=>
spark-connector/v3.3/spark/src/test/java/org/apache/gravitino/spark/connector/integration/test/authorization/SparkAuthorizationIT33.java
(84%)
copy
bundles/aliyun/src/main/java/org/apache/gravitino/oss/credential/policy/Effect.java
=>
spark-connector/v3.4/spark/src/test/java/org/apache/gravitino/spark/connector/integration/test/authorization/SparkAuthorizationIT34.java
(84%)
copy
bundles/aliyun/src/main/java/org/apache/gravitino/oss/credential/policy/Effect.java
=>
spark-connector/v3.5/spark/src/test/java/org/apache/gravitino/spark/connector/integration/test/authorization/SparkAuthorizationIT35.java
(84%)
create mode 100644
trino-connector/integration-test/src/test/resources/trino-ci-testset/testsets/jdbc-mysql/00012_update_table.sql
create mode 100644
trino-connector/integration-test/src/test/resources/trino-ci-testset/testsets/jdbc-mysql/00012_update_table.txt
create mode 100644
trino-connector/integration-test/src/test/resources/trino-ci-testset/testsets/jdbc-mysql/00013_delete_table.sql
create mode 100644
trino-connector/integration-test/src/test/resources/trino-ci-testset/testsets/jdbc-mysql/00013_delete_table.txt
create mode 100644
trino-connector/integration-test/src/test/resources/trino-ci-testset/testsets/jdbc-postgresql/00008_update_table.sql
create mode 100644
trino-connector/integration-test/src/test/resources/trino-ci-testset/testsets/jdbc-postgresql/00008_update_table.txt
create mode 100644
trino-connector/integration-test/src/test/resources/trino-ci-testset/testsets/jdbc-postgresql/00009_delete_table.sql
create mode 100644
trino-connector/integration-test/src/test/resources/trino-ci-testset/testsets/jdbc-postgresql/00009_delete_table.txt
rename
trino-connector/trino-connector/src/main/java/org/apache/gravitino/trino/connector/system/{storedprocdure
=> storedprocedure}/AlterCatalogStoredProcedure.java (98%)
rename
trino-connector/trino-connector/src/main/java/org/apache/gravitino/trino/connector/system/{storedprocdure
=> storedprocedure}/CreateCatalogStoredProcedure.java (98%)
rename
trino-connector/trino-connector/src/main/java/org/apache/gravitino/trino/connector/system/{storedprocdure
=> storedprocedure}/DropCatalogStoredProcedure.java (98%)
rename
trino-connector/trino-connector/src/main/java/org/apache/gravitino/trino/connector/system/{storedprocdure
=> storedprocedure}/GravitinoStoredProcedure.java (94%)
rename
trino-connector/trino-connector/src/main/java/org/apache/gravitino/trino/connector/system/{storedprocdure
=> storedprocedure}/GravitinoStoredProcedureFactory.java (97%)
create mode 100644
trino-connector/trino-connector/src/test/java/org/apache/gravitino/trino/connector/TestGravitinoConnectorNullChecks.java