This is a node.js API for integrating with the Domino's Pizza APIs. See the pretty Domino's Pizza API documentation
npm dominos info : See npm trends and stats for dominos
This work is licenced via the MIT Licence. It is a derivative work from Dominos API.
npm i dominos
npm i
(this will install required dependencies, depending on what your system may require)See the examples directory for simple apps and demonstrations on using the basic functionality.
For testing we have started using the extremely light vanilla-test
testing suite. It is a pretty bare-bones testing framework, but it works really well and simply with native ES6 and ESM. vanilla-test on npm
Simply run npm test
This will setup everything that is needed to run the tests, install the modules required and run the tests for you.
Remember, the Dominos API is rate limited, so if you make too many requests, like running tests back to back too many times, you may need to wait a short while before making new requests.
For coverage, we are using the amazing c8
coverage suite. It produces awesome instanbul style reports as well as lcov and much more. It allows testing of pure ES6 code without transpiling, and does not modify the code at all for coverage. It uses the built in node coverage tools to test the execution directly inside v8 c8 on npm
Simply run npm test
and the coverage files will be added to the ./coverage
directory automatically. You can start a local coverage server to view your results by running npm run coverage
. This will start a simple node-http-server
for your local coverage directory.
import {Order,Customer,Item,Payment,NearbyStores,Tracking} from 'dominos';
//extra cheese thin crust pizza
const pizza=new Item(
{
//16 inch hand tossed crust
code:'16SCREEN',
options:{
//sauce, whole pizza : normal
X: {'1/1' : '1'},
//cheese, whole pizza : double
C: {'1/1' : '1.5'},
//pepperoni, whole pizza : double
P: {'1/2' : '1.5'}
}
}
);
const customer = new Customer(
{
//this could be an Address instance if you wanted
address: '2 Portola Plaza, Monterey, Ca, 93940',
firstName: 'Brandon',
lastName: 'Miller',
//where's that 555 number from?
phone: '941-555-2368',
email: 'brandon@diginow.it'
}
);
let storeID=0;
let distance=100;
//find the nearest store
const nearbyStores=await new NearbyStores(customer.address);
//inspect nearby stores
//console.log('\n\nNearby Stores\n\n')
//console.dir(nearbyStores,{depth:5});
//get closest delivery store
for(const store of nearbyStores.stores){
//inspect each store
//console.dir(store,{depth:3});
if(
//we check all of these because the API responses seem to say true for some
//and false for others, but it is only reliably ok for delivery if ALL are true
//this may become an additional method on the NearbyStores class.
store.IsOnlineCapable
&& store.IsDeliveryStore
&& store.IsOpen
&& store.ServiceIsOpen.Delivery
&& store.MinDistance<distance
){
distance=store.MinDistance;
storeID=store.StoreID;
//console.log(store)
}
}
if(storeID==0){
throw ReferenceError('No Open Stores');
}
//console.log(storeID,distance);
//create
const order=new Order(customer);
// console.log('\n\nInstance\n\n');
// console.dir(order,{depth:0});
order.storeID=storeID;
// add pizza
order.addItem(pizza);
//validate order
await order.validate();
// console.log('\n\nValidate\n\n');
//console.dir(order,{depth:3});
//price order
await order.price();
// console.log('\n\nPrice\n\n');
// console.dir(order,{depth:0});
//grab price from order and setup payment
const myCard=new Payment(
{
amount:order.amountsBreakdown.customer,
// dashes are not needed, they get filtered out
number:'4100-1234-2234-3234',
//slashes not needed, they get filtered out
expiration:'01/35',
securityCode:'867',
postalCode:'93940',
tipAmount:4
}
);
order.payments.push(myCard);
//place order
try{
//will throw a dominos error because
//we used a fake credit card
await order.place();
console.log('\n\nPlaced Order\n\n');
console.dir(order,{depth:3});
const tracking=new Tracking();
const trackingResult=await tracking.byPhone(customer.phone);
console.dir(trackingResult,{depth:1});
}catch(err){
console.trace(err);
//inspect Order Response to see more information about the
//failure, unless you added a real card, then you can inspect
//the order itself
console.log('\n\nFailed Order Probably Bad Card, here is order.priceResponse the raw response from Dominos\n\n');
console.dir(
order.placeResponse,
{depth:5}
);
}
This is for those who wish to use the dominos api
in older code bases still using require
. While node v12+ is still required, see the detailed info and order example in CommonJS.md for how to include and use the module in your code.
(async () => {
const dominos=await import('dominos');
//importing variables into the global like this just allows us to use the same code
//from the ESM implementation for the commonJS implementation
//This is the same as an ESM import of
//import {Address,NearbyStores,Store,Menu,Customer,Item,Image,Order,Payment,Tracking,urls,IsDominos} from 'dominos'
Object.assign(global,dominos);
//need to await dominos promise completion
//because ES6 is async by nature
start();
})()
function start(){
//any of the ESM examples from the other docs will work as is here
//because we mimiced an ESM import above.
const n='\n';
console.log(
n,
Address,n,
NearbyStores,n,
Store,n,
Menu,n,
Customer,n,
Item,n,
Image,n,
Order,n,
Payment,n,
Tracking,n,
urls,n,
IsDominos,n
);
}
The module now supports using multiple sets of endpoints that we have in ./utils/urls.js
or even custom endpoints. However, if you get your country working with custom endpoints, PLEASE CONTRIBUTE THEM BACK! You will get credit as soon as your endpoints are merged back in.
See detailed information on how to use the international endpoints or custom endpoints here : International Dominos Endpoints and how to use them
USA is the default so you really don't need to do anything other than import {urls} from 'dominos';
if you want access to the USA endpoints.
import {urls} from 'dominos';
console.dir(urls);
//Or to reset the usa if you switched to custom or another country
import {urls} from 'dominos';
import {useInternational,canada,usa} from 'dominos/utils/urls.js';
//first set to canada so we can see it work since USA is default
useInternational(canada);
console.dir(urls);
//then set it back to usa so we can confirm it works
useInternational(usa);
console.dir(urls);
import {urls} from 'dominos';
import {useInternational,canada} from 'dominos/utils/urls.js';
useInternational(canada);
console.dir(urls);
import {urls} from 'dominos';
import {useInternational,canada} from 'dominos/utils/urls.js';
const myCountriesURLs={
referer :"https://order.dominos.nz/en/pages/order/",
sourceUri :"order.dominos.nz",
location:{
find:urls.location.find
},
store : {
find : "https://order.dominos.nz/power/store-locator?s=${line1}&c=${line2}&type=${type}",
info : "https://order.dominos.nz/power/store/${storeID}/profile",
menu : "https://order.dominos.nz/power/store/${storeID}/menu?lang=${lang}&structured=true"
},
order : {
validate: "https://order.dominos.nz/power/validate-order",
price : "https://order.dominos.nz/power/price-order",
place : "https://order.dominos.nz/power/place-order"
},
track : "https://order.dominos.nz/orderstorage/GetTrackerData?"
}
useInternational(myCountriesURLs);
console.log('MY COUSTOM FAKE NZ ENDPOINTS');
console.dir(urls);
See the detailed docs on addresses here : Address.md
import {Address} from 'dominos';
//full address examples
const address = new Address(
{
street:'900 Clark Ave',
city:'St. Louis',
region:'MO',
postalCode:'63102'
}
);
const address=new Address('900 Clark Ave, St. Louis, MO, 63102');
//partial address examples
const address = new Address(
{
street:'900 Clark Ave',
city:'St. Louis',
postalCode:'63102'
}
);
const address=new Address('900 Clark Ave, St. Louis, 63102');
//street and zip only examples
const fullAddressObject = new Address(
{
street:'900 Clark Ave',
postalCode:'63102'
}
);
const address=new Address('900 Clark Ave, 63102');
//zip only examples
const fullAddressObject = new Address(
{
postalCode:'63102'
}
);
const onlyZip = new Address('63102');
This provides a list of basic info on stores that are near an address.
See the detailed docs on finding nearby stores here : NearbyStores.md
import {NearbyStores, Store} from 'dominos';
const nearbyStores=await new NearbyStores('88 Colin P Kelly Jr St, 94107');
console.dir(nearbyStores,{depth:1});
console.log('\n\nFirst nearby store');
console.dir(nearbyStores.stores[0],{depth:1});
//initialize the frst of the nearbyStores.stores
const store=await new Store(nearbyStores.stores[0].StoreID);
console.log('\n\nFull Store info called from the first nearby stores ID');
console.dir(store,{depth:1});
This provides a detailed menu for a given store.
See the detailed docs on menus here : Menu.md
import {Menu} from 'dominos';
const menu=await new Menu(4337);
console.dir(menu,{depth:1});
This provides detailed store information.
See the detailed docs on stores here : Store.md
import {Store} from 'dominos';
const store=await new Store(4337);
console.dir(store,{depth:1});
Items are used to place orders.
See the detailed docs on items here : Item.md
import {Item} from 'dominos';
const pepperoniPizza=new Item(
{
code:'P_14SCREEN'
}
)
console.dir(pepperoniPizza);
This creates a customer object for use when making an order.
See the detailed docs on customers here : Customer.md
import {Customer} from 'dominos';
const customer = new Customer(
{
address: '900 Clark Ave, 63102',
firstName: 'Barack',
lastName: 'Obama',
phone: '1-800-555-2368',
email: 'chief@us.gov'
}
);
console.dir(customer);
The Image class will grab the image for a product code and base 64 encode it. It extends the js-base64-file
class.
See the detailed docs on the image here : Image.md
import {Image} from 'dominos';
const productCode='S_PIZPX';
const savePath='./';
const pepperoniPizza=await new Image(productCode);
console.log(pepperoniPizza.base64Image);
//you could pass this to a user via sms, web socket, http, tcp, make an ascii art for the terminal, OR save it to disk or a database
//here we just save it to disk as an example.
//this is part of the js-base64-file class refrence, there is a link at the top of this file
pepperoniPizza.saveSync(pepperoniPizza.base64Image,savePath,productCode+'.jpg');
This class will initialize a credit card payment object for an order.
See the detailed docs on payment here : Payment.md
import {Payment} from 'dominos';
const myCard=new Payment(
{
amount:10.77,
//dashes are not needed, they just make it easier to read
//the class sanitizes the data
number:'4444-4444-4444-4444',
expiration:'01/12',
securityCode:'867',
postalCode:'93940'
}
)
Finally... This class will order you pizza, and other things from the menu.
See the detailed docs on order here : Order.md
import {Order,Customer,Item,Payment} from 'dominos';
//extra cheese thin crust pizza
const pizza=new Item(
{
code:'14THIN',
options:{
//sauce, whole pizza : normal
X: {'1/1' : '1'},
//cheese, whole pizza : double
C: {'1/1' : '1.5'}
}
}
);
const customer = new Customer(
{
//this could be an Address instance if you wanted
address: '110 S Fairfax Ave, 90036',
firstName: 'Barack',
lastName: 'Obama',
//where's that 555 number from?
phone: '1-800-555-2368',
email: 'chief@us.gov'
}
);
//create
const order=new Order(customer);
order.storeID=8244;
// add pizza
order.addItem(pizza);
//validate order
await order.validate();
//price order
await order.price();
//grab price from order and setup payment
const myCard=new Payment(
{
amount:order.amountsBreakdown.customer,
// dashes are not needed, they get filtered out
number:'4100-1234-2234-3234',
//slashes not needed, they get filtered out
expiration:'01/35',
securityCode:'867',
postalCode:'93940'
}
);
order.payments.push(myCard);
//place order
await order.place();
//inspect Order
console.dir(order,{depth:5});
//you probably want to add some tracking too...
This is how you track Pizzas! (and other things)
You can track its progress, who is working on it, who your delivery person is, and how many stops they have before you use this Class.
If there are no orders for a given phone number, it will throw a DominosTrackingError
.
import {Tracking} from 'dominos';
const tracking=new Tracking();
const trackingResult=await tracking.byPhone('3108675309');
console.dir(trackingResult,{depth:1});
This class extends strong-type
to allow strong and weak type checking of dominos specific types, errors and classes. It is used a lot in the dominos
module to ensure correct types of arguments and errors. The strong-type
module is really cool.
See the DominosTypes.md for more information.
import {IsDominos,Address} from 'dominos'
isDominos=new IsDominos;
let address='bob';
//address is a string so this will throw an Error
try{
isDominos.address(address);
}catch(err){
console.trace(err);
}
address=new Address('1 alvarado st, 93940');
//will not throw because this is an Address instance
isDominos.address(address);
These custom errors are added to the global object for use in your code and the dominos
API. You can use them to validate errors or even throw your own if you are making a module ontop of this one.
See the detailed docs on DominosErrors here : DominosErrors.md
error | parameters | description |
---|---|---|
DominosValidationError | .validationResponse |
this error is thrown when a dominos validation request fails |
DominosPriceError | .priceResponse |
this error is thrown when a dominos price request fails |
DominosPlaceOrderError | .placeOrderResponse |
this error is thrown when a dominos place request fails |
DominosTrackingError | message string | this error is thrown when no trackable orders are found for a phone number |
DominosAddressError | message string | this error is thrown when an issue is detected with a dominos address |
DominosDateError | message string | this error is thrown when an issue is detected with a date being used for a dominos order |
DominosStoreError | message string | this error is thrown when an issue is detected with a store being used for a dominos order |
DominosProductsError | message string | this error is thrown when an issue is detected with an orders product list |