Embedded API
Obsidian 2.3 introduced a new unified Embedded API which contains all the same actions and semantics as the REST API. It replaces the old Legacy API.
This API is accessible through Java, and can be used in software environments where the REST API is unavailable or undesired.
Javadoc is also available to supplement this page.
Overview
The Obsidian Embedded API allows your application a way to access Obsidian data, schedule jobs, and control Obsidian in a variety of ways.
The API gives users the power to do things like initialize scheduled jobs at deployment time, trigger jobs based on events in your applications, and expose pieces of the Obsidian API in their own custom user interfaces.
Accessing the API
The Embedded API is written in Java and can be be accessed within the context of a running Obsidian node, although the scheduler itself need not be active.
In addition, it can be embedded in applications that are not running Obsidian, simply by including Obsidian's dependent libraries and properties file.
Authorization
The Embedded API is not secured, though all actions accept an audit user which is linked to actions which modify Obsidian state. Any code that has access to the Obsidian database via its defined credentials can manipulate Obsidian job configurations.
Transactions
By default, when you invoke actions within the API, each individual call is in its own transaction which is committed when successful, and rolls back on failure.
However, you can wrap multiple API calls into a single transaction, so you get one unit of work which either is fully committed or rolled back. An example is shown below. For full semantics, see AbstractAPIManager.withTransaction.
final String auditUser = "Bob";
List<HostDetail> updated = new HostManager().withTransaction(auditUser, new Callable<<HostDetail>>() {
public List<HostDetail> call() throws Exception {
// disable some hosts in an atomic manner (does not have to be the same instance of even type of Manager class)
HostDetail hostA = new HostManager().updateHost("hostA", new HostUpdateRequest().withEnabled(false), auditUser );
HostDetail hostB = new HostManager().updateHost("hostB", new HostUpdateRequest().withEnabled(false), auditUser );
// this is within the same transaction
new JobManager().resubmitRuntime(jobToResubmit, auditUser);
return Arrays.asList(hostA, hostB);
}
});
System.out.println("Updated hosts: " + updated);
API Basics
The API is exposed through Manager classes in the package com.carfey.ops.api.embedded:
JobManager- Create and manage jobs.RuntimeManager- List job runtime history, resubmit jobs, preview scheduled times, etc.HostManager- Manage and list active scheduling hosts (i.e. nodes).CustomCalendarManager- Manage custom calendars.
To invoke an API method, simply create a new Manager instance, and invoke the appropriate method:
RuntimeListing recentRuntimes = new RuntimeManager().listRuntimes(new RuntimeListingParameters());
You can reuse manager instances if you like, but it is ultimately up to your preference, as it offers no clear benefit.
Exceptions
API calls generally throw three types of exceptions:
- ValidationException - some sort of validation error occurred.
- MissingEntityException - The requested entity could not be found by the ID supplied.
- All other Exception types - some other type of error that you probably can't do much with (database issues, etc.).
When integrating the API into your application, you may wish to apply appropriate handling to ValidationException and MissingEntityException, but otherwise you can treat exceptions as a generic server errors.
API Details
This section documents all the operations that the Embedded API exposes, through the various manager classes.
JobManager
Coming soon
RuntimeManager
Coming soon
HostManager
Coming soon
CustomCalendarManager
Coming soon