solagent_plugin_helius/
delete_webhook.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
// Copyright 2025 zTgx
//
// 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.

use solagent_core::SolanaAgentKit;

/// Deletes a Helius Webhook by its ID.
///
/// # Arguments
/// * `agent` - An instance of SolanaAgentKit (with .config.HELIUS_API_KEY)
/// * `webhook_id` - The unique ID of the webhook to delete
///
/// # Returns
/// The response body from the Helius API (which may contain status or other info)
pub async fn delete_webhook(
    agent: &SolanaAgentKit,
    webhook_id: &str,
) -> Result<serde_json::Value, Box<dyn std::error::Error>> {
    // Get the Helius API key from the agent's configuration
    let api_key = match agent.config.helius_api_key.as_ref() {
        Some(key) => key,
        None => return Err("Missing Helius API key in agent.config.HELIUS_API_KEY".into()),
    };

    // Construct the URL for the DELETE request
    let url = format!("https://api.helius.xyz/v0/webhooks/{}?api-key={}", webhook_id, api_key);

    // Create an HTTP client
    let client = reqwest::Client::new();

    // Send the DELETE request
    let response = client.delete(&url).header("Content-Type", "application/json").send().await?;

    // Check if the request was successful
    if !response.status().is_success() {
        return Err(format!(
            "Failed to delete webhook: {} {}",
            response.status(),
            response.status().canonical_reason().unwrap_or("Unknown")
        )
        .into());
    }

    // Handle different response status codes
    if response.status().as_u16() == 204 {
        return Ok(serde_json::json!({"message": "Webhook deleted successfully (no content returned)"}));
    }

    // Check if the response body is empty
    let content_length = response.headers().get("Content-Length");
    if content_length.is_none() || content_length.expect("HeaderValue").to_str()? == "0" {
        return Ok(serde_json::json!({"message": "Webhook deleted successfully (empty body)"}));
    }

    // Parse the response body as JSON
    let data: serde_json::Value = response.json().await?;
    Ok(data)
}