Transporter alternatives and similar libraries
Based on the "Network" category.
Alternatively, view Transporter alternatives based on common mentions on social networks and blogs.
-
Perfect
Server-side Swift. The Perfect core toolset and framework for Swift Developers. (For mobile back-end development, website and API development, and moreβ¦) -
SwiftSoup
SwiftSoup: Pure Swift HTML Parser, with best of DOM, CSS, and jquery (Supports Linux, iOS, Mac, tvOS, watchOS) -
Zewo
Lightweight library for web server applications in Swift on macOS and Linux powered by coroutines. -
BlueSocket
Socket framework for Swift using the Swift Package Manager. Works on iOS, macOS, and Linux. -
Connectivity
π Makes Internet connectivity detection more robust by detecting Wi-Fi networks without Internet access. -
WKZombie
WKZombie is a Swift framework for iOS/OSX to navigate within websites and collect data without the need of User Interface or API, also known as Headless browser. It can be used to run automated tests / snapshots and manipulate websites using Javascript. -
PeerKit
An open-source Swift framework for building event-driven, zero-config Multipeer Connectivity apps -
Digger
Digger is a lightweight download framework that requires only one line of code to complete the file download task -
SOAPEngine
This generic SOAP client allows you to access web services using a your iOS app, Mac OS X app and AppleTV app. -
BigBrother
DISCONTINUED. Automatically sets the network activity indicator for any performed request.
InfluxDB - Purpose built for real-time analytics at any scale.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of Transporter or a related project?
README
Features
- uploading/downloading multiple files concurrently or sequentially
- grouping tasks with awesome custom operators (
|||
and-->
)
- grouping tasks with awesome custom operators (
- supports background uploading/downloading
- supports progress tracking (single task and group of tasks)
- enable to resume, pause, cancel, retry the task
- header configurable
- request parameters configurable
Quick example
let path = NSBundle.mainBundle().pathForResource("bigfile", ofType: "zip")
let fileUrl = NSURL(fileURLWithPath: path!)!
let task = UploadTask(url: "http://server.com", file: fileUrl)
.progress { sent, total in
let per = Double(sent) / Double(total)
println("uploading: \(per)")
}
.completed { response, json, error in
println("completed")
}
Transporter.add(task1 ||| task2 ||| task3) // concurrent tasks
.progress { bytes, total in
let per = Double(bytes) / Double(total)
println("concurrent tasks: \(per)")
}
.completed { alltasks in
println("task1, task2, task3: completed")
}
.add(task4 --> task5 --> task6) // sequential tasks
.progress { bytes, total in
println("serial tasks")
}
.resume()
Usage
// downloading task
let task = DownloadTask(url: downloadUrl, destination: des)
.progress { bytes, total in
let per = Double(bytes) / Double(total)
println("downloading: \(per)")
}
.completed { response, _, error in
println("completed")
}
// uploading task
// upload types: File, Data, Stream
let task = UploadTask(url: "http://server.com", data: uploadData)
.progress { sent, total in
let per = Double(sent) / Double(total)
println("uploading: \(per)")
}
.completed { response, json, error in
println("completed")
}
// using `|||` operator to create a group of concurrent tasks
Transporter.add(task1 ||| task2 ||| task3)
// using `-->` operator to create a group of sequential tasks
Transporter.add(task1 --> task2 --> task3)
// task
task.headers = ["key": "value"]
task.params = ["key": "value"]
task.pause()
task.cancel()
task.retry
// background handling
// add the following method in the app delegate
func application(application: UIApplication, handleEventsForBackgroundURLSession identifier: String, completionHandler: () -> Void) {
Transporter.handleEventsForBackgroundURLSection(identifier, completionHandler: completionHandler)
}
// Transporter configurations
Transporter.headers = [key: value]
Transporter.timeoutIntervalForRequest = 30.0
Transporter.timeoutIntervalForResource = 24 * 60 * 60.0
Transporter.HTTPMaximumconnectionsPerHost = 5
Installation
- Installation with CocoaPods
pod 'TransporterSwift', '0.1.1'
Then run the following command:
pod install
- Copying all the files into your project
- Using submodule
Todo
- [ ] retry, pause, cancel
- [ ] validation
Requirements
- iOS 8.0+
- Xcode 6.1
License
Transporter is released under the MIT license. See LICENSE for details.
*Note that all licence references and agreements mentioned in the Transporter README section above
are relevant to that project's source code only.