rspack_plugin_mf 0.100.0-beta.8

rspack module federation plugin
Documentation
use rspack_cacheable::{cacheable, cacheable_dyn};
use rspack_core::{
  AsContextDependency, AsDependencyCodeGeneration, Dependency, DependencyCategory, DependencyId,
  DependencyType, FactorizeInfo, ModuleDependency, ResourceIdentifier,
};

use crate::{ExposeOptions, ShareScope};

#[cacheable]
#[derive(Debug, Clone)]
pub struct ContainerEntryDependency {
  id: DependencyId,
  pub name: String,
  pub exposes: Vec<(String, ExposeOptions)>,
  pub share_scope: ShareScope,
  pub request: Option<String>,
  pub version: Option<String>,
  resource_identifier: ResourceIdentifier,
  pub(crate) enhanced: bool,
  dependency_type: DependencyType,
  factorize_info: FactorizeInfo,
}

impl ContainerEntryDependency {
  pub fn new(
    name: String,
    exposes: Vec<(String, ExposeOptions)>,
    share_scope: ShareScope,
    enhanced: bool,
  ) -> Self {
    let resource_identifier = format!("container-entry-{}", &name).into();
    Self {
      id: DependencyId::new(),
      name,
      exposes,
      share_scope,
      request: None,
      version: None,
      resource_identifier,
      enhanced,
      dependency_type: DependencyType::ContainerEntry,
      factorize_info: Default::default(),
    }
  }

  pub fn new_share_container_entry(name: String, request: String, version: String) -> Self {
    let resource_identifier = format!("share-container-entry-{}", &name).into();
    Self {
      id: DependencyId::new(),
      name,
      exposes: vec![],
      share_scope: ShareScope::Multiple(vec![]),
      request: Some(request),
      version: Some(version),
      resource_identifier,
      enhanced: false,
      dependency_type: DependencyType::ShareContainerEntry,
      factorize_info: Default::default(),
    }
  }
}

#[cacheable_dyn]
impl Dependency for ContainerEntryDependency {
  fn id(&self) -> &DependencyId {
    &self.id
  }

  fn category(&self) -> &DependencyCategory {
    &DependencyCategory::Esm
  }

  fn dependency_type(&self) -> &DependencyType {
    &self.dependency_type
  }

  fn resource_identifier(&self) -> Option<&str> {
    Some(&self.resource_identifier)
  }

  fn could_affect_referencing_module(&self) -> rspack_core::AffectType {
    rspack_core::AffectType::Transitive
  }
}

#[cacheable_dyn]
impl ModuleDependency for ContainerEntryDependency {
  fn request(&self) -> &str {
    if self.dependency_type == DependencyType::ShareContainerEntry {
      self.request.as_deref().unwrap_or_default()
    } else {
      &self.resource_identifier
    }
  }

  fn factorize_info(&self) -> &FactorizeInfo {
    &self.factorize_info
  }

  fn factorize_info_mut(&mut self) -> &mut FactorizeInfo {
    &mut self.factorize_info
  }
}

impl AsContextDependency for ContainerEntryDependency {}
impl AsDependencyCodeGeneration for ContainerEntryDependency {}