Skip to content

[FEATURE]: Add Wildcard/Auto-Discovery Support for Dependabot Configuration #72

@kpj2006

Description

@kpj2006

Feature and its Use Cases

Dependabot currently requires maintainers to manually configure each package-ecosystem and its corresponding directory in the dependabot.yml file.

This creates maintenance challenges, especially in repositories with multiple services or monorepo structures. Whenever:

  • A new package ecosystem is introduced
  • A new subdirectory is added
  • The project structure changes

the configuration file must be manually updated.

If directories or ecosystems are not explicitly added to dependabot.yml, Dependabot will not monitor or update dependencies in those locations. This increases the risk of missed updates and adds ongoing maintenance overhead.

Current Manual Approach Example:

- package-ecosystem: "npm"
  directory: "/"  # Must manually change to "/frontend", "/backend", etc.

think around this:

  1. Wildcard Directory Support
    Allow wildcards in directory specification to automatically discover all matching paths:
- package-ecosystem: "npm"
  directory: "/*"  # Auto-discover all directories with package.json
  # OR
  directory: "**/packages/*"  # Glob pattern for monorepos
  1. Auto-Discovery Mode
    Enable Dependabot to automatically detect which package ecosystems are actually present:
version: 2
updates:
  - auto-discover: true  # Automatically detect all package ecosystems
    directory: "/**"      # Search entire repository
    # Common settings apply to all discovered ecosystems:
    schedule:
      interval: "weekly"
    labels:
      - "dependencies"

resources:

Additional Context

Example Use Case
A monorepo with the following structure:

/
├── frontend/package.json
├── backend/package.json
├── services/api/package.json
├── services/worker/package.json
└── mobile/pubspec.yaml

Current approach: Requires 4 separate npm blocks + 1 pub block (5 total sections)
With wildcards: 1 npm block with directory: "**/package.json" pattern + 1 pub block (2 total sections)

Code of Conduct

  • I have joined the Discord server and will post updates there
  • I have searched existing issues to avoid duplicates

Metadata

Metadata

Assignees

No one assigned

    Labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions