Dietrich Schulten created CAMEL-15750:
-----------------------------------------
Summary: camel-undertow-spring-security-starter always forbidden
Key: CAMEL-15750
URL: https://issues.apache.org/jira/browse/CAMEL-15750
Project: Camel
Issue Type: Bug
Components: camel-spring-security, camel-undertow
Affects Versions: 3.5.0
Environment: Windows 10, Java 8
Reporter: Dietrich Schulten
Example:
[https://github.com/apache/camel-spring-boot-examples/tree/master/camel-example-spring-boot-undertow-spring-security]
Make sure port 8081 is not in use.
All requests to [http://localhost:8082/hi] get a 403 response, no matter if I
send an oauth Token or not. The oauth token itself seems correct, I have
decoded it on jwt.io and it shows that the role is present:
{code:java}
{
"exp": 1603546060,
"iat": 1603546000,
"jti": "3392de8c-8309-4187-8b9a-9f8edaefe226",
"iss": "http://localhost:8080/auth/realms/master",
"aud": "account",
"sub": "4612ff79-81a8-4209-a7f7-fd4b963c574e",
"typ": "Bearer",
"azp": "example-service",
"session_state": "693f9c78-2e54-447e-9749-ce6a1288877d",
"acr": "1",
"allowed-origins": [
"http://localhost:8082"
],
"realm_access": {
"roles": [
"role01",
"offline_access",
"uma_authorization"
]
},
"resource_access": {
"account": {
"roles": [
"manage-account",
"manage-account-links",
"view-profile"
]
}
},
"scope": "email profile",
"email_verified": false,
"preferred_username": "user01"
}{code}
The reason seems to be that the camel-undertow-spring-security-starter tries to
start two Undertow servlets: the Spring Undertow servlet runs on port 8081, and
the Camel Undertow servlet on port 8082. Only the Spring servlet has token
security, but not the Camel Undertow Servlet.
In the log below you see that the
org.springframework.boot.web.embedded.undertow.UndertowWebServer starts on port
8081, and it receives the filter chain with the BearerTokenAuthenticationFilter.
Then the org.apache.camel.component.undertow.DefaultUndertowHost comes up on
port 8082. The log message {{Illegal state caused by missing securitProvider
but existing allowed roles!}} also seem to show that no securityProvider is
configured on the DefaultUndertowHost which runs on port 8082.
{code:java}
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: (v2.3.3.RELEASE)2020-10-24 15:08:26.339 INFO 27932
--- [ main] o.a.c.undertow.spring.boot.Application : Starting
Application on DZS20N436 with PID 27932
(C:\Users\Schulten\Documents\projekte\camel-spring-boot-examples-3.5.0\camel-example-spring-boot-undertow-spring-security\target\classes
started by Schulten in
C:\Users\Schulten\Documents\projekte\camel-spring-boot-examples-3.5.0\camel-example-spring-boot-undertow-spring-security)
2020-10-24 15:08:26.343 INFO 27932 --- [ main]
o.a.c.undertow.spring.boot.Application : No active profile set, falling back
to default profiles: default
2020-10-24 15:08:28.378 INFO 27932 --- [ main] io.undertow.servlet
: Initializing Spring embedded WebApplicationContext
2020-10-24 15:08:28.381 INFO 27932 --- [ main]
w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext:
initialization completed in 1954 ms
2020-10-24 15:08:28.770 INFO 27932 --- [ main]
o.s.s.web.DefaultSecurityFilterChain : Creating filter chain: any request,
[org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter@5395ea39,
org.springframework.security.web.context.SecurityContextPersistenceFilter@5c41d037,
org.springframework.security.web.header.HeaderWriterFilter@6d64b553,
org.springframework.security.web.csrf.CsrfFilter@12477988,
org.springframework.security.web.authentication.logout.LogoutFilter@29a23c3d,
org.springframework.security.oauth2.server.resource.web.BearerTokenAuthenticationFilter@43b0ade,
org.springframework.security.web.savedrequest.RequestCacheAwareFilter@5ec77191,
org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter@796d3c9f,
org.springframework.security.web.authentication.AnonymousAuthenticationFilter@1517f633,
org.springframework.security.web.session.SessionManagementFilter@757529a4,
org.springframework.security.web.access.ExceptionTranslationFilter@203dd56b,
org.springframework.security.web.access.intercept.FilterSecurityInterceptor@522b2631]
2020-10-24 15:08:28.876 INFO 27932 --- [ main]
o.apache.camel.support.LRUCacheFactory : Detected and using LRUCacheFactory:
camel-caffeine-lrucache
2020-10-24 15:08:29.309 INFO 27932 --- [ main] io.undertow
: starting server: Undertow - 2.1.3.Final
2020-10-24 15:08:29.316 INFO 27932 --- [ main] org.xnio
: XNIO version 3.8.0.Final
2020-10-24 15:08:29.324 INFO 27932 --- [ main] org.xnio.nio
: XNIO NIO Implementation Version 3.8.0.Final
2020-10-24 15:08:29.419 INFO 27932 --- [ main] org.jboss.threads
: JBoss Threads version 3.1.0.Final
2020-10-24 15:08:29.472 INFO 27932 --- [ main]
o.s.b.w.e.undertow.UndertowWebServer : Undertow started on port(s) 8081
(http)
2020-10-24 15:08:29.490 INFO 27932 --- [ main]
o.a.c.s.boot.SpringBootRoutesCollector : Loading additional Camel XML routes
from: classpath:camel/*.xml
2020-10-24 15:08:29.495 INFO 27932 --- [ main]
o.a.c.s.boot.SpringBootRoutesCollector : Loading additional Camel XML route
templates from: classpath:camel-template/*.xml
2020-10-24 15:08:29.497 INFO 27932 --- [ main]
o.a.c.s.boot.SpringBootRoutesCollector : Loading additional Camel XML rests
from: classpath:camel-rest/*.xml
2020-10-24 15:08:29.652 INFO 27932 --- [ main]
o.a.c.impl.engine.AbstractCamelContext : Apache Camel 3.5.0 (camel-1) is
starting
2020-10-24 15:08:29.655 INFO 27932 --- [ main]
o.a.c.impl.engine.AbstractCamelContext : StreamCaching is not in use. If
using streams then its recommended to enable stream caching. See more details
at http://camel.apache.org/stream-caching.html
2020-10-24 15:08:29.656 INFO 27932 --- [ main]
o.a.c.impl.engine.AbstractCamelContext : Using HealthCheck: camel-health
2020-10-24 15:08:29.669 INFO 27932 --- [ main]
o.a.c.c.undertow.DefaultUndertowHost : Starting Undertow server on
http://localhost:8082
2020-10-24 15:08:29.669 INFO 27932 --- [ main] io.undertow
: starting server: Undertow - 2.1.3.Final
2020-10-24 15:08:29.681 INFO 27932 --- [ main]
o.a.c.i.e.InternalRouteStartupManager : Route: route1 started and consuming
from: http://localhost:8082/hi
2020-10-24 15:08:29.687 INFO 27932 --- [ main]
o.a.c.impl.engine.AbstractCamelContext : Total 1 routes, of which 1 are
started
2020-10-24 15:08:29.688 INFO 27932 --- [ main]
o.a.c.impl.engine.AbstractCamelContext : Apache Camel 3.5.0 (camel-1) started
in 0.035 seconds
2020-10-24 15:08:29.696 INFO 27932 --- [ main]
o.a.c.undertow.spring.boot.Application : Started Application in 3.809 seconds
(JVM running for 4.35)
2020-10-24 15:10:41.530 WARN 27932 --- [ XNIO-2 task-1]
o.a.c.c.undertow.UndertowConsumer : Illegal state caused by missing
securitProvider but existing allowed roles!
2020-10-24 15:13:16.234 WARN 27932 --- [ XNIO-2 task-1]
o.a.c.c.undertow.UndertowConsumer : Illegal state caused by missing
securitProvider but existing allowed roles!
2020-10-24 15:13:53.090 WARN 27932 --- [ XNIO-2 task-1]
o.a.c.c.undertow.UndertowConsumer : Illegal state caused by missing
securitProvider but existing allowed roles!
2020-10-24 15:15:22.183 WARN 27932 --- [ XNIO-2 task-1]
o.a.c.c.undertow.UndertowConsumer : Illegal state caused by missing
securitProvider but existing allowed roles!
2020-10-24 15:16:38.260 WARN 27932 --- [ XNIO-2 task-1]
o.a.c.c.undertow.UndertowConsumer : Illegal state caused by missing
securitProvider but existing allowed roles!{code}
--
This message was sent by Atlassian Jira
(v8.3.4#803005)