Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Beacon is causing problems when using Spring Security and Collaboration Engine together #41

Closed
Peppe opened this issue Jun 1, 2021 · 6 comments
Labels
bug Something isn't working

Comments

@Peppe
Copy link
Contributor

Peppe commented Jun 1, 2021

Describe the bug
Collaboration Engine adds beacon HTTP calls to your app. Adding Spring Security to your app denies access to many urls by default, including /beacon/*. When you press the login button in your app, maybe four times out of five it works correctly. But every now and then, it will instead download a zero byte file with a UUID name. The file is downloaded due to a request to ie /beacon/ec3fff5a-2f77-4318-90c6-4104460637bd.

image

To Reproduce
Steps to reproduce the behavior:

  1. Download a new Vaadin app from start
  2. Secure your app with Spring Security and add a login page that posts
  3. Add CE components to your application
  4. Login multiple times
  5. Notice that every now and again you do not get logged in, but instead you get a file download

Expected behavior
You don't have to do anything extra about CE when using it in a Spring Security -secured Vaadin app and login works every time.

Versions
- Vaadin version: V20
- Collaboration Engine version: V3.1
- Java version: 11
- OS version: Mac OS

@Peppe Peppe added the bug Something isn't working label Jun 1, 2021
@Peppe
Copy link
Contributor Author

Peppe commented Jun 1, 2021

As a workaround, I did a custom request handler to my Vaadin project, and handled /beacon/ in it, to avoid the problem.

The implementation is here: https://github.com/Peppe/vabber/blob/main/src/main/java/com/example/application/security/CustomRequestCache.java#L23-L30

@Legioth
Copy link
Member

Legioth commented Jun 1, 2021

If we assume that applications use VaadinWebSecurityConfigurerAdapter or some other mechanism that uses helpers defined by HandlerHelper, then we would just have to change the beacon handler to use a URL that would be matched by one of those.

One obvious candidate would be to use the /VAADIN namespace which is covered by HandlerHelper.getPublicResourcesRequiringSecurityContext(), e.g. using /VAADIN/beacon/<id> as the URL.

@Peppe
Copy link
Contributor Author

Peppe commented Jun 1, 2021

@Artur-
Copy link
Member

Artur- commented Jun 8, 2021

This also causes problems with live reload. When you have collaboration engine in your app and do a change (with Spring Boot Dev Tools enabled) then the app will reload and you will be redirected to the login view, as expected. However, after logging in you will end up on /error showing

{"timestamp": sometime, "status":999,"error":"None","message":"No message available"}

@tulioag tulioag self-assigned this Jun 8, 2021
@tulioag tulioag closed this as completed Jun 10, 2021
@chrosim
Copy link

chrosim commented Jan 12, 2022

@tulioag for me the beacon is still causing problems in combination with the spring-boot-keycloak-adapter.
We are using a pattern based whitelisting approach which has been working with the /beacon url.
If i understand it correctly the beacon url is now pointing to the servlet-root only using query parameters which makes it impossible to whitelist.
Would it be possible to move the beacon url to the /VAADIN namespace as @Legioth suggested?

@tulioag tulioag removed their assignment Jan 12, 2022
@tulioag
Copy link
Contributor

tulioag commented Jan 12, 2022

Hi @chrosim. I'm no longer working on this project. IIRC, the url was changed to the servlet-root so the beacon is now just another type of Flow request. I suggest that you open a new issue about that.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

5 participants