Skip to content
forked from carabina/Ursus

An Urbit HTTP/%eyre client for iOS/macOS.

License

Notifications You must be signed in to change notification settings

famousj/UrsusHTTP

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Ursus HTTP

An Urbit HTTP/%eyre client for iOS/macOS in Swift.

See my Ursus Chat repository for a demo project.

Usage

Ursus HTTP is very much a work in progress - better documentation and a demo app to come. Here's a quick sketch for now:

let client = Client(url: URL(string: "http://localhost")!, code: "fipfes-fipfes-fipfes-fipfes")
client.loginRequest() { result in
    switch result {
    case .success(let ship):
        client.connect()
        client.subscribeRequest(ship: ship, app: "chat-view", path: "/primary") { event in
            print(event)
        }
    case .failure(let error):
        print(error)
    }
}

Installation

Ursus can be installed using Cocoapods by adding the following line to your podfile:

pod 'UrsusHTTP', '~> 1.10'

I can probably help set up Carthage or Swift Package Manager support if you need it.

Todo list

Things that would make this codebase nicer:

  • Should the new %logout endpoint clear the urbauth cookie?
  • Pass IDs back through to the event handlers so unsubscribe requests can be made.
  • Event source request should initially .put to create a new channel before .get to retrieve the existing channel; have tried this but %eyre returns a 400 error code.
  • Login and channel requests could use state enums to maintain LoginState and ChannelState
    • If user is not authenticated or the channel is not connected, then requests can be chained together.
    • Poke and subscribe handlers could be removed with a custom response serializer.
  • Test UnsubscribeRequest, DeleteRequest properly.
  • Better documentation/examples.

Other clients

Dependencies

About

An Urbit HTTP/%eyre client for iOS/macOS.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Swift 97.3%
  • Ruby 2.7%