Skip to content

Utility library for managing remote configuration in Angular applications

License

Notifications You must be signed in to change notification settings

dadadcko/ngx-remote-configuration

Repository files navigation

🚀 Ngx Remote Configuration

Build Status npm npm GitHub code style: prettier

Utility library for managing remote configuration in Angular applications.

Configuration is loaded from remote URL and accessible via simple configuration facade.

Samples

The best way to find out, what library can offer to you, is by exploring the examples. There is a demo app prepared, which showcases all features of this library.

🔧 Instalation

To install the package, simply run following command at path, where your package.json is located:

npm install ngx-remote-configuration

Then, register library providers:

// register the remote configuration providers
provideRemoteConfiguration(...);

Usage

Public Api of the library is represented by single ConfigurationManager facade. This facade provides stream with latest configuration object from remote source. Sample usage of the facade:

// full configuration
inject(ConfigurationManager)
    .configuration$.subscribe(config => console.log('Full configuration:', config));

// some value/ section
inject(ConfigurationManager)
      .value$<string>('nestedObj.secondProp')
      .subscribe(value => console.log('Configuration value under <nestedObj.secondProp> :', value));

// section bound to a class instance
inject(ConfigurationManager)
      .value$<NestedConfigurationSection>('nestedObj', NestedConfigurationSection)
      .subscribe(value =>
        console.log('Configuration value under <nestedObj>, bound to class instance :', value)
      );

For detailed usage preview, check out demo sample app.

Add-ins

Library provides several add-ins features, which can modify/enrich the default behaviour.

Example of some Add-ins:

  • Resilient configuration loading: Adds resiliency when loading configuration from remote source. Enabled by calling withResilientConfigurationLoader(retryOptions) when registering providers.
  • Periodic configuration reloads: Adds periodic reloads of configuration. Consumers are notified only when configuration value changes. Enabled by calling withPeriodicReloads(intervalInSeconds) when registering providers.
  • On bootstrap load: By default, configuration is loaded when it is requested for the first time. This add-in opposes this default behaviour, and loads configuration before application starts - blocking the startup until configuration is resolved. Enabled by calling withLoadOnApplicationBootstrap() when registering providers.

For the full list of features, check provider registration in demo sample app.