Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/evscott/barcodelookup
A Node.js package that can retrieve data for EPC/EAN/ISBN formatted barcodes.
https://github.com/evscott/barcodelookup
barcode barcodelookup ean isbn javascript nodejs npm upc
Last synced: 3 months ago
JSON representation
A Node.js package that can retrieve data for EPC/EAN/ISBN formatted barcodes.
- Host: GitHub
- URL: https://github.com/evscott/barcodelookup
- Owner: evscott
- License: mit
- Created: 2019-05-04T17:28:17.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-03T08:14:47.000Z (about 2 years ago)
- Last Synced: 2024-10-04T21:10:13.443Z (3 months ago)
- Topics: barcode, barcodelookup, ean, isbn, javascript, nodejs, npm, upc
- Language: JavaScript
- Homepage: https://www.npmjs.com/package/barcodelookup
- Size: 146 KB
- Stars: 3
- Watchers: 3
- Forks: 1
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
![David](https://david-dm.org/evscott/barcodelookup.svg)
# barcodelookupAn installable Node.js package that easily handles [barcodelookup](https://www.barcodelookup.com/) requests.
### Prerequisites
1. Ensure that you have a valid API key provided by [barcodelookup](https://www.barcodelookup.com/api#sign-up).
2. Ensure that Node.js and npm is installed on your machine.
```
node --version // v11.14.0
npm --version // 6.9.0
```### Installing
Inside of your projects root directory, install the barcodelookup package using npm.
```
npm install barcodelookup
```## How to use
Inside any file of your project, import the barcodelookup package from node_modules.
```
const bc = require('barcodelookup');
```To make a request, call either [lookup](#lookup) or [rateLimits](#ratelimits) and provide the necessary arguments in a key-value object format to fulfill the request.
```
bc.lookup({
key: 'your api key',
barcode: 'some barcode to lookup'
});bc.rateLimits({
key: 'your api key'
});
```## Functions available
### lookup
`lookup` uses destructured parameters to accept arguments marked by the keys which barcodelookup accepts:
i.e. barcode, mpn, asin, key, etc.```
lookup({ barcode: barcode, mpn: mpn, asin: asin, productName: productName, category: category,
search: search, page: page, geo: geo, formatted: formatted, key: key })
````lookup` returns an object as a promise. The object will contain a status code
and either a data packet of products or an error message.```
{ statusCode: 200, data: { products: [ [Object] ] } }
...
{ statusCode: 403, data: 'Forbidden' }
...
{ statusCode: 404, data: 'Not Found' }
...
{ statusCode: 429, data: 'Too Many Requests' }
```Example product object:
```
{ products:
[ { barcode_number: '063652852403',
barcode_type: 'UPC',
barcode_formats: 'UPC 063652852403, EAN 0063652852403',
mpn: '063652852403',
model: '',
asin: '',
product_name: 'Crayola 24 Ultra Clean Washable Markers by Crayola',
title: 'Crayola 24 Ultra Clean Washable Markers by Crayola',
category:
'Sporting Goods > Outdoor Recreation > Golf > Golf Ball Markers',
manufacturer: 'Crayola',
brand: 'Crayola',
label: '',
author: '',
publisher: '',
artist: '',
actor: '',
director: '',
studio: '',
genre: '',
audience_rating: '',
ingredients: '',
nutrition_facts: '',
color: '',
format: '',
package_quantity: '',
size: '',
length: '',
width: '',
height: '',
weight: '',
release_date: '',
description:
'Crayola Washable markers are now Ultra Washable! Washable from skin, clothing and now from walls! Washability you can trust from the world's most washable marker!Markers that deliver superb colour coverage and lay down. The markers come in various degrees of washability and a wide variety of marker tips.Fine tip for outlining, writing and drawingInk washes easily from skin and fabricsMachine washable.',
features: [],
images: [Array],
stores: [Array],
reviews: [] } ] }
```See the official [barcodelookup api documentation](https://www.barcodelookup.com/api) for more information on returned fields.
### rateLimits
`rateLimits` queries the barcodelookup account registry to return account details pertaining to an api-key.```
rateLimits({ key: key })
````rateLimits` returns an object as a promise. The object will contain a status code
and either a data packet of account information or an error message.```
{ statusCode: 200,
data:
{ allowed_calls_per_month: '50',
remaining_calls_per_month: '48',
allowed_calls_per_minute: '50',
remaining_calls_per_minute: '49' } }
...
{ statusCode: 403, data: 'Forbidden' }
...
```See the official [barcodelookup api documentation](https://www.barcodelookup.com/api) for more information on returned fields.
## Built With
* [barcodelookup](https://www.barcodelookup.com/) - The barcode database.
* [node-fetch](https://www.npmjs.com/package/node-fetch) - The HTTP request framework.## Authors
* **[Eliot Scott](https://github.com/evscott)** - *Initial work*
* **[Robin C Samuel](https://github.com/robincsamuel)** - *Second contributor*See also the list of [contributors](https://github.com/evscott/barcodelookup/graphs/contributors) who participated in this project.
## License
This project is licensed under the MIT License - see the [LICENSE.md](LICENSE.md) file for details