Project

General

Profile

Actions

User story #25970

closed

Make compilation resolved loops over Blocks/Methods in techniques possible

Added by Félix DALLIDET 4 months ago. Updated 2 months ago.

Status:
Released
Priority:
N/A
Category:
rudderc
Target version:
UX impact:
Suggestion strength:
User visibility:
Effort required:
Name check:
To do
Fix check:
To do
Regression:
No

Description

Being able to loop/repeat a method|block call in a technique using parameterized local variables would be great.
The loops will be resolved at technique compilation, right before the starting from the leaf element when nested.

The proposed syntax is heavily inspired from the Ansible loops syntax https://docs.ansible.com/ansible/latest/playbook_guide/playbooks_loops.html#using-loops.

  - name: "Install a package" 
    method: package_present
    params:
      name: "${plouf.name}" 
      version: "${plouf.version}" 
    foreach:                 # field to force a loop
      - name: "vim" 
        version: "latest" 
      - name: "htop" 
        version: "2.3.4" 
      - name: "${technique_id.extra_package}" 
        version: "latest" 
    foreach_name: "plouf"    # loop iterator name, useful when loops are nested using blocks

Subtasks 2 (0 open2 closed)

User story #26116: Add Scala backend for technique loopsReleasedFrançois ARMANDActions
User story #26120: Make sure that bundle arity is always strict when resolving loopsReleasedAlexis MoussetActions

Related issues 3 (3 open0 closed)

Related to Rudder - Bug #26651: Compilation error when loop key with empty valueNewActions
Related to Rudder - Bug #26652: Compliance repeated when using the new “foreach” loopsPending releaseVincent MEMBRÉActions
Related to Rudder - Bug #26650: Tecnique loop copy box pastes wrong valueNewActions
Actions

Also available in: Atom PDF