Skip to content

[micrometer] Fix interference with user-configured request logger#2533

Merged
tipsy merged 4 commits intomasterfrom
copilot/fix-request-logger-issue
Feb 25, 2026
Merged

[micrometer] Fix interference with user-configured request logger#2533
tipsy merged 4 commits intomasterfrom
copilot/fix-request-logger-issue

Conversation

Copy link
Copy Markdown
Contributor

Copilot AI commented Feb 24, 2026

MicrometerPlugin.onInitialize() registered its metrics collection via state.requestLogger.http { ... }, which overwrote any user-configured request logger. This meant users had to choose between metrics and request logging — they couldn't have both.

Changes

  • MicrometerPlugin.kt: Before registering its own logger, the plugin now captures the existing httpRequestLogger. The new logger composites both: metrics are recorded first, then the user's logger is invoked. The user's logger is never lost regardless of registration order.
  • MicrometerPluginTest.kt: Added a test asserting the user-configured request logger is still called when the plugin is registered.
// Both of these now work together — no longer mutually exclusive
config.requestLogger.http { ctx, ms -> println("${ctx.method()} ${ctx.path()} ${ms}ms") }
config.registerPlugin(MicrometerPlugin { it.registry = registry })
Original prompt

This section details on the original issue you should resolve

<issue_title>javalin-micrometer interferance with request logger</issue_title>
<issue_description>Actual behavior (the bug)
When register the micrometer after setting the request logger, then the request logger in not called on fulfilled requests.

Expected behavior
Request logger should be triggered regardless of metrics plugin.

To Reproduce

  1. set the request logger
  2. register micrometer plugin
  3. create an http endpoint
  4. do a http request to that endpoint

Example Java code:

    public static void main(String[] args) {
    var micrometerPlugin = new MicrometerPlugin();
    var javalin =
        Javalin.create(
                config -> {
                  config.registerPlugin(micrometerPlugin);
                  config.requestLogger.http(
                      (ctx, ms) -> {
                        var format = "Request: %s %s took %s ms";
                        System.out.printf(format + "%n", ctx.method(), ctx.path(), ms);
                      });

                  config.routes.get("/hello", ctx -> ctx.result("Hello World"));
                })
            .start(8089);
  }

Additional context

I believe this is the issue:

// Register HTTP request logger to collect metrics
state.requestLogger.http { ctx, executionTimeMs ->
    recordHttpMetrics(ctx, executionTimeMs, state)
}

Based on this, it looks like we have to choose between a request logger and metrics, not both.</issue_description>

<agent_instructions>Please ensure that micrometer does not interfere with user config. </agent_instructions>

Comments on the Issue (you are @copilot in this section)


💬 We'd love your input! Share your thoughts on Copilot coding agent in our 2 minute survey.

Copilot AI changed the title [WIP] Fix request logger interference with micrometer plugin Fix MicrometerPlugin overwriting user-configured HTTP request logger Feb 24, 2026
Copilot AI requested a review from tipsy February 24, 2026 10:00
@tipsy
Copy link
Copy Markdown
Member

tipsy commented Feb 24, 2026

@copilot I think we should avoid touching the request logger, can you use an after and grab the time manually?

@codecov
Copy link
Copy Markdown

codecov bot commented Feb 24, 2026

Codecov Report

✅ All modified and coverable lines are covered by tests.
✅ Project coverage is 86.26%. Comparing base (9c3461f) to head (587d292).
⚠️ Report is 4 commits behind head on master.

Additional details and impacted files
@@            Coverage Diff            @@
##             master    #2533   +/-   ##
=========================================
  Coverage     86.26%   86.26%           
  Complexity     1505     1505           
=========================================
  Files           155      155           
  Lines          4338     4338           
  Branches        522      522           
=========================================
  Hits           3742     3742           
  Misses          363      363           
  Partials        233      233           

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.
  • 📦 JS Bundle Analysis: Save yourself from yourself by tracking and limiting bundle sizes in JS merges.

Copy link
Copy Markdown
Contributor Author

Copilot AI commented Feb 24, 2026

@copilot I think we should avoid touching the request logger, can you use an after and grab the time manually?

Done in 161997a. The plugin now uses before/after handlers to capture timing and record metrics without touching requestLogger at all.

One trade-off with the after handler approach: auto-generated ETag 304s aren't visible since the 304 status is set during response writing (after our after handler runs). The etags test is updated to reflect this — metrics record the handler's status (200), not the ETag transport optimization (304). Explicit ETags set by the handler would still work correctly.

Warning

Firewall rules blocked me from connecting to one or more addresses (expand for details)

