Skip to content
Swift HTTP for Humans
Branch: master
Clone or download
Latest commit b314be4 Sep 28, 2018
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
Docs
Just.xcodeproj
Sources/Just
Supporting Files Fix code signing issue Sep 27, 2018
Tests/JustTests
.gitignore Fix code signing issue Sep 27, 2018
.gitmodules delete Quick Jun 29, 2016
.travis.yml Update project to Swift 4.2 Sep 22, 2018
Just.podspec
LICENSE.md
Makefile
Package.swift
README.md fix URL in readme Sep 22, 2018
Releasing.md

README.md

Carthage compatible CocoaPods Build Status Supported Flatform

Just is a client-side HTTP library inspired by python-requests - HTTP for Humans.

Just requires Swift 4.2. For Swift 3.1 support, use version 0.6.0.

Follow @JustHTTP for updates, if you are into that kind of things 😉

Features

Just lets you to the following effortlessly:

  • URL queries
  • custom headers
  • form (x-www-form-encoded) / JSON HTTP body
  • redirect control
  • multipart file upload along with form values.
  • basic/digest authentication
  • cookies
  • timeouts
  • synchronous / asynchronous requests
  • upload / download progress tracking for asynchronous requests
  • link headers
  • friendly accessible results

Use

The simplest request with Just looks like this:

//  A simple get request
Just.get("http://httpbin.org/get")

The next example shows how to upload a file along with some data:

//  talk to registration end point
let r = Just.post(
    "http://justiceleauge.org/member/register",
    data: ["username": "barryallen", "password":"ReverseF1ashSucks"],
    files: ["profile_photo": .URL(fileURLWithPath:"flash.jpeg", nil)]
)

if r.ok { /* success! */ }

Here's the same example done asynchronously:

//  talk to registration end point
Just.post(
    "http://justiceleauge.org/member/register",
    data: ["username": "barryallen", "password":"ReverseF1ashSucks"],
    files: ["profile_photo": .URL(fileURLWithPath:"flash.jpeg", nil)]
) { r in
    if r.ok { /* success! */ }
}

Read Getting Started on the web or in this playground to learn more!

Install

Here are some ways to leverage Just.

Swift Package Manager

Add the following to your dependencies:

.package(url: "https://github.com/JustHTTP/Just.git",  from: "0.7.0")

… and "Just" to your target dependencies.

Carthage (Swift 3 only)

Include the following in your Cartfile:

github "JustHTTP/Just"

Just includes dynamic framework targets for both iOS and OS X.

CocoaPods

The usual way:

platform :ios, '8.0'
use_frameworks!

target 'MyApp' do
  pod 'Just'
end

Manual

Drop Just.xcodeproj into your project navigator. Under the General tab of your project settings, use the plus sign to add Just.framework to Linked Framework and Libraries. Make sure to include the correct version for your target's platform.

It's also common to add Just as a git submodule to your projects repository:

cd path/to/your/project
git submodule add https://github.org/JustHTTP/Just.git

Source File

Put Just.swift directly into your project. Alternately, put it in the Sources folder of a playground. (The latter makes a fun way to explore the web.)

Contribute

Pull requests are welcome. Here are some tips for code contributors:

Work in Just.xcworkspace.

The tests for link headers relies on Github APIs, which has a low per-hour limit. To overcome this, you can edit the Xcode build schemes and add environment variables GITHUB_TOKEN. Learn more about personal tokens here.

For Xcode rebels, checkout Makefile.

HTML documentation pages are generated by literate programmin tool docco

License

MIT, see LICENSE.md.

You can’t perform that action at this time.
You signed in with another tab or window. Reload to refresh your session. You signed out in another tab or window. Reload to refresh your session.