filter_config
 
  Filter configuration dictionaries based on specified criteria.
This function filters a list of configuration dictionaries by applying ALL criteria specified in filter_dict. A configuration is included in the result if it satisfies every key-value constraint in the filter dictionary. For each filter key, the configuration's corresponding field value must match at least one of the acceptable values (OR logic within each criteria, AND logic between different criteria).
| PARAMETER | DESCRIPTION | 
|---|---|
| config_list | A list of configuration dictionaries to be filtered.   TYPE:  | 
| filter_dict | A dictionary specifying filter criteria where: - Keys are field names to check in each configuration dictionary - Values can be: * a single string value (e.g., {"model": "gpt-4o"}) * a list or set of acceptable values for that field (e.g., {"model": ["gpt-4o", "gpt-4o-mini"]}) - A configuration matches if ALL filter keys are satisfied AND for each key, the config's field value matches at least one acceptable value - If a filter value includes None, configurations missing that field will match - If None, no filtering is applied   TYPE:  | 
| exclude | If False (default), return configurations that match the filter. If True, return configurations that do NOT match the filter.   TYPE:  | 
| RETURNS | DESCRIPTION | 
|---|---|
| list[dict[str, Any]] | list of dict: Filtered list of configuration dictionaries. | 
Matching Logic
- Between different filter keys: AND logic (all criteria must be satisfied)
- Within each filter key's values: OR logic (any acceptable value can match)
- For list-type config values: Match if there's any intersection with acceptable values
- For scalar config values: Match if the value is in the list of acceptable values
- Missing fields: Only match if None is included in the acceptable values for that field
Examples:
configs = [
    {"model": "gpt-3.5-turbo", "api_type": "openai"},
    {"model": "gpt-4", "api_type": "openai"},
    {"model": "gpt-3.5-turbo", "api_type": "azure", "api_version": "2024-02-01"},
    {"model": "gpt-4", "tags": ["premium", "latest"]},
]
# Example 1: Single criterion with single string
filter_dict = {"model": "gpt-4o"}
result = filter_config(configs, filter_dict)
# Returns: [{"model": "gpt-4o", "api_type": "openai"}] if present
# Example 2: Single criterion - matches any model in the list
filter_dict = {"model": ["gpt-4", "gpt-4o"]}
result = filter_config(configs, filter_dict)
# Returns: [{"model": "gpt-4", "api_type": "openai"}, {"model": "gpt-4", "tags": ["premium", "latest"]}]
# Example 3: Multiple criteria - must satisfy ALL the conditions
filter_dict = {"model": ["gpt-3.5-turbo"], "api_type": ["azure"]}
result = filter_config(configs, filter_dict)
# Returns: [{"model": "gpt-3.5-turbo", "api_type": "azure", "api_version": "2024-02-01"}]
# Example 4: Tag filtering with list intersection
filter_dict = {"tags": ["premium"]}
result = filter_config(configs, filter_dict)
# Returns: [{"model": "gpt-4", "tags": ["premium", "latest"]}]
# Example 5: Exclude matching configurations
filter_dict = {"api_type": ["openai"]}
result = filter_config(configs, filter_dict, exclude=True)
# Returns configs that do NOT have api_type="openai"
Note: - If filter_dict is empty or None, no filtering is applied and config_list is returned as is. - If a configuration dictionary in config_list does not contain a key specified in filter_dict, it is considered a non-match and is excluded from the result.
Source code in autogen/oai/openai_utils.py
 | 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 |  |