Class: Aidp::Harness::Configuration

Inherits:
Object
  • Object
show all
Defined in:
lib/aidp/harness/configuration.rb

Overview

Handles loading and validation of harness configuration from aidp.yml

Defined Under Namespace

Classes: ConfigurationError

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(project_dir) ⇒ Configuration

Returns a new instance of Configuration.



12
13
14
15
16
# File 'lib/aidp/harness/configuration.rb', line 12

def initialize(project_dir)
  @project_dir = project_dir
  @config = Aidp::Config.load_harness_config(project_dir)
  validate_configuration!
end

Instance Attribute Details

#project_dirObject (readonly)

Returns the value of attribute project_dir.



10
11
12
# File 'lib/aidp/harness/configuration.rb', line 10

def project_dir
  @project_dir
end

Instance Method Details

#allow_provider_switch_for_tier?Boolean

Check if provider switching for tier is allowed

Returns:

  • (Boolean)


444
445
446
# File 'lib/aidp/harness/configuration.rb', line 444

def allow_provider_switch_for_tier?
  thinking_config[:allow_provider_switch] != false
end

#auto_escalate?Boolean

Check if auto-escalation is enabled

Returns:

  • (Boolean)


600
601
602
# File 'lib/aidp/harness/configuration.rb', line 600

def auto_escalate?
  thinking_config[:auto_escalate] != false
end

#build_commandsObject

Get build commands



190
191
192
# File 'lib/aidp/harness/configuration.rb', line 190

def build_commands
  normalize_commands(work_loop_config[:build_commands] || [])
end

#circuit_breaker_configObject

Get circuit breaker configuration



111
112
113
# File 'lib/aidp/harness/configuration.rb', line 111

def circuit_breaker_config
  harness_config[:circuit_breaker] || default_circuit_breaker_config
end

#config_exists?Boolean

Check if configuration file exists

Returns:

  • (Boolean)


523
524
525
# File 'lib/aidp/harness/configuration.rb', line 523

def config_exists?
  Aidp::Config.config_exists?(@project_dir)
end

#config_pathObject

Get configuration path



419
420
421
# File 'lib/aidp/harness/configuration.rb', line 419

def config_path
  Aidp::ConfigPaths.config_file(@project_dir)
end

#configuration_summaryObject

Get configuration summary



554
555
556
557
558
559
560
561
562
563
564
565
566
567
# File 'lib/aidp/harness/configuration.rb', line 554

def configuration_summary
  {
    providers: configured_providers.size,
    default_provider: default_provider,
    fallback_providers: fallback_providers.size,
    max_retries: max_retries,
    no_api_keys_required: no_api_keys_required?,
    load_balancing_enabled: load_balancing_config[:enabled],
    model_switching_enabled: model_switching_config[:enabled],
    circuit_breaker_enabled: circuit_breaker_config[:enabled],
    health_check_enabled: health_check_config[:enabled],
    metrics_enabled: metrics_config[:enabled]
  }
end

#configured_providersObject

Get all configured providers



29
30
31
# File 'lib/aidp/harness/configuration.rb', line 29

def configured_providers
  @config[:providers]&.keys&.map(&:to_s) || []
end

#configured_tiers(provider_name) ⇒ Array<String>

Get all configured tiers for a provider

Parameters:

  • provider_name (String)

    The provider name

Returns:

  • (Array<String>)

    Array of tier names



513
514
515
# File 'lib/aidp/harness/configuration.rb', line 513

def configured_tiers(provider_name)
  provider_thinking_tiers(provider_name).keys.map(&:to_s)
end

#conventional_commits?Boolean

Check if conventional commits are enabled

Returns:

  • (Boolean)


314
315
316
# File 'lib/aidp/harness/configuration.rb', line 314

def conventional_commits?
  version_control_config[:conventional_commits] == true
end

#coverage_configObject

Get coverage configuration



319
320
321
# File 'lib/aidp/harness/configuration.rb', line 319

def coverage_config
  work_loop_config[:coverage] || default_coverage_config
end

#coverage_enabled?Boolean

Check if coverage is enabled

Returns:

  • (Boolean)


324
325
326
# File 'lib/aidp/harness/configuration.rb', line 324

def coverage_enabled?
  coverage_config[:enabled] == true
end

#coverage_fail_on_drop?Boolean

Check if should fail on coverage drop

Returns:

  • (Boolean)


344
345
346
# File 'lib/aidp/harness/configuration.rb', line 344

def coverage_fail_on_drop?
  coverage_config[:fail_on_drop] == true
end

#coverage_minimumObject

Get minimum coverage threshold



349
350
351
# File 'lib/aidp/harness/configuration.rb', line 349

def coverage_minimum
  coverage_config[:minimum_coverage]
end

#coverage_report_pathsObject

