Nebula is a development framework for Salesforce's Apex language on the Force.com platform. It aims to...
- Provide a foundation for Apex development, with the flexibility to be easily adapted to meet your implementation needs
- Promote the design of scalable, bulkified code
- Standardise how your code is written & organised
- Overcome some gaps in Apex and the Force.com platform
Nebula focusses on streamlining how you work with SObjects
- SObjectRepository.cls - this module handles all DML actions & querying needs for an SObject, making the implementation of SObjects much easier & faster
- QueryBuilder.cls powers Nebula's querying, allowing you to dynamically build reusable SOQL & SOSL queries
- SObjectRepositoryMock.cls can be used in unit tests for test-driven development (TDD) & to drastically reduce the time of your unit tests.
 
- SObjectTriggerHandler.cls - this module provides a trigger framework to handle all trigger contexts provided by Salesforce, along with additional features like recursion prevention
The framework also provides several additional classes to make development easier
- SObjectRecordTypes.cls - record types are an important feature of the Force.com platform. Unfortunately, Apex has limitations with handling them - record types have a field called DeveloperName that (you guessed it!) should be used by developers... but native Apex describe methods cannot access this field. Nebula tries to overcome this by providing cacheable query results of record types so you can access the DeveloperName.
- Logger.cls - a flexible logging solution for Apex, leveraged by the framework itself
- Environment.cls - provides information about the current Salesforce environment
- UUID.cls - used to reate a randomly-generated unique ID in your code, using the Universally Unique Identifier (UUID) standard
Nebula uses interfaces, virtual & abstract classes and some Salesforce features (like custom settings) to provide a baseline for your own Apex development. You can deploy the latest version of Nebula to your org and build your implementation on top of it. If you want to customise how Nebula works, most classes & methods can be overridden with your own logic. Ideally, you should minimise any code changes to Nebula's classes so that you can easily upgrade in the future when new versions of Nebula are released.
Nebula also leverages custom settings to give you control over how the framework works within your Salesforce environment. There are 4 settings
- Logger Settings (API Name: NebulaLoggerSettings__c)
- Enable or disable logging
 
- Record Type Settings (API Name: NebulaRecordTypesSettings__c)
- Choose how record types are cached
- Select if you want to include managed record types
 
- Repository Settings (API Name: NebulaRepositorySettings__c)
- Automatically include common fields in your queries, like record ID, audit fields (CreatedById, CreatedDate, etc), Name field (or Subject field, where applicable) and more
 
- Trigger Handler Settings (API Name: NebulaTriggerHandlerSettings__c)
- Easily disable all triggers & handlers (great for data migration and other admin tasks),
- Enable or disable recursion prevention
 
Releases are versioned using Semantic Versioning in the format 'v1.0.2' (MAJOR.MINOR.PATCH):
- MAJOR version when incompatible API changes are made
- MINOR version new functionality is added in a backwards-compatible manner
- PATCH version when backwards-compatible bug fixes are made