Memperbarui atribut pengguna misalnya nomor telepon pengguna
Dalam contoh ini, kami menunjukkan cara memperbarui atribut pengguna, seperti nomor telepon mereka, menggunakan API OneEntry.
✅ Tujuan skenario:
- Pengguna melakukan otentikasi dengan login dan kata sandi
- Kami mendapatkan data pengguna saat ini untuk mengisi formulir frontend
- Pengguna mengedit sebuah field (misalnya telepon) dan menyimpan
- Menyimpan data pengguna di Platform OneEntry
✅ Apa yang Anda butuhkan:
- PROJECT_URL dan APP_TOKEN yang valid untuk otentikasi dengan API OneEntry.
- Formulir pendaftaran dengan penanda "reg"
- Field formulir (atribut) dengan penanda "email_reg", "password_reg", "name_reg", "phone_reg"
- Pengguna yang sudah ada dan diaktifkan untuk diautentikasi
📌 Penting:
- Contoh-contoh ini tidak mencakup penanganan kesalahan.
- Anda dapat mengelola kesalahan menggunakan blok try-catch atau dengan menggunakan konstruksi seperti await Promise.catch((error) => error).
- Pastikan bahwa formIdentifier yang digunakan dalam metode updateUser() cocok dengan yang dikonfigurasi dalam proyek OneEntry Anda.
📚 Lihat di dokumentasi:
📦 Referensi SDK:
Coba secara langsung
Jalankan metode ini secara interaktif di JS SDK sandbox — sambungkan Project URL dan App Token Anda pada kunjungan pertama, lalu buka:
- Memperbarui atribut pengguna misalnya nomor telepon pengguna — Dalam contoh ini, kami menunjukkan cara memperbarui atribut pengguna, seperti nomor telepon mereka, menggunakan API OneEntry.
Skenario
1. Impor defineOneEntry dari SDK dan definisikan PROJECT_URL dan APP_TOKEN
Contoh:
import { defineOneEntry } from 'oneentry';
const PROJECT_URL = 'your-project-url';
const APP_TOKEN = 'your-app-token';
2. Membuat klien API dengan defineOneEntry()
Contoh:
const { AuthProvider, Users } = defineOneEntry(PROJECT_URL, {
token: APP_TOKEN,
});
3. Membentuk authData dan mengautentikasi pengguna dengan AuthProvider.auth()
Contoh:
useEffect(() => {
const authData = [
{ marker: 'email_reg', value: emailReg },
{ marker: 'password_reg', value: passwordReg },
];
AuthProvider.auth('email', { authData })
4. Mendapatkan pengguna saat ini untuk mengisi formulir Users.getUser()
Contoh:
.then(() => Users.getUser())
.then((data: any) => {
setUser(data);
const initial: Record<string, string> = {};
(Array.isArray(data?.formData) ? data.formData : []).forEach((d: any) => {
initial[d.marker] = displayValue(d.value);
});
setValues(initial);
console.log('User ', data);
})
.catch(console.error);
]);
Hasil:
{
"id": 39,
"total": "1",
"identifier": "kvasssukr.net@gmail.com",
"authProviderIdentifier": "email",
"formData": [
{
"marker": "name_reg",
"type": "string",
"value": "Ivan"
},
{
"marker": "phone_reg",
"type": "string",
"value": "+10000000001"
},
{
"marker": "email_notification_reg",
"type": "string",
"value": "test@example.com"
}
],
"formIdentifier": "reg",
"groups": [
1
],
"state": {},
"rating": {},
"moduleFormConfigs": []
}
5. Memperbarui pengguna dengan Users.updateUser()
Contoh:
const formData = fields.map((d: any) => ({
marker: d.marker,
type: d.type,
value: prepareValue(d.type, values[d.marker] ?? displayValue(d.value)),
}));
const body = {
formIdentifier: 'reg',
authData: [{ marker: 'password_reg', value: passwordReg }],
formData,
notificationData: {
email: emailReg,
phonePush: values['phone_reg'] ? [values['phone_reg']] : [],
phoneSMS: values['phone_reg'] ?? '',
},
};
const updateUser = (await Users.updateUser(body as any).catch(
(err: any) => err,
)) as any;
6. Mendapatkan pengguna yang diperbarui dengan Users.getUser()
Contoh:
const userData = await Users.getUser().catch((err: any) => err);
Hasil:
{
"id": 39,
"total": "1",
"identifier": "kvasssukr.net@gmail.com",
"authProviderIdentifier": "email",
"formData": [
{
"marker": "name_reg",
"type": "string",
"value": "Ivan"
},
{
"marker": "phone_reg",
"type": "string",
"value": "+10000000001"
},
{
"marker": "email_notification_reg",
"type": "string",
"value": "test@example.com"
}
],
"formIdentifier": "reg",
"groups": [
1
],
"state": {},
"rating": {},
"moduleFormConfigs": []
}
Contoh akhir
import React from 'react';
// Note: React is a sandbox global — in your project use named imports from 'react'
const { useState, useEffect } = React;
// 1. Import defineOneEntry from SDK and define PROJECT_URL and APP_TOKEN
import { defineOneEntry } from 'oneentry';
const PROJECT_URL = 'your-project-url';
const APP_TOKEN = 'your-app-token';
// 2. Creating an API client with [defineOneEntry()](/docs/index/#Installation)
const { AuthProvider, Users } = defineOneEntry(PROJECT_URL, {
token: APP_TOKEN,
});
// Prepare value for API submission by field type
function prepareValue(type: string, value: string) {
if (type === 'text') return [{ plainValue: value }];
if (type === 'list' || type === 'radioButton') return [value];
return value;
}
// Read a displayable string from a user formData entry's value
function displayValue(value: any): string {
if (typeof value === 'string') return value;
if (Array.isArray(value)) return value[0]?.plainValue ?? value[0]?.value ?? '';
return value?.plainValue ?? '';
}
// Choose a sensible input type for a field by its marker
function inputTypeFor(marker: string) {
if (marker.includes('password')) return 'password';
if (marker.includes('email')) return 'email';
if (marker.includes('phone')) return 'tel';
return 'text';
}
const UpdateUser = () => {
const [user, setUser] = useState<any>(null);
const [values, setValues] = useState<Record<string, string>>({});
const [status, setStatus] = useState<'idle' | 'loading' | 'success' | 'error'>('idle');
const [errorMsg, setErrorMsg] = useState('');
// Pre-filled credentials (substituted at runtime from your settings)
const emailReg = 'your-email';
const passwordReg = 'your-password';
// 3. Forming authData and authenticate user with [AuthProvider.auth()](/docs/auth-provider/auth)
useEffect(() => {
const authData = [
{ marker: 'email_reg', value: emailReg },
{ marker: 'password_reg', value: passwordReg },
];
AuthProvider.auth('email', { authData })
// 4. Get the current user with [Users.getUser()](/docs/users/getUser) to pre-fill the form
.then(() => Users.getUser())
.then((data: any) => {
setUser(data);
const initial: Record<string, string> = {};
(Array.isArray(data?.formData) ? data.formData : []).forEach((d: any) => {
initial[d.marker] = displayValue(d.value);
});
setValues(initial);
console.log('User ', data);
})
.catch(console.error);
}, []);
if (!user) return <div>Loading...</div>;
const fields = Array.isArray(user.formData) ? user.formData : [];
const handleSubmit = async (e: any) => {
e.preventDefault();
setStatus('loading');
setErrorMsg('');
// 5. Update user with [Users.updateUser()](/docs/users/updateUser)
const formData = fields.map((d: any) => ({
marker: d.marker,
type: d.type,
value: prepareValue(d.type, values[d.marker] ?? displayValue(d.value)),
}));
const body = {
formIdentifier: 'reg',
authData: [{ marker: 'password_reg', value: passwordReg }],
formData,
notificationData: {
email: emailReg,
phonePush: values['phone_reg'] ? [values['phone_reg']] : [],
phoneSMS: values['phone_reg'] ?? '',
},
};
const updateUser = (await Users.updateUser(body as any).catch(
(err: any) => err,
)) as any;
if (updateUser?.statusCode >= 400) {
setErrorMsg(updateUser.message || 'Update failed');
setStatus('error');
return;
}
// 6. Get the updated user with [Users.getUser()](/docs/users/getUser)
const userData = await Users.getUser().catch((err: any) => err);
setUser(userData);
console.log({ updateUser, userData });
setStatus('success');
};
return (
<form onSubmit={handleSubmit}>
<h2>{user.localizeInfos?.title || 'Update profile'}</h2>
{fields.map((field: any) => {
const value = values[field.marker] ?? '';
const onChange = (val: string) =>
setValues((prev) => ({ ...prev, [field.marker]: val }));
return (
<div key={field.marker}>
<label htmlFor={field.marker}>{field.marker}</label>
<input
id={field.marker}
type={inputTypeFor(field.marker)}
value={value}
onChange={(e: { target: { value: string } }) => onChange(e.target.value)}
/>
</div>
);
})}
<button type="submit" disabled={status === 'loading'}>
{status === 'loading' ? 'Saving...' : 'Save'}
</button>
{status === 'error' && <p role="alert">{errorMsg}</p>}
{status === 'success' && <p role="status">User updated!</p>}
</form>
);
};
export default UpdateUser;