Get coverage report paths



339
340
341
# File 'lib/aidp/harness/configuration.rb', line 339

def coverage_report_paths
  coverage_config[:report_paths] || []
end

#coverage_run_commandObject

Get coverage run command



334
335
336
# File 'lib/aidp/harness/configuration.rb', line 334

def coverage_run_command
  coverage_config[:run_command]
end

#coverage_toolObject

Get coverage tool



329
330
331
# File 'lib/aidp/harness/configuration.rb', line 329

def coverage_tool
  coverage_config[:tool]
end

#create_example_configObject

Create example configuration



528
529
530
# File 'lib/aidp/harness/configuration.rb', line 528

def create_example_config
  Aidp::Config.create_example_config(@project_dir)
end

#default_flags(provider_name) ⇒ Object

Get default flags for a provider



64
65
66
# File 'lib/aidp/harness/configuration.rb', line 64

def default_flags(provider_name)
  provider_config(provider_name)[:default_flags] || []
end

#default_model(provider_name) ⇒ Object

Get default model for provider



74
75
76
77
# File 'lib/aidp/harness/configuration.rb', line 74

def default_model(provider_name)
  models = provider_models(provider_name)
  models.first || default_model_for_provider(provider_name)
end

#default_providerObject

Get default provider



34
35
36
# File 'lib/aidp/harness/configuration.rb', line 34

def default_provider
  harness_config[:default_provider]
end

#default_tierObject

Get default thinking tier



434
435
436
# File 'lib/aidp/harness/configuration.rb', line 434

def default_tier
  thinking_config[:default_tier] || default_thinking_config[:default_tier]
end

#devcontainer_allowed_domainsObject

Get allowed domains for devcontainer firewall



805
806
807
# File 'lib/aidp/harness/configuration.rb', line 805

def devcontainer_allowed_domains
  devcontainer_settings[:allowed_domains] || []
end

#devcontainer_configObject

Get devcontainer configuration



721
722
723
724
725
726
727
728
729
730
731
732
# File 'lib/aidp/harness/configuration.rb', line 721

def devcontainer_config
  return @devcontainer_config if defined?(@devcontainer_config)

  raw_config = @config[:devcontainer] || @config["devcontainer"]
  base = deep_dup(default_devcontainer_config)

  @devcontainer_config = if raw_config.is_a?(Hash)
    deep_merge_hashes(base, deep_symbolize_keys(raw_config))
  else
    base
  end
end

#devcontainer_dangerous_ops_allowed?Boolean

Check if dangerous filesystem operations are allowed in devcontainer

Returns:

  • (Boolean)


767
768
769
# File 'lib/aidp/harness/configuration.rb', line 767

def devcontainer_dangerous_ops_allowed?
  devcontainer_permissions[:dangerous_filesystem_ops] == true
end

#devcontainer_enabled?Boolean

Check if devcontainer features are enabled

Returns:

  • (Boolean)


735
736
737
# File 'lib/aidp/harness/configuration.rb', line 735

def devcontainer_enabled?
  devcontainer_config[:enabled] != false
end

#devcontainer_force_detectionObject

Get forced detection value (nil for auto-detection)



745
746
747
# File 'lib/aidp/harness/configuration.rb', line 745

def devcontainer_force_detection
  devcontainer_config[:force_detection]
end

#devcontainer_permissionsObject

Get devcontainer permissions config



759
760
761
762
763
764
# File 'lib/aidp/harness/configuration.rb', line 759

def devcontainer_permissions
  permissions = devcontainer_config[:permissions]
  return {} unless permissions.is_a?(Hash)

  permissions.transform_keys { |key| key.to_sym }
end

#devcontainer_settingsObject

Get devcontainer settings



790
791
792
# File 'lib/aidp/harness/configuration.rb', line 790

def devcontainer_settings
  devcontainer_config[:settings] || {}
end

#devcontainer_skip_permission_checksObject

Get list of providers that should skip permission checks in devcontainer



772
773
774
775
776
777
778
779
780
781
782
# File 'lib/aidp/harness/configuration.rb', line 772

def devcontainer_skip_permission_checks
  permissions = devcontainer_config[:permissions]
  list = nil

  if permissions.is_a?(Hash)
    list = permissions[:skip_permission_checks] || permissions["skip_permission_checks"]
  end

  list = default_skip_permission_checks if list.nil?
  Array(list).map(&:to_s)
end

#devcontainer_skip_permissions_for?(provider_name) ⇒ Boolean

Check if a specific provider should skip permission checks in devcontainer

Returns:

  • (Boolean)


785
786
787
# File 'lib/aidp/harness/configuration.rb', line 785

def devcontainer_skip_permissions_for?(provider_name)
  devcontainer_skip_permission_checks.include?(provider_name.to_s)
end

