게임 로그인 (getUserKeyForGame) - 유저 식별자 받기
지원환경: React NativeReact Native SDKv1.4.0WebViewWebView SDKv1.4.0
실행환경: Toss App최소버전v5.232.0Sandbox App
getUserKeyForGame은 게임 미니앱에서 유저를 식별하기 위한 전용 API예요.
토스 로그인처럼 별도의 인증 화면이나 서버 연동 없이,
게임 미니앱 내부에서 안정적인 유저 식별자를 바로 얻을 수 있어요.
이 함수는 게임 카테고리 미니앱에서만 사용 가능하며,
반환되는 유저 식별자(hash)는 미니앱(게임)별로 고유해요.
이 값은 게임 내 데이터 저장, 랭킹 관리, 프로모션(토스 포인트) 기능 연동 등에 사용할 수 있어요.
주의하세요
- 이 함수는 게임 카테고리 미니앱에서만 사용 가능해요. 비게임 미니앱에서 호출하면
'INVALID_CATEGORY'를 반환해요. - 토스앱 5.232.0 이상에서만 지원돼요. 그 이하 버전에서는
undefined를 반환해요. - 모든 유저의 식별자를 안정적으로 제공하기 위해 게임 미니앱의 최소 지원 토스앱 버전이 5.232.0으로 상향되었어요.
- 지원 버전 미만에서는 미니앱 진입 시 업데이트 안내 화면이 표시돼요.
- 반환되는 유저 키는 토스 서버 API 호출용 키가 아니에요.
- 게임사 내부 유저 식별, 데이터 관리 용도로만 사용해 주세요.
- 샌드박스 환경에서는 mock 데이터가 내려와요. 실제 동작은 QR 코드로 토스앱에서 테스트해 주세요.
시그니처
typescript
function getUserKeyForGame(): Promise<GetUserKeyForGameSuccessResponse | 'INVALID_CATEGORY' | 'ERROR' | undefined>;반환 값
- Promise<GetUserKeyForGameSuccessResponse | 'INVALID_CATEGORY' | 'ERROR' | undefined>
사용자 키 조회 결과를 반환해요.
GetUserKeyForGameSuccessResponse: 사용자 키 조회에 성공했어요.{ type: 'HASH', hash: string }형태로 반환돼요.hash값은 해당 게임 미니앱에서만 유효한 유저 식별자예요.
'INVALID_CATEGORY': 게임 카테고리가 아닌 미니앱에서 호출했어요.'ERROR': 알 수 없는 오류가 발생했어요.undefined: 앱 버전이 최소 지원 버전보다 낮아요.
예제 : 게임 유저 식별자 가져오기
아래 예제는 게임 미니앱에서 getUserKeyForGame을 호출해 유저 식별자를 받아 처리하는 기본적인 흐름을 보여줘요.
js
import { getUserKeyForGame } from '@apps-in-toss/web-framework';
async function handleGetUserKey() {
const result = await getUserKeyForGame();
if (!result) {
console.warn('지원하지 않는 앱 버전이에요.');
} else if (result === 'INVALID_CATEGORY') {
console.error('게임 카테고리가 아닌 미니앱이에요.');
} else if (result === 'ERROR') {
console.error('사용자 키 조회 중 오류가 발생했어요.');
} else if (result.type === 'HASH') {
console.log('사용자 키:', result.hash);
// 여기에서 사용자 키를 사용해 게임 데이터를 관리할 수 있어요.
}
}tsx
// webview
import { getUserKeyForGame } from '@apps-in-toss/web-framework';
function GameUserKeyButton() {
async function handleClick() {
const result = await getUserKeyForGame();
if (!result) {
console.warn('지원하지 않는 앱 버전이에요.');
return;
}
if (result === 'INVALID_CATEGORY') {
console.error('게임 카테고리가 아닌 미니앱이에요.');
return;
}
if (result === 'ERROR') {
console.error('사용자 키 조회 중 오류가 발생했어요.');
return;
}
if (result.type === 'HASH') {
console.log('사용자 키:', result.hash);
// 여기에서 사용자 키를 사용해 게임 데이터를 관리할 수 있어요.
}
}
return <button onClick={handleClick}>유저 키 가져오기</button>;
}tsx
// react-native
import { Button } from 'react-native';
import { getUserKeyForGame } from '@apps-in-toss/framework';
function GameUserKeyButton() {
async function handlePress() {
const result = await getUserKeyForGame();
if (!result) {
console.warn('지원하지 않는 앱 버전이에요.');
return;
}
if (result === 'INVALID_CATEGORY') {
console.error('게임 카테고리가 아닌 미니앱이에요.');
return;
}
if (result === 'ERROR') {
console.error('사용자 키 조회 중 오류가 발생했어요.');
return;
}
if (result.type === 'HASH') {
console.log('사용자 키:', result.hash);
// 여기에서 사용자 키를 사용해 게임 데이터를 관리할 수 있어요.
}
}
return <Button onPress={handlePress} title="유저 키 가져오기" />;
}참고사항
getUserKeyForGame은 게임 미니앱 전용 로그인/식별 수단이에요.- 토스 로그인(
appLogin)과 달리 서버 API 연동 없이도 사용할 수 있어요. - 게임 유저 데이터(랭킹, 포인트, 세이브 데이터 등)는 이 유저 키를 기준으로 관리하는 것을 권장해요.
