Architecture of Libproxy
Architecture
Starting with release 0.5.0 Libproxy is making use of glib. glib has many advantages and helps to get rid of one of the major issues we have had with previous versions of Libproxy. To name a few advantages:
- Testing Framework
- Make use of existing plugin loader
- Automatic documentation out of code
- Gobject Introspection bindings for almost every programming language
Plugin types
Libproxy is using internal plugins to extend it’s knowledge about different configuration options and handling of PAC files. Most of those plugins are configuration plugins:
- config-env
- config-gnome
- config-kde
- config-osx
- config-sysconfig
- config-windows
Then there is only one pacrunner plugin which handles parsing of JS PAC files:
- pacrunner-duktape
Configuration plugin priority
Configuration plugins are executed in a specific priority:
- PX_CONFIG_PRIORITY_FIRST (highest)
- PX_CONFIG_PRIORITY_DEFAULT
- PX_CONFIG_PRIORITY_LAST (lowest)
Highest priority is used in config-env and lowest priority in
config-sysconfig. All the other plugins are running on default priority.
Configuration plugin enforcement
In case you want to use a specific configuration plugin for a given application,
you are able to overwrite the priority. Therefore set a environment variable
PX_FORCE_CONFIG=config-name and libproxy will just use this configuration plugin.