I tried to connect to the following addresses, but was blocked by firewall rules:

  • www.google.com
    • Triggering command: /proc/self/exe /proc/self/exe --type=utility --utility-sub-type=network.mojom.NetworkService --lang=en-US --service-sandbox-type=none --no-sandbox --disable-dev-shm-usage --use-angle=swiftshader-webgl --crashpad-handler-pid=5757 --enable-crash-reporter=, --noerrdialogs --user-data-dir=/tmp/org.chromium.Chromium.scoped_dir.79vxVn --change-stack-guard-on-fork=enable --shared-files=v8_context_snapshot_data:100 --field-trial-handle=3,i,5491375344045772556,12134624301296659610,262144 --disable-features=IgnoreDuplicateNavs,PaintHolding,Prewarm --variations-seed-version --trace-process-track-uuid=3190708989122997041 --enable-logging --log-level=0 (dns block)
    • Triggering command: /opt/google/chrome/chrome /opt/google/chrome/chrome --allow-pre-commit-input --disable-REDACTED-networking --disable-REDACTED-timer-throttling --disable-REDACTEDing-occluded-windows --disable-client-side-phishing-detection --disable-default-apps --disable-dev-shm-usage --disable-features=IgnoreDuplicateNavs,Prewarm --disable-gpu --disable-hang-monitor --disable-popup-blocking --disable-prompt-on-repost --disable-sync --enable-automation --enable-logging --headless=new --log-level=0 --no-first-run --no-sandbox (dns block)
    • Triggering command: /proc/self/exe /proc/self/exe --type=utility --utility-sub-type=network.mojom.NetworkService --lang=en-US --service-sandbox-type=none --no-sandbox --disable-dev-shm-usage --use-angle=swiftshader-webgl --crashpad-handler-pid=9128 --enable-crash-reporter=, --noerrdialogs --user-data-dir=/tmp/org.chromium.Chromium.scoped_dir.53Dp3K --change-stack-guard-on-fork=enable --shared-files=v8_context_snapshot_data:100 --field-trial-handle=3,i,11119842164605674254,4817581800876992358,262144 --disable-features=IgnoreDuplicateNavs,PaintHolding,Prewarm --variations-seed-version --trace-process-track-uuid=3190708989122997041 --enable-logging --log-level=0 (dns block)

If you need me to access, download, or install something from one of these locations, you can either:

Copilot AI changed the title Fix MicrometerPlugin overwriting user-configured HTTP request logger Fix MicrometerPlugin interference with user-configured HTTP request logger Feb 24, 2026
@tipsy
Copy link
Copy Markdown
Member

tipsy commented Feb 24, 2026

@copilot good point, let's go back to your original proposal.

Copy link
Copy Markdown
Contributor Author

Copilot AI commented Feb 24, 2026

@copilot good point, let's go back to your original proposal.

Reverted in 587d292. Back to capturing the existing logger and chaining it after metrics recording.

Warning

Firewall rules blocked me from connecting to one or more addresses (expand for details)

I tried to connect to the following addresses, but was blocked by firewall rules:

  • optimizationguide-pa.googleapis.com
    • Triggering command: /proc/self/exe /proc/self/exe --type=utility --utility-sub-type=network.mojom.NetworkService --lang=en-US --service-sandbox-type=none --no-sandbox --disable-dev-shm-usage --use-angle=swiftshader-webgl --crashpad-handler-pid=8977 --enable-crash-reporter=, --noerrdialogs --user-data-dir=/tmp/org.chromium.Chromium.scoped_dir.eR20v7 --change-stack-guard-on-fork=enable --shared-files=v8_context_snapshot_data:100 --field-trial-handle=3,i,17441623299415734598,13366108916326324218,262144 --disable-features=IgnoreDuplicateNavs,PaintHolding,Prewarm --variations-seed-version --trace-process-track-uuid=3190708989122997041 --enable-logging --log-level=0 (dns block)
    • Triggering command: /opt/google/chrome/chrome /opt/google/chrome/chrome --allow-pre-commit-input --disable-REDACTED-networking --disable-REDACTED-timer-throttling --disable-REDACTEDing-occluded-windows --disable-client-side-phishing-detection --disable-default-apps --disable-dev-shm-usage --disable-features=IgnoreDuplicateNavs,Prewarm --disable-gpu --disable-hang-monitor --disable-popup-blocking --disable-prompt-on-repost --disable-sync --enable-automation --enable-logging --headless=new --log-level=0 --no-first-run --no-sandbox (dns block)
  • www.google.com
    • Triggering command: /proc/self/exe /proc/self/exe --type=utility --utility-sub-type=network.mojom.NetworkService --lang=en-US --service-sandbox-type=none --no-sandbox --disable-dev-shm-usage --use-angle=swiftshader-webgl --crashpad-handler-pid=8977 --enable-crash-reporter=, --noerrdialogs --user-data-dir=/tmp/org.chromium.Chromium.scoped_dir.eR20v7 --change-stack-guard-on-fork=enable --shared-files=v8_context_snapshot_data:100 --field-trial-handle=3,i,17441623299415734598,13366108916326324218,262144 --disable-features=IgnoreDuplicateNavs,PaintHolding,Prewarm --variations-seed-version --trace-process-track-uuid=3190708989122997041 --enable-logging --log-level=0 (dns block)
    • Triggering command: /opt/google/chrome/chrome /opt/google/chrome/chrome --allow-pre-commit-input --disable-REDACTED-networking --disable-REDACTED-timer-throttling --disable-REDACTEDing-occluded-windows --disable-client-side-phishing-detection --disable-default-apps --disable-dev-shm-usage --disable-features=IgnoreDuplicateNavs,Prewarm --disable-gpu --disable-hang-monitor --disable-popup-blocking --disable-prompt-on-repost --disable-sync --enable-automation --enable-logging --headless=new --log-level=0 --no-first-run --no-sandbox (dns block)
    • Triggering command: /proc/self/exe /proc/self/exe --type=utility --utility-sub-type=network.mojom.NetworkService --lang=en-US --service-sandbox-type=none --no-sandbox --disable-dev-shm-usage --use-angle=swiftshader-webgl --crashpad-handler-pid=9111 --enable-crash-reporter=, --noerrdialogs --user-data-dir=/tmp/org.chromium.Chromium.scoped_dir.yTjVhr --change-stack-guard-on-fork=enable --shared-files=v8_context_snapshot_data:100 --field-trial-handle=3,i,3741048064751700057,16289580944237695656,262144 --disable-features=IgnoreDuplicateNavs,PaintHolding,Prewarm --variations-seed-version --trace-process-track-uuid=3190708989122997041 --enable-logging --log-level=0 (dns block)

