core
core copied to clipboard
Clicking an external link to a shared file logs out the current user
Steps to reproduce
- Create a public link for a file.
- Add the link to page on a different domain.
- Click the shared link on the external site - the shared file appears as normal.
- Click on the ownCloud banner - at this point the user expects to return to the file list.
- The user is redirected to the ownCloud login page.
Note: pasting the shared link into the URL bar will not trigger the issue - it must come from a cross-site redirect.
Expected behaviour
Viewing a shared file via a link should display the file and leave the user logged in (if already). When the user attempts to view the file list or a non-shared file they should not be forced to reauthenticate.
Actual behaviour
Viewing a shared file from an external link invalidates the currently authenticated session forcing the user to re-authenticate again.
Server configuration
ownCloud version: 10.10.0.3
Updated from an older ownCloud or fresh install: Fresh install.
Where did you install ownCloud from: Docker Compose.
Client configuration
Browser: Confirmed affects:
- Firefox 102.0
- Chrome 103
- Safari 15.5
Operating system: macOS 12.4 (Monterey)
Logs
No errors seen at default logging levels.
Browser log
Taken from Firefox:
data:image/s3,"s3://crabby-images/e8b12/e8b1231ee783825c18545350b707b3da0ba51c02" alt="Screenshot 2022-07-06 at 11 51 13"
Cookie “oclbm24h6kt2” with the “SameSite” attribute value “Lax” or “Strict” was omitted because of a cross-site redirect. [xIhpWNReO0tEdNj](http://owncloud.capsule.run:9080/s/xIhpWNReO0tEdNj)
Cookie “oc_sessionPassphrase” with the “SameSite” attribute value “Lax” or “Strict” was omitted because of a cross-site redirect. [xIhpWNReO0tEdNj](http://owncloud.capsule.run:9080/s/xIhpWNReO0tEdNj)
Additional Info
I'm not an ownCloud user but one of the customers of the company I work for (Capsule) uses it and encountered this issue. They want to be able to add links in Capsule to files stored in ownCloud but are getting logged out as soon as they click on them - this is making it difficult to work in both system simultaneously.
From the outside it looks like the following is happening:
- The session cookies (
oc_sessionPassphrase
&ocXXXX
) are stored usingSameSite=Strict
. - The user clicks a shared link inside Capsule.
- The share link is opened in a new tab:
- The browser treats this as a cross-site request as it was not initiated from insite ownCloud.
- The session cookies are not sent as they are
SameSite=Strict
.
- ownCloud receives no session cookies in the request to automatically creates a new session with cookies.
- These new cookies stomp the existing session cookies for the authenticated user.
I can replicate this with our system too (although we're running OC 10.9). In fact, clicking on any link on a site with a different domain forces a new login.
This was tested with Chrome 105.0.5195.102. We run ownCloud using docker-compose, and have upgraded from 10.1 through different versions to 10.9.
This issue has been automatically marked as stale because it has not had recent activity. It will be closed in 10 days if no further activity occurs. Thank you for your contributions.
This issue has been automatically closed.