1
0
Fork 0
ecommerce-exporter is a prometheus exporter that export the price of products in e-commerce site as prometheus metrics.
Go to file
Massaki Archambault a0b13f2fe7 drop httpx in favour of requests 2024-10-09 22:37:34 -04:00
ecommerce_exporter drop httpx in favour of requests 2024-10-09 22:37:34 -04:00
.drone.yml fetch tags 2022-11-06 01:26:30 -04:00
.gitignore rename project to ecommerce-exporter 2022-10-31 17:54:13 -04:00
.python-version do not crash on unhandled exception 2024-10-09 18:21:30 -04:00
Dockerfile fix typos 2022-11-04 17:29:15 -04:00
LICENSE
README.md improve readme 2022-11-06 14:37:28 -05:00
ecommerce-exporter.example.yml add readme and document configuration file 2022-11-03 01:11:47 -04:00
setup.cfg drop httpx in favour of requests 2024-10-09 22:37:34 -04:00
setup.py add pypi publish pipeline to ci 2022-11-04 17:43:26 -04:00

README.md

ecommerce-exporter

ecommerce-exporter is a prometheus exporter that webscrape the storefront of various e-commerces and expose the price of their products as prometheus metrics. These metrics can then be used to graph the pricing evolution over time, send alerts when the price drop, or to easily compare the price of a product on many e-commerces at once.

Install

Using docker

An aarch64 and an amd64 docker images are available on docker hub. You can pull it using:

docker pull badjware/ecommerce-exporter

This is the recommended way of running the exporter.

Using pip

Alternatively, if you prefer to avoid having to use docker, you can install ecommerce-exporter as a standard python package.

pip install ecommerce-exporter

Usage

Download the example configuration file and edit it to configure the e-commerce sites you wish to scrape. You can configure multiple products and multiple targets in the same configuration file.

Assuming you named your configuration file ecommerce-exporter.yml, you can use the following command to run the exporter with docker:

docker run -v "$PWD/ecommerce-exporter.yml:/ecommerce-exporter.yml" -p 8000:8000 badjware/ecommerce-exporter

The prices of the configured products will start being scraped and exposed on http://localhost:8000/metrics. You can then configure prometheus to scrape that endpoint. It is recommended to set the scrape interval to be the same as the webscrape interval of the exporter (15m by default).

A full list of available flags can be printed using -h:

usage: An utility to scrape e-commerce product price and expose them as prometheus metrics
       [-h] [-c CONFIG] [-i INTERVAL] [--user-agent USER_AGENT]
       [-p LISTEN_PORT] [-a LISTEN_ADDRESS]

options:
  -h, --help            show this help message and exit
  -c CONFIG, --config CONFIG
                        The configuration file. (default: ecommerce-
                        exporter.yml)
  -i INTERVAL, --interval INTERVAL
                        The target scrape interval, in minutes. (default: 15)
  --user-agent USER_AGENT
                        The user-agent to spoof. (default: Mozilla/5.0 (X11;
                        Linux x86_64; rv:106.0) Gecko/20100101 Firefox/106.0)
  -p LISTEN_PORT, --listen-port LISTEN_PORT
                        The listen port for the http server. (default: 8000)
  -a LISTEN_ADDRESS, --listen-address LISTEN_ADDRESS
                        The listen address for the http server. (default:
                        0.0.0.0)

Configuring the selectors

Finding the correct value for a selector will require some effort. Once you find the correct selector to use, you should be able to use the same one across the whole site.

html parser

The general procedure to figure out the selector for a site using an html parser is as follow:

  1. Open up the product page in your browser.
  2. Right-click the price of the product and select "inspect element" in the drop-down.
  3. Take note of the class, the id, and the type of the element containing the price of the product.
  4. Build a CSS selector to select the element with the price of the product you wish to extract.

Refer to the documentation on how to build a CSS selector: https://www.w3schools.com/CSS/css_selectors.asp

Below is a table with examples of some CSS selectors that match the html element containing the price of a product. Keep in mind that if the design of the site changes in the future, these selector may stop working.

site selector
amazon.ca .priceToPay .a-offscreen::text
canadacomputer.com .price-show-panel .h2-big strong::text
memoryexpress.com .GrandTotal

json parser

The general procedure to figure out the selector for a site using an json parser is as follow:

  1. Open up the development tool of your browser using the F12 key.
  2. Open up the product page in your favorite browser.
  3. Go to the "network" tab in your development tool and dig through the resources of the page to find the api call that returned the price of the product.
  4. Take note of the url of this api call.
  5. Use the commands curl http://url_you_found_in_your_dev_tool | jq 'some_selector' and build a selector to extract the price of the product from the json response.

Refer to the documentation of jq on how to build a selector for it: https://stedolan.github.io/jq/manual/#Basicfilters

Below is a table with examples of some jq selectors that match the json field containing the price of a product. Keep in mind that if the backend/api of the site changes in the future, these selector may stop working. Finding correct url of your product may require some digging in the developper tools of your browser.

site selector url example
newegg.ca .MainItem.UnitCost https://www.newegg.ca/product/api/ProductRealtime?ItemNumber=19-118-343&RecommendItem=&BestSellerItemList=9SIAA4YGC82324%2C9SIADGEGMY7603%2C9SIAVH1J0A6685&IsVATPrice=true
bestbuy.ca .[] | .salePrice,.regularPrice https://www.bestbuy.ca/api/offers/v1/products/15778672/offers

Developing

Setup a virtualenv and activate it:

python -m venv env
source env/bin/activate

Setup the project as an editable install:

pip install -e .

You can now run the exporter using ecommerce-exporter while your virtualenv is active.

Happy hacking!