Research
Security News
Malicious npm Packages Inject SSH Backdoors via Typosquatted Libraries
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
This is a node.js wrapper for the Domino's pizza APIs.
The dominos
module is the latest release and pizzapi
should provide the dev release from our pizzapi development branch this branch is maintained by madelinecameron.
See the pretty PizzaPI documentation
PAYMENT-SUPPORTED-MODULE
This module will pass payment information directly from the customer to Domino's Pizza for Domino's Pizza to process.
npm dominos info : See npm trends and stats for dominos
PAYMENT-DISSALLOWED-MODULE
For individuals who wish to test without the risk of actually purchasing @madelinecameron, a major contributor to this repo and module have created the npm pizzapi module it is the same as the dominos
module but has no built in method to purchase, you would need to manually create the payment object to send to Domino's Pizza.
See npm trends and stats for pizzapi
This work is licenced via the DBAD Public Licence. It is a derivative work from Dominos API.
payments are allowed and will purchase Pizza npm install dominos
no payments allowed, no actual pizza purchases npm install pizzapi
npm install
(this will install required dependancies, depending on your system may require)You can run the domino's pizza command line interface from your terminal just by running npm start
! See the example in the examples directory.
See the examples directory for simple apps and demonstrations on using the basic functionality.
Simply run npm test
if you have issues with this you may want to try installing mocha globally like this : npm install -g mocha
-OR for manual testing-
npm install -g mocha
mocha
argument | type | default | required |
---|---|---|---|
address | full or partial address string | null | true |
type | Delivery, Carryout, all | all | true |
callback | function to pass the api result to | null | true |
Note: the 'address' parameter is passed to the Address class. This means any formatting that works for Address will work being passed here. This means you can pass JSON, array or string.
this yields the least accurate information
```javascript
var pizzapi=require('dominos'); // or without payment option : var pizzapi=require('pizzapi');
pizzapi.Util.findNearbyStores(
'63102',))
'Delivery',
function(storeData){
console.log(storeData);
}
);
```
this yields less accurate information but is better than just using the postal code
var pizzapi=require('dominos'); // or without payment option : var pizzapi=require('pizzapi');
pizzapi.Util.findNearbyStores(
'St. Louis, MO, 63102',
'Delivery',
function(storeData){
console.log(storeData);
}
);
this yields the best information and sorts stores by actual distance
var pizzapi=require('dominos'); // or without payment option : var pizzapi=require('pizzapi');
pizzapi.Util.findNearbyStores(
'700 Clark Ave, St. Louis, MO, 63102',
'Delivery',
function(storeData){
console.log(storeData);
}
);
argument | type | default | required |
---|---|---|---|
ID | Integer | null | true |
//Get Store Info for Store #4336
var pizzapi=require('dominos'); // or without payment option : var pizzapi=require('pizzapi');
var myStore=new pizzapi.Store();
myStore.ID=4336;
myStore.getInfo(
function(storeData){
console.log(storeData);
}
);
```
### Store menu
|argument|type|default|required|
|--------|----|-------|--------|
|callback|function|null|true |
```javascript
//Get Menu for Store #4336
var pizzapi=require('dominos'); // or without payment option : var pizzapi=require('pizzapi');
var myStore=new pizzapi.Store();
myStore.ID=4336;
myStore.getMenu(
function(storeData){
console.log(storeData);
}
);
argument | type | default | required |
---|---|---|---|
callback | function | null | true |
//Get Info for Store #4336
var pizzapi=require('dominos'); // or without payment option : var pizzapi=require('pizzapi');
var myStore=new pizzapi.Store();
myStore.ID=4336;
myStore.getInfo(
function(storeData){
console.log(storeData);
}
);
argument | type | default | required |
---|---|---|---|
callback | function | null | true |
Returns a list of all items the store offers in an JSON array, formatted {Code: Friendly Name}
//Get friendly name menu for Store #4336
var pizzapi=require('dominos'); // or without payment option : var pizzapi=require('pizzapi');
var myStore=new pizzapi.Store();
myStore.ID=4336;
myStore.getFriendlyNames(
function(storeData){
console.log(storeData);
}
);
When creating a new Address object, there are many ways to instantiate the object!
The following are examples of the methods:
var fullAddress = new Address('900 Clark Ave, St. Louis, MO, 63102');
//or
var partAddress = new Address('St. Louis, MO, 63102');
//or
var stateAndZip = new Address('St. Louis, 63102');
//or
var cityAndZip = new Address('St. Louis, 63102');
//only zip
var onlyZip = new Address('63102');
var jsonAddress = new Address(
{
Street: '900 Clark Ave',
City: 'St. Louis',
Region: 'MO',
PostalCode: 63102
}
);
var arrayAddress = new Address(['900 Clark Ave', 'St. Louis', 'MO', '63102']);
argument | type | default |
---|---|---|
address | Address | null |
firstName | String | '' |
lastName | String | '' |
String | '' | |
phone | String | '' |
var customer = new Customer(
{
address: someAddressObj,
firstName: 'Barack',
lastName: 'Obama',
phone: '1-800-The-White-House',
email: 'br'
}
)
You can get the codes from one of the menu requests.
argument | type | default |
---|---|---|
code | String | null |
quantity | Integer | 1 |
options | Array | [] |
var newItem = new Item(
{
code: '14SCREEN'
}
);
//and so on...
This is the class that every other class feeds into.
argument | type | default |
---|---|---|
code | String | null |
quantity | Integer | 1 |
options | Array | [] |
var pizzapi=require('dominos'); // or without payment option : var pizzapi=require('pizzapi');
var thePresident = new pizzapi.Customer(
{
firstName: 'Barack',
lastName: 'Obama',
address: '700 Pennsylvania Avenue, Washington, DC',
email: 'barack@whitehouse.gov'
}
);
var order = new pizzapi.Order(
{
customer: thePresident,
//optional set the store ID right away
storeID: myStore.ID,
deliveryMethod: 'Delivery' //(or 'Carryout')
}
);
//or
var order = new pizzapi.Order();
order.FirstName=data;
order.LastName=data;
order.Email=data;
order.Phone=data;
//and if you want to update the store id just :
order.StoreID=myStore.ID;
var anotherIdenticalOrder = new pizzapi.Order(
{
order:order
//or
//Order:order
//because domino's pizza web API returns pascal case...
}
);
//or create a duplicate order WITH different customer params
var order = new pizzapi.Order(
{
customer: thePresident,
deliveryMethod: 'Delivery' //(or 'Carryout')
}
);
order.addItem(
new pizzapi.Item(
{
code: '14SCREEN',
options: [],
quantity: 1
}
)
);
This step is Strongly recommended
order.validate(
function(result) {
console.log("We did it!");
}
);
order.price(
function(result) {
console.log("Price!")
}
);
At least one item must've been added to place an order.
You don't have to do anything for the payment, Domino's Pizza will handle all transactions.
var pizzapi=require('dominos');
var cardNumber='4100123422343234';
var cardInfo = new order.PaymentObject();
cardInfo.Amount = order.Amounts.Customer;
cardInfo.Number = cardNumber;
cardInfo.CardType = order.validateCC(cardNumber);
cardInfo.Expiration = '0115';// 01/15 just the numbers "01/15".replace(/\D/g,'');
cardInfo.SecurityCode = '777';
cardInfo.PostalCode = '90210'; // Billing Zipcode
order.Payments.push(cardInfo);
order.place(
function(result) {
console.log("Order placed!");
}
);
// if you want no accidental purchase or liability use the pizzapi module!
var pizzapi=require('pizzapi');
order.place(
function(result) {
console.log("Order placed!");
}
);
argument | type | default | required |
---|---|---|---|
phone | Phone number string or int | null | true |
callback | function to pass the api result to | null | true |
var pizzapi=require('dominos'); // or without payment option : var pizzapi=require('pizzapi');
pizzapi.Track.byPhone(
2024561111,
function(pizzaData){
console.log(pizzaData);
}
);
argument | type | default | required |
---|---|---|---|
orderKey | string or int | null | true |
storeID | sting or int | null | true |
callback | function to pass the api result to | null | true |
var pizzapi=require('dominos'); // or without payment option : var pizzapi=require('pizzapi');
pizzapi.Track.byId(
123456,
12345,
function(pizzaData){
console.log(pizzaData)
}
);
Code, Order, Eat, Be Happy!
FAQs
node js API for Domino's pizza
We found that dominos demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 5 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.