-
Notifications
You must be signed in to change notification settings - Fork 334
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
Writing to package AppData results in broken permissions #2788
Comments
That's due to different decisions/policies regarding i/o virtualization vs package management (not defending or attacking the policies, just stating the facts). If you'd like to discuss it further please open a new Discussion thread. |
@yoshiask Hm, I can't reproduce this on 25163 or 22000.795. Are you using any kind of disk middleware that could be touching the files during the trip to disk? |
@riverar There really can't be anything, I thought it was virtualized resources causing problems but even using StorageFile directly doesn't work. I was able to reproduce this on my own machine and a friend's with the debugger, and many of my app's users were experiencing crashes related to this issue. I believe ShareX ran into the same bug a while back as well. |
@yoshiask - Regarding “Observe that the file attributes are Archive | Encrypted”
• IOW, the Encrypted attribute is generally unexpected for a file under an AppData folder when it’s on the System Drive but is expected when the app is on a non-System Drive. That’s the baseline I’d like to establish, and it's not specific to WinAppSDK.
I hope these steps can help narrow this down, please let us know what you find out. |
@yoshiask - I'm wondering whether this issue is still impacting you, and if so, what further info you can supply to fuel further investigations? |
@yoshiask - is there any update? Investigation of this issue has been blocked for a while due to the lack of diagnostic information. I suggest we close this issue as "not planned" if investigation remain blocked for another week or so. |
Closing this issue due to lack of diagnostic info. |
Describe the bug
Attempting to write to the packaged app data directory using
System.IO
orStorageFile
from a packaged WinUI 3 Desktop app causes unusual permissions issues. Any files or directories created will have theArchive | Encrypted
attributes, despite being neither an archive nor encrypted. Programmatically copying the files into a different, non-AppData directory of course doesn't solve the issue (the file is still "encrypted").Steps to reproduce the bug
WinAppSdk (Package)
project and look at the debug console output.or
ApplicationData.Current.LocalFolder.Path
to get the packaged app data directoryFile.WriteAllText
orStorageFile.CreateFileAsync
to write to a file in that directoryArchive | Encrypted
Expected behavior
Successfully read and write to the packaged app data directory.
Screenshots
No response
NuGet package version
1.1.3, 1.1.2
Packaging type
Packaged (MSIX)
Windows version
Windows 11 version 21H2 (22000), Windows 10 version 21H2 (19044, November 2021 Update), Windows 10 version 21H1 (19043, May 2021 Update)
IDE
Visual Studio 2022-preview, Visual Studio 2022
Additional context
This issue effectively means apps can't write to app data at all. File system virtualization for the app data directory is enabled by default for packaged apps, which means even trying to write to
%appdata%
directly gets redirected to the packaged app data directory. The only workaround I could find (apart from just not writing to App Data) is to disable virtualization, but App Installer refuses to install any package that declares theunvirtualizedResources
rescap.As a side note, my app also declares the
packageQuery
andpackageManagement
rescaps. Why does App Installer care that my app can write to the real App Data, but not that it can install any arbitrary package to the user's system? Seems pretty arbitrary to me, but that's a separate problem.The text was updated successfully, but these errors were encountered: