-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathtracker.rs
More file actions
115 lines (101 loc) · 3.51 KB
/
tracker.rs
File metadata and controls
115 lines (101 loc) · 3.51 KB
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
103
104
105
106
107
108
109
110
111
112
113
114
115
//! Tracker Template Rendering Service
//!
//! This service is responsible for rendering Tracker configuration templates.
//! It's used by multiple contexts (render command, release steps) to prepare
//! tracker.toml configuration files.
use std::path::PathBuf;
use std::sync::Arc;
use thiserror::Error;
use tracing::info;
use crate::domain::template::TemplateManager;
use crate::domain::tracker::TrackerConfig;
use crate::infrastructure::templating::tracker::{
TrackerProjectGenerator, TrackerProjectGeneratorError,
};
use crate::shared::Clock;
/// Errors that can occur during Tracker template rendering
#[derive(Error, Debug)]
pub enum TrackerTemplateRenderingServiceError {
/// Template rendering failed
#[error("Failed to render Tracker templates: {reason}")]
RenderingFailed {
/// Detailed reason for the failure
reason: String,
},
}
impl From<TrackerProjectGeneratorError> for TrackerTemplateRenderingServiceError {
fn from(error: TrackerProjectGeneratorError) -> Self {
Self::RenderingFailed {
reason: error.to_string(),
}
}
}
/// Service for rendering Tracker configuration templates
///
/// This service encapsulates the logic for rendering tracker.toml configuration
/// files. It's designed to be shared across command handlers and steps that need
/// to prepare Tracker configuration.
pub struct TrackerTemplateRenderingService {
build_dir: PathBuf,
template_manager: Arc<TemplateManager>,
clock: Arc<dyn Clock>,
}
impl TrackerTemplateRenderingService {
/// Build a `TrackerTemplateRenderingService` from environment paths
///
/// # Arguments
///
/// * `templates_dir` - Directory containing the source templates
/// * `build_dir` - Directory where rendered templates will be written
/// * `clock` - The clock for generating timestamps
///
/// # Returns
///
/// Returns a configured `TrackerTemplateRenderingService` ready for template rendering
#[must_use]
pub fn from_paths(templates_dir: PathBuf, build_dir: PathBuf, clock: Arc<dyn Clock>) -> Self {
let template_manager = Arc::new(TemplateManager::new(templates_dir));
Self {
build_dir,
template_manager,
clock,
}
}
/// Render Tracker configuration templates
///
/// This renders the tracker.toml configuration file to the build directory.
///
/// # Arguments
///
/// * `tracker_config` - Tracker configuration from user inputs
///
/// # Returns
///
/// Returns the path to the rendered tracker build directory
///
/// # Errors
///
/// Returns `TrackerTemplateRenderingServiceError::RenderingFailed` if template rendering fails.
pub fn render(
&self,
tracker_config: &TrackerConfig,
) -> Result<PathBuf, TrackerTemplateRenderingServiceError> {
info!(
templates_dir = %self.template_manager.templates_dir().display(),
build_dir = %self.build_dir.display(),
"Rendering Tracker configuration templates"
);
let generator = TrackerProjectGenerator::new(
&self.build_dir,
self.template_manager.clone(),
self.clock.clone(),
);
generator.render(Some(tracker_config))?;
let tracker_build_dir = self.build_dir.join("tracker");
info!(
tracker_build_dir = %tracker_build_dir.display(),
"Tracker configuration templates rendered successfully"
);
Ok(tracker_build_dir)
}
}