No Description

Sergey 5044d9dfb3 Change file provider extension document group 1 week ago
.github 6656230705 Version 6.1.5 (#3179) 1 month ago
Brand 5044d9dfb3 Change file provider extension document group 1 week ago
ExternalResources 574ab7e3a2 Version 6.0.0 (#3122) 2 months ago
File Provider Extension 84f7922766 Version 6.1.6 (#3185) 1 month ago
File Provider Extension UI 574ab7e3a2 Version 6.0.0 (#3122) 2 months ago
Nextcloud.xcodeproj 8d8e14ea6f Fix SWIFT_OBJC_INTERFACE_HEADER_NAME 2 weeks ago
Notification Service Extension 574ab7e3a2 Version 6.0.0 (#3122) 2 months ago
Share 6656230705 Version 6.1.5 (#3179) 1 month ago
Tests 6656230705 Version 6.1.5 (#3179) 1 month ago
Widget 574ab7e3a2 Version 6.0.0 (#3122) 2 months ago
WidgetDashboardIntentHandler 574ab7e3a2 Version 6.0.0 (#3122) 2 months ago
iOSClient 84f7922766 Version 6.1.6 (#3185) 1 month ago
.gitattributes deeb84170c test 5 years ago
.gitignore 422440e1a9 CI test integration (#2429) 1 year ago
.swiftlint.yml e97f47ba86 New version 5.4.0 (#2966) 5 months ago
AUTHORS.md 6656230705 Version 6.1.5 (#3179) 1 month ago
Animation.gif 62c79619fc V 5.2.0 (#2833) 9 months ago
CHANGELOG.md 2dd7592278 Update CHANGELOG.md 3 years ago
CODE_OF_CONDUCT.md d20bc8e000 update file txt 6 years ago
COPYING.iOS b8a008690b Initial commit 8 years ago
LICENSE.txt d20bc8e000 update file txt 6 years ago
Nextcloud Hub.png 5196a54a85 add ViewerQuickLook 1 year ago
README.md 6656230705 Version 6.1.5 (#3179) 1 month ago
Reasons to use Nextcloud.pdf 6724a6163e new class 2 years ago
SECURITY.md 32b1371365 docs: Add reporting issues guidance, first time contributor reply and funding info 3 months ago
create-docker-test-server.sh ffefb25d14 Version 5.3.0 (#2930) 7 months ago
wait-for-server.sh ffefb25d14 Version 5.3.0 (#2930) 7 months ago
widget.png 979d01034a add image 2 years ago

README.md

Nextcloud iOS app

Releases Build SwiftLint irc

Demo of the Nextcloud iOS files appWidget of the Nextcloud iOS files app

Demo of the Nextcloud iOS files app

Check out https://nextcloud.com and follow us on twitter.com/nextclouders

How to contribute

If you want to contribute to Nextcloud, you are very welcome:

Contribution Guidelines & License

GPLv3 with Apple app store exception.

Nextcloud doesn't require a CLA (Contributor License Agreement). The copyright belongs to all the individual contributors. Therefore we recommend that every contributor adds following line to the header of a file, if they changed it substantially:

@copyright Copyright (c) <year>, <your name> (<your email address>)

Please read the Code of Conduct. This document offers some guidance to ensure Nextcloud participants can cooperate effectively in a positive and inspiring atmosphere, and to explain how together we can strengthen and support each other.

More information how to contribute: https://nextcloud.com/contribute/

Start contributing

You can start by forking this repository and creating pull requests on the develop branch. Maybe start working on starter issues.

Easy starting points are also reviewing pull requests

Xcode 16 Project Setup

Dependencies

In order to build the project in Xcode you will also need a file GoogleService-Info.plist at the root of the repository which contains the Firebase configuration. For development work you can use a mock version found here.

Creating Pull requests

DCO Signoff

Nextcloud enforces the Developer Certificate of Origin (DCO) on Pull Requests. It requires your commit messages to contain a Signed-off-by line with an email address that matches your GitHub account.

How to Sign off

The DCO is a way for contributors to certify that they wrote or otherwise have the right to submit the code they are contributing by adding a Signed-off-by line to commit messages.

My Commit message

Signed-off-by: Random Contributor <random@contributor.dev>

Git even has a -s | --signoff command line option to append this to your commit messages automatically.

Support

If you need assistance or want to ask a question about the iOS app, you are welcome to ask for support in our Forums. If you have found a bug, feel free to open a new Issue on GitHub. Keep in mind, that this repository only manages the iOS app. If you find bugs or have problems with the server/backend, you should ask the Nextcloud server team for help!

TestFlight

Do you want to try the latest version in development of Nextcloud iOS ? Simple, follow this simple step

Apple TestFlight

Testing

Note: If a Unit or Integration test exclusively uses and tests NextcloudKit functions and components, then write that test in the NextcloudKit repo. NextcloudKit is used in many other repos as an API, and it's better if such tests are located there.

Unit tests:

There are currently no preresquites for unit testing that need to be done. Mock everything that's not needed.

Integration tests:

To run integration tests, you need a docker instance of a Nextcloud test server. This is a good start.

  1. In TestConstants.swift you must specify your instance credentials. App Token is automatically generated.

    public class TestConstants {
    static let timeoutLong: Double = 400
    static let server = "http://localhost:8080"
    static let username = "admin"
    static let password = "admin"
    static let account = "\(username) \(server)"
    }
    
  2. Run the integration tests.

UI tests

UI tests also use the docker server, but besides that there is nothing else you need to do.