No description
Find a file
2026-04-18 21:47:33 +02:00
config/01 [tutorial v1.1_080] Proxy custom type (config and doc) 2026-04-18 21:47:33 +02:00
firefox [tutorial v1.1_080] Proxy custom type 2026-04-18 21:47:33 +02:00
types/proxy [tutorial v1.1_080] Proxy custom type 2026-04-18 21:47:33 +02:00
CHANGELOG.md [tutorial v1.1_080] Proxy custom type (config and doc) 2026-04-18 21:47:33 +02:00
DOCUMENTATION.md [tutorial v1.1_080] Proxy custom type (config and doc) 2026-04-18 21:47:33 +02:00
firefox.png [tutorial v1.1_052] A hidden family (config and doc) 2026-04-18 21:46:57 +02:00
foxyproxy.png [init] Discover Rougail 2026-04-18 21:45:41 +02:00
install.txt [init] Discover Rougail 2026-04-18 21:45:41 +02:00
README.md [tutorial v1.1_080] Proxy custom type (config and doc) 2026-04-18 21:47:33 +02:00
tree.html [tutorial v1.1_080] Proxy custom type (config and doc) 2026-04-18 21:47:33 +02:00

[tutorial v1.1_080] Proxy custom type

Read the tutorial "Proxy custom type" in the documentation

Screenshot

Firefox Proxy setting

Clone and install

To test this tutorial, you need to download this repository and install Rougail:

git clone -b 1.1 https://forge.cloud.silique.fr/stove/rougail-tutorials.git
cd rougail-tutorials
python -m venv venv_rougail
. venv_rougail/bin/activate
pip install rougail-cli rougail-output-exporter rougail-output-doc rougail-user-data-yaml

Then switch to the tutorial page:

git switch --detach v1.1_080

Structure

.
├── firefox
│   ├── 00-proxy.yml
│   ├── 10-manual.yml
│   └── 20-manual.yml
└── types
    └── proxy
        └── 00-type.yml


Contents of the firefox/20-manual.yml file

%YAML 1.2
---
version: 1.1

manual:

  use_for_https: true  # Also use this proxy for HTTPS

  '{{ identifier }}_proxy':
    description: '{{ identifier }} Proxy'
    hidden:
      jinja: |-
        {{ my_identifier == 'HTTPS' and _.use_for_https }}        
      return_type: boolean
      description: in HTTPS case if "_.use_for_https" is set to "true"
      params:
        my_identifier:
          type: identifier
    dynamic:
      - HTTPS
      - SOCKS

    address:
      description: '{{ identifier }} address'
      default:
        variable: __.http_proxy.address

    port:
      description: '{{ identifier }} port'
      default:
        variable: __.http_proxy.port

    version:
      description: SOCKS host version used by proxy
      choices:
        - v4
        - v5
      default: v5
      disabled:
        type: identifier
        when: HTTPS
...


Let's generate the documentation

rougail -m firefox/ --types types/proxy -o doc

View the documentation file


Let's generate the changelog

rougail -m firefox/ --types types/proxy -o doc --doc.contents changelog --doc.changelog.previous_json_file previous.yml

View the changelog file


User datas

Example 1

config/01/config.yml

---
proxy_mode: Manual proxy configuration
manual:
  http_proxy:
    address: http.proxy.net
    port: 3128
  use_for_https: false
  https_proxy:
    address: https.proxy.net

Output

rougail -m firefox/ --types types/proxy -u yaml -yf config/01/config.yml

Note

Caption:

  • Variable
  • Default value
  • Modified value
  • ( Original default value)

Variables:

  • 📓 proxy_mode (Configure Proxy Access to the Internet): Manual proxy configuration ← loaded from the YAML file "config/01/config.yml" ( No proxy)
  • 📂 manual (Manual proxy configuration)
    • 📂 http_proxy (HTTP Proxy)
      • 📓 address (Proxy address): http.proxy.net ← loaded from the YAML file "config/01/config.yml"
      • 📓 port (Proxy port): 3128 ← loaded from the YAML file "config/01/config.yml" ( 8080)
    • 📓 use_for_https (Also use this proxy for HTTPS): false ← loaded from the YAML file "config/01/config.yml" ( true)
    • 📂 https_proxy (HTTPS Proxy)
      • 📓 address (HTTPS address): https.proxy.net ← loaded from the YAML file "config/01/config.yml" ( http.proxy.net)
      • 📓 port (HTTPS port): 3128
    • 📂 socks_proxy (SOCKS Proxy)
      • 📓 address (SOCKS address): http.proxy.net
      • 📓 port (SOCKS port): 3128
      • 📓 version (SOCKS host version used by proxy): v5