mirror of
https://github.com/rustfs/rustfs.git
synced 2026-01-16 17:20:33 +00:00
* improve code for notify * fix * cargo fmt * improve code and create `DEFAULT_DELIMITER` * fix * fix * improve code for notify * fmt * Update crates/notify/src/registry.rs Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update crates/notify/src/factory.rs Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * fix cllipy --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
175 lines
5.9 KiB
Rust
175 lines
5.9 KiB
Rust
use ecstore::config::{Config, ENABLE_KEY, ENABLE_ON, KV, KVS};
|
|
// Using Global Accessories
|
|
use rustfs_config::notify::{
|
|
DEFAULT_LIMIT, DEFAULT_TARGET, MQTT_BROKER, MQTT_PASSWORD, MQTT_QOS, MQTT_QUEUE_DIR, MQTT_QUEUE_LIMIT, MQTT_TOPIC,
|
|
MQTT_USERNAME, NOTIFY_MQTT_SUB_SYS, NOTIFY_WEBHOOK_SUB_SYS, WEBHOOK_AUTH_TOKEN, WEBHOOK_ENDPOINT, WEBHOOK_QUEUE_DIR,
|
|
WEBHOOK_QUEUE_LIMIT,
|
|
};
|
|
use rustfs_notify::arn::TargetID;
|
|
use rustfs_notify::{BucketNotificationConfig, Event, EventName, LogLevel, NotificationError, init_logger};
|
|
use rustfs_notify::{initialize, notification_system};
|
|
use std::sync::Arc;
|
|
use std::time::Duration;
|
|
use tracing::info;
|
|
|
|
#[tokio::main]
|
|
async fn main() -> Result<(), NotificationError> {
|
|
init_logger(LogLevel::Debug);
|
|
|
|
// Get global NotificationSystem instance
|
|
let system = match notification_system() {
|
|
Some(sys) => sys,
|
|
None => {
|
|
let config = Config::new();
|
|
initialize(config).await?;
|
|
notification_system().expect("Failed to initialize notification system")
|
|
}
|
|
};
|
|
|
|
// --- Initial configuration ---
|
|
let mut config = Config::new();
|
|
let current_root = rustfs_utils::dirs::get_project_root().expect("failed to get project root");
|
|
// Webhook target
|
|
let webhook_kvs_vec = vec![
|
|
KV {
|
|
key: ENABLE_KEY.to_string(),
|
|
value: ENABLE_ON.to_string(),
|
|
hidden_if_empty: false,
|
|
},
|
|
KV {
|
|
key: WEBHOOK_ENDPOINT.to_string(),
|
|
value: "http://127.0.0.1:3020/webhook".to_string(),
|
|
hidden_if_empty: false,
|
|
},
|
|
KV {
|
|
key: WEBHOOK_AUTH_TOKEN.to_string(),
|
|
value: "secret-token".to_string(),
|
|
hidden_if_empty: false,
|
|
},
|
|
KV {
|
|
key: WEBHOOK_QUEUE_DIR.to_string(),
|
|
value: current_root
|
|
.clone()
|
|
.join("../../deploy/logs/notify/webhook")
|
|
.to_str()
|
|
.unwrap()
|
|
.to_string(),
|
|
hidden_if_empty: false,
|
|
},
|
|
KV {
|
|
key: WEBHOOK_QUEUE_LIMIT.to_string(),
|
|
value: DEFAULT_LIMIT.to_string(),
|
|
hidden_if_empty: false,
|
|
},
|
|
];
|
|
let webhook_kvs = KVS(webhook_kvs_vec);
|
|
|
|
let mut webhook_targets = std::collections::HashMap::new();
|
|
webhook_targets.insert(DEFAULT_TARGET.to_string(), webhook_kvs);
|
|
config.0.insert(NOTIFY_WEBHOOK_SUB_SYS.to_string(), webhook_targets);
|
|
|
|
// Load the initial configuration and initialize the system
|
|
*system.config.write().await = config;
|
|
system.init().await?;
|
|
info!("✅ System initialized with Webhook target.");
|
|
|
|
tokio::time::sleep(Duration::from_secs(1)).await;
|
|
|
|
// --- Dynamically update system configuration: Add an MQTT Target ---
|
|
info!("\n---> Dynamically adding MQTT target...");
|
|
|
|
let mqtt_kvs_vec = vec![
|
|
KV {
|
|
key: ENABLE_KEY.to_string(),
|
|
value: ENABLE_ON.to_string(),
|
|
hidden_if_empty: false,
|
|
},
|
|
KV {
|
|
key: MQTT_BROKER.to_string(),
|
|
value: "mqtt://localhost:1883".to_string(),
|
|
hidden_if_empty: false,
|
|
},
|
|
KV {
|
|
key: MQTT_TOPIC.to_string(),
|
|
value: "rustfs/events".to_string(),
|
|
hidden_if_empty: false,
|
|
},
|
|
KV {
|
|
key: MQTT_QOS.to_string(),
|
|
value: "1".to_string(), // AtLeastOnce
|
|
hidden_if_empty: false,
|
|
},
|
|
KV {
|
|
key: MQTT_USERNAME.to_string(),
|
|
value: "test".to_string(),
|
|
hidden_if_empty: false,
|
|
},
|
|
KV {
|
|
key: MQTT_PASSWORD.to_string(),
|
|
value: "123456".to_string(),
|
|
hidden_if_empty: false,
|
|
},
|
|
KV {
|
|
key: MQTT_QUEUE_DIR.to_string(),
|
|
value: current_root
|
|
.join("../../deploy/logs/notify/mqtt")
|
|
.to_str()
|
|
.unwrap()
|
|
.to_string(),
|
|
hidden_if_empty: false,
|
|
},
|
|
KV {
|
|
key: MQTT_QUEUE_LIMIT.to_string(),
|
|
value: DEFAULT_LIMIT.to_string(),
|
|
hidden_if_empty: false,
|
|
},
|
|
];
|
|
|
|
let mqtt_kvs = KVS(mqtt_kvs_vec);
|
|
// let mut mqtt_targets = std::collections::HashMap::new();
|
|
// mqtt_targets.insert(DEFAULT_TARGET.to_string(), mqtt_kvs.clone());
|
|
|
|
system
|
|
.set_target_config(NOTIFY_MQTT_SUB_SYS, DEFAULT_TARGET, mqtt_kvs)
|
|
.await?;
|
|
info!("✅ MQTT target added and system reloaded.");
|
|
|
|
tokio::time::sleep(Duration::from_secs(1)).await;
|
|
|
|
// --- Loading and managing Bucket configurations ---
|
|
info!("\n---> Loading bucket notification config...");
|
|
let mut bucket_config = BucketNotificationConfig::new("us-east-1");
|
|
bucket_config.add_rule(
|
|
&[EventName::ObjectCreatedPut],
|
|
"*".to_string(),
|
|
TargetID::new(DEFAULT_TARGET.to_string(), "webhook".to_string()),
|
|
);
|
|
bucket_config.add_rule(
|
|
&[EventName::ObjectCreatedPut],
|
|
"*".to_string(),
|
|
TargetID::new(DEFAULT_TARGET.to_string(), "mqtt".to_string()),
|
|
);
|
|
system.load_bucket_notification_config("my-bucket", &bucket_config).await?;
|
|
info!("✅ Bucket 'my-bucket' config loaded.");
|
|
|
|
// --- Send events ---
|
|
info!("\n---> Sending an event...");
|
|
let event = Arc::new(Event::new_test_event("my-bucket", "document.pdf", EventName::ObjectCreatedPut));
|
|
system.send_event(event).await;
|
|
info!("✅ Event sent. Both Webhook and MQTT targets should receive it.");
|
|
|
|
tokio::time::sleep(Duration::from_secs(2)).await;
|
|
|
|
// --- Dynamically remove configuration ---
|
|
info!("\n---> Dynamically removing Webhook target...");
|
|
system.remove_target_config("notify_webhook", "1").await?;
|
|
info!("✅ Webhook target removed and system reloaded.");
|
|
|
|
info!("\n---> Removing bucket notification config...");
|
|
system.remove_bucket_notification_config("my-bucket").await;
|
|
info!("✅ Bucket 'my-bucket' config removed.");
|
|
|
|
info!("\nDemo completed successfully");
|
|
Ok(())
|
|
}
|