Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alickbass/sweetrouter
Declarative URL routing in swift
https://github.com/alickbass/sweetrouter
declarative endpoints router swift
Last synced: about 2 months ago
JSON representation
Declarative URL routing in swift
- Host: GitHub
- URL: https://github.com/alickbass/sweetrouter
- Owner: alickbass
- License: mit
- Created: 2017-03-16T10:14:40.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2017-12-29T13:56:33.000Z (about 7 years ago)
- Last Synced: 2024-10-28T12:55:34.489Z (2 months ago)
- Topics: declarative, endpoints, router, swift
- Language: Swift
- Size: 77.1 KB
- Stars: 46
- Watchers: 4
- Forks: 6
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# SweetRouter
Declarative URL routing in swift for Alamofire and not only :)[![Carthage compatible](https://img.shields.io/badge/Carthage-compatible-4BC51D.svg?style=flat)](https://github.com/Carthage/Carthage)
[![Build Status](https://travis-ci.org/alickbass/SweetRouter.svg?branch=master)](https://travis-ci.org/alickbass/SweetRouter)
[![codecov](https://codecov.io/gh/alickbass/SweetRouter/branch/master/graph/badge.svg)](https://codecov.io/gh/alickbass/SweetRouter)## Integration
### CocoaPods
You can use CocoaPods to install SweetRouter by adding it to your Podfile:
```swift
platform :ios, '8.0'
use_frameworks!target 'MyApp' do
pod 'SweetRouter'
end
```### Carthage
You can use Carthage to install SweetRouter by adding it to your Cartfile:
```swift
github "alickbass/SweetRouter"
```## Definitions
Imagine that you use the following `URLs` within your App
```
https://myservercom.com:123/api/new/signIn
https://myservercom.com:123/api/new/signOut
https://myservercom.com:123/api/new/posts?date=today&userId=id
```Every `URL` in the list is called an **`Endpoint`**
### Endpoint
Endpoint has the following structure:
```
Endpoint
┌─────────────────────────────────┴────────────────────────────────────┐
https://myservercom.com:123/api/new/posts?date=today&userId=id#paragraph
└────────────────┬────────────────┘└────────────────┬──────────────────┘
Environment Route
```Endpoint is represented with `EndpointType` `protocol`.
### Environment
Environment has the following structure:
```
Environment
┌────────────────┴─────────────────┐
https://myservercom.com:123/api/new/posts?date=today&userId=id#paragraph
└─┬─┘ └───────┬───────┘└┬┘└─────┬─┘
scheme host port default path
```**Examples of Environment**
```swift
URL.Env(.https, "mytestserver.com").at("api", "new") // https://mytestserver.com/api/new/
URL.Env(IP(127, 0, 0, 1), 8080) // http://127.0.01:8080
URL.Env.localhost(4001) // http://localhost:4001
```### Route
Route has the following structure:```
Route
┌─────────────────┴─────────────────┐
https://myservercom.com:123/api/new/posts?date=today&userId=id#paragraph
└──┬──┘└────────┬─────────┘└───┬────┘
path query fragment
```**Example of Route**
```swift
// /api/new/posts?date=today&userId=id#paragraph
URL.Route(at: "api", "new", "posts").query(("date", "today"), ("userId", "id")).fragment("paragraph")
```## Example of usage
Here is an example of the Router for some back-end `API`:
```swift
enum Api: EndpointType {
enum Environment: EnvironmentType {
case localhost
case test
case production
var value: URL.Env {
switch self {
case .localhost: return .localhost(8080)
case .test: return .init(IP(126, 251, 20, 32))
case .production: return .init(.https, "myproductionserver.com", 3000)
}
}
}
enum Route: RouteType {
case auth, me
case posts(for: Date)
var route: URL.Route {
switch self {
case .me: return .init(at: "me")
case .auth: return .init(at: "auth")
case let .posts(for: date):
return URL.Route(at: "posts").query(("date", date), ("userId", "someId"))
}
}
}
static let current: Environment = .localhost
}
```And in our application we would use it like this:
```swift
print(Router(at: .me).url) // http://localhost:8080/me
print(Router(.test, at: .auth).url) // http://126.251.20.32/auth
print(Router(.production, at: .posts(for: Date())).url) // https://myproductionserver.com:3000/posts?date=12.04.2017&userId=someId
```## What if I have only one environment?
It can often happen, that you will be using some third-party `API` and you will have only access to Production environment. So in this case your Router will look something like this:
```swift
struct Auth: EndpointType {
enum Route: RouteType {
case signIn, signOut
var route: URL.Route {
switch self {
case .signIn: return .init(path: ["signIn"])
case .signOut: return .init(path: ["signOut"])
}
}
}
static let current = URL.Env(.https, "auth.server.com", 8080).at("api", "new")
}
```And use it like this:
```swift
print(Router(at: .signIn).url) // https://auth.server.com:8080/api/new/signIn
print(Router(at: .signOut).url) // https://auth.server.com:8080/api/new/signOut
```## How to use with Alamofire?
Add the following code somewhere in your app:
```swift
import Alamofire
import SweetRouterextension Router: URLConvertible {
public func asURL() throws -> URL {
return url
}
}
```And then you can use the same Routers like this:
```swift
Alamofire.request(Router(at: .signIn))
```As easy as that 😉