A pure Swift client for interfacing with a PocketBase instance.
Easiest way to get started with PocketBase for Swift is to run an instance inside of a Docker container.
Run the following commands to start PocketBase locally:
cd <path>/PocketBase/Developer
docker-compose up
You should then see something like:
Starting pocketbase ... done
Attaching to pocketbase
pocketbase | > Server started at: http://0.0.0.0:8090
pocketbase | - REST API: http://0.0.0.0:8090/api/
pocketbase | - Admin UI: http://0.0.0.0:8090/_/
Now you're ready to incorporate the library.
The PocketBase Swift library defaults to sending requests to the default PocketBase docker image URL: http://0.0.0.0:8090/`.
import PocketBase // <~ 1.
import SwiftUI
- Import
PocketBase
to your project.
@main
struct TestApp: App {
@Client var client: PocketBase // <~ 2
var body: some Scene {
WindowGroup {
ContentView()
.environmentObject(client) // <~ 3
.environment(\.baseUrl, URL(string: "http://0.0.0.0:8090/")!) // <~ 4 (Optional)
}
}
}
- Create an instance of PocketBase with the
@Client
property wrapper. This internally creates a singleton that lives throughout the lifecycle of your app. - Add the
client
to the environment so that child views can access the singleton. - Optionally specify the URL where your PocketBase instance is served. If this is omitted the URL will default to
http://0.0.0.0:8090/
.
struct Test: Codable, Identifiable { // <~ 5
var id: String?
var foo: String
}
- Create the model object. Must conform to both
Codable
andIdentifiable
.
struct ContentView: View {
@Query("test") var tests: [Test] // <~ 6
var body: some View {
NavigationView {
List {
ForEach(tests) { test in // <~ 7
Text(test.foo)
}
}
.navigationTitle("Tests Collection")
}
}
}
- Create a
@Query
instance. This is the object that does the most magic. It will download the records for the given collection and then subscribe to realtime updatest to keep the server and the client in sync. - Display the data in your view.