Uber Rides Node.js Wrapper
This projects helps you to make HTTP requests to the Uber Rides API.
Installation
Before you begin, you need to register your app in the Uber developer dashboard. Notice that the app gets a client ID, secret, and server token required for authenticating with the API.
After registering your application, you need to install this module in your Node.js project:
npm install node-uber
Initialization
In order to use this module, you have to import it in your application first:
var Uber = require('node-uber');
Next, initialize the Uber object with the keys you obtained from the Uber developer dashboard:
var uber = new Uber({ client_id: 'CLIENT_ID', client_secret: 'CLIENT_SECRET', server_token: 'SERVER_TOKEN', redirect_uri: 'REDIRECT URL', name: 'APP_NAME', language: 'en_US', // optional, defaults to en_US sandbox: true, // optional, defaults to false proxy: 'PROXY URL' // optional, defaults to none});
Note: For all available
language
options check out the Localization page of the API.
Authenticating
To make HTTP calls, you need to create an authenticated session with the API. User-specific operations require you to use a OAuth 2 bearer token with specific scopes. Jump to the method overview section to identify required scopes for methods. General operations can use a simple server-token authentication.
Step one: Authorize
To obtain an OAuth 2 bearer token, you have to authorize your application with the required scope. Available scopes are: history
, history_lite
, profile
, request
, all_trips
, and places
.
To do so, you are initially required to redirect your user to an authorization URL. You can generate the authorization URL using uber.getAuthorizeUrl
. In case you are using Express, your route definition could look as follows:
app;
The URL will lead to a page where your user will be required to login and approve access to his/her Uber account. In case that step was successful, Uber will issue an HTTP 302 redirect to the redirect_uri defined in the Uber developer dashboard. On that redirect, you will receive an authorization code, which is single use and expires in 10 minutes.
Step two: Receive redirect and get an access token
To complete the authorization you now need to receive the callback and convert the given authorization code into an OAuth access token. You can accomplish that using uber.authorizationAsync
. This method will retrieve and store the access_token, refresh_token, authorized scopes, and token expiration date within the uber object for consecutive requests.
Using Express, you could achieve that as follows:
app;
Nodeback: Looking for nodeback-style methods? Check out the nodeback-readme.
Step three: Make HTTP requests to available resources
Now that you are authenticated, you can issue requests using provided methods.
For instance, to obtain a list of available Uber products for a specific location, you can use uber.products.getAllForLocationAsync
.
In case you are using Express, your route definition could look as follows:
app;
Optional: Revoke user access (token)
If your users decide to disconnect or revoke access to their Uber accounts, you can use the uber.revokeTokenAsync
method. This will invalidate either access_token
or refresh_token
. Note that per RFC7009, revoke will return success for any string you pass into the function provided the client_id and client_secret are correct. This includes previously revoked tokens and invalid tokens.
uber;
Method Overview
Nodeback: Looking for nodeback-style methods? Check out the nodeback-readme.
Riders API
HTTP Method | Endpoint | Auth Method | Required Scope | Methods |
---|---|---|---|---|
GET | /v1.2/products | OAuth or server_token | products.getAllForAddressAsync | |
GET | /v1.2/products | OAuth or server_token | products.getAllForLocationAsync | |
GET | /v1.2/products/{product_id} | OAuth or server_token | products.getByIDAsync | |
PUT | /v1.2/sandbox/products/{product_id} | OAuth or server_token | (Sandbox mode) | products.setSurgeMultiplierByIDAsync |
PUT | /v1.2/sandbox/products/{product_id} | OAuth or server_token | (Sandbox mode) | products.setDriversAvailabilityByIDAsync |
GET | /v1.2/estimates/price | OAuth or server_token | estimates.getPriceForRouteAsync | |
GET | /v1.2/estimates/price | OAuth or server_token | estimates.getPriceForRouteByAddressAsync | |
GET | /v1.2/estimates/time | OAuth or server_token | estimates.getETAForAddressAsync | |
GET | /v1.2/estimates/time | OAuth or server_token | estimates.getETAForLocationAsync | |
GET | /v1.2/history | OAuth | history or history_lite | user.getHistoryAsync |
GET | /v1.2/me | OAuth | profile | user.getProfileAsync |
PATCH | /v1.2/me | OAuth | profile | user.applyPromoAsync |
POST | /v1.2/requests | OAuth | request (privileged) | requests.createAsync |
GET | /v1.2/requests/current | OAuth | request (privileged) or all_trips (privileged) | requests.getCurrentAsync |
PATCH | /v1.2/requests/current | OAuth | request (privileged) | requests.updateCurrentAsync |
DELETE | /v1.2/requests/current | OAuth | request (privileged) | requests.deleteCurrentAsync |
POST | /v1.2/requests/estimate | OAuth | request (privileged) | requests.getEstimatesAsync |
GET | /v1.2/requests/{request_id} | OAuth | request (privileged) | requests.getByIDAsync |
PATCH | /v1.2/requests/{request_id} | OAuth | request (privileged) | requests.updateByIDAsync |
PUT | /v1.2/sandbox/requests/{request_id} | OAuth | request (privileged & Sandbox mode ) | requests.setStatusByIDAsync |
DELETE | /v1.2/requests/{request_id} | OAuth | request (privileged) | requests.deleteByIDAsync |
GET | /v1.2/requests/{request_id}/map | OAuth | request (privileged) | requests.getMapByIDAsync |
GET | /v1.2/requests/{request_id}/receipt | OAuth | request_receipt (privileged) | requests.getReceiptByIDAsync |
GET | /v1.2/places/{place_id} | OAuth | places | places.getHomeAsync and places.getWorkAsync |
PUT | /v1.2/places/{place_id} | OAuth | places | places.updateHomeAsync and places.updateWorkAsync |
GET | /v1.2/payment-methods | OAuth | request (privileged) | payment.getMethodsAsync |
Drivers API
HTTP Method | Endpoint | Auth Method | Required Scope | Methods |
---|---|---|---|---|
GET | /v1/partners/me | OAuth | partner.accounts | partnerprofile.getProfileAsync |
GET | /v1/partners/payments | OAuth | partner.payments | partnerpayments.getPaymentsAsync |
GET | /v1/partners/trips | OAuth | partner.trips | partnertrips.getTripsAsync |
Endpoint Details
Authorization (OAuth 2.0)
Generate Authorize URL
After getting the authorize url, the user will be redirected to the redirect url with authorization code used in the next function.
uber;
Parameter
- Array of scopes
Example
uber;
Authorize
Used to convert authorization code or refresh token into access token.
uber;
Parameter
- JS Object with attribute
authorization_code
ORrefresh_token
Example: Just access_token
uber ;});
Example: All properties
uber ;});
/products
The product endpoint can be accessed either with an OAuth access_token
or simply with the server_token
because it is not user-specific. It has, therefore, no required scope for access.
Get available products for address
This method utilizes geocoder to retrieve the coordinates for an address using Google as the provider. It uses the first element of the response. In other words, the coordinates represent what the Google algorithm provides with most confidence value.
Note: To ensure correct coordinates you should provide the complete address, including city, ZIP code, state, and country.
uberproducts;
Example
uberproducts;
Get available products for location
uberproducts;
Example
uberproducts;
Get product details by product_id
uberproducts;
Example
uberproducts;
Set driver's availability by product_id
uberproducts;
Note: This method is only allowed in Sandbox mode.
Parameter
- availability (boolean) will force requests to return a
no_drivers_available
error if set to false
Example
uberproducts;
Set surge multiplier by product_id
uberproducts;
Note: This method is only allowed in Sandbox mode.
Parameter
- multiplier (float) will force two stage confirmation for requests if > 2.0
Example
uberproducts;
/estimates
The estimates endpoint can be accessed either with an OAuth access_token
or simply with the server_token
because it is not user-specific. It has, therefore, no required scope for access.
Get price estimates for specific address
This method utilizes geocoder to retrieve the coordinates for an address using Google as the provider. It uses the first element of the response. In other words, the coordinates represent what the Google algorithm provides with most confidence value.
Note: To ensure correct coordinates you should provide the complete address, including city, ZIP code, state, and country.
uberestimates;
seats
defaults to 2, which is also the maximum value for this parameter.
Example
uberestimates ;
Get price estimates for specific route
uberestimates;
seats
defaults to 2, which is also the maximum value for this parameter.
Example
uberestimates;
Get ETA for address
This method utilizes geocoder to retrieve the coordinates for an address using Google as the provider. It uses the first element of the response. In other words, the coordinates represent what the Google algorithm provides with most confidence value.
Note: To ensure correct coordinates you should provide the complete address, including city, ZIP code, state, and country.
uberestimates;
Example
uberestimates;});
Get ETA for location
uberestimates;
Example
uberestimates;
/history
The history endpoint can be accessed ONLY with an OAuth access_token
authorized with either the history
or history_lite
(without city information) scope.
Get user activity
uberuser;
offset
defaults to 0 and limit
defaults to 5 with a maximum value of 50.
Example
uberuser;
/me
The me endpoint can be accessed ONLY with an OAuth access_token
authorized with the profile
scope.
Get user profile
uberuser;
Example
uberuser;
Apply promo code to user account
uberuser;
Parameter
- user promotion code (string)
Example
uberuser;
/requests
The requests endpoint can be accessed ONLY with an OAuth access_token
authorized with the request
scope.
Create new request
uberrequests;
Parameter
- JS Object with at least the following attributes:
start_latitude
&start_longitude
ORstart_place_id
end_latitude
&end_longitude
ORend_place_id
- The key for the upfront fare of a ride (
fare_id
)
- You can provide
startAddress
instead ofstart_latitude
&start_longitude
andendAddress
instead ofend_latitude
&end_longitude
thanks to geocoder
Note: To ensure correct coordinates you should provide the complete address, including city, ZIP code, state, and country.
Example
uberrequests;
Get current request
Note: By default, only details about trips your app requested will be returned. This endpoint can be used with the scope
all_trips
to get all trips irrespective of which application initiated them.
uberrequests;
Example
uberrequests;
Update current request
uberrequests;
Parameter
- JS Object with attributes to be updated (only destination-related attributes enabled)
- You can provide
startAddress
instead ofstart_latitude
&start_longitude
andendAddress
instead ofend_latitude
&end_longitude
thanks to geocoder
Note: To ensure correct coordinates you should provide the complete address, including city, ZIP code, state, and country.
Example
uberrequests;
Delete current request
uberrequests;
Example
uberrequests;
Get estimates
uberrequests;
Parameter
- JS Object with at least the following attributes:
start_latitude
&start_longitude
ORstart_place_id
end_latitude
&end_longitude
ORend_place_id
- You can provide
startAddress
instead ofstart_latitude
&start_longitude
andendAddress
instead ofend_latitude
&end_longitude
thanks to geocoder
Note: To ensure correct coordinates you should provide the complete address, including city, ZIP code, state, and country.
Example
uberrequests;
Get request by request_id
uberrequests;
Example
uberrequests;
Update request by request_id
uberrequests;
Parameter
- JS Object with attributes to be updated (only destination-related attributes enabled)
- You can provide
startAddress
instead ofstart_latitude
&start_longitude
andendAddress
instead ofend_latitude
&end_longitude
thanks to geocoder
Note: To ensure correct coordinates you should provide the complete address, including city, ZIP code, state, and country.
Example
uberrequests;
Set request status by request_id
uberrequests;
Note: This method is only allowed in Sandbox mode. Check out the documentation for valid status properties.
Example
uberrequests;
Delete request by request_id
uberrequests;
Example
uberrequests;
Get request map by request_id
uberrequests;
Unless the referenced request is in status accepted
, a 404 error will be returned.
Example
uberrequests;
Get request receipt by request_id
Note: This endpoint requires OAuth authentication with the scope
request_receipt
uberrequests;
The referenced request must be in status completed
.
Example
uberrequests;
/places
The places endpoint can be accessed ONLY with an OAuth access_token
authorized with the places
scope.
Note: As of right now, only two place_ids are allowed:
home
andwork
.
Get home address
uberplaces;
Example
uberplaces;
Get work address
uberplaces;
Example
uberplaces;
Update home address
uberplaces;
Example
uberplaces;
Update work address
uberplaces;
Example
uberplaces;
/payment-methods
The payment-methods endpoint can be accessed ONLY with an OAuth access_token
authorized with the request
scope.
Get available payment methods
uberpayment;
Example
uberpayment;
/partners
The partners endpoints (Driver API) can be accessed ONLY with an OAuth access_token
authorized with the respective scopes (partner.accounts
, partner.trips
, or partner.payments
).
Get driver profile
uberpartnerprofile;
Example
uberpartnerprofile;
Get driver payments
uberpartnerpayments;
Parameter
- offset for payments list (sorted by creation time). Defaults to
0
- limit of payments list. Defaults to
5
- minimum Unix timestamp for filtered payments list
- maximum Unix timestamp for filtered payments list
Example
uberpartnerpayments;
Get driver trips
uberpartnertrips;
Parameter
- offset for trips list (sorted by creation time). Defaults to
0
- limit of trips list. Defaults to
5
- minimum Unix timestamp for filtered trips list
- maximum Unix timestamp for filtered trips list
Example
uberpartnertrips;
Test
You can execute all existing tests using script test/allTests.js
. These tests include linting, code coverage, and unit tests.
npm test
In case you would like to contribute to this project, please ensure that all the tests pass before you create a PR. We have strict code style and code coverage (>= 95%) requirements.
Version History
The change-log can be found in the Wiki: Version History.