wiki:GeniApi

Version 16 (modified by tmitchel@bbn.com, 13 years ago) (diff)

--

The GENI API

The GENI API is an effort to enable interoperability between Control Frameworks/Clearinghouses and Aggregates.

The GENI API implements a key interface of the SFA 2.0 Draft, providing a common interface to Aggregate Managers. Experimenters can use the API to access resources belonging to any compliant Control Framework. The API lets you mix and match aggregates with control frameworks.

ProtoGENI, PlanetLab, and Openflow all have implemented the API and are now interoperable, as demonstrated at GEC8 (mostly).

The ProtoGENI implementation is live in Utah, and is part of emulab-stable. Contact the mailing list (geni-dev@emulab.net) with questions on using it.

The PlanetLab implementation is on trunk. To run it on your MyPLC instance, follow the upgrade instructions? and use the mailing list: devel@planet-lab.org for questions. PLC rollout is expected, but requires some careful coordination.

Contact OpenFlow for availability of the OpenFlow implementation of this API.

The GPO has developed a reference implementation of this API, particularly demonstrating the use of certificates, credentials and credential verification. Also provided is a reference client, omni. Omni communicates with each clearinghouse in its 'native tongue', and then calls the Aggregate Manager API at any compliant Aggregate. These packages are available together for download here: Download Sample Code.

Experimenters should begin designing and conducting experiments that take advantage of the broad variety of resources now available to them. Contact Mark Berman and the Experimentation Working Group with questions.

Full details on the API specification are available here: GENI Aggregate Manager API

Questions? Comments? Suggestions? Contact Tom Mitchell (tmitchell) or Josh Karlin (jkarlin) or Aaron Helsinger (ahelsing) at geni.net