From 8249587542770a281b3a312c1bcbbe5ecf2a192a Mon Sep 17 00:00:00 2001
From: daizhenyu <1449308021@qq.com>
Date: Mon, 29 Jan 2024 10:34:09 +0800
Subject: [PATCH] =?UTF-8?q?=E6=95=B0=E6=8D=AE=E5=BA=93=E7=A6=81=E5=86=99?=
=?UTF-8?q?=E5=8A=A8=E6=80=81=E9=85=8D=E7=BD=AE?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
Signed-off-by: daizhenyu <1449308021@qq.com>
---
.../database-config-service/pom.xml | 50 +++++++
.../dynamicconfig/DatabaseConfigListener.java | 139 ++++++++++++++++++
.../dynamicconfig/DatabaseConfigService.java | 45 ++++++
....sermant.core.plugin.service.PluginService | 16 ++
.../DatabaseWriteProhibitionConfig.java | 116 ++++++++++++---
.../DatabaseWriteProhibitionManager.java | 63 ++++++--
.../DatabaseWriteProhibitionManagerTest.java | 122 ++++++++++++---
.../mongodb/constant/MethodParamTypeName.java | 101 +++++++++++++
.../ExecuteCommandInterceptor.java | 2 +-
.../ExecuteRetryableCommandInterceptor.java | 2 +-
.../MixedBulkWriteOperationInterceptor.java | 2 +-
.../utils/MongoDbEnhancementHelper.java | 61 ++++----
.../ExecuteCommandInterceptorTest.java | 10 +-
...xecuteRetryableCommandInterceptorTest.java | 9 +-
...ixedBulkWriteOperationInterceptorTest.java | 8 +-
.../pom.xml | 3 +
16 files changed, 649 insertions(+), 100 deletions(-)
create mode 100644 sermant-plugins/sermant-database-write-prohibition/database-config-service/pom.xml
create mode 100644 sermant-plugins/sermant-database-write-prohibition/database-config-service/src/main/java/com/huaweicloud/sermant/database/dynamicconfig/DatabaseConfigListener.java
create mode 100644 sermant-plugins/sermant-database-write-prohibition/database-config-service/src/main/java/com/huaweicloud/sermant/database/dynamicconfig/DatabaseConfigService.java
create mode 100644 sermant-plugins/sermant-database-write-prohibition/database-config-service/src/main/resources/META-INF/services/com.huaweicloud.sermant.core.plugin.service.PluginService
create mode 100644 sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/constant/MethodParamTypeName.java
diff --git a/sermant-plugins/sermant-database-write-prohibition/database-config-service/pom.xml b/sermant-plugins/sermant-database-write-prohibition/database-config-service/pom.xml
new file mode 100644
index 0000000000..e432e09996
--- /dev/null
+++ b/sermant-plugins/sermant-database-write-prohibition/database-config-service/pom.xml
@@ -0,0 +1,50 @@
+
+
+
+ sermant-database-write-prohibition
+ com.huaweicloud.sermant
+ 1.0.0
+
+ 4.0.0
+
+ database-config-service
+
+
+ 8
+ 8
+ false
+ service
+ 2.0
+
+
+
+
+ com.huaweicloud.sermant
+ sermant-agentcore-core
+ provided
+
+
+ org.yaml
+ snakeyaml
+ ${snakeyaml.version}
+
+
+ com.huaweicloud.sermant
+ database-controller
+ ${project.version}
+ provided
+
+
+
+
+
+
+ org.apache.maven.plugins
+ maven-shade-plugin
+
+
+
+
+
\ No newline at end of file
diff --git a/sermant-plugins/sermant-database-write-prohibition/database-config-service/src/main/java/com/huaweicloud/sermant/database/dynamicconfig/DatabaseConfigListener.java b/sermant-plugins/sermant-database-write-prohibition/database-config-service/src/main/java/com/huaweicloud/sermant/database/dynamicconfig/DatabaseConfigListener.java
new file mode 100644
index 0000000000..dc3c00a6d6
--- /dev/null
+++ b/sermant-plugins/sermant-database-write-prohibition/database-config-service/src/main/java/com/huaweicloud/sermant/database/dynamicconfig/DatabaseConfigListener.java
@@ -0,0 +1,139 @@
+/*
+ * Copyright (C) 2024-2024 Huawei Technologies Co., Ltd. All rights reserved.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package com.huaweicloud.sermant.database.dynamicconfig;
+
+import com.huaweicloud.sermant.core.common.LoggerFactory;
+import com.huaweicloud.sermant.core.config.ConfigManager;
+import com.huaweicloud.sermant.core.plugin.config.ServiceMeta;
+import com.huaweicloud.sermant.core.service.dynamicconfig.common.DynamicConfigEvent;
+import com.huaweicloud.sermant.core.service.dynamicconfig.common.DynamicConfigEventType;
+import com.huaweicloud.sermant.core.service.dynamicconfig.common.DynamicConfigListener;
+import com.huaweicloud.sermant.database.config.DatabaseWriteProhibitionConfig;
+import com.huaweicloud.sermant.database.config.DatabaseWriteProhibitionManager;
+
+import org.yaml.snakeyaml.DumperOptions;
+import org.yaml.snakeyaml.Yaml;
+import org.yaml.snakeyaml.error.YAMLException;
+import org.yaml.snakeyaml.representer.Representer;
+
+import java.util.Locale;
+import java.util.logging.Logger;
+
+/**
+ * 数据层中间件禁写插件的动态配置监听器
+ *
+ * @author daizhenyu
+ * @since 2024-01-26
+ */
+public class DatabaseConfigListener implements DynamicConfigListener {
+ /**
+ * 全局配置的Key
+ */
+ public static final String GLOBAL_CONFIG_KEY = "sermant.database.write.globalConfig";
+
+ /**
+ * 局部配置的key的前缀
+ */
+ public static final String LOCAL_CONFIG_KEY_PREFIX = "sermant.database.write.";
+
+ private static final Logger LOGGER = LoggerFactory.getLogger();
+
+ private final Yaml yaml;
+
+ /**
+ * 监听器构造方法
+ */
+ public DatabaseConfigListener() {
+ Representer representer = new Representer(new DumperOptions());
+ representer.getPropertyUtils().setSkipMissingProperties(true);
+ this.yaml = new Yaml(representer);
+ }
+
+ @Override
+ public void process(DynamicConfigEvent event) {
+ try {
+ if (event.getEventType() == DynamicConfigEventType.INIT) {
+ processInitEvent(event);
+ return;
+ }
+
+ if (event.getEventType() == DynamicConfigEventType.DELETE) {
+ processDeleteEvent(event);
+ return;
+ }
+ processCreateOrUpdateEvent(event);
+ } catch (YAMLException e) {
+ LOGGER.severe(String.format(Locale.ROOT, "Fail to convert dynamic database-write-prohibition config, %s",
+ e.getMessage()));
+ }
+ }
+
+ /**
+ * 处理创建或者更新配置的事件
+ *
+ * @param event 事件
+ */
+ private void processCreateOrUpdateEvent(DynamicConfigEvent event) {
+ if (GLOBAL_CONFIG_KEY.equals(event.getKey())) {
+ DatabaseWriteProhibitionManager
+ .updateGlobalConfig(yaml.loadAs(event.getContent(), DatabaseWriteProhibitionConfig.class));
+ }
+ if ((LOCAL_CONFIG_KEY_PREFIX + ConfigManager.getConfig(ServiceMeta.class).getService()).equals(
+ event.getKey())) {
+ DatabaseWriteProhibitionManager
+ .updateLocalConfig(yaml.loadAs(event.getContent(), DatabaseWriteProhibitionConfig.class));
+ }
+ LOGGER.info(String.format(Locale.ROOT, "Update database-write-prohibition config, current config: %s",
+ DatabaseWriteProhibitionManager.printConfig()));
+ }
+
+ /**
+ * 处理删除配置的事件
+ *
+ * @param event 事件
+ */
+ private void processDeleteEvent(DynamicConfigEvent event) {
+ if (GLOBAL_CONFIG_KEY.equals(event.getKey())) {
+ DatabaseWriteProhibitionManager.updateGlobalConfig(new DatabaseWriteProhibitionConfig());
+ }
+ if ((LOCAL_CONFIG_KEY_PREFIX + ConfigManager.getConfig(ServiceMeta.class).getService()).equals(
+ event.getKey())) {
+ DatabaseWriteProhibitionManager.updateLocalConfig(new DatabaseWriteProhibitionConfig());
+ }
+ LOGGER.info(String.format(Locale.ROOT, "Delete database-write-prohibition config, current config: %s",
+ DatabaseWriteProhibitionManager.printConfig()));
+ }
+
+ /**
+ * 处理启动时初始化配置的事件
+ *
+ * @param event 事件
+ */
+ private void processInitEvent(DynamicConfigEvent event) {
+ if (GLOBAL_CONFIG_KEY.equals(event.getKey())) {
+ DatabaseWriteProhibitionManager.updateGlobalConfig(
+ yaml.loadAs(event.getContent(), DatabaseWriteProhibitionConfig.class));
+ }
+ if ((LOCAL_CONFIG_KEY_PREFIX + ConfigManager.getConfig(ServiceMeta.class).getService()).equals(
+ event.getKey())) {
+ DatabaseWriteProhibitionManager.updateLocalConfig(
+ yaml.loadAs(event.getContent(), DatabaseWriteProhibitionConfig.class));
+ }
+ LOGGER.info(String.format(Locale.ROOT, "Init database-write-prohibition config, current config: %s",
+ DatabaseWriteProhibitionManager.printConfig()));
+ }
+}
diff --git a/sermant-plugins/sermant-database-write-prohibition/database-config-service/src/main/java/com/huaweicloud/sermant/database/dynamicconfig/DatabaseConfigService.java b/sermant-plugins/sermant-database-write-prohibition/database-config-service/src/main/java/com/huaweicloud/sermant/database/dynamicconfig/DatabaseConfigService.java
new file mode 100644
index 0000000000..8d6222d410
--- /dev/null
+++ b/sermant-plugins/sermant-database-write-prohibition/database-config-service/src/main/java/com/huaweicloud/sermant/database/dynamicconfig/DatabaseConfigService.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright (C) 2024-2024 Huawei Technologies Co., Ltd. All rights reserved.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package com.huaweicloud.sermant.database.dynamicconfig;
+
+import com.huaweicloud.sermant.core.common.LoggerFactory;
+import com.huaweicloud.sermant.core.config.ConfigManager;
+import com.huaweicloud.sermant.core.plugin.config.ServiceMeta;
+import com.huaweicloud.sermant.core.plugin.service.PluginService;
+import com.huaweicloud.sermant.core.plugin.subscribe.CommonGroupConfigSubscriber;
+import com.huaweicloud.sermant.core.plugin.subscribe.ConfigSubscriber;
+
+import java.util.logging.Logger;
+
+/**
+ * 数据层中间件禁写的动态配置服务
+ *
+ * @author daizhenyu
+ * @since 2024-01-27
+ */
+public class DatabaseConfigService implements PluginService {
+ private static final Logger LOGGER = LoggerFactory.getLogger();
+
+ @Override
+ public void start() {
+ ConfigSubscriber subscriber = new CommonGroupConfigSubscriber(
+ ConfigManager.getConfig(ServiceMeta.class).getService(),
+ new DatabaseConfigListener(), "database-write-prohibition");
+ subscriber.subscribe();
+ LOGGER.info("Success to subscribe database-write-prohibition config");
+ }
+}
diff --git a/sermant-plugins/sermant-database-write-prohibition/database-config-service/src/main/resources/META-INF/services/com.huaweicloud.sermant.core.plugin.service.PluginService b/sermant-plugins/sermant-database-write-prohibition/database-config-service/src/main/resources/META-INF/services/com.huaweicloud.sermant.core.plugin.service.PluginService
new file mode 100644
index 0000000000..be9705c32c
--- /dev/null
+++ b/sermant-plugins/sermant-database-write-prohibition/database-config-service/src/main/resources/META-INF/services/com.huaweicloud.sermant.core.plugin.service.PluginService
@@ -0,0 +1,16 @@
+#
+# Copyright (C) 2024-2024 Huawei Technologies Co., Ltd. All rights reserved.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+com.huaweicloud.sermant.database.dynamicconfig.DatabaseConfigService
\ No newline at end of file
diff --git a/sermant-plugins/sermant-database-write-prohibition/database-controller/src/main/java/com/huaweicloud/sermant/database/config/DatabaseWriteProhibitionConfig.java b/sermant-plugins/sermant-database-write-prohibition/database-controller/src/main/java/com/huaweicloud/sermant/database/config/DatabaseWriteProhibitionConfig.java
index c59d7d4cda..8067512772 100644
--- a/sermant-plugins/sermant-database-write-prohibition/database-controller/src/main/java/com/huaweicloud/sermant/database/config/DatabaseWriteProhibitionConfig.java
+++ b/sermant-plugins/sermant-database-write-prohibition/database-controller/src/main/java/com/huaweicloud/sermant/database/config/DatabaseWriteProhibitionConfig.java
@@ -27,38 +27,118 @@
**/
public class DatabaseWriteProhibitionConfig {
/**
- * 是否开启禁写
+ * MongoDb是否开启禁写
*/
- private boolean enableDatabaseWriteProhibition = false;
+ private boolean enableMongoDbWriteProhibition = false;
/**
- * 需要禁写的数据库
+ * MongoDb需要禁写的数据库
*/
- private Set databases = new HashSet<>();
+ private Set mongoDbDatabases = new HashSet<>();
- public boolean isEnableDatabaseWriteProhibition() {
- return enableDatabaseWriteProhibition;
- }
+ /**
+ * Mysql是否开启禁写
+ */
+ private boolean enableMysqlWriteProhibition = false;
- public void setEnableDatabaseWriteProhibition(boolean enableDatabaseWriteProhibition) {
- this.enableDatabaseWriteProhibition = enableDatabaseWriteProhibition;
- }
+ /**
+ * Mysql需要禁写的数据库
+ */
+ private Set mysqlDatabases = new HashSet<>();
+
+ /**
+ * PostgreSQL是否开启禁写
+ */
+ private boolean enablePostgreSqlWriteProhibition = false;
+
+ /**
+ * PostgreSQL需要禁写的数据库
+ */
+ private Set postgreSqlDatabases = new HashSet<>();
+
+ /**
+ * OpenGauss是否开启禁写
+ */
+ private boolean enableOpenGaussWriteProhibition = false;
/**
- * 获取禁消费的数据库列表
- *
- * @return 数据库列表
+ * OpenGauss需要禁写的数据库
*/
- public Set getDatabases() {
- return databases;
+ private Set openGaussDatabases = new HashSet<>();
+
+ public boolean isEnableMongoDbWriteProhibition() {
+ return enableMongoDbWriteProhibition;
+ }
+
+ public void setEnableMongoDbWriteProhibition(boolean enableMongoDbWriteProhibition) {
+ this.enableMongoDbWriteProhibition = enableMongoDbWriteProhibition;
+ }
+
+ public Set getMongoDbDatabases() {
+ return mongoDbDatabases;
+ }
+
+ public void setMongoDbDatabases(Set mongoDbDatabases) {
+ this.mongoDbDatabases = mongoDbDatabases;
+ }
+
+ public boolean isEnableMysqlWriteProhibition() {
+ return enableMysqlWriteProhibition;
+ }
+
+ public void setEnableMysqlWriteProhibition(boolean enableMysqlWriteProhibition) {
+ this.enableMysqlWriteProhibition = enableMysqlWriteProhibition;
+ }
+
+ public Set getMysqlDatabases() {
+ return mysqlDatabases;
+ }
+
+ public void setMysqlDatabases(Set mysqlDatabases) {
+ this.mysqlDatabases = mysqlDatabases;
+ }
+
+ public boolean isEnablePostgreSqlWriteProhibition() {
+ return enablePostgreSqlWriteProhibition;
+ }
+
+ public void setEnablePostgreSqlWriteProhibition(boolean enablePostgreSqlWriteProhibition) {
+ this.enablePostgreSqlWriteProhibition = enablePostgreSqlWriteProhibition;
+ }
+
+ public Set getPostgreSqlDatabases() {
+ return postgreSqlDatabases;
+ }
+
+ public void setPostgreSqlDatabases(Set postgreSqlDatabases) {
+ this.postgreSqlDatabases = postgreSqlDatabases;
+ }
+
+ public boolean isEnableOpenGaussWriteProhibition() {
+ return enableOpenGaussWriteProhibition;
+ }
+
+ public void setEnableOpenGaussWriteProhibition(boolean enableOpenGaussWriteProhibition) {
+ this.enableOpenGaussWriteProhibition = enableOpenGaussWriteProhibition;
+ }
+
+ public Set getOpenGaussDatabases() {
+ return openGaussDatabases;
}
- public void setDatabases(Set databases) {
- this.databases = databases;
+ public void setOpenGaussDatabases(Set openGaussDatabases) {
+ this.openGaussDatabases = openGaussDatabases;
}
@Override
public String toString() {
- return "enableDatabaseWriteProhibition=" + enableDatabaseWriteProhibition + ", databases=" + databases;
+ return "enableMongoDbWriteProhibition=" + enableMongoDbWriteProhibition
+ + ", mongoDbDatabases=" + mongoDbDatabases + "; "
+ + "enableMysqlWriteProhibition=" + enableMysqlWriteProhibition
+ + ", mysqlDatabases=" + mysqlDatabases + "; "
+ + "enablePostgreSqlWriteProhibition=" + enablePostgreSqlWriteProhibition
+ + ", postgreSqlDatabases=" + postgreSqlDatabases + ";"
+ + " enableOpenGaussWriteProhibition=" + enableOpenGaussWriteProhibition
+ + ", openGaussDatabases=" + openGaussDatabases;
}
}
diff --git a/sermant-plugins/sermant-database-write-prohibition/database-controller/src/main/java/com/huaweicloud/sermant/database/config/DatabaseWriteProhibitionManager.java b/sermant-plugins/sermant-database-write-prohibition/database-controller/src/main/java/com/huaweicloud/sermant/database/config/DatabaseWriteProhibitionManager.java
index 8ab9f9963a..57c3e0faa1 100644
--- a/sermant-plugins/sermant-database-write-prohibition/database-controller/src/main/java/com/huaweicloud/sermant/database/config/DatabaseWriteProhibitionManager.java
+++ b/sermant-plugins/sermant-database-write-prohibition/database-controller/src/main/java/com/huaweicloud/sermant/database/config/DatabaseWriteProhibitionManager.java
@@ -35,16 +35,61 @@ private DatabaseWriteProhibitionManager() {
}
/**
- * 获取要禁止消费的数据库集合
+ * 获取MongoDb禁止写入的数据库集合
*
- * @return 禁止消费的数据库集合
+ * @return MongoDb禁止写入的数据库集合
*/
- public static Set getProhibitionDatabases() {
- if (globalConfig.isEnableDatabaseWriteProhibition()) {
- return globalConfig.getDatabases();
+ public static Set getMongoDbProhibitionDatabases() {
+ if (globalConfig.isEnableMongoDbWriteProhibition()) {
+ return globalConfig.getMongoDbDatabases();
}
- if (localConfig.isEnableDatabaseWriteProhibition()) {
- return localConfig.getDatabases();
+ if (localConfig.isEnableMongoDbWriteProhibition()) {
+ return localConfig.getMongoDbDatabases();
+ }
+ return Collections.EMPTY_SET;
+ }
+
+ /**
+ * 获取Mysql要禁止写入的数据库集合
+ *
+ * @return Mysql禁止写入的数据库集合
+ */
+ public static Set getMysqlProhibitionDatabases() {
+ if (globalConfig.isEnableMysqlWriteProhibition()) {
+ return globalConfig.getMysqlDatabases();
+ }
+ if (localConfig.isEnableMysqlWriteProhibition()) {
+ return localConfig.getMysqlDatabases();
+ }
+ return Collections.EMPTY_SET;
+ }
+
+ /**
+ * 获取PostgreSQL要禁止写入的数据库集合
+ *
+ * @return PostgreSQL禁止写入的数据库集合
+ */
+ public static Set getPostgreSqlProhibitionDatabases() {
+ if (globalConfig.isEnablePostgreSqlWriteProhibition()) {
+ return globalConfig.getPostgreSqlDatabases();
+ }
+ if (localConfig.isEnablePostgreSqlWriteProhibition()) {
+ return localConfig.getPostgreSqlDatabases();
+ }
+ return Collections.EMPTY_SET;
+ }
+
+ /**
+ * 获取OpenGauss要禁止写入的数据库集合
+ *
+ * @return OpenGauss禁止写入的数据库集合
+ */
+ public static Set getOpenGaussProhibitionDatabases() {
+ if (globalConfig.isEnableOpenGaussWriteProhibition()) {
+ return globalConfig.getOpenGaussDatabases();
+ }
+ if (localConfig.isEnableOpenGaussWriteProhibition()) {
+ return localConfig.getOpenGaussDatabases();
}
return Collections.EMPTY_SET;
}
@@ -70,7 +115,7 @@ public static DatabaseWriteProhibitionConfig getLocalConfig() {
/**
* 更新全局配置
*
- * @param config 禁止消费配置
+ * @param config 禁止写数据库配置
*/
public static void updateGlobalConfig(DatabaseWriteProhibitionConfig config) {
if (config == null) {
@@ -83,7 +128,7 @@ public static void updateGlobalConfig(DatabaseWriteProhibitionConfig config) {
/**
* 更新局部配置
*
- * @param config 禁止消费配置
+ * @param config 禁止写数据库配置
*/
public static void updateLocalConfig(DatabaseWriteProhibitionConfig config) {
if (config == null) {
diff --git a/sermant-plugins/sermant-database-write-prohibition/database-controller/src/test/java/com/huaweicloud/sermant/database/config/DatabaseWriteProhibitionManagerTest.java b/sermant-plugins/sermant-database-write-prohibition/database-controller/src/test/java/com/huaweicloud/sermant/database/config/DatabaseWriteProhibitionManagerTest.java
index f2fe074d29..bb91fab330 100644
--- a/sermant-plugins/sermant-database-write-prohibition/database-controller/src/test/java/com/huaweicloud/sermant/database/config/DatabaseWriteProhibitionManagerTest.java
+++ b/sermant-plugins/sermant-database-write-prohibition/database-controller/src/test/java/com/huaweicloud/sermant/database/config/DatabaseWriteProhibitionManagerTest.java
@@ -36,13 +36,31 @@ public class DatabaseWriteProhibitionManagerTest {
@BeforeClass
public static void setUp() {
globalConfig = new DatabaseWriteProhibitionConfig();
- HashSet globalDatabases = new HashSet<>();
- globalDatabases.add("database-test-1");
- globalConfig.setDatabases(globalDatabases);
+ HashSet globalMongoDbDatabases = new HashSet<>();
+ globalMongoDbDatabases.add("mongodb-test-1");
+ globalConfig.setMongoDbDatabases(globalMongoDbDatabases);
+ HashSet globalMysqlDatabases = new HashSet<>();
+ globalMysqlDatabases.add("mysql-test-1");
+ globalConfig.setMysqlDatabases(globalMysqlDatabases);
+ HashSet globalPostgreSqlDatabases = new HashSet<>();
+ globalPostgreSqlDatabases.add("postgresql-test-1");
+ globalConfig.setPostgreSqlDatabases(globalPostgreSqlDatabases);
+ HashSet globalOpenGaussDatabases = new HashSet<>();
+ globalOpenGaussDatabases.add("mongodb-test-1");
+ globalConfig.setOpenGaussDatabases(globalOpenGaussDatabases);
localConfig = new DatabaseWriteProhibitionConfig();
- HashSet localDatabases = new HashSet<>();
- localDatabases.add("database-test-2");
- localConfig.setDatabases(localDatabases);
+ HashSet localMongoDbDatabases = new HashSet<>();
+ localMongoDbDatabases.add("mongodb-test-1");
+ localConfig.setMongoDbDatabases(localMongoDbDatabases);
+ HashSet localMysqlDatabases = new HashSet<>();
+ localMysqlDatabases.add("mysql-test-1");
+ globalConfig.setMysqlDatabases(localMysqlDatabases);
+ HashSet localPostgreSqlDatabases = new HashSet<>();
+ localPostgreSqlDatabases.add("postgresql-test-1");
+ globalConfig.setPostgreSqlDatabases(localPostgreSqlDatabases);
+ HashSet localOpenGaussDatabases = new HashSet<>();
+ localOpenGaussDatabases.add("mongodb-test-1");
+ globalConfig.setOpenGaussDatabases(localOpenGaussDatabases);
}
/**
@@ -50,12 +68,25 @@ public static void setUp() {
*/
@Test
public void testGetProhibitionDatabasesWithGlobalAndLocalConfigEnabled() {
- globalConfig.setEnableDatabaseWriteProhibition(true);
- localConfig.setEnableDatabaseWriteProhibition(true);
+ globalConfig.setEnableMongoDbWriteProhibition(true);
+ globalConfig.setEnableMysqlWriteProhibition(true);
+ globalConfig.setEnablePostgreSqlWriteProhibition(true);
+ globalConfig.setEnableOpenGaussWriteProhibition(true);
+ localConfig.setEnableMongoDbWriteProhibition(true);
+ localConfig.setEnableMysqlWriteProhibition(true);
+ localConfig.setEnablePostgreSqlWriteProhibition(true);
+ localConfig.setEnableOpenGaussWriteProhibition(true);
DatabaseWriteProhibitionManager.updateGlobalConfig(globalConfig);
DatabaseWriteProhibitionManager.updateLocalConfig(localConfig);
- Assert.assertEquals(globalConfig.getDatabases(), DatabaseWriteProhibitionManager.getProhibitionDatabases());
+ Assert.assertEquals(globalConfig.getMongoDbDatabases(),
+ DatabaseWriteProhibitionManager.getMongoDbProhibitionDatabases());
+ Assert.assertEquals(globalConfig.getMysqlDatabases(),
+ DatabaseWriteProhibitionManager.getMysqlProhibitionDatabases());
+ Assert.assertEquals(globalConfig.getPostgreSqlDatabases(),
+ DatabaseWriteProhibitionManager.getPostgreSqlProhibitionDatabases());
+ Assert.assertEquals(globalConfig.getOpenGaussDatabases(),
+ DatabaseWriteProhibitionManager.getOpenGaussProhibitionDatabases());
}
/**
@@ -63,12 +94,25 @@ public void testGetProhibitionDatabasesWithGlobalAndLocalConfigEnabled() {
*/
@Test
public void testGetProhibitionDatabasesWithJustGlobalConfigEnabled() {
- globalConfig.setEnableDatabaseWriteProhibition(true);
- localConfig.setEnableDatabaseWriteProhibition(false);
+ globalConfig.setEnableMongoDbWriteProhibition(true);
+ globalConfig.setEnableMysqlWriteProhibition(true);
+ globalConfig.setEnablePostgreSqlWriteProhibition(true);
+ globalConfig.setEnableOpenGaussWriteProhibition(true);
+ localConfig.setEnableMongoDbWriteProhibition(false);
+ localConfig.setEnableMysqlWriteProhibition(false);
+ localConfig.setEnablePostgreSqlWriteProhibition(false);
+ localConfig.setEnableOpenGaussWriteProhibition(false);
DatabaseWriteProhibitionManager.updateGlobalConfig(globalConfig);
DatabaseWriteProhibitionManager.updateLocalConfig(localConfig);
- Assert.assertEquals(globalConfig.getDatabases(), DatabaseWriteProhibitionManager.getProhibitionDatabases());
+ Assert.assertEquals(globalConfig.getMongoDbDatabases(),
+ DatabaseWriteProhibitionManager.getMongoDbProhibitionDatabases());
+ Assert.assertEquals(globalConfig.getMysqlDatabases(),
+ DatabaseWriteProhibitionManager.getMysqlProhibitionDatabases());
+ Assert.assertEquals(globalConfig.getPostgreSqlDatabases(),
+ DatabaseWriteProhibitionManager.getPostgreSqlProhibitionDatabases());
+ Assert.assertEquals(globalConfig.getOpenGaussDatabases(),
+ DatabaseWriteProhibitionManager.getOpenGaussProhibitionDatabases());
}
/**
@@ -76,12 +120,25 @@ public void testGetProhibitionDatabasesWithJustGlobalConfigEnabled() {
*/
@Test
public void testGetProhibitionDatabasesWithJustLocalConfigEnabled() {
- globalConfig.setEnableDatabaseWriteProhibition(false);
- localConfig.setEnableDatabaseWriteProhibition(true);
+ globalConfig.setEnableMongoDbWriteProhibition(false);
+ globalConfig.setEnableMysqlWriteProhibition(false);
+ globalConfig.setEnablePostgreSqlWriteProhibition(false);
+ globalConfig.setEnableOpenGaussWriteProhibition(false);
+ localConfig.setEnableMongoDbWriteProhibition(true);
+ localConfig.setEnableMysqlWriteProhibition(true);
+ localConfig.setEnablePostgreSqlWriteProhibition(true);
+ localConfig.setEnableOpenGaussWriteProhibition(true);
DatabaseWriteProhibitionManager.updateGlobalConfig(globalConfig);
DatabaseWriteProhibitionManager.updateLocalConfig(localConfig);
- Assert.assertEquals(localConfig.getDatabases(), DatabaseWriteProhibitionManager.getProhibitionDatabases());
+ Assert.assertEquals(localConfig.getMongoDbDatabases(),
+ DatabaseWriteProhibitionManager.getMongoDbProhibitionDatabases());
+ Assert.assertEquals(localConfig.getMysqlDatabases(),
+ DatabaseWriteProhibitionManager.getMysqlProhibitionDatabases());
+ Assert.assertEquals(localConfig.getPostgreSqlDatabases(),
+ DatabaseWriteProhibitionManager.getPostgreSqlProhibitionDatabases());
+ Assert.assertEquals(localConfig.getOpenGaussDatabases(),
+ DatabaseWriteProhibitionManager.getOpenGaussProhibitionDatabases());
}
/**
@@ -89,12 +146,21 @@ public void testGetProhibitionDatabasesWithJustLocalConfigEnabled() {
*/
@Test
public void testGetProhibitionDatabasesWithBothConfigsDisabled() {
- globalConfig.setEnableDatabaseWriteProhibition(false);
- localConfig.setEnableDatabaseWriteProhibition(false);
+ globalConfig.setEnableMongoDbWriteProhibition(false);
+ globalConfig.setEnableMysqlWriteProhibition(false);
+ globalConfig.setEnablePostgreSqlWriteProhibition(false);
+ globalConfig.setEnableOpenGaussWriteProhibition(false);
+ localConfig.setEnableMongoDbWriteProhibition(false);
+ localConfig.setEnableMysqlWriteProhibition(false);
+ localConfig.setEnablePostgreSqlWriteProhibition(false);
+ localConfig.setEnableOpenGaussWriteProhibition(false);
DatabaseWriteProhibitionManager.updateGlobalConfig(globalConfig);
DatabaseWriteProhibitionManager.updateLocalConfig(localConfig);
- Assert.assertTrue(DatabaseWriteProhibitionManager.getProhibitionDatabases().isEmpty());
+ Assert.assertTrue(DatabaseWriteProhibitionManager.getMongoDbProhibitionDatabases().isEmpty());
+ Assert.assertTrue(DatabaseWriteProhibitionManager.getMysqlProhibitionDatabases().isEmpty());
+ Assert.assertTrue(DatabaseWriteProhibitionManager.getPostgreSqlProhibitionDatabases().isEmpty());
+ Assert.assertTrue(DatabaseWriteProhibitionManager.getOpenGaussProhibitionDatabases().isEmpty());
}
/**
@@ -116,9 +182,21 @@ public void testUpdateConfigWithNullConfig() {
DatabaseWriteProhibitionManager.updateGlobalConfig(null);
DatabaseWriteProhibitionManager.updateLocalConfig(null);
- Assert.assertEquals(0, DatabaseWriteProhibitionManager.getGlobalConfig().getDatabases().size());
- Assert.assertEquals(0, DatabaseWriteProhibitionManager.getLocalConfig().getDatabases().size());
- Assert.assertFalse(DatabaseWriteProhibitionManager.getGlobalConfig().isEnableDatabaseWriteProhibition());
- Assert.assertFalse(DatabaseWriteProhibitionManager.getLocalConfig().isEnableDatabaseWriteProhibition());
+ Assert.assertEquals(0, DatabaseWriteProhibitionManager.getGlobalConfig().getMongoDbDatabases().size());
+ Assert.assertEquals(0, DatabaseWriteProhibitionManager.getGlobalConfig().getMysqlDatabases().size());
+ Assert.assertEquals(0, DatabaseWriteProhibitionManager.getGlobalConfig().getPostgreSqlDatabases().size());
+ Assert.assertEquals(0, DatabaseWriteProhibitionManager.getGlobalConfig().getOpenGaussDatabases().size());
+ Assert.assertEquals(0, DatabaseWriteProhibitionManager.getLocalConfig().getMongoDbDatabases().size());
+ Assert.assertEquals(0, DatabaseWriteProhibitionManager.getLocalConfig().getMysqlDatabases().size());
+ Assert.assertEquals(0, DatabaseWriteProhibitionManager.getLocalConfig().getPostgreSqlDatabases().size());
+ Assert.assertEquals(0, DatabaseWriteProhibitionManager.getLocalConfig().getOpenGaussDatabases().size());
+ Assert.assertFalse(DatabaseWriteProhibitionManager.getGlobalConfig().isEnableMongoDbWriteProhibition());
+ Assert.assertFalse(DatabaseWriteProhibitionManager.getGlobalConfig().isEnableMysqlWriteProhibition());
+ Assert.assertFalse(DatabaseWriteProhibitionManager.getGlobalConfig().isEnablePostgreSqlWriteProhibition());
+ Assert.assertFalse(DatabaseWriteProhibitionManager.getGlobalConfig().isEnableOpenGaussWriteProhibition());
+ Assert.assertFalse(DatabaseWriteProhibitionManager.getLocalConfig().isEnableMongoDbWriteProhibition());
+ Assert.assertFalse(DatabaseWriteProhibitionManager.getLocalConfig().isEnableMysqlWriteProhibition());
+ Assert.assertFalse(DatabaseWriteProhibitionManager.getLocalConfig().isEnablePostgreSqlWriteProhibition());
+ Assert.assertFalse(DatabaseWriteProhibitionManager.getLocalConfig().isEnableOpenGaussWriteProhibition());
}
}
diff --git a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/constant/MethodParamTypeName.java b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/constant/MethodParamTypeName.java
new file mode 100644
index 0000000000..adc763a841
--- /dev/null
+++ b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/constant/MethodParamTypeName.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright (C) 2024-2024 Huawei Technologies Co., Ltd. All rights reserved.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package com.huaweicloud.sermant.mongodb.constant;
+
+/**
+ * 方法参数类型的全限定名常量类
+ *
+ * @author daizhenyu
+ * @since 2024-01-27
+ **/
+public class MethodParamTypeName {
+ /**
+ * String类全限定名
+ */
+ public static final String STRING_CLASS_NAME = "java.lang.String";
+
+ /**
+ * WriteBinding类全限定名
+ */
+ public static final String WRITE_BINDING_CLASS_NAME = "com.mongodb.internal.binding.WriteBinding";
+
+ /**
+ * ReadPreference类全限定名
+ */
+ public static final String READ_PREFERENCE_CLASS_NAME = "com.mongodb.ReadPreference";
+
+ /**
+ * FieldNameValidator类全限定名
+ */
+ public static final String FIELD_NAME_VALIDATOR_CLASS_NAME = "org.bson.FieldNameValidator";
+
+ /**
+ * Decoder类全限定名
+ */
+ public static final String DECODER_CLASS_NAME = "org.bson.codecs.Decoder";
+
+ /**
+ * CommandCreator类全限定名
+ */
+ public static final String COMMAND_CREATOR_CLASS_NAME =
+ "com.mongodb.internal.operation.CommandOperationHelper.CommandCreator";
+
+ /**
+ * CommandWriteTransformer类全限定名
+ */
+ public static final String COMMAND_WRITE_TRANSFORMER_CLASS_NAME =
+ "com.mongodb.internal.operation.CommandOperationHelper.CommandWriteTransformer";
+
+ /**
+ * Function类全限定名
+ */
+ public static final String FUNCTION_CLASS_NAME = "com.mongodb.Function";
+
+ /**
+ * BsonDocument类全限定名
+ */
+ public static final String BSON_DOCUMENT_CLASS_NAME = "org.bson.BsonDocument";
+
+ /**
+ * ConnectionSource类全限定名
+ */
+ public static final String CONNECTION_SOURCE_CLASS_NAME = "com.mongodb.internal.binding.ConnectionSource";
+
+ /**
+ * Connection类全限定名
+ */
+ public static final String CONNECTION_CLASS_NAME = "com.mongodb.internal.connection.Connection";
+
+ /**
+ * AsyncWriteBinding类全限定名
+ */
+ public static final String ASYNC_WRITE_BINDING_CLASS_NAME = "com.mongodb.internal.binding.AsyncWriteBinding";
+
+ /**
+ * CommandWriteTransformerAsync类全限定名
+ */
+ public static final String COMMAND_WRITE_TRANSFORMER_ASYNC_CLASS_NAME =
+ "com.mongodb.internal.operation.CommandOperationHelper.CommandWriteTransformerAsync";
+
+ /**
+ * SingleResultCallback类全限定名
+ */
+ public static final String SINGLE_RESULT_CALLBACK_CLASS_NAME = "com.mongodb.internal.async.SingleResultCallback";
+
+ private MethodParamTypeName() {
+ }
+}
diff --git a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteCommandInterceptor.java b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteCommandInterceptor.java
index 28028e5a5c..ad098161bc 100644
--- a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteCommandInterceptor.java
+++ b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteCommandInterceptor.java
@@ -47,7 +47,7 @@ public ExecuteCommandInterceptor(DatabaseHandler handler) {
@Override
public ExecuteContext doBefore(ExecuteContext context) {
String database = (String) context.getArguments()[0];
- if (DatabaseWriteProhibitionManager.getProhibitionDatabases().contains(database)) {
+ if (DatabaseWriteProhibitionManager.getMongoDbProhibitionDatabases().contains(database)) {
DatabaseController.disableDatabaseWriteOperation(database, context);
}
return context;
diff --git a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteRetryableCommandInterceptor.java b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteRetryableCommandInterceptor.java
index 12179ffc32..79db0cdfe3 100644
--- a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteRetryableCommandInterceptor.java
+++ b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteRetryableCommandInterceptor.java
@@ -47,7 +47,7 @@ public ExecuteRetryableCommandInterceptor(DatabaseHandler handler) {
@Override
public ExecuteContext doBefore(ExecuteContext context) {
String database = (String) context.getArguments()[1];
- if (DatabaseWriteProhibitionManager.getProhibitionDatabases().contains(database)) {
+ if (DatabaseWriteProhibitionManager.getMongoDbProhibitionDatabases().contains(database)) {
DatabaseController.disableDatabaseWriteOperation(database, context);
}
return context;
diff --git a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/interceptors/MixedBulkWriteOperationInterceptor.java b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/interceptors/MixedBulkWriteOperationInterceptor.java
index 711cf40f1c..4fb0dc3fb8 100644
--- a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/interceptors/MixedBulkWriteOperationInterceptor.java
+++ b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/interceptors/MixedBulkWriteOperationInterceptor.java
@@ -49,7 +49,7 @@ public MixedBulkWriteOperationInterceptor(DatabaseHandler handler) {
@Override
public ExecuteContext doBefore(ExecuteContext context) {
String database = ((MixedBulkWriteOperation) context.getObject()).getNamespace().getDatabaseName();
- if (DatabaseWriteProhibitionManager.getProhibitionDatabases().contains(database)) {
+ if (DatabaseWriteProhibitionManager.getMongoDbProhibitionDatabases().contains(database)) {
DatabaseController.disableDatabaseWriteOperation(database, context);
}
return context;
diff --git a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/utils/MongoDbEnhancementHelper.java b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/utils/MongoDbEnhancementHelper.java
index fc14be7a63..3566b4a7c2 100644
--- a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/utils/MongoDbEnhancementHelper.java
+++ b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/main/java/com/huaweicloud/sermant/mongodb/utils/MongoDbEnhancementHelper.java
@@ -20,20 +20,13 @@
import com.huaweicloud.sermant.core.plugin.agent.matcher.ClassMatcher;
import com.huaweicloud.sermant.core.plugin.agent.matcher.MethodMatcher;
import com.huaweicloud.sermant.database.handler.DatabaseHandler;
+import com.huaweicloud.sermant.mongodb.constant.MethodParamTypeName;
import com.huaweicloud.sermant.mongodb.interceptors.ExecuteCommandInterceptor;
import com.huaweicloud.sermant.mongodb.interceptors.ExecuteRetryableCommandInterceptor;
import com.huaweicloud.sermant.mongodb.interceptors.MixedBulkWriteOperationInterceptor;
-import com.mongodb.ReadPreference;
-import com.mongodb.internal.binding.ConnectionSource;
-import com.mongodb.internal.connection.Connection;
-
-import org.bson.BsonDocument;
-import org.bson.FieldNameValidator;
-import org.bson.codecs.Decoder;
-
/**
- * mongo拦截点辅助类
+ * mongodb拦截点辅助类
*
* @author daizhenyu
* @since 2024-01-16
@@ -57,37 +50,37 @@ public class MongoDbEnhancementHelper {
private static final int METHOD_PARAM_COUNT = 9;
- private static final Class[] EXECUTE_COMMAND_PARAMS_TYPE = {
- String.class,
- BsonDocument.class,
- FieldNameValidator.class,
- Decoder.class,
- ConnectionSource.class,
- Connection.class,
- ReadPreference.class
+ private static final String[] EXECUTE_COMMAND_PARAMS_TYPE = {
+ MethodParamTypeName.STRING_CLASS_NAME,
+ MethodParamTypeName.BSON_DOCUMENT_CLASS_NAME,
+ MethodParamTypeName.FIELD_NAME_VALIDATOR_CLASS_NAME,
+ MethodParamTypeName.DECODER_CLASS_NAME,
+ MethodParamTypeName.CONNECTION_SOURCE_CLASS_NAME,
+ MethodParamTypeName.CONNECTION_CLASS_NAME,
+ MethodParamTypeName.READ_PREFERENCE_CLASS_NAME
};
private static final String[] EXECUTE_RETRY_COMMAND_PARAMS_TYPE = {
- "com.mongodb.internal.binding.WriteBinding",
- "java.lang.String",
- "com.mongodb.ReadPreference",
- "org.bson.FieldNameValidator",
- "org.bson.codecs.Decoder",
- "com.mongodb.internal.operation.CommandOperationHelper.CommandCreator",
- "com.mongodb.internal.operation.CommandOperationHelper.CommandWriteTransformer",
- "com.mongodb.Function"
+ MethodParamTypeName.WRITE_BINDING_CLASS_NAME,
+ MethodParamTypeName.STRING_CLASS_NAME,
+ MethodParamTypeName.READ_PREFERENCE_CLASS_NAME,
+ MethodParamTypeName.FIELD_NAME_VALIDATOR_CLASS_NAME,
+ MethodParamTypeName.DECODER_CLASS_NAME,
+ MethodParamTypeName.COMMAND_CREATOR_CLASS_NAME,
+ MethodParamTypeName.COMMAND_WRITE_TRANSFORMER_CLASS_NAME,
+ MethodParamTypeName.FUNCTION_CLASS_NAME
};
private static final String[] EXECUTE_RETRY_COMMAND_ASYNC_PARAMS_TYPE = {
- "com.mongodb.internal.binding.AsyncWriteBinding",
- "java.lang.String",
- "com.mongodb.ReadPreference",
- "org.bson.FieldNameValidator",
- "org.bson.codecs.Decoder",
- "com.mongodb.internal.operation.CommandOperationHelper.CommandCreator",
- "com.mongodb.internal.operation.CommandOperationHelper.CommandWriteTransformerAsync",
- "com.mongodb.Function",
- "com.mongodb.internal.async.SingleResultCallback"
+ MethodParamTypeName.ASYNC_WRITE_BINDING_CLASS_NAME,
+ MethodParamTypeName.STRING_CLASS_NAME,
+ MethodParamTypeName.READ_PREFERENCE_CLASS_NAME,
+ MethodParamTypeName.FIELD_NAME_VALIDATOR_CLASS_NAME,
+ MethodParamTypeName.DECODER_CLASS_NAME,
+ MethodParamTypeName.COMMAND_CREATOR_CLASS_NAME,
+ MethodParamTypeName.COMMAND_WRITE_TRANSFORMER_ASYNC_CLASS_NAME,
+ MethodParamTypeName.FUNCTION_CLASS_NAME,
+ MethodParamTypeName.SINGLE_RESULT_CALLBACK_CLASS_NAME
};
private MongoDbEnhancementHelper() {
diff --git a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/test/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteCommandInterceptorTest.java b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/test/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteCommandInterceptorTest.java
index 0b585f9aa1..97fd8133cb 100644
--- a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/test/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteCommandInterceptorTest.java
+++ b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/test/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteCommandInterceptorTest.java
@@ -61,7 +61,7 @@ public static void setUp() {
operationMock = Mockito.mock(MixedBulkWriteOperation.class);
methodMock = Mockito.mock(Method.class);
Mockito.when(operationMock.getNamespace()).thenReturn(namespace);
- argument = new Object[] {"database-test"};
+ argument = new Object[]{"database-test"};
}
@AfterClass
@@ -72,7 +72,7 @@ public static void tearDown() {
@Test
public void testDoBefore() {
// 数据库禁写开关关闭
- globalConfig.setEnableDatabaseWriteProhibition(false);
+ globalConfig.setEnableMongoDbWriteProhibition(false);
context = ExecuteContext.forMemberMethod(operationMock, methodMock, argument, null, null);
interceptor.doBefore(context);
Assert.assertNull(context.getThrowableOut());
@@ -80,18 +80,18 @@ public void testDoBefore() {
// 数据库禁写开关关闭,禁写数据库set包含被拦截的数据库
Set databases = new HashSet<>();
databases.add("database-test");
- globalConfig.setDatabases(databases);
+ globalConfig.setMongoDbDatabases(databases);
Assert.assertNull(context.getThrowableOut());
//数据库禁写开关打开,禁写数据库集合包含被拦截的数据库
- globalConfig.setEnableDatabaseWriteProhibition(true);
+ globalConfig.setEnableMongoDbWriteProhibition(true);
context = ExecuteContext.forMemberMethod(operationMock, methodMock, argument, null, null);
interceptor.doBefore(context);
Assert.assertEquals("Database prohibit to write, database: database-test",
context.getThrowableOut().getMessage());
//数据库禁写开关打开,禁写数据库集合不包含被拦截的数据库
- globalConfig.setDatabases(new HashSet<>());
+ globalConfig.setMongoDbDatabases(new HashSet<>());
interceptor.doBefore(context);
context = ExecuteContext.forMemberMethod(operationMock, methodMock, argument, null, null);
Assert.assertNull(context.getThrowableOut());
diff --git a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/test/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteRetryableCommandInterceptorTest.java b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/test/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteRetryableCommandInterceptorTest.java
index 5414d76000..aed7687745 100644
--- a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/test/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteRetryableCommandInterceptorTest.java
+++ b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/test/java/com/huaweicloud/sermant/mongodb/interceptors/ExecuteRetryableCommandInterceptorTest.java
@@ -72,7 +72,7 @@ public static void tearDown() {
@Test
public void testDoBefore() {
// 数据库禁写开关关闭
- globalConfig.setEnableDatabaseWriteProhibition(false);
+ globalConfig.setEnableMongoDbWriteProhibition(false);
context = ExecuteContext.forMemberMethod(operationMock, methodMock, argument, null, null);
interceptor.doBefore(context);
Assert.assertNull(context.getThrowableOut());
@@ -80,19 +80,18 @@ public void testDoBefore() {
// 数据库禁写开关关闭,禁写数据库set包含被拦截的数据库
Set databases = new HashSet<>();
databases.add("database-test");
- globalConfig.setDatabases(databases);
+ globalConfig.setMongoDbDatabases(databases);
Assert.assertNull(context.getThrowableOut());
//数据库禁写开关打开,禁写数据库集合包含被拦截的数据库
- globalConfig.setEnableDatabaseWriteProhibition(true);
- globalConfig.setDatabases(databases);
+ globalConfig.setEnableMongoDbWriteProhibition(true);
context = ExecuteContext.forMemberMethod(operationMock, methodMock, argument, null, null);
interceptor.doBefore(context);
Assert.assertEquals("Database prohibit to write, database: database-test",
context.getThrowableOut().getMessage());
//数据库禁写开关打开,禁写数据库集合不包含被拦截的数据库
- globalConfig.setDatabases(new HashSet<>());
+ globalConfig.setMongoDbDatabases(new HashSet<>());
interceptor.doBefore(context);
context = ExecuteContext.forMemberMethod(operationMock, methodMock, argument, null, null);
Assert.assertNull(context.getThrowableOut());
diff --git a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/test/java/com/huaweicloud/sermant/mongodb/interceptors/MixedBulkWriteOperationInterceptorTest.java b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/test/java/com/huaweicloud/sermant/mongodb/interceptors/MixedBulkWriteOperationInterceptorTest.java
index a9323cfd0a..0552ac010f 100644
--- a/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/test/java/com/huaweicloud/sermant/mongodb/interceptors/MixedBulkWriteOperationInterceptorTest.java
+++ b/sermant-plugins/sermant-database-write-prohibition/mongodb-3.x-4.x-plugin/src/test/java/com/huaweicloud/sermant/mongodb/interceptors/MixedBulkWriteOperationInterceptorTest.java
@@ -69,7 +69,7 @@ public static void tearDown() {
@Test
public void testDoBefore() {
// 数据库禁写开关关闭
- globalConfig.setEnableDatabaseWriteProhibition(false);
+ globalConfig.setEnableMongoDbWriteProhibition(false);
context = ExecuteContext.forMemberMethod(operationMock, methodMock, null, null, null);
interceptor.doBefore(context);
Assert.assertNull(context.getThrowableOut());
@@ -77,18 +77,18 @@ public void testDoBefore() {
// 数据库禁写开关关闭,禁写数据库set包含被拦截的数据库
Set databases = new HashSet<>();
databases.add("database-test");
- globalConfig.setDatabases(databases);
+ globalConfig.setMongoDbDatabases(databases);
Assert.assertNull(context.getThrowableOut());
//数据库禁写开关打开,禁写数据库集合包含被拦截的数据库
- globalConfig.setEnableDatabaseWriteProhibition(true);
+ globalConfig.setEnableMongoDbWriteProhibition(true);
context = ExecuteContext.forMemberMethod(operationMock, methodMock, null, null, null);
interceptor.doBefore(context);
Assert.assertEquals("Database prohibit to write, database: database-test",
context.getThrowableOut().getMessage());
//数据库禁写开关打开,禁写数据库集合不包含被拦截的数据库
- globalConfig.setDatabases(new HashSet<>());
+ globalConfig.setMongoDbDatabases(new HashSet<>());
interceptor.doBefore(context);
context = ExecuteContext.forMemberMethod(operationMock, methodMock, null, null, null);
Assert.assertNull(context.getThrowableOut());
diff --git a/sermant-plugins/sermant-database-write-prohibition/pom.xml b/sermant-plugins/sermant-database-write-prohibition/pom.xml
index 053aca2eeb..524194daa6 100644
--- a/sermant-plugins/sermant-database-write-prohibition/pom.xml
+++ b/sermant-plugins/sermant-database-write-prohibition/pom.xml
@@ -27,6 +27,7 @@
database-controller
+ database-config-service
mongodb-3.x-4.x-plugin
@@ -34,6 +35,7 @@
test
database-controller
+ database-config-service
mongodb-3.x-4.x-plugin
@@ -41,6 +43,7 @@
release
database-controller
+ database-config-service
mongodb-3.x-4.x-plugin