If you need me to access, download, or install something from one of these locations, you can either:

@tipsy tipsy marked this pull request as ready for review February 24, 2026 14:50
@tipsy tipsy changed the title Fix MicrometerPlugin interference with user-configured HTTP request logger [micrometer] Fix interference with user-configured request logger Feb 24, 2026
@tipsy tipsy merged commit e134377 into master Feb 25, 2026
16 checks passed
@tipsy tipsy deleted the copilot/fix-request-logger-issue branch February 25, 2026 23:25
mergify bot added a commit to robfrank/linklift that referenced this pull request Mar 10, 2026
Bumps `javalin.version` from 6.7.0 to 7.0.1.
Updates `io.javalin:javalin-bundle` from 6.7.0 to 7.0.1
Release notes

*Sourced from [io.javalin:javalin-bundle's releases](https://github.com/javalin/javalin/releases).*

> 7.0.1
> -----
>
> What's Changed
> --------------
>
> * [readme] v7 release updates by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2527](https://redirect.github.com/javalin/javalin/pull/2527)
> * [micrometer] Fix interference with user-configured request logger by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2533](https://redirect.github.com/javalin/javalin/pull/2533)
> * [logging] Allow for multiple request loggers by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2539](https://redirect.github.com/javalin/javalin/pull/2539)
>
> **Full Changelog**: <javalin/javalin@javalin-parent-7.0.0...javalin-parent-7.0.1>
>
> 7.0.0
> -----
>
> What's Changed
> --------------
>
> * Fix infinite loop in custom exception handling by [`@​LordOfLeaks`](https://github.com/LordOfLeaks) in [javalin/javalin#2423](https://redirect.github.com/javalin/javalin/pull/2423)
> * [workflow]: Bump actions/checkout from 4 to 5 in the dependencies group by [`@​dependabot`](https://github.com/dependabot)[bot] in [javalin/javalin#2428](https://redirect.github.com/javalin/javalin/pull/2428)
> * Add comprehensive GitHub Copilot instructions with commit message convention by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2433](https://redirect.github.com/javalin/javalin/pull/2433)
> * Bump and rename sslcontext-kickstart to ayza by [`@​Hakky54`](https://github.com/Hakky54) in [javalin/javalin#2434](https://redirect.github.com/javalin/javalin/pull/2434)
> * Update Javalin to version 7.0.0-SNAPSHOT with Java 17 requirement by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2431](https://redirect.github.com/javalin/javalin/pull/2431)
> * Improve test suite by adding HTTP status code assertions and cleaning up static files tests by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2437](https://redirect.github.com/javalin/javalin/pull/2437)
> * [core] Migrate to Jetty 12 by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2444](https://redirect.github.com/javalin/javalin/pull/2444)
> * [workflow]: Bump the dependencies group with 3 updates by [`@​dependabot`](https://github.com/dependabot)[bot] in [javalin/javalin#2445](https://redirect.github.com/javalin/javalin/pull/2445)
> * Optimize static file handling by leveraging Jetty 12 native capabilities by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2447](https://redirect.github.com/javalin/javalin/pull/2447)
> * Upgrade Kotlin from 1.9.25 to 2.0.21 and remove JTE integration by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2452](https://redirect.github.com/javalin/javalin/pull/2452)
> * [deps] Update Pebble to 3.2.4 and fix package imports for CVE security fix by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2453](https://redirect.github.com/javalin/javalin/pull/2453)
> * Update all dependencies and plugins to latest stable versions by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2456](https://redirect.github.com/javalin/javalin/pull/2456)
> * [context] add support for quoted charset in content-type header ([#2448](https://redirect.github.com/javalin/javalin/issues/2448)) by [`@​Pinusar`](https://github.com/Pinusar) in [javalin/javalin#2449](https://redirect.github.com/javalin/javalin/pull/2449)
> * Add onUpgrade method to WebSocket RequestLogger by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2450](https://redirect.github.com/javalin/javalin/pull/2450)
> * Fix cookie handling in JavalinTest client by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2459](https://redirect.github.com/javalin/javalin/pull/2459)
> * Replace OkHTTP with native JDK HttpClient in javalin-testtools by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2461](https://redirect.github.com/javalin/javalin/pull/2461)
> * [ssl] Drop Conscrypt ALPN support from SSL Plugin by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2464](https://redirect.github.com/javalin/javalin/pull/2464)
> * [compression] Add preferred compressors list by [`@​fabiobento512`](https://github.com/fabiobento512) in [javalin/javalin#2427](https://redirect.github.com/javalin/javalin/pull/2427)
> * Add Zstandard compression support using zstd-jni by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2465](https://redirect.github.com/javalin/javalin/pull/2465)
> * Fix Missing Allow Header in HTTP 405 Responses by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2468](https://redirect.github.com/javalin/javalin/pull/2468)
> * [sse] Relax Accept header validation to support multiple content types by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2474](https://redirect.github.com/javalin/javalin/pull/2474)
> * [routing] Support custom HTTP methods by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2478](https://redirect.github.com/javalin/javalin/pull/2478)
> * [tests] Fix flakiness in TestRateLimitUtil by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2477](https://redirect.github.com/javalin/javalin/pull/2477)
> * [javalin] Move routing to config by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2479](https://redirect.github.com/javalin/javalin/pull/2479)
> * [maven] Refactor modules by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2481](https://redirect.github.com/javalin/javalin/pull/2481)
> * [github] Improve copilot-instructions.md with comprehensive Javalin patterns and philosophy by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2483](https://redirect.github.com/javalin/javalin/pull/2483)
> * [core] Introduce endpoint stack and utilize endpoints more by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2486](https://redirect.github.com/javalin/javalin/pull/2486)
> * [async] Improve async handling by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2489](https://redirect.github.com/javalin/javalin/pull/2489)
> * [deps] Upgrade OkHttp to 5.3.0 by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2496](https://redirect.github.com/javalin/javalin/pull/2496)
> * [core] Add config option to disable old version check warning by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2499](https://redirect.github.com/javalin/javalin/pull/2499)
> * Add static keyword to wsBefore and wsAfter in ApiBuilder by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2501](https://redirect.github.com/javalin/javalin/pull/2501)
> * [deps] Update Pebble to 4.0.0 by [`@​kamenitxan`](https://github.com/kamenitxan) in [javalin/javalin#2502](https://redirect.github.com/javalin/javalin/pull/2502)
> * [workflow]: Bump actions/checkout from 5 to 6 in the dependencies group by [`@​dependabot`](https://github.com/dependabot)[bot] in [javalin/javalin#2503](https://redirect.github.com/javalin/javalin/pull/2503)
> * [config] Rework JavalinConfig by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2504](https://redirect.github.com/javalin/javalin/pull/2504)
> * [tests] Add missing test cases by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2506](https://redirect.github.com/javalin/javalin/pull/2506)
> * [cors] Use JDK's URI class by [`@​Playacem`](https://github.com/Playacem) in [javalin/javalin#2180](https://redirect.github.com/javalin/javalin/pull/2180)
> * [micrometer] Restore Micrometer plugin for Javalin7/Jetty12 by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2511](https://redirect.github.com/javalin/javalin/pull/2511)
> * [json] Fix NoClassDefFoundError for ObjectMapper on Kotlin 2.x by [`@​fahrradflucht`](https://github.com/fahrradflucht) in [javalin/javalin#2510](https://redirect.github.com/javalin/javalin/pull/2510)
> * Extend Context#redirect to beforeMatched and rename skipIfExceptionOccurred by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2515](https://redirect.github.com/javalin/javalin/pull/2515)
> * [routing] Clean up unused interfaces and generics by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2517](https://redirect.github.com/javalin/javalin/pull/2517)

... (truncated)


Commits

* [`bbe55e5`](javalin/javalin@bbe55e5) [maven-release-plugin] prepare release javalin-parent-7.0.1
* [`f5a4934`](javalin/javalin@f5a4934) [logging] Allow for multiple request loggers ([#2539](https://redirect.github.com/javalin/javalin/issues/2539))
* [`e134377`](javalin/javalin@e134377) [micrometer] Fix interference with user-configured request logger ([#2533](https://redirect.github.com/javalin/javalin/issues/2533))
* [`5b5b2fb`](javalin/javalin@5b5b2fb) [websocket] Fix attributes set in wsBeforeUpgrade not persisting to onConnect
* [`d4b8c5b`](javalin/javalin@d4b8c5b) [ratelimitplugin] Fix regression in default key function
* [`698995d`](javalin/javalin@698995d) [endpoints] Add option to get the future matched enpoint
* [`9c3461f`](javalin/javalin@9c3461f) [docs] Update for v7
* [`6821dea`](javalin/javalin@6821dea) [maven-release-plugin] prepare for next development iteration
* [`3e02e28`](javalin/javalin@3e02e28) [maven-release-plugin] prepare release javalin-parent-7.0.0
* [`a02ecb7`](javalin/javalin@a02ecb7) [pom] Publish aggregator poms to fix release deploy
* Additional commits viewable in [compare view](javalin/javalin@javalin-parent-6.7.0...javalin-parent-7.0.1)
  
Updates `io.javalin.community.openapi:javalin-openapi-plugin` from 6.7.0 to 7.0.1
Release notes

*Sourced from [io.javalin.community.openapi:javalin-openapi-plugin's releases](https://github.com/javalin/javalin-openapi/releases).*

> 7.0.0
> -----
>
> **Changes**
>
> * See: <https://javalin.github.io/javalin-openapi/introduction/migration-from-6x.html>
>
> **Sponsors**
> Thanks to everyone who supported me this month 💜
>
> **Minimal requirements**
>
> * Java 17+ / Kotlin 2.3+
> * Javalin 7.0.0
>
> **Download**
>
> * [Wiki / Installation](https://github.com/javalin/javalin-openapi/wiki/1.-Installation)
>
> 7.0.0-beta.1
> ------------
>
> **Changes**
>
> * Support Javalin 7.0.0-beta.1
>
> **Sponsors**
> Thanks to everyone who supported me this month 💜

... (truncated)


Commits

* [`4a073c8`](javalin/javalin-openapi@4a073c8) [GH-274](https://redirect.github.com/javalin/javalin-openapi/issues/274) Release 7.0.1 (Resolves [#274](https://redirect.github.com/javalin/javalin-openapi/issues/274))
* [`11d10d5`](javalin/javalin-openapi@11d10d5) [GH-273](https://redirect.github.com/javalin/javalin-openapi/issues/273) Restructure dependencies (Fixes [#272](https://redirect.github.com/javalin/javalin-openapi/issues/272))
* [`41b3061`](javalin/javalin-openapi@41b3061) [GH-271](https://redirect.github.com/javalin/javalin-openapi/issues/271) Migration guide from 6.x
* [`1669065`](javalin/javalin-openapi@1669065) [GH-271](https://redirect.github.com/javalin/javalin-openapi/issues/271) Redesign core implementation for Javalin 7.x
* [`0c6ba93`](javalin/javalin-openapi@0c6ba93) [GH-268](https://redirect.github.com/javalin/javalin-openapi/issues/268) Replace wiki reference with a new docs in README ([#268](https://redirect.github.com/javalin/javalin-openapi/issues/268))
* [`5346ada`](javalin/javalin-openapi@5346ada) chore: adjust module resource path formatting in readme
* [`dd49a03`](javalin/javalin-openapi@dd49a03) fix: modify OpenAPI plugin resource path description
* [`13e6778`](javalin/javalin-openapi@13e6778) chore: update README for Javalin 7.x changes
* [`57ff8f7`](javalin/javalin-openapi@57ff8f7) [GH-264](https://redirect.github.com/javalin/javalin-openapi/issues/264) Drop GitHub Wiki
* [`b94bc1f`](javalin/javalin-openapi@b94bc1f) [GH-264](https://redirect.github.com/javalin/javalin-openapi/issues/264) Define custom base path for docs deployed to GitHub pages
* Additional commits viewable in [compare view](javalin/javalin-openapi@6.7.0...7.0.1)
  
Updates `io.javalin.community.openapi:javalin-swagger-plugin` from 6.7.0 to 7.0.1
Release notes

*Sourced from [io.javalin.community.openapi:javalin-swagger-plugin's releases](https://github.com/javalin/javalin-openapi/releases).*

> 7.0.0
> -----
>
> **Changes**
>
> * See: <https://javalin.github.io/javalin-openapi/introduction/migration-from-6x.html>
>
> **Sponsors**
> Thanks to everyone who supported me this month 💜
>
> **Minimal requirements**
>
> * Java 17+ / Kotlin 2.3+
> * Javalin 7.0.0
>
> **Download**
>
> * [Wiki / Installation](https://github.com/javalin/javalin-openapi/wiki/1.-Installation)
>
> 7.0.0-beta.1
> ------------
>
> **Changes**
>
> * Support Javalin 7.0.0-beta.1
>
> **Sponsors**
> Thanks to everyone who supported me this month 💜

... (truncated)


Commits

* [`4a073c8`](javalin/javalin-openapi@4a073c8) [GH-274](https://redirect.github.com/javalin/javalin-openapi/issues/274) Release 7.0.1 (Resolves [#274](https://redirect.github.com/javalin/javalin-openapi/issues/274))
* [`11d10d5`](javalin/javalin-openapi@11d10d5) [GH-273](https://redirect.github.com/javalin/javalin-openapi/issues/273) Restructure dependencies (Fixes [#272](https://redirect.github.com/javalin/javalin-openapi/issues/272))
* [`41b3061`](javalin/javalin-openapi@41b3061) [GH-271](https://redirect.github.com/javalin/javalin-openapi/issues/271) Migration guide from 6.x
* [`1669065`](javalin/javalin-openapi@1669065) [GH-271](https://redirect.github.com/javalin/javalin-openapi/issues/271) Redesign core implementation for Javalin 7.x
* [`0c6ba93`](javalin/javalin-openapi@0c6ba93) [GH-268](https://redirect.github.com/javalin/javalin-openapi/issues/268) Replace wiki reference with a new docs in README ([#268](https://redirect.github.com/javalin/javalin-openapi/issues/268))
* [`5346ada`](javalin/javalin-openapi@5346ada) chore: adjust module resource path formatting in readme
* [`dd49a03`](javalin/javalin-openapi@dd49a03) fix: modify OpenAPI plugin resource path description
* [`13e6778`](javalin/javalin-openapi@13e6778) chore: update README for Javalin 7.x changes
* [`57ff8f7`](javalin/javalin-openapi@57ff8f7) [GH-264](https://redirect.github.com/javalin/javalin-openapi/issues/264) Drop GitHub Wiki
* [`b94bc1f`](javalin/javalin-openapi@b94bc1f) [GH-264](https://redirect.github.com/javalin/javalin-openapi/issues/264) Define custom base path for docs deployed to GitHub pages
* Additional commits viewable in [compare view](javalin/javalin-openapi@6.7.0...7.0.1)
  
Updates `io.javalin:javalin-micrometer` from 6.7.0 to 7.0.1
Release notes

*Sourced from [io.javalin:javalin-micrometer's releases](https://github.com/javalin/javalin/releases).*

> 7.0.1
> -----
>
> What's Changed
> --------------
>
> * [readme] v7 release updates by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2527](https://redirect.github.com/javalin/javalin/pull/2527)
> * [micrometer] Fix interference with user-configured request logger by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2533](https://redirect.github.com/javalin/javalin/pull/2533)
> * [logging] Allow for multiple request loggers by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2539](https://redirect.github.com/javalin/javalin/pull/2539)
>
> **Full Changelog**: <javalin/javalin@javalin-parent-7.0.0...javalin-parent-7.0.1>
>
> 7.0.0
> -----
>
> What's Changed
> --------------
>
> * Fix infinite loop in custom exception handling by [`@​LordOfLeaks`](https://github.com/LordOfLeaks) in [javalin/javalin#2423](https://redirect.github.com/javalin/javalin/pull/2423)
> * [workflow]: Bump actions/checkout from 4 to 5 in the dependencies group by [`@​dependabot`](https://github.com/dependabot)[bot] in [javalin/javalin#2428](https://redirect.github.com/javalin/javalin/pull/2428)
> * Add comprehensive GitHub Copilot instructions with commit message convention by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2433](https://redirect.github.com/javalin/javalin/pull/2433)
> * Bump and rename sslcontext-kickstart to ayza by [`@​Hakky54`](https://github.com/Hakky54) in [javalin/javalin#2434](https://redirect.github.com/javalin/javalin/pull/2434)
> * Update Javalin to version 7.0.0-SNAPSHOT with Java 17 requirement by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2431](https://redirect.github.com/javalin/javalin/pull/2431)
> * Improve test suite by adding HTTP status code assertions and cleaning up static files tests by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2437](https://redirect.github.com/javalin/javalin/pull/2437)
> * [core] Migrate to Jetty 12 by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2444](https://redirect.github.com/javalin/javalin/pull/2444)
> * [workflow]: Bump the dependencies group with 3 updates by [`@​dependabot`](https://github.com/dependabot)[bot] in [javalin/javalin#2445](https://redirect.github.com/javalin/javalin/pull/2445)
> * Optimize static file handling by leveraging Jetty 12 native capabilities by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2447](https://redirect.github.com/javalin/javalin/pull/2447)
> * Upgrade Kotlin from 1.9.25 to 2.0.21 and remove JTE integration by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2452](https://redirect.github.com/javalin/javalin/pull/2452)
> * [deps] Update Pebble to 3.2.4 and fix package imports for CVE security fix by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2453](https://redirect.github.com/javalin/javalin/pull/2453)
> * Update all dependencies and plugins to latest stable versions by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2456](https://redirect.github.com/javalin/javalin/pull/2456)
> * [context] add support for quoted charset in content-type header ([#2448](https://redirect.github.com/javalin/javalin/issues/2448)) by [`@​Pinusar`](https://github.com/Pinusar) in [javalin/javalin#2449](https://redirect.github.com/javalin/javalin/pull/2449)
> * Add onUpgrade method to WebSocket RequestLogger by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2450](https://redirect.github.com/javalin/javalin/pull/2450)
> * Fix cookie handling in JavalinTest client by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2459](https://redirect.github.com/javalin/javalin/pull/2459)
> * Replace OkHTTP with native JDK HttpClient in javalin-testtools by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2461](https://redirect.github.com/javalin/javalin/pull/2461)
> * [ssl] Drop Conscrypt ALPN support from SSL Plugin by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2464](https://redirect.github.com/javalin/javalin/pull/2464)
> * [compression] Add preferred compressors list by [`@​fabiobento512`](https://github.com/fabiobento512) in [javalin/javalin#2427](https://redirect.github.com/javalin/javalin/pull/2427)
> * Add Zstandard compression support using zstd-jni by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2465](https://redirect.github.com/javalin/javalin/pull/2465)
> * Fix Missing Allow Header in HTTP 405 Responses by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2468](https://redirect.github.com/javalin/javalin/pull/2468)
> * [sse] Relax Accept header validation to support multiple content types by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2474](https://redirect.github.com/javalin/javalin/pull/2474)
> * [routing] Support custom HTTP methods by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2478](https://redirect.github.com/javalin/javalin/pull/2478)
> * [tests] Fix flakiness in TestRateLimitUtil by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2477](https://redirect.github.com/javalin/javalin/pull/2477)
> * [javalin] Move routing to config by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2479](https://redirect.github.com/javalin/javalin/pull/2479)
> * [maven] Refactor modules by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2481](https://redirect.github.com/javalin/javalin/pull/2481)
> * [github] Improve copilot-instructions.md with comprehensive Javalin patterns and philosophy by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2483](https://redirect.github.com/javalin/javalin/pull/2483)
> * [core] Introduce endpoint stack and utilize endpoints more by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2486](https://redirect.github.com/javalin/javalin/pull/2486)
> * [async] Improve async handling by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2489](https://redirect.github.com/javalin/javalin/pull/2489)
> * [deps] Upgrade OkHttp to 5.3.0 by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2496](https://redirect.github.com/javalin/javalin/pull/2496)
> * [core] Add config option to disable old version check warning by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2499](https://redirect.github.com/javalin/javalin/pull/2499)
> * Add static keyword to wsBefore and wsAfter in ApiBuilder by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2501](https://redirect.github.com/javalin/javalin/pull/2501)
> * [deps] Update Pebble to 4.0.0 by [`@​kamenitxan`](https://github.com/kamenitxan) in [javalin/javalin#2502](https://redirect.github.com/javalin/javalin/pull/2502)
> * [workflow]: Bump actions/checkout from 5 to 6 in the dependencies group by [`@​dependabot`](https://github.com/dependabot)[bot] in [javalin/javalin#2503](https://redirect.github.com/javalin/javalin/pull/2503)
> * [config] Rework JavalinConfig by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2504](https://redirect.github.com/javalin/javalin/pull/2504)
> * [tests] Add missing test cases by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2506](https://redirect.github.com/javalin/javalin/pull/2506)
> * [cors] Use JDK's URI class by [`@​Playacem`](https://github.com/Playacem) in [javalin/javalin#2180](https://redirect.github.com/javalin/javalin/pull/2180)
> * [micrometer] Restore Micrometer plugin for Javalin7/Jetty12 by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2511](https://redirect.github.com/javalin/javalin/pull/2511)
> * [json] Fix NoClassDefFoundError for ObjectMapper on Kotlin 2.x by [`@​fahrradflucht`](https://github.com/fahrradflucht) in [javalin/javalin#2510](https://redirect.github.com/javalin/javalin/pull/2510)
> * Extend Context#redirect to beforeMatched and rename skipIfExceptionOccurred by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2515](https://redirect.github.com/javalin/javalin/pull/2515)
> * [routing] Clean up unused interfaces and generics by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2517](https://redirect.github.com/javalin/javalin/pull/2517)

... (truncated)


Commits

* [`bbe55e5`](javalin/javalin@bbe55e5) [maven-release-plugin] prepare release javalin-parent-7.0.1
* [`f5a4934`](javalin/javalin@f5a4934) [logging] Allow for multiple request loggers ([#2539](https://redirect.github.com/javalin/javalin/issues/2539))
* [`e134377`](javalin/javalin@e134377) [micrometer] Fix interference with user-configured request logger ([#2533](https://redirect.github.com/javalin/javalin/issues/2533))
* [`5b5b2fb`](javalin/javalin@5b5b2fb) [websocket] Fix attributes set in wsBeforeUpgrade not persisting to onConnect
* [`d4b8c5b`](javalin/javalin@d4b8c5b) [ratelimitplugin] Fix regression in default key function
* [`698995d`](javalin/javalin@698995d) [endpoints] Add option to get the future matched enpoint
* [`9c3461f`](javalin/javalin@9c3461f) [docs] Update for v7
* [`6821dea`](javalin/javalin@6821dea) [maven-release-plugin] prepare for next development iteration
* [`3e02e28`](javalin/javalin@3e02e28) [maven-release-plugin] prepare release javalin-parent-7.0.0
* [`a02ecb7`](javalin/javalin@a02ecb7) [pom] Publish aggregator poms to fix release deploy
* Additional commits viewable in [compare view](javalin/javalin@javalin-parent-6.7.0...javalin-parent-7.0.1)
  
Updates `io.javalin:javalin-testtools` from 6.7.0 to 7.0.1
Release notes

*Sourced from [io.javalin:javalin-testtools's releases](https://github.com/javalin/javalin/releases).*

> 7.0.1
> -----
>
> What's Changed
> --------------
>
> * [readme] v7 release updates by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2527](https://redirect.github.com/javalin/javalin/pull/2527)
> * [micrometer] Fix interference with user-configured request logger by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2533](https://redirect.github.com/javalin/javalin/pull/2533)
> * [logging] Allow for multiple request loggers by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2539](https://redirect.github.com/javalin/javalin/pull/2539)
>
> **Full Changelog**: <javalin/javalin@javalin-parent-7.0.0...javalin-parent-7.0.1>
>
> 7.0.0
> -----
>
> What's Changed
> --------------
>
> * Fix infinite loop in custom exception handling by [`@​LordOfLeaks`](https://github.com/LordOfLeaks) in [javalin/javalin#2423](https://redirect.github.com/javalin/javalin/pull/2423)
> * [workflow]: Bump actions/checkout from 4 to 5 in the dependencies group by [`@​dependabot`](https://github.com/dependabot)[bot] in [javalin/javalin#2428](https://redirect.github.com/javalin/javalin/pull/2428)
> * Add comprehensive GitHub Copilot instructions with commit message convention by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2433](https://redirect.github.com/javalin/javalin/pull/2433)
> * Bump and rename sslcontext-kickstart to ayza by [`@​Hakky54`](https://github.com/Hakky54) in [javalin/javalin#2434](https://redirect.github.com/javalin/javalin/pull/2434)
> * Update Javalin to version 7.0.0-SNAPSHOT with Java 17 requirement by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2431](https://redirect.github.com/javalin/javalin/pull/2431)
> * Improve test suite by adding HTTP status code assertions and cleaning up static files tests by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2437](https://redirect.github.com/javalin/javalin/pull/2437)
> * [core] Migrate to Jetty 12 by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2444](https://redirect.github.com/javalin/javalin/pull/2444)
> * [workflow]: Bump the dependencies group with 3 updates by [`@​dependabot`](https://github.com/dependabot)[bot] in [javalin/javalin#2445](https://redirect.github.com/javalin/javalin/pull/2445)
> * Optimize static file handling by leveraging Jetty 12 native capabilities by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2447](https://redirect.github.com/javalin/javalin/pull/2447)
> * Upgrade Kotlin from 1.9.25 to 2.0.21 and remove JTE integration by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2452](https://redirect.github.com/javalin/javalin/pull/2452)
> * [deps] Update Pebble to 3.2.4 and fix package imports for CVE security fix by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2453](https://redirect.github.com/javalin/javalin/pull/2453)
> * Update all dependencies and plugins to latest stable versions by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2456](https://redirect.github.com/javalin/javalin/pull/2456)
> * [context] add support for quoted charset in content-type header ([#2448](https://redirect.github.com/javalin/javalin/issues/2448)) by [`@​Pinusar`](https://github.com/Pinusar) in [javalin/javalin#2449](https://redirect.github.com/javalin/javalin/pull/2449)
> * Add onUpgrade method to WebSocket RequestLogger by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2450](https://redirect.github.com/javalin/javalin/pull/2450)
> * Fix cookie handling in JavalinTest client by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2459](https://redirect.github.com/javalin/javalin/pull/2459)
> * Replace OkHTTP with native JDK HttpClient in javalin-testtools by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2461](https://redirect.github.com/javalin/javalin/pull/2461)
> * [ssl] Drop Conscrypt ALPN support from SSL Plugin by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2464](https://redirect.github.com/javalin/javalin/pull/2464)
> * [compression] Add preferred compressors list by [`@​fabiobento512`](https://github.com/fabiobento512) in [javalin/javalin#2427](https://redirect.github.com/javalin/javalin/pull/2427)
> * Add Zstandard compression support using zstd-jni by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2465](https://redirect.github.com/javalin/javalin/pull/2465)
> * Fix Missing Allow Header in HTTP 405 Responses by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2468](https://redirect.github.com/javalin/javalin/pull/2468)
> * [sse] Relax Accept header validation to support multiple content types by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2474](https://redirect.github.com/javalin/javalin/pull/2474)
> * [routing] Support custom HTTP methods by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2478](https://redirect.github.com/javalin/javalin/pull/2478)
> * [tests] Fix flakiness in TestRateLimitUtil by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2477](https://redirect.github.com/javalin/javalin/pull/2477)
> * [javalin] Move routing to config by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2479](https://redirect.github.com/javalin/javalin/pull/2479)
> * [maven] Refactor modules by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2481](https://redirect.github.com/javalin/javalin/pull/2481)
> * [github] Improve copilot-instructions.md with comprehensive Javalin patterns and philosophy by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2483](https://redirect.github.com/javalin/javalin/pull/2483)
> * [core] Introduce endpoint stack and utilize endpoints more by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2486](https://redirect.github.com/javalin/javalin/pull/2486)
> * [async] Improve async handling by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2489](https://redirect.github.com/javalin/javalin/pull/2489)
> * [deps] Upgrade OkHttp to 5.3.0 by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2496](https://redirect.github.com/javalin/javalin/pull/2496)
> * [core] Add config option to disable old version check warning by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2499](https://redirect.github.com/javalin/javalin/pull/2499)
> * Add static keyword to wsBefore and wsAfter in ApiBuilder by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2501](https://redirect.github.com/javalin/javalin/pull/2501)
> * [deps] Update Pebble to 4.0.0 by [`@​kamenitxan`](https://github.com/kamenitxan) in [javalin/javalin#2502](https://redirect.github.com/javalin/javalin/pull/2502)
> * [workflow]: Bump actions/checkout from 5 to 6 in the dependencies group by [`@​dependabot`](https://github.com/dependabot)[bot] in [javalin/javalin#2503](https://redirect.github.com/javalin/javalin/pull/2503)
> * [config] Rework JavalinConfig by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2504](https://redirect.github.com/javalin/javalin/pull/2504)
> * [tests] Add missing test cases by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2506](https://redirect.github.com/javalin/javalin/pull/2506)
> * [cors] Use JDK's URI class by [`@​Playacem`](https://github.com/Playacem) in [javalin/javalin#2180](https://redirect.github.com/javalin/javalin/pull/2180)
> * [micrometer] Restore Micrometer plugin for Javalin7/Jetty12 by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2511](https://redirect.github.com/javalin/javalin/pull/2511)
> * [json] Fix NoClassDefFoundError for ObjectMapper on Kotlin 2.x by [`@​fahrradflucht`](https://github.com/fahrradflucht) in [javalin/javalin#2510](https://redirect.github.com/javalin/javalin/pull/2510)
> * Extend Context#redirect to beforeMatched and rename skipIfExceptionOccurred by [`@​Copilot`](https://github.com/Copilot) in [javalin/javalin#2515](https://redirect.github.com/javalin/javalin/pull/2515)
> * [routing] Clean up unused interfaces and generics by [`@​tipsy`](https://github.com/tipsy) in [javalin/javalin#2517](https://redirect.github.com/javalin/javalin/pull/2517)

... (truncated)


Commits

* [`bbe55e5`](javalin/javalin@bbe55e5) [maven-release-plugin] prepare release javalin-parent-7.0.1
* [`f5a4934`](javalin/javalin@f5a4934) [logging] Allow for multiple request loggers ([#2539](https://redirect.github.com/javalin/javalin/issues/2539))
* [`e134377`](javalin/javalin@e134377) [micrometer] Fix interference with user-configured request logger ([#2533](https://redirect.github.com/javalin/javalin/issues/2533))
* [`5b5b2fb`](javalin/javalin@5b5b2fb) [websocket] Fix attributes set in wsBeforeUpgrade not persisting to onConnect
* [`d4b8c5b`](javalin/javalin@d4b8c5b) [ratelimitplugin] Fix regression in default key function
* [`698995d`](javalin/javalin@698995d) [endpoints] Add option to get the future matched enpoint
* [`9c3461f`](javalin/javalin@9c3461f) [docs] Update for v7
* [`6821dea`](javalin/javalin@6821dea) [maven-release-plugin] prepare for next development iteration
* [`3e02e28`](javalin/javalin@3e02e28) [maven-release-plugin] prepare release javalin-parent-7.0.0
* [`a02ecb7`](javalin/javalin@a02ecb7) [pom] Publish aggregator poms to fix release deploy
* Additional commits viewable in [compare view](javalin/javalin@javalin-parent-6.7.0...javalin-parent-7.0.1)
  
Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting `@dependabot rebase`.
[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)
---
Dependabot commands and options
  
You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it
- `@dependabot show  ignore conditions` will show all of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

javalin-micrometer interferance with request logger

2 participants