#devcontainer_timeout_multiplierObject

Get timeout multiplier for devcontainer



795
796
797
# File 'lib/aidp/harness/configuration.rb', line 795

def devcontainer_timeout_multiplier
  devcontainer_settings[:timeout_multiplier] || 1.0
end

#devcontainer_verbose_logging?Boolean

Check if verbose logging is enabled in devcontainer

Returns:

  • (Boolean)


800
801
802
# File 'lib/aidp/harness/configuration.rb', line 800

def devcontainer_verbose_logging?
  devcontainer_settings[:verbose_logging] == true
end

#documentation_commandsObject

Get documentation commands



195
196
197
# File 'lib/aidp/harness/configuration.rb', line 195

def documentation_commands
  normalize_commands(work_loop_config[:documentation_commands] || [])
end

#escalation_complexity_thresholdObject

Get complexity threshold configuration for escalation



459
460
461
# File 'lib/aidp/harness/configuration.rb', line 459

def escalation_complexity_threshold
  escalation_config[:on_complexity_threshold] || {}
end

#escalation_configObject

Get escalation configuration



449
450
451
# File 'lib/aidp/harness/configuration.rb', line 449

def escalation_config
  thinking_config[:escalation] || default_escalation_config
end

#escalation_fail_attemptsObject

Get fail attempts threshold for escalation



454
455
456
# File 'lib/aidp/harness/configuration.rb', line 454

def escalation_fail_attempts
  escalation_config[:on_fail_attempts] || 2
end

#escalation_thresholdObject

Get escalation threshold



605
606
607
# File 'lib/aidp/harness/configuration.rb', line 605

def escalation_threshold
  thinking_config[:escalation_threshold] || 2
end

#fallback_configObject

Get fallback configuration



518
519
520
# File 'lib/aidp/harness/configuration.rb', line 518

def fallback_config
  harness_config[:fallback] || default_fallback_config
end

#fallback_providersObject

Get fallback providers



39
40
41
# File 'lib/aidp/harness/configuration.rb', line 39

def fallback_providers
  harness_config[:fallback_providers]
end

#filter_definition_for(key) ⇒ FilterDefinition?

Get filter definition for a specific tool/category

Parameters:

  • key (String, Symbol)

    Tool key (e.g., “unit_test”, “lint”)

Returns:



250
251
252
253
254
255
256
257
258
259
260
261
# File 'lib/aidp/harness/configuration.rb', line 250

def filter_definition_for(key)
  definitions = filter_definitions
  definition_hash = definitions[key.to_s] || definitions[key.to_sym]
  return nil unless definition_hash

  require_relative "filter_definition"
  FilterDefinition.from_hash(definition_hash)
rescue => e
  Aidp.log_warn("configuration", "failed_to_load_filter_definition",
    key: key, error: e.message)
  nil
end

#filter_definitionsHash

Get all filter definitions from config

Returns:

  • (Hash)

    Map of tool keys to filter definition hashes



243
244
245
# File 'lib/aidp/harness/configuration.rb', line 243

def filter_definitions
  output_filtering_config[:filter_definitions] || {}
end

#formatter_commandsObject

Get formatter commands



185
186
187
# File 'lib/aidp/harness/configuration.rb', line 185

def formatter_commands
  normalize_commands(work_loop_config[:formatter_commands] || [])
end

#full_permissions_in_devcontainer?Boolean

Check if full permissions should be granted in devcontainer

Returns:

  • (Boolean)


740
741
742
# File 'lib/aidp/harness/configuration.rb', line 740

def full_permissions_in_devcontainer?
  devcontainer_config[:full_permissions_when_in_devcontainer] == true
end

#guards_bypass?Boolean

Check if guards are bypassed

Returns:

  • (Boolean)


294
295
296
# File 'lib/aidp/harness/configuration.rb', line 294

def guards_bypass?
  guards_config[:bypass] == true
end

#guards_configObject

Get guards configuration



264
265
266
# File 'lib/aidp/harness/configuration.rb', line 264

def guards_config
  work_loop_config[:guards] || default_guards_config
end

#guards_confirm_filesObject

Get files requiring confirmation for guards



284
285
286
# File 'lib/aidp/harness/configuration.rb', line 284

def guards_confirm_files
  guards_config[:confirm_files] || []
end

#guards_enabled?Boolean

Check if guards are enabled

Returns:

  • (Boolean)


269
270
271
# File 'lib/aidp/harness/configuration.rb', line 269

def guards_enabled?
  guards_config[:enabled] == true
end

#guards_exclude_filesObject

Get exclude file patterns for guards



279
280
281
# File 'lib/aidp/harness/configuration.rb', line 279

def guards_exclude_files
  guards_config[:exclude_files] || []
end

#guards_include_filesObject

Get include file patterns for guards



274
275
276
# File 'lib/aidp/harness/configuration.rb', line 274

def guards_include_files
  guards_config[:include_files] || []
end

#guards_max_lines_per_commitObject

Get max lines per commit for guards



289
290
291
# File 'lib/aidp/harness/configuration.rb', line 289

def guards_max_lines_per_commit
  guards_config[:max_lines_per_commit]
end

#harness_configObject

Get harness-specific configuration



19
20
21
# File 'lib/aidp/harness/configuration.rb', line 19

def harness_config
  @config[:harness]
end

#health_check_configObject

Get provider health check configuration



136
137
138
# File 'lib/aidp/harness/configuration.rb', line 136

def health_check_config
  harness_config[:health_check] || default_health_check_config
end

#in_devcontainer?Boolean

Check if currently in devcontainer (with optional force override)

Returns:

  • (Boolean)


750
751
752
753
754
755
756
# File 'lib/aidp/harness/configuration.rb', line 750

def in_devcontainer?
  forced = devcontainer_force_detection
  return forced unless forced.nil?

  require_relative "../utils/devcontainer_detector"
  Aidp::Utils::DevcontainerDetector.in_devcontainer?
end

#interactive_testing_app_typeObject

Get interactive testing app type



364
365
366
# File 'lib/aidp/harness/configuration.rb', line 364

def interactive_testing_app_type
  interactive_testing_config[:app_type]
end

#interactive_testing_configObject

Get interactive testing configuration



354
355
356
# File 'lib/aidp/harness/configuration.rb', line 354

def interactive_testing_config
  work_loop_config[:interactive_testing] || default_interactive_testing_config
end

#interactive_testing_enabled?Boolean

Check if interactive testing is enabled

Returns:

  • (Boolean)


359
360
361
# File 'lib/aidp/harness/configuration.rb', line 359

def interactive_testing_enabled?
  interactive_testing_config[:enabled] == true
end

#interactive_testing_toolsObject

Get interactive testing tools configuration



369
370
371
# File 'lib/aidp/harness/configuration.rb', line 369

def interactive_testing_tools
  interactive_testing_config[:tools] || {}
end

#lint_commandsObject

Get lint commands



180
181
182
# File 'lib/aidp/harness/configuration.rb', line 180

def lint_commands
  normalize_commands(work_loop_config[:lint_commands] || [])
end

#lint_max_output_linesObject

Get max output lines for linters



227
228
229
# File 'lib/aidp/harness/configuration.rb', line 227

def lint_max_output_lines
  output_filtering_config[:lint_max_lines] || 300
end

#lint_output_modeObject

Get lint output mode



221
222
223
224
# File 'lib/aidp/harness/configuration.rb', line 221

def lint_output_mode
  mode = output_filtering_config[:lint_mode]
  mode ? mode.to_sym : :full
end

#load_balancing_configObject

Get load balancing configuration



126
127
128
# File 'lib/aidp/harness/configuration.rb', line 126

def load_balancing_config
  harness_config[:load_balancing] || default_load_balancing_config
end

#logging_configObject

Get logging configuration



424
425
426
# File 'lib/aidp/harness/configuration.rb', line 424

def logging_config
  harness_config[:logging] || default_logging_config
end

#max_retriesObject

Get maximum retries



44
45
46
# File 'lib/aidp/harness/configuration.rb', line 44

def max_retries
  harness_config[:max_retries]
end

#max_tierObject

Get maximum thinking tier



439
440
441
# File 'lib/aidp/harness/configuration.rb', line 439

def max_tier
  thinking_config[:max_tier] || default_thinking_config[:max_tier]
end

#max_tokens(provider_name) ⇒ Object

Get maximum tokens for API providers



59
60
61
# File 'lib/aidp/harness/configuration.rb', line 59

def max_tokens(provider_name)
  provider_config(provider_name)[:max_tokens]
end

#metrics_configObject

Get metrics configuration



141
142
143
# File 'lib/aidp/harness/configuration.rb', line 141

def metrics_config
  harness_config[:metrics] || default_metrics_config
end

#model_config(provider_name, model_name) ⇒ Object

Get model configuration for provider



80
81
82
83
# File 'lib/aidp/harness/configuration.rb', line 80

def model_config(provider_name, model_name)
  models_config = provider_config(provider_name)[:models_config] || {}
  models_config[model_name] || {}
end

#model_family(provider_name) ⇒ Object

Get model family for a provider



374
375
376
# File 'lib/aidp/harness/configuration.rb', line 374

def model_family(provider_name)
  provider_config(provider_name)[:model_family] || "auto"
end

#model_flags(provider_name, model_name) ⇒ Object

Get model-specific flags



86
87
88
# File 'lib/aidp/harness/configuration.rb', line 86

