Skip to content

はじめに

ターミナルウィンドウ
npm install @capgo/capacitor-supabase
npx cap sync

Androidの最小バージョンはSDK

Android 最小 SDK

Android の実装には Android 8.0 またはそれ以降が必要です。設定 minSdkVersion = 26android/variables.gradle.

import { CapacitorSupabase } from '@capgo/capacitor-supabase';
await CapacitorSupabase.initialize({
supabaseUrl: 'https://your-project.supabase.co',
supabaseKey: 'your-anon-key',
});
const { session, user } = await CapacitorSupabase.signInWithPassword({
email: 'user@example.com',
password: 'password123',
});
console.log('User', user?.id);
console.log('JWT available', Boolean(session?.accessToken));
const listener = await CapacitorSupabase.addListener('authStateChange', ({ event, session }) => {
console.log('Auth event', event);
console.log('Current JWT available', Boolean(session?.accessToken));
});
await listener.remove();

Native Auth と supabase-js をペア

Native Auth と supabase-js をペア
import { createClient } from '@supabase/supabase-js';
const { session } = await CapacitorSupabase.getSession();
const supabase = createClient('https://your-project.supabase.co', 'your-anon-key', {
global: {
headers: {
Authorization: `Bearer ${session?.accessToken}`,
},
},
});
const { data } = await supabase.from('table').select('*');
console.log(data);

ネイティブ データベース ヘルパー

ネイティブ データベース ヘルパー
const { data, error } = await CapacitorSupabase.select({
table: 'users',
columns: 'id, name, email',
filter: { active: true },
limit: 10,
orderBy: 'created_at',
ascending: false,
});
console.log(data, error);
  • リアルタイム、ストレージ、エッジ関数、そして高度なクエリを
  • ネイティブ JWT を JavaScript クライアントに渡すと、Supabase の残りの機能エリアが利用可能になります。 @supabase/supabase-js.
  • ページを編集