Skip to main content

alien_core/resources/
azure_storage_account.rs

1use crate::error::{ErrorData, Result};
2use crate::resource::{ResourceDefinition, ResourceOutputsDefinition, ResourceRef, ResourceType};
3use alien_error::AlienError;
4use bon::Builder;
5use serde::{Deserialize, Serialize};
6use std::any::Any;
7use std::fmt::Debug;
8
9/// Represents an Azure Storage Account for blob, file, table, and queue storage.
10#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize, Builder)]
11#[cfg_attr(feature = "openapi", derive(utoipa::ToSchema))]
12#[serde(rename_all = "camelCase", deny_unknown_fields)]
13#[builder(start_fn = new)]
14pub struct AzureStorageAccount {
15    /// Identifier for the storage account. Must contain only alphanumeric characters, hyphens, and underscores ([A-Za-z0-9-_]).
16    /// Maximum 64 characters.
17    #[builder(start_fn)]
18    pub id: String,
19}
20
21impl AzureStorageAccount {
22    /// The resource type identifier for Azure Storage Accounts
23    pub const RESOURCE_TYPE: ResourceType = ResourceType::from_static("azure_storage_account");
24
25    /// Returns the storage account's unique identifier.
26    pub fn id(&self) -> &str {
27        &self.id
28    }
29}
30
31/// Outputs generated by a successfully provisioned Azure Storage Account.
32#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
33#[cfg_attr(feature = "openapi", derive(utoipa::ToSchema))]
34#[serde(rename_all = "camelCase")]
35pub struct AzureStorageAccountOutputs {
36    /// The name of the storage account.
37    pub account_name: String,
38    /// The resource ID of the storage account.
39    pub resource_id: String,
40    /// The primary endpoint for blob storage.
41    pub primary_blob_endpoint: String,
42    /// The primary endpoint for file storage.
43    pub primary_file_endpoint: String,
44    /// The primary endpoint for queue storage.
45    pub primary_queue_endpoint: String,
46    /// The primary endpoint for table storage.
47    pub primary_table_endpoint: String,
48}
49
50impl ResourceOutputsDefinition for AzureStorageAccountOutputs {
51    fn get_resource_type(&self) -> ResourceType {
52        AzureStorageAccount::RESOURCE_TYPE.clone()
53    }
54
55    fn as_any(&self) -> &dyn Any {
56        self
57    }
58
59    fn box_clone(&self) -> Box<dyn ResourceOutputsDefinition> {
60        Box::new(self.clone())
61    }
62
63    fn outputs_eq(&self, other: &dyn ResourceOutputsDefinition) -> bool {
64        other.as_any().downcast_ref::<AzureStorageAccountOutputs>() == Some(self)
65    }
66
67    fn to_json_value(&self) -> serde_json::Result<serde_json::Value> {
68        serde_json::to_value(self)
69    }
70}
71
72// Implementation of ResourceDefinition trait for AzureStorageAccount
73impl ResourceDefinition for AzureStorageAccount {
74    fn get_resource_type(&self) -> ResourceType {
75        Self::RESOURCE_TYPE
76    }
77
78    fn id(&self) -> &str {
79        &self.id
80    }
81
82    fn get_dependencies(&self) -> Vec<ResourceRef> {
83        Vec::new()
84    }
85
86    fn validate_update(&self, _new_config: &dyn ResourceDefinition) -> Result<()> {
87        Err(AlienError::new(ErrorData::InvalidResourceUpdate {
88            resource_id: self.id.clone(),
89            reason: "Azure storage accounts cannot be updated once created".to_string(),
90        }))
91    }
92
93    fn as_any(&self) -> &dyn Any {
94        self
95    }
96
97    fn as_any_mut(&mut self) -> &mut dyn Any {
98        self
99    }
100
101    fn box_clone(&self) -> Box<dyn ResourceDefinition> {
102        Box::new(self.clone())
103    }
104
105    fn resource_eq(&self, other: &dyn ResourceDefinition) -> bool {
106        other.as_any().downcast_ref::<AzureStorageAccount>() == Some(self)
107    }
108
109    fn to_json_value(&self) -> serde_json::Result<serde_json::Value> {
110        serde_json::to_value(self)
111    }
112}
113
114#[cfg(test)]
115mod tests {
116    use super::*;
117
118    #[test]
119    fn test_azure_storage_account_creation() {
120        let storage_account = AzureStorageAccount::new("my-storage".to_string()).build();
121        assert_eq!(storage_account.id, "my-storage");
122    }
123}