def model_flags(provider_name, model_name)
  model_config(provider_name, model_name)[:flags] || []
end

#model_max_tokens(provider_name, model_name) ⇒ Object

Get model-specific max tokens



91
92
93
# File 'lib/aidp/harness/configuration.rb', line 91

def model_max_tokens(provider_name, model_name)
  model_config(provider_name, model_name)[:max_tokens] || max_tokens(provider_name)
end

#model_switching_configObject

Get model switching configuration



131
132
133
# File 'lib/aidp/harness/configuration.rb', line 131

def model_switching_config
  harness_config[:model_switching] || default_model_switching_config
end

#model_timeout(provider_name, model_name) ⇒ Object

Get model-specific timeout



96
97
98
# File 'lib/aidp/harness/configuration.rb', line 96

def model_timeout(provider_name, model_name)
  model_config(provider_name, model_name)[:timeout] || default_timeout_for_provider(provider_name)
end

#model_weights(provider_name) ⇒ Object

Get model weights for load balancing



106
107
108
# File 'lib/aidp/harness/configuration.rb', line 106

def model_weights(provider_name)
  provider_config(provider_name)[:model_weights] || {}
end

#models_for_tier(tier, provider_name) ⇒ Array<String>

Get models configured for a specific tier and provider

Parameters:

  • tier (String, Symbol)

    The tier name (mini, standard, thinking, pro, max)

  • provider_name (String)

    The provider name (required)

Returns:

  • (Array<String>)

    Array of model names for the tier



496
497
498
499
500
501
502
503
504
505
506
507
508
# File 'lib/aidp/harness/configuration.rb', line 496

def models_for_tier(tier, provider_name)
  return [] unless provider_name

  tier_config = provider_thinking_tiers(provider_name)[tier] ||
    provider_thinking_tiers(provider_name)[tier.to_sym]
  return [] unless tier_config

  models = tier_config[:models] || tier_config["models"]
  return [] unless models

  # Return simple array of model name strings
  Array(models).map(&:to_s).compact
end

#no_api_keys_required?Boolean

Check if restricted to providers that don’t require API keys

Returns:

  • (Boolean)


49
50
51
# File 'lib/aidp/harness/configuration.rb', line 49

def no_api_keys_required?
  harness_config[:no_api_keys_required]
end

#output_filtering_configObject

Get output filtering configuration



200
201
202
# File 'lib/aidp/harness/configuration.rb', line 200

def output_filtering_config
  work_loop_config[:output_filtering] || default_output_filtering_config
end

#output_filtering_context_linesObject

Get context_lines setting for output filtering



237
238
239
# File 'lib/aidp/harness/configuration.rb', line 237

def output_filtering_context_lines
  output_filtering_config[:context_lines] || 3
end

#output_filtering_enabled?Boolean

Check if output filtering is enabled

Returns:

  • (Boolean)


205
206
207
# File 'lib/aidp/harness/configuration.rb', line 205

def output_filtering_enabled?
  output_filtering_config[:enabled] != false
end

#output_filtering_include_contextObject

Get include_context setting for output filtering



232
233
234
# File 'lib/aidp/harness/configuration.rb', line 232

def output_filtering_include_context
  output_filtering_config.fetch(:include_context, true)
end

#permission_for_tier(tier) ⇒ Object

Get permission level for a tier



469
470
471
# File 'lib/aidp/harness/configuration.rb', line 469

def permission_for_tier(tier)
  permissions_by_tier[tier] || permissions_by_tier[tier.to_sym] || "tools"
end

#permissions_by_tierObject

Get permissions by tier configuration



464
465
466
# File 'lib/aidp/harness/configuration.rb', line 464

def permissions_by_tier
  thinking_config[:permissions_by_tier] || {}
end

#prompt_dynamic_adjustment?Boolean

Check if dynamic adjustment is enabled

Returns:

  • (Boolean)


709
710
711
# File 'lib/aidp/harness/configuration.rb', line 709

def prompt_dynamic_adjustment?
  prompt_optimization_config[:dynamic_adjustment] != false
end

#prompt_include_thresholdsObject

Get include threshold configuration



689
690
691
# File 'lib/aidp/harness/configuration.rb', line 689

def prompt_include_thresholds
  prompt_optimization_config[:include_threshold] || default_include_thresholds
end

#prompt_log_fragments?Boolean

Check if fragment logging is enabled

Returns:

  • (Boolean)


714
715
716
# File 'lib/aidp/harness/configuration.rb', line 714

def prompt_log_fragments?
  prompt_optimization_config[:log_selected_fragments] == true
end

#prompt_max_tokensObject

Get maximum tokens for prompt



684
685
686
# File 'lib/aidp/harness/configuration.rb', line 684

def prompt_max_tokens
  prompt_optimization_config[:max_tokens] || 16000
end

