UNPKG

google-images

Version:

Search images using Google Custom Search Engine API

146 lines (84 loc) 3.7 kB
# google-images [![Build Status](https://travis-ci.org/vadimdemedes/google-images.svg?branch=master)](https://travis-ci.org/vadimdemedes/google-images) > Search images using Google Custom Search Engine API. ## Installation ``` $ npm install --save google-images ``` ## Usage **Note**: You'll need to [set up your own Google Custom Search Engine](#set-up-google-custom-search-engine) to execute queries. ```js const GoogleImages = require('google-images'); const client = new GoogleImages('CSE ID', 'API KEY'); client.search('Steve Angello') .then(images => { /* [{ "url": "http://steveangello.com/boss.jpg", "type": "image/jpeg", "width": 1024, "height": 768, "size": 102451, "thumbnail": { "url": "http://steveangello.com/thumbnail.jpg", "width": 512, "height": 512 } }] */ }); // paginate results client.search('Steve Angello', {page: 2}); // search for certain size client.search('Steve Angello', {size: 'large'}); ``` ## API Please see Google's [API documentation](https://developers.google.com/custom-search/json-api/v1/reference/cse/list#parameters) for details on the option and response properties and their possible values. Note that the option names used here may differ slightly (e.g. no `img` prefix). ### Client(engineId, apiKey) #### engineId Type: `string` The [identifier](https://developers.google.com/custom-search/json-api/v1/overview#prerequisites) for a Custom Search Engine to use. #### apiKey Type: `string` The [credentials](https://support.google.com/googleapi/answer/6158857?hl=en) for accessing Google's API. ### Instance #### .search(query, option) Perform an image search for `query`. ##### query Type: `string` The search terms to use for finding images. Identical to those you would use in a web search. ##### option Type: `object` ###### page Type: `number`<br> Default: `1` The range of results to return. Useful because often results cannot be returned in a single response. Note that it is a one-based unsigned integer. E.g. page `1` has the first 10 results, page `2` has the next set of 10, etc. ###### size Type: `string` The size of images to search. E.g. `medium` or `xxlarge`. ###### type Type: `string` The category of images to search. E.g. `face` or `photo`. ###### dominantColor Type: `string` The [dominant color](https://designshack.net/articles/graphics/understanding-color-dominant-vs-recessive-colors/) to search for. E.g. `yellow` or `purple`. ###### colorType Type: `string` The category of color spectrums to search. E.g. `gray` or `color`. ###### safe Type: `string` The heuristic level to use for filtering out explicit content using [SafeSearch](https://en.wikipedia.org/wiki/SafeSearch). E.g. `off` or `high`. ## Set up Google Custom Search Engine Google deprecated their public Google Images API, so to search for images you need to sign up for Google Custom Search Engine. Here are the steps you need to do: ### 1. Create a Google Custom Search Engine You can do this here: [https://cse.google.com/cse](https://cse.google.com/cse). Do not specify any sites to search but instead use the "Restrict Pages using Schema.org Types" under the "Advanced options". For the most inclusive set, use the Schema: `Thing`. Make a note of the CSE ID. ### 2. Enable Image Search In your search engine settings, enable "Image search": <img src="media/screenshot.png" width="408" /> ### 3. Set up a Google Custom Search Engine API Register a new app and enable Google Custom Search Engine API here: [Google Developers Console](https://console.developers.google.com). Make a note of the API key. ## License MIT © [Vadim Demedes](https://vadimdemedes.com)