This is a minimal demo app demonstrating use of the PowerSync Kotlin Mutiplatform SDK together with Supabase in a basic Kotlin Multiplatform Compose App.
The app lists customers and allows you to add or delete rows. Data is synced to users globally. For more advanced sync rules and functionality, see the PowerSync+Supabase Todo-List demo application.
Supported targets: Android and iOS, and Desktop (JVM).
The Kotlin Multiplatform SDK is currently in a beta release. If you find a bug or issue, please open a GitHub issue. Questions or feedback can be posted on our community Discord - we'd love to hear from you.
- Create a new Supabase project, and run the below in the Supabase SQL editor. This creates a
customers
table and a publication calledpowersync
for thecustomers
table.
-- Create tables
create table
public.customers (
id uuid not null default gen_random_uuid (),
name text not null,
email text not null,
constraint customers_pkey primary key (id)
) tablespace pg_default;
drop publication powersync;
-- Create publication for powersync
create publication powersync for table customers;
- Create a user which this demo app will use for authentication. This is done under Authentication > Users > Add user. Enter an email address and password for the user.
-
In your PowerSync dashboard, create a new PowerSync instance, connecting to the database of the Supabase project. Find detailed instructions in the Connect PowerSync to Your Supabase section of the Supabase<>PowerSync integration guide.
-
Then deploy the sync rules to the newly created instance.
-
Open the
sync-rules.yaml
file. -
Replace the file's contents with the below:
# sync-rules.yaml bucket_definitions: global: data: # Sync all rows - SELECT * FROM public.customers
-
Deploy to the newly created instance.
- To setup your environment, please consult these instructions.
- JDK version 17 is required.
- Android Gradle plugin version 8.2.2 is required.
- Clone this repo:
git clone https://github.com/powersync-ja/powersync-kotlin.git
- Open the repo in Android Studio. This creates a
local.properties
file in root and should contain asdk.dir=/path/to/android/sdk
line. - Sync the project with Gradle (this should happen automatically, or choose File > Sync project with Gradle Files).
- Open the
demos/hello-powersync
directory in Android Studio and sync this project with Gradle. - Insert your Supabase project URL, Supabase Anon Key, and PowerSync instance URL into the
local.properties
file:
# local.properties
sdk.dir=/path/to/android/sdk
# Enter your PowerSync instance URL
POWERSYNC_URL=https://foo.powersync.journeyapps.com
# Enter your Supabase project's URL and public anon key (Project settings > API)
SUPABASE_URL=https://foo.supabase.co
SUPABASE_ANON_KEY=foo
# Enter your Supabase auth user's details
[email protected]
SUPABASE_USER_PASSWORD=foo
- To run the Android app, run the
composeApp
Android Studio target configuration. - To run the iOS app, run the
iosApp
Android Studio target configuration.
- To run the desktop app, run the
run
Gradle task (in the "compose desktop" group) or execute./gradlew run
.
-
/composeApp
is for code that will be shared across your Compose Multiplatform applications. It contains several subfolders:commonMain
is for code that’s common for all targets.- Other folders are for Kotlin code that will be compiled for only the platform indicated in the folder name.
-
/iosApp
contains iOS applications. Even if you’re sharing your UI with Compose Multiplatform, you need this entry point for your iOS app. This is also where you should add SwiftUI code for your project.