#prompt_optimization_configObject

Get prompt optimization configuration



674
675
676
# File 'lib/aidp/harness/configuration.rb', line 674

def prompt_optimization_config
  @config[:prompt_optimization] || default_prompt_optimization_config
end

#prompt_optimization_enabled?Boolean

Check if prompt optimization is enabled

Returns:

  • (Boolean)


679
680
681
# File 'lib/aidp/harness/configuration.rb', line 679

def prompt_optimization_enabled?
  prompt_optimization_config[:enabled] == true
end

#prompt_source_thresholdObject

Get source code include threshold



704
705
706
# File 'lib/aidp/harness/configuration.rb', line 704

def prompt_source_threshold
  prompt_include_thresholds[:source] || 0.7
end

#prompt_style_guide_thresholdObject

Get style guide include threshold



694
695
696
# File 'lib/aidp/harness/configuration.rb', line 694

def prompt_style_guide_threshold
  prompt_include_thresholds[:style_guide] || 0.75
end

#prompt_templates_thresholdObject

Get templates include threshold



699
700
701
# File 'lib/aidp/harness/configuration.rb', line 699

def prompt_templates_threshold
  prompt_include_thresholds[:templates] || 0.8
end

#provider_auth_config(provider_name) ⇒ Object

Get provider authentication configuration



394
395
396
# File 'lib/aidp/harness/configuration.rb', line 394

def provider_auth_config(provider_name)
  provider_config(provider_name)[:auth] || {}
end

#provider_config(provider_name) ⇒ Object

Get provider configuration



24
25
26
# File 'lib/aidp/harness/configuration.rb', line 24

def provider_config(provider_name)
  @config.dig(:providers, provider_name.to_sym) || {}
end

#provider_configured?(provider_name) ⇒ Boolean

Check if provider is configured

Returns:

  • (Boolean)


414
415
416
# File 'lib/aidp/harness/configuration.rb', line 414

def provider_configured?(provider_name)
  configured_providers.include?(provider_name.to_s)
end

#provider_cost_config(provider_name) ⇒ Object

Get provider cost configuration



384
385
386
# File 'lib/aidp/harness/configuration.rb', line 384

def provider_cost_config(provider_name)
  provider_config(provider_name)[:cost] || {}
end

#provider_endpoints(provider_name) ⇒ Object

Get provider endpoint configuration



399
400
401
# File 'lib/aidp/harness/configuration.rb', line 399

def provider_endpoints(provider_name)
  provider_config(provider_name)[:endpoints] || {}
end

#provider_features(provider_name) ⇒ Object

Get provider feature flags



404
405
406
# File 'lib/aidp/harness/configuration.rb', line 404

def provider_features(provider_name)
  provider_config(provider_name)[:features] || {}
end

#provider_models(provider_name) ⇒ Object

Get provider models configuration



69
70
71
# File 'lib/aidp/harness/configuration.rb', line 69

def provider_models(provider_name)
  provider_config(provider_name)[:models] || default_models_for_provider(provider_name)
end

#provider_monitoring_config(provider_name) ⇒ Object

Get provider monitoring configuration



409
410
411
# File 'lib/aidp/harness/configuration.rb', line 409

def provider_monitoring_config(provider_name)
  provider_config(provider_name)[:monitoring] || {}
end

#provider_priority(provider_name) ⇒ Object

Get provider priority



379
380
381
# File 'lib/aidp/harness/configuration.rb', line 379

def provider_priority(provider_name)
  provider_config(provider_name)[:priority] || 0
end

#provider_regions(provider_name) ⇒ Object

Get provider region configuration



389
390
391
# File 'lib/aidp/harness/configuration.rb', line 389

def provider_regions(provider_name)
  provider_config(provider_name)[:regions] || []
end

#provider_thinking_tiers(provider_name) ⇒ Hash

Get thinking tiers configuration for a specific provider

Parameters:

  • provider_name (String)

    The provider name

Returns:

  • (Hash)

    The thinking tiers configuration for the provider



487
488
489
490
# File 'lib/aidp/harness/configuration.rb', line 487

def provider_thinking_tiers(provider_name)
  provider_cfg = provider_config(provider_name)
  provider_cfg[:thinking_tiers] || provider_cfg["thinking_tiers"] || {}
end

#provider_type(provider_name) ⇒ Object

Get provider type (usage_based, subscription, etc.)



54
55
56
# File 'lib/aidp/harness/configuration.rb', line 54

def provider_type(provider_name)
  provider_config(provider_name)[:type] || "unknown"
end

#provider_weightsObject

Get provider weights for load balancing



101
102
103
# File 'lib/aidp/harness/configuration.rb', line 101

def provider_weights
  harness_config[:provider_weights] || {}
end

#rate_limit_configObject

Get rate limit configuration



121
122
123
# File 'lib/aidp/harness/configuration.rb', line 121

def rate_limit_config
  harness_config[:rate_limit] || default_rate_limit_config
end

#raw_configObject

Get raw configuration



533
534
535
# File 'lib/aidp/harness/configuration.rb', line 533

def raw_config
  @config.dup
end

#retry_configObject

Get retry configuration



116
117
118
# File 'lib/aidp/harness/configuration.rb', line 116

def retry_config
  harness_config[:retry] || default_retry_config
end

#session_configObject

Get session configuration



146
147
148
# File 'lib/aidp/harness/configuration.rb', line 146

def session_config
  harness_config[:session] || default_session_config
end

#should_use_full_permissions?(provider_name) ⇒ Boolean

Check if provider should run with full permissions Combines devcontainer detection with configuration

Returns:

  • (Boolean)


811
812
813
814
815
816
817
818
819
820
# File 'lib/aidp/harness/configuration.rb', line 811

def should_use_full_permissions?(provider_name)
  return false unless devcontainer_enabled?
  return false unless in_devcontainer?

  # Check if full permissions are globally enabled for devcontainer
  return true if full_permissions_in_devcontainer?

  # Check if this specific provider should skip permissions
  devcontainer_skip_permissions_for?(provider_name)
end

#task_completion_required?Boolean

Check if task completion is required for work loop completion

Returns:

  • (Boolean)


170
171
172
# File 'lib/aidp/harness/configuration.rb', line 170

def task_completion_required?
  work_loop_config.fetch(:task_completion_required, true)
end

#test_commandsObject

Get test commands



175
176
177
# File 'lib/aidp/harness/configuration.rb', line 175

def test_commands
  normalize_commands(work_loop_config[:test_commands] || [])
end

#test_max_output_linesObject

Get max output lines for tests



216
217
218
# File 'lib/aidp/harness/configuration.rb', line 216

def test_max_output_lines
  output_filtering_config[:test_max_lines] || 500
end

#test_output_modeObject

Get test output mode



210
211
212
213
# File 'lib/aidp/harness/configuration.rb', line 210

def test_output_mode
  mode = output_filtering_config[:test_mode]
  mode ? mode.to_sym : :full
end

#thinking_configObject

Get thinking depth configuration



429
430
431
# File 'lib/aidp/harness/configuration.rb', line 429

def thinking_config
  @config[:thinking] || default_thinking_config
end

#thinking_overridesObject

Get thinking tier overrides



474
475
476
# File 'lib/aidp/harness/configuration.rb', line 474

def thinking_overrides
  thinking_config[:overrides] || {}
end

#tier_override_for(key) ⇒ Object

Get tier override for a skill or template

Parameters:

  • key (String)

    skill or template key (e.g., “skill.generate_tests”, “template.large_refactor”)



480
481
482
# File 'lib/aidp/harness/configuration.rb', line 480

def tier_override_for(key)
  thinking_overrides[key] || thinking_overrides[key.to_sym]
end

#tier_overridesObject

Get tier overrides



610
611
612
# File 'lib/aidp/harness/configuration.rb', line 610

def tier_overrides
  thinking_config[:overrides] || {}
end

#validate_model_config(provider_name, model_name, model_config, errors) ⇒ Object

Validate model configuration



538
539
540
541
542
543
544
545
546
547
548
549
550
551
# File 'lib/aidp/harness/configuration.rb', line 538

def validate_model_config(provider_name, model_name, model_config, errors)
  # Validate model-specific fields
  if model_config[:max_tokens] && !model_config[:max_tokens].is_a?(Integer)
    errors << "Model '#{provider_name}:#{model_name}' max_tokens must be integer"
  end

  if model_config[:timeout] && !model_config[:timeout].is_a?(Integer)
    errors << "Model '#{provider_name}:#{model_name}' timeout must be integer"
  end

  if model_config[:flags] && !model_config[:flags].is_a?(Array)
    errors << "Model '#{provider_name}:#{model_name}' flags must be array"
  end
end

#validate_provider_config(provider_name) ⇒ Object

Validate provider configuration



570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
# File 'lib/aidp/harness/configuration.rb', line 570

def validate_provider_config(provider_name)
  errors = []

  unless provider_configured?(provider_name)
    errors << "Provider '#{provider_name}' not configured"
    return errors
  end

  # Validate provider type
  provider_type = provider_type(provider_name)
  unless %w[usage_based subscription passthrough].include?(provider_type)
    errors << "Provider '#{provider_name}' has invalid type: #{provider_type}"
  end

  # Validate required fields based on type
  case provider_type
  when "usage_based"
    unless max_tokens(provider_name)
      errors << "Provider '#{provider_name}' missing max_tokens for usage_based type"
    end
  when "passthrough"
    unless provider_config(provider_name)[:underlying_service]
      errors << "Provider '#{provider_name}' missing underlying_service for passthrough type"
    end
  end

  errors
end

#vcs_behaviorObject

Get VCS behavior (stage/commit/nothing)



309
310
311
# File 'lib/aidp/harness/configuration.rb', line 309

def vcs_behavior
  version_control_config[:behavior]
end

#vcs_toolObject

Get VCS tool



304
305
306
# File 'lib/aidp/harness/configuration.rb', line 304

def vcs_tool
  version_control_config[:tool]
end

#version_control_configObject

Get version control configuration



299
300
301
# File 'lib/aidp/harness/configuration.rb', line 299

def version_control_config
  work_loop_config[:version_control] || default_version_control_config
end

#work_loop_configObject

Get work loop configuration



151
152
153
# File 'lib/aidp/harness/configuration.rb', line 151

def work_loop_config
  harness_config[:work_loop] || default_work_loop_config
end

#work_loop_enabled?Boolean

Check if work loops are enabled

Returns:

  • (Boolean)


160
161
162
# File 'lib/aidp/harness/configuration.rb', line 160

def work_loop_enabled?
  work_loop_config[:enabled]
end

#work_loop_max_iterationsObject

Get maximum iterations for work loops



165
166
167
# File 'lib/aidp/harness/configuration.rb', line 165

def work_loop_max_iterations
  work_loop_config[:max_iterations]
end

#work_loop_units_configObject



155
156
157
# File 'lib/aidp/harness/configuration.rb', line 155

def work_loop_units_config
  work_loop_config[:units] || default_units_config
end

#zfc_ab_testing_configObject

Get ZFC A/B testing configuration



662
663
664
# File 'lib/aidp/harness/configuration.rb', line 662

def zfc_ab_testing_config
  zfc_config[:ab_testing] || default_zfc_ab_testing_config
end

#zfc_ab_testing_enabled?Boolean

Check if ZFC A/B testing is enabled

Returns:

  • (Boolean)


667
668
669
# File 'lib/aidp/harness/configuration.rb', line 667

def zfc_ab_testing_enabled?
  zfc_ab_testing_config[:enabled] == true
end

#zfc_configObject

Get ZFC configuration



615
616
617
# File 'lib/aidp/harness/configuration.rb', line 615

def zfc_config
  @config[:zfc] || default_zfc_config
end

#zfc_cost_limitsObject

Get ZFC cost limits



657
658
659
# File 'lib/aidp/harness/configuration.rb', line 657

def zfc_cost_limits
  zfc_config[:cost_limits] || default_zfc_cost_limits
end

#zfc_decision_cache_ttl(decision_type) ⇒ Object

Get ZFC decision cache TTL



647
648
649
# File 'lib/aidp/harness/configuration.rb', line 647

def zfc_decision_cache_ttl(decision_type)
  zfc_decision_config(decision_type)[:cache_ttl]
end

#zfc_decision_confidence_threshold(decision_type) ⇒ Object

Get ZFC decision confidence threshold



652
653
654
# File 'lib/aidp/harness/configuration.rb', line 652

def zfc_decision_confidence_threshold(decision_type)
  zfc_decision_config(decision_type)[:confidence_threshold] || 0.7
end

#zfc_decision_config(decision_type) ⇒ Object

Get ZFC decision configuration



630
631
632
# File 'lib/aidp/harness/configuration.rb', line 630

def zfc_decision_config(decision_type)
  zfc_config.dig(:decisions, decision_type.to_sym) || {}
end

#zfc_decision_enabled?(decision_type) ⇒ Boolean

Check if specific ZFC decision type is enabled

Returns:

  • (Boolean)


635
636
637
638
639
# File 'lib/aidp/harness/configuration.rb', line 635

def zfc_decision_enabled?(decision_type)
  return false unless zfc_enabled?
  decision_config = zfc_decision_config(decision_type)
  decision_config[:enabled] == true
end

#zfc_decision_tier(decision_type) ⇒ Object

Get ZFC decision tier



642
643
644
# File 'lib/aidp/harness/configuration.rb', line 642

def zfc_decision_tier(decision_type)
  zfc_decision_config(decision_type)[:tier] || "mini"
end

#zfc_enabled?Boolean

Check if ZFC is enabled

Returns:

  • (Boolean)


620
621
622
# File 'lib/aidp/harness/configuration.rb', line 620

def zfc_enabled?
  zfc_config[:enabled] == true
end

#zfc_fallback_to_legacy?Boolean

Check if ZFC should fallback to legacy on failure

Returns:

  • (Boolean)


625
626
627
# File 'lib/aidp/harness/configuration.rb', line 625

def zfc_fallback_to_legacy?
  zfc_config[:fallback_to_legacy] != false
end