Skip to content
This repository has been archived by the owner on Feb 11, 2019. It is now read-only.
/ device-proxy Public archive

Inspect an incoming HTTP request and add extra headers or cookies. Useful for mobile device User-Agent inspection.

Notifications You must be signed in to change notification settings

praekelt/device-proxy

Repository files navigation

device-proxy

Inspects incoming HTTP requests adds some HTTP headers and proxies upstream. Has ability to add extra cookies for HTTP responses being sent back to the client.

travis coveralls

Installation

$ pip install device-proxy

Running

Run with twistd:

$ twistd -n devproxy --config config.yaml

Configuration

This is what the processing chain looks like:

       +------------------+
       |                  |
       |           Header & Cookie set
       v                  |
(1) HAProxy -> (2) *n* DeviceProxies
       |
      (3)
       | (if Cookie or Header set)
       +--------------------------------> (4) *n* Backend Apps
  1. Haproxy receives incoming traffic from Nginx
  2. Request is passed to n number of Device Proxies running. HTTP headers are inserted (possibly from cached WURFL or OpenDDR lookups). Device Proxy has the option of inserting Cookies into the HTTP response which can cache the Device Lookup (for subsequent requests HAProxy (1) could use these cookie values to skip DeviceProxy completely for the lifetime of the Cookie.) DeviceProxy reverse proxies back to HAProxy with HTTP headers inserted.
  3. HAProxy inspects the HTTP headers & cookies received and selects appropriate backend application for the request. HAProxy can have a default fallback backend. If the Cookie is already set then the DeviceProxies are skipped.
  4. The Backend application renders the request with a template set suitable for the given HTTP request.

Note

By default DeviceProxy only caches the lookup in Memcache, not in the Cookie.

About

Inspect an incoming HTTP request and add extra headers or cookies. Useful for mobile device User-Agent inspection.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages