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

Fileprovider support for importing bundle documents (Pages/Keynote) #235

Closed
felix-schwarz opened this issue Jan 25, 2019 · 4 comments
Closed
Assignees
Milestone

Comments

@felix-schwarz
Copy link
Contributor

felix-schwarz commented Jan 25, 2019

Steps to reproduce

  1. Create Pages document on iCloud Drive
  2. Open Files app
  3. Move Pages document from iCloud Drive to ownCloud File Provider

Expected behaviour

The document is a single file and gets imported.

Actual behaviour

The document is a folder and importing fails (even crashes in older versions).

Observation

  • copying folders from iCloud Drive to OC FP via drag and drop leads to Files app sending createDir/import commands for all folders and files (=> worked without issue)
  • unlike on iCloud Drive, Pages itself creates a flat file on third-party File Providers, which is really a zip file of the folder on iCloud Drive (using a Mac, compressing a bundle Pages document as zip and removing the zip file allows one to open and preview it)
  • other file providers (like Working Copy) seem to compress the bundle documents transparently as zip files and therefore work fine with the steps above

Recommended solution

Detect bundle-style documents on import and transparently produce a zip file for upload to the OC server.

felix-schwarz added a commit that referenced this issue Jan 26, 2019
	- external/libzip/update-libzip.sh allows simple updates
	- external/libzip/libzip.xcodeproj wraps libzip into a standard Xcode framework project that's reusable across extensions and the app
	- added license text to acknowledgments in the app
- Adding ClientActivityViewController
	- new tab in ClientRootViewController
	- POC-level display of activity information
- Fileprovider
	- supports on-the-fly compression of Pages and Keynote documents moved to ownCloud File Provider from iCloud (#235)
	- rejects import of any other bundle documents
	- prevent use of the broken "Duplicate" action in the Files app
@felix-schwarz felix-schwarz added this to the 0.4.0 milestone Jan 26, 2019
@felix-schwarz
Copy link
Contributor Author

felix-schwarz commented Jan 26, 2019

Implemented as of f6afc6d

@jesmrec
Copy link
Contributor

jesmrec commented Jan 29, 2019

Importing the files via Files App works correctly. I've also checked it using MS Word documents and this is OK.

With the current latest commit 966eddf, i noticed that the steps mentioned here #167 (comment) -> bullet (1) are again reproducible. I mean:

  • Open MSWord, create document
  • Select as target the attached ownCloud app and save the document there

Current: file appears in the list with 0 KB

jesmrec pushed a commit that referenced this issue Feb 4, 2019
* - Minor memory optimizations - Updated to latest SDK

* - Save changes prior to merge with master

* - Convert to Swift 4.2

* - Further Swift 4.2 changes

* - Update to latest SDK develop commit

* - Adapting APP to latest SDK changes
	- maintenance mode support
	- replacing uses of reachability monitor with OCCore.connectionStatus

* - Added back ownCloudUI.framework to copy phase of ownCloud target
- Updated to latest SDK

* - Add support for OCLogToggle in Settings
- App now logs current log settings at launch

* - Fix issues in ClientQueryViewController related to UITableView not reloading when its view controller is not "visible":
	- no longer uses items from table view cells to initiate actions
	- detects if UITableView.reloadData is set to do nothing and repeats the call in viewWillAppear
- The fixed issue was causing #178 and possibly others

* - Remove last traces of OCMocking.framework from ownCloud app target, make sure it's only built, linked to and copied in the ownCloudTests target

* - Fix EarlGrey/CocoaPods workspace / build errors

* - Adopt new OCLogger tags APIs in Log.swift and FileProviderExtension

* - Update SDK

* - Remove superfluous [FP] from log message

* - Make sure DisplayViewController uses the updated version of an item after downloading it instead of the (now) outdated original version

* - Update to latest SDK

* - Fixing thumbnail aspect ratio and removing duplicate code in NamingViewController (#141)

* - Update SDK

* - Exit editing mode in the server list when the user selects an existing or adds a new bookmark (as reported by @mneuwert)

* - Adapt app code base to change in OCError Swift conversion (following OCErrorAuthorizationCancelled typo correction)

* - Fix #152: if the user cancels OAuth2, an error is no longer shown (and errors are better to read with recent SDK updates)

* - Update to latest SDK

* - Make ProgressSummarizer only consider Progress objects with descriptions, resolving "ghost" progress bars without any information in them

* - Adapt to change of name of OCConnectionIssue to OCIssue

* - Update to latest SDK
- ConnectionIssueViewController
        - added option to provide a block to be called when dismissal has finished
        - normalize code formatting
- UIAlertController+OCIssue
        - added option to provide a completionHandler that's called when the user made a choice
- ClientRootViewController
        - switched issue and alert presentation to use a AsyncSequentialQueue to present them in order and not on top of each other
        - fixed a bug where a UIViewController that's in the process of being dismissed led to a failure to present alerts and issues

* - Make DisplayViewController use OCCoreOptionReturnImmediatelyIfOfflineOrUnavailable and fix a typo (#179)

* - Added priority summaries to ProgressSummarizer
- Fixed a crash bug in ImageDisplayViewController
- Removed core connection status interpretation from ClientQueryViewController
- Added core connection status tracking to ClientRootViewController and utilize priority summaries to display offline or server in maintenance mode status messages

* - Fix an issue where "Offline." was shortly shown when logging in
- Switch to utilizing short connection status descriptions coming straight from the SDK's connection signal providers
- Adapt Localizable.strings accordingly

* - Add *.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist to .gitignore

* - Updated ios-sdk

* - Made FileProviderEnumerator use an OCQuery that includes the root item (fixes #203)
- Made FileProviderExtension observe the domain property and trigger an initial query of the root directory when none has even been done before (fixes #205)

* - Adapted to latest round of nullability additions in the SDK
- Fixing potential crash bugs in DisplayHostViewController, ConnectionIssueViewController, SortMethod and others
- Update actions
	- make use of .completed() instead of calling the completionHandler directly
	- fixing multi-item support for several actions (completionHandler would previously get executed once for every item instead of once)
- ClientDirectoryPickerViewController now calls the completinHandler even on cancelation
- Cleaned up OCIssue+Extension and OCItem+Extension
- Replacing AsyncSequentialQueue with OCAsyncSequentialQueue

* - Update SDK

* - Updated ios-sdk

* - Update ios-sdk with IPC fixes

* - Adapt tests to SDK changes (all tests pass)
- Stop CocoaPods from sending statistics by adding a line to the Podfile turning this off

* - Present cache contents while waiting for a reply from the server
- Updated SDK fixing a lot of issues

* - Replacing DispatchQueue.main.async* with OnMainThread and a newly added OnMainThread(after: timeInterval)

* - Add verbose logging to FileProviderExtension to track the commands received by iOS and the results that were returned

* - Temporary workaround: make importFileFromURL: not return directly with the placeholder, but only when upload has completed - and then return the final item

* - Updated to latest SDK with OCLocalID support
- Updated FileProvider to use OCItem.localID and OCItem.localParentID instead of the fileID equivalents
- Updated importFile method to take advantage of localID staying the same even across placeholder -> item on the server transition
	- creating new documents is now possible without Internet connection and waiting for the upload to finish
	- progress information can again be made available to iOS

* - UI test update
	- decrease fragility of most tests
	- minor reorganization of source code
	- added new utility methods to EarlGrey to wait until an element appears or disappears before proceeding

* - Update SDK to latest

* - Adding libzip 1.5.1
	- external/libzip/update-libzip.sh allows simple updates
	- external/libzip/libzip.xcodeproj wraps libzip into a standard Xcode framework project that's reusable across extensions and the app
	- added license text to acknowledgments in the app
- Adding ClientActivityViewController
	- new tab in ClientRootViewController
	- POC-level display of activity information
- Fileprovider
	- supports on-the-fly compression of Pages and Keynote documents moved to ownCloud File Provider from iCloud (#235)
	- rejects import of any other bundle documents
	- prevent use of the broken "Duplicate" action in the Files app

* - Added ClientActivityCell
- Updated ClientRootViewController to properly support Themeing
- Added progressColors to ThemeCollection
- Added ProgressView for circular display of indeterminate progress, progress info and cancellation
- Added UIColor.greyscale() method

* - Client Query View improvements
	- inline download and upload progress indicators
	- tapping an item no longer immediately opens the viewer
	- instead, tapping an item now triggers a download
	- when multiple items are tapped in quick succession, only the last one's file is shown when the download finishes
	- added inline cloud status badges for cloud-only and local-only to indicate file status
- Switch from Swift-KVO to legacy-KVO in ProgressView due to https://bugs.swift.org/browse/SR-6795 :'(
	- removed SwiftLint rule
- Latest SDK

* Included the ownCloudTests shared scheme

* Fixed the test testCheckURLBasicAuthWarningIssueCertificateDisplayInfo

* - added design resource
- updated SDK
- various fixes to make progress observation in ProgressView and ProgressSummarizer thread-safe

* Modified the test testCheckURLBasicAuthWarningIssueCertificateDisplayInfo

* Remove the test testCheckURLBasicAuthWarningIssueCertificateDisplayInfo

* - Make general-purpose version of EarlGrey.waitForElement extension that allows waiting not just for elements with accessibilityIdentifiers
- Re-add CreateBookmarkTests.testCheckURLBasicAuthWarningIssueCertificateDisplayInfo()
- Fix CreateBookmarkTests.testCheckURLBasicAuthWarningIssueCertificateDisplayInfo() using EarlGrey.waitForElement to address the timing issues that made it fail

* - Updated SDK
- Improved "double-tap" behaviour: if an item is tapped, it starts downloading. If it is tapped again while still downloading, the viewer is only opened once.

* - If a file is not immediately available and can't be downloaded either, the DisplayViewController is now shown anyway for error feedback

* - cleaned up DisplayHostViewController
- cleaned up DisplayViewController and improved its error handling
- updated DisplayViewController to use a single-item OCQuery to update its contents dynamically
- minor code cleanups and adaptions to DisplayViewController changes in other places

* - Update SDK

* - ProgressView resumes animation after removing and readding the view, and after switching away and back to the app
- Fixed broken German localizations I noticed

* - Clarify name of refreshControl in ClientQueryViewController
- Block drag-to-refresh if the core status is not .online
- Fixed an issue in DisplayViewController that prevented updates after the file was moved remotely

* - Add libzip to THIRD_PARTY.txt
- Switch to updated ios-sdk master

* - Fix visual glitch in progress reporting
@jesmrec jesmrec modified the milestones: 0.4.0, 1.0.0 Feb 4, 2019
@jesmrec
Copy link
Contributor

jesmrec commented Feb 22, 2019

Fixed in #253

@jesmrec jesmrec closed this as completed Feb 22, 2019
@michaelstingl
Copy link
Contributor

@felix-schwarz FYI Doesn't work with GarageBand projects. (created on the iOs device)

2019-03-01_02_51_50

Related:
https://twitter.com/palmin/status/1034730403305873408

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants