You're Invited:Meet the Socket Team at BlackHat and DEF CON in Las Vegas, Aug 4-6.RSVP
Socket
Book a DemoInstallSign in
Socket

@powersync/op-sqlite

Package Overview
Dependencies
Maintainers
2
Versions
69
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@powersync/op-sqlite

PowerSync - sync Postgres or MongoDB with SQLite in your React Native app for offline-first and real-time data

0.7.4
latest
Source
npmnpm
Version published
Weekly downloads
2.5K
16.78%
Maintainers
2
Weekly downloads
 
Created
Source

OP-SQLite Factory for the PowerSync React Native SDK

Overview

This package (packages/powersync-op-sqlite) enables using OP-SQLite with PowerSync alongside the React Native SDK.

If you are not yet familiar with PowerSync, please see the PowerSync React Native SDK README for more information.

Installation

Follow the installation instructions for the React Native SDK if you haven't yet set up PowerSync in your project. However, note that this package cannot be installed alongside @journeyapps/react-native-quick-sqlite. Skip the step about installing it as a peer dependency, or uninstall it if it is already installed.

Install Package

npx expo install @powersync/op-sqlite

When using this package without a frameowrk like Expo, we recommend adding this metro config to avoid issues related to bundling PowerSync. Without it, you may be getting TypeError: Cannot read property 'PowerSyncDatabase' of undefined or similar errors.

Install Peer Dependency:

This SDK currently requires @op-engineering/op-sqlite as a peer dependency.

Install it in your app with:

npx expo install @op-engineering/op-sqlite

Usage

import { OPSqliteOpenFactory } from '@powersync/op-sqlite';
import { PowerSyncDatabase } from '@powersync/react-native';

const factory = new OPSqliteOpenFactory({
  dbFilename: 'sqlite.db'
});

this.powersync = new PowerSyncDatabase({ database: factory, schema: AppSchema });

Encryption with SQLCipher

To enable SQLCipher you need to add the following configuration option to your application's package.json. Note that for monorepos you may have to add this configuration to the monorepo root package.json instead, this depends on where your package manager tool hoists modules.

{
  // your normal package.json
  // ...
  "op-sqlite": {
    "sqlcipher": true
  }
}

Additionally you will need to add an encryption key to the OPSQLite factory constructor

const factory = new OPSqliteOpenFactory({
  dbFilename: 'sqlite.db',
  sqliteOptions: {
    encryptionKey: 'your-encryption-key'
  }
});

Loading SQLite extensions

To load additional SQLite extensions include the extensions option in sqliteOptions which expects an array of objects with a path and an entryPoint:

sqliteOptions: {
  extensions: [{ path: libPath, entryPoint: 'sqlite3_powersync_init' }];
}

More info can be found in the OP-SQLite docs.

Example usage:

import { getDylibPath } from '@op-engineering/op-sqlite';

let libPath: string;
if (Platform.OS === 'ios') {
  libPath = getDylibPath('co.powersync.sqlitecore', 'powersync-sqlite-core');
} else {
  libPath = 'libpowersync';
}

const factory = new OPSqliteOpenFactory({
  dbFilename: 'sqlite.db',
  sqliteOptions: {
    extensions: [{ path: libPath, entryPoint: 'sqlite3_powersync_init' }]
  }
});

Native Projects

This package uses native libraries. Create native Android and iOS projects (if not created already) by running:

npx expo run:android
# OR
npx expo run:ios

Keywords

data sync

FAQs

Package last updated on 17 Jul 2025

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts