No description
Find a file
Iva Horn 71c06c6b1e fix: NKTypeReachability conforms to Sendable.
Signed-off-by: Iva Horn <iva.horn@nextcloud.com>
2025-10-17 13:47:48 +02:00
.github Fix CI and remove Sourcery (#187) 2025-09-15 12:36:54 +02:00
LICENSES Multisession (#98) 2024-10-22 11:57:51 +02:00
Sources/NextcloudKit fix: NKTypeReachability conforms to Sendable. 2025-10-17 13:47:48 +02:00
Tests fix: Remove unnecessary UIKit imports to fix macOS builds. 2025-09-26 20:16:21 +02:00
.gitignore cod 2025-06-20 18:44:53 +02:00
.swiftlint.yml Fix CI and remove Sourcery (#187) 2025-09-15 12:36:54 +02:00
AUTHORS.md Multisession (#98) 2024-10-22 11:57:51 +02:00
Cartfile first beta 2022-08-18 15:26:37 +02:00
COPYING.iOS V 4.0.0 (#77) 2024-07-09 09:55:08 +02:00
create-docker-test-server.sh Multisession (#98) 2024-10-22 11:57:51 +02:00
Gemfile New version (#37) 2023-07-17 10:34:43 +02:00
LICENSE.txt V 4.0.0 (#77) 2024-07-09 09:55:08 +02:00
NextcloudKit.png Library 5.0.2 (#113) 2024-12-14 11:19:10 +01:00
NextcloudKit.pxd Library 5.0.2 (#113) 2024-12-14 11:19:10 +01:00
NextcloudKit.svg Library 5.0.2 (#113) 2024-12-14 11:19:10 +01:00
Package.resolved V 6.0.0 (#122) 2025-02-22 16:44:30 +01:00
Package.swift Remove commented code 2025-09-01 14:26:31 +02:00
README.md Library 5.0.2 (#113) 2024-12-14 11:19:10 +01:00
REUSE.toml Library 5.0.2 (#113) 2024-12-14 11:19:10 +01:00

Logo of NextcloudKit

NextcloudKit

REUSE status

Installation

Carthage

Carthage is a decentralized dependency manager that builds your dependencies and provides you with binary frameworks. To integrate NextcloudKit into your Xcode project using Carthage, specify it in your Cartfile:

github "nextcloud/NextcloudKit" "main"

Run carthage update to build the framework and drag the built NextcloudKit.framework into your Xcode project.

Swift Package Manager

Swift Package Manager is a tool for automating the distribution of Swift code and is integrated into the swift compiler. Once you have your Swift package set up, adding NextcloudKit as a dependency is as easy as adding it to the dependencies value of your Package.swift.

dependencies: [
    .package(url: "https://github.com/Nextcloud/NextcloudKit.git", .upToNextMajor(from: "2.0.0"))
]

Manual

To add NextcloudKit to your app without Carthage, clone this repo and place it somewhere in your project folder. Then, add NextcloudKit.xcodeproj to your project, select your app target and add the NextcloudKit framework as an embedded binary under General and as a target dependency under Build Phases.

Testing

Unit Tests

Since most functions in NextcloudKit involve a server call, you can mock the Alamofire session request. For that we use Mocker.

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. The 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)"
}
  1. Run the integration tests.

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/