Runtime
Introduction to OSGi
The OSGi Alliance (Open Services Gateway initiative) provides hardware-independent specifications for component- and service-based software platforms. Originally, these specifications were designed to run in Java Virtual Machines. map.apps uses this specification and implements core parts of it using JavaScript to provide a modular and service-based framework to develop dynamic web map applications.
“Services” in the sense of OSGi does not mean “web services”. Instead it means that an object with a set of properties is registered in an OSGi Runtime. The term for “Module” in OSGi is "Bundle". Both are synonyms for the same concept.
OSGi was adopted for JavaScript because of the following facts:
- 
It provides a clean and modular programing model. 
- 
There is high potential for reuse of created modules. 
- 
Independent versioning of modules is possible. 
- 
It defines a dynamic service layer over which the modules communicate. 
- 
It is designed for runtime changes: - 
Installation, updates, removal of modules during runtime 
- 
Registration/unregistration of services during runtime 
 
- 
The JavaScript OSGi Runtime adopts the following OSGi Specifications:
- 
OSGi Core Specifications - 
Module Layer (partial) 
- 
Module Lifecycle Layer 
- 
Service Layer 
- 
Start Level Service Specification 
 
- 
- 
OSGi Compendium Specifications - 
Declarative Services Specification 
- 
Event Admin Service Specification 
- 
Log Service Specification 
- 
User Admin Service Specification 
- 
Configuration Admin Service Specification 
- 
Metatype Service Specification (only prepared) 
 
- 
In the following chapters, some core principles of OSGi and its adoption in JavaScript are explained. For in-depth understanding of the next sections, it is recommended to read the OSGi specifications or one of the OSGi books.
map.apps OSGi Runtime
The JavaScript (JS) OSGi runtime is running completely within the browser of the user. The ArcGIS API for JavaScript and the Dojo JavaScript Toolkit are used as base APIs. Components in the application can communicate with different backend systems, for example ArcGIS for Server, to execute different tasks.
map.apps is shipped with a backend server, which provides special performance enhancements and functionality, such as the app and app-template storage system. Nevertheless, this is fully optional and the JS OSGi runtime is independent of it.
Within the JS OSGi runtime, custom code is structured in modules. In OSGi terms, a module is called 'bundle'. Bundles might depend on other bundles and together they define the behavior of the application.
On an abstract level, each JS OSGi application consists of the following architectural layers:

- 
Module Layer: Defines how a bundle is structured and how it is resolved. 
- 
Module Lifecycle: Defines how bundles can be installed in the JS OSGi runtime and which lifecycle states they have. 
- 
Dynamic Service Layer: Defines how bundles can register/unregister/resolve services (logical components) in the JS OSGi runtime. 
- 
Declarative Components: Defines how services can be declared declaratively within bundles. 
- 
Configuration: Defines how the configuration process works and how it can be used to change configuration properties at runtime. 
- 
Application Infrastructure Modules: Defines the current base bundles needed to run an application in the browser. 
In the next chapters each of these layers is described in more detail.