Github.swift alternatives and similar libraries
Based on the "Unofficial" category.
Alternatively, view Github.swift alternatives based on common mentions on social networks and blogs.
-
CloudRail SI
DISCONTINUED. Unified API Library for: Cloud Storage, Social Log-In, Social Interaction, Payment, Email, SMS, POIs, Video & Messaging. Included services are Dropbox, Google Drive, OneDrive, OneDrive for Business, Box, Egnyte, PayPal, Stripe, Google Places, Foursquare, Yelp, YouTube, Vimeo, Twitch, Facebook Messenger, Telegram, Line, Viber, Facebook, GitHub, Google+, LinkedIn, Slack, Twitter, Windows Live, Yahoo, Mailjet, Sendgrid, Twilio, Nexmo, Twizo. -
DribbbleSDK
Unofficial Dribbble iOS wrapper allows you to integrate Dribble API into iOS application (Designer, Shot, Comment, User Story, Like, Follow)
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 Github.swift or a related project?
README
Github.swift
❤️ Support my apps ❤️
- Push Hero - pure Swift native macOS application to test push notifications
- PastePal - Pasteboard, note and shortcut manager
- Quick Check - smart todo manager
- Alias - App and file shortcut manager
- My other apps
❤️❤️😇😍🤘❤️❤️
[](Screenshots/Banner.png)
Description
- A Swift implementation of octokit.objc, using RxSwift, Alamofire and Tailor
- Try to use more Swift style as possible
- Note: you may consider using GraphQL https://developer.github.com/v4/
Usage
Client
- User: identify a user
- Server: identify server (Github or Github Enterprise)
- Client: make request. If associated with a valid token, it is considered authenticated client
let _ =
Client.signInUsingWebBrowser(Server.dotComServer, scopes: [.Repository])
.flatMap { client in
return client.fetchUserRepositories()
}.subscribeNext { repositories in
repositories.forEach { print($0.name)
}
}
Request Descriptor
Make your own request using RequestDescriptor
, using syntax from Construction
let requestDescriptor: RequestDescriptor = construct {
$0.path = "repos/\(owner)/\(name)"
$0.etag = "12345"
$0.offset = 2
$0.perPage = 50
$0.parameters["param"] = "value"
$0.headers["header"] = "value"
$0.method = .PUT
}
return enqueue(requestDescriptor).map {
return Parser.one($0)
}
Pagination
- The
subscribe
gets called many times if there is pagination
client
.fetchUserRepositories()
.subscribeNext { repositories in
// This gets called many times depending pagination
repositories.forEach { print($0.name)
}
- Use
toArray
if we wantsubscribe
to be called once with all the values collected
client
.fetchUserRepositories()
.toArray()
.subscribeNext { repositories: [[Repository]] in
repositories.flatMap({$0}).forEach { print($0.name)
}
Features
Metadata
- Fetch server metadata
Sign in
- Native flow
- OAuth flow
User
- Follow
- Unfollow
- Fetch user info
Repository
- Fetch repositories
- Create repository
- Fetch commits
- Fetch pull requests
- Fetch issues
- Watch
Pull request
- Make pull requests
Issue
- Create issue
- Fetch issues
Organization
- Fetch organizations
- Fetch teams
Search
- Search repositories
Event
- Fetch user events
Gists
- Fetch gists
Git
- Create tree
- Create blob
- Create commit
Activity
- Star
- Unstar
Notification
- Fetch notifications
Installation
GithubSwift is available through CocoaPods. To install it, simply add the following line to your Podfile:
pod 'GithubSwift'
GithubSwift is also available through Carthage. To install just write into your Cartfile:
github "onmyway133/Github.swift"
Author
Khoa Pham, [email protected]
Contributing
We would love you to contribute to GithubSwift, check the CONTRIBUTING file for more info.
License
GithubSwift is available under the MIT license. See the LICENSE file for more info.
*Note that all licence references and agreements mentioned in the Github.swift README section above
are relevant to that project's source code only.