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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
use Url;
use crateAuth;
/// The main Sure API client
///
/// This client provides access to all Sure API endpoints. It handles authentication,
/// request execution, and error handling.
///
/// The API supports two authentication methods:
/// - Bearer token (JWT) via Authorization header
/// - API key via X-Api-Key header
///
/// # Example with API Key
/// ```no_run
/// use sure_client_rs::{SureClient, Auth};
///
/// # async fn example() -> Result<(), Box<dyn std::error::Error>> {
/// let client = SureClient::new(
/// reqwest::Client::new(),
/// Auth::api_key("your_api_key"),
/// "http://localhost:3000".to_string().parse().unwrap(),
/// );
///
/// let categories = client.get_categories().call().await?;
/// # Ok(())
/// # }
/// ```
///
/// # Example with Bearer Token
/// ```no_run
/// use sure_client_rs::{SureClient, Auth};
///
/// # async fn example() -> Result<(), Box<dyn std::error::Error>> {
/// let client = SureClient::new(
/// reqwest::Client::new(),
/// Auth::bearer("your_jwt_token"),
/// "http://localhost:3000".to_string().parse().unwrap(),
/// );
///
/// let categories = client.get_categories().call().await?;
/// # Ok(())
/// # }
/// ```