This Library wraps calls to Airbnb's API endpoints using v2 where possible (HostAPI
mainly uses v2 for CRUD).
There are three main API classes:
PublicAPI
- All calls can be made with authenticationUserAPI
- Calls that an Airbnb user would do (requires auth)HostAPI
- Create, update and delete listings (requires auth)
All methods return a Promise<Object>
.
npm i oenomaus -S
import { PublicAPI, UserAPI, HostAPI } from 'oenomaus';
const publicApi = new PublicAPI();
const userApi = new UserAPI(access_token);
const hostApi = new PublicAPI(access_token);
import { PublicAPI } from 'oenomaus';
const api = new PublicAPI(); // <-- No access_token required
api.loginByEmail('some@email.com', 'password123')
.then({ access_token } => {
console.log(access_token);
});
import { HostAPI } from 'oenomaus';
const api = new HostAPI(access_token); // <-- access_token required
// all calls will be authenticated
api.createListing({
name: 'Beautiful Apartment w Opera House views'
city: 'Sydney',
state: 'NSW',
country_code: 'AU',
});
UserAPI
and HostAPI
both require the access_token
to be passed to the constructor.
NOTE: API will return an APIError
if you request authorization too often (as it's throttled by Airbnb); best to cache the access_token
;
Please see the Source Code and the tests for details. The source uses Flow Type Checker where possible which should help you understand the method options.
To aid development, some of the Airbnb types have been declared using an Enum:
import {
PropertyTypes,
RoomTypes,
BedTypes,
CommonAmenities,
ExtraAmenities,
HomeSafetyAmenities,
HostPreferencesAmenities,
} from 'oenomaus';
console.log(PropertyTypes.HOUSE > PropertyTypes.APARTMENT);
// true
console.log(PropertyTypes.HOUSE !== PropertyTypes.APARTMENT);
// true
console.log(BedTypes.REAL_BED.name);
// REAL_BED
console.log(RoomTypes.ENTIRE_HOME.display);
// Entire home/apt
console.log(RoomTypes.ENTIRE_HOME.vale);
// entire_home
console.log(CommonAmenities.ESSENTIALS.value);
// 40
We built this API as part of a fully featured Short Term Rental Management System; this system was code named: Spartacus. Oenomaus became one of the leaders of rebellious slaves during the Third Servile War (alongside Spartacus).
Thanks to @nrahnemoon who created the original documentation that this API is based.