申请注销
请求账号注销的API。在注销宽限期内账号将被保留。
URL确认
此API使用 service-account.playnanoo.com 域名。
API信息
- URL:
https://service-account.playnanoo.com/api/v20240401/token/withdrawal - Method:
PUT - 需要认证: 是
请求参数
| 参数 | 类型 | 必填 | 说明 |
|---|---|---|---|
| period | int | 必填 | 注销宽限期 (天为单位) |
| account_token | string | 必填 | 账号Token |
| memo | string | 必填 | 注销原因备注 |
| platform | string | 必填 | 平台 (例如: "aos", "ios") |
| device_id | string | 必填 | 设备唯一ID |
| device_model | string | 必填 | 设备型号 |
| device_os | string | 必填 | 设备OS |
| device_language | string | 必填 | 设备语言 (例如: "KO", "EN") |
响应数据
Res结构体
| 字段 | 类型 | 说明 |
|---|---|---|
| Status | FString | 状态值 |
Unreal C++实现
头文件 (WithDrawal.h)
// WithDrawal.h
#pragma once
#include "CoreMinimal.h"
#include "Json.h"
#include "JsonUtilities.h"
// 응답 콜백 델리게이트
DECLARE_DELEGATE_OneParam(FOnWithDrawalSuccess, const FString&);
DECLARE_DELEGATE_OneParam(FOnWithDrawalError, const FString&);
class YOURPROJECT_API FWithDrawal
{
public:
// 요청 구조체 (디바이스 정보는 FPlayNANOOHelper::CreateRequestBody()에서 자동 생성)
struct FReq
{
int32 period;
FString account_token;
FString memo;
};
// 응답 구조체
struct FRes
{
FString ErrorCode;
FString Message;
FString Status;
bool FromJson(const FString& JsonString)
{
TSharedPtr<FJsonObject> JsonObject;
TSharedRef<TJsonReader<>> Reader = TJsonReaderFactory<>::Create(JsonString);
if (FJsonSerializer::Deserialize(Reader, JsonObject) && JsonObject.IsValid())
{
JsonObject->TryGetStringField(TEXT("ErrorCode"), ErrorCode);
JsonObject->TryGetStringField(TEXT("Message"), Message);
JsonObject->TryGetStringField(TEXT("Status"), Status);
return true;
}
return false;
}
};
/**
* 회원 탈퇴 요청 전송
*/
static void Send(
int32 Period,
const FString& AccountToken,
const FString& Memo,
FOnWithDrawalSuccess OnSuccess,
FOnWithDrawalError OnError
);
};
实现文件 (WithDrawal.cpp)
// WithDrawal.cpp
#include "WithDrawal.h"
#include "PlayNANOOHelper.h"
#include "Http.h"
void FWithDrawal::Send(
int32 Period,
const FString& AccountToken,
const FString& Memo,
FOnWithDrawalSuccess OnSuccess,
FOnWithDrawalError OnError)
{
// 요청 데이터 생성 (디바이스 정보는 자동 포함)
TSharedPtr<FJsonObject> JsonObject = FPlayNANOOHelper::CreateRequestBody();
// API 전용 파라미터 추가
JsonObject->SetNumberField(TEXT("period"), Period);
JsonObject->SetStringField(TEXT("account_token"), AccountToken);
if (!Memo.IsEmpty())
{
JsonObject->SetStringField(TEXT("memo"), Memo);
}
// JSON 변환
FString JsonBody;
TSharedRef<TJsonWriter<>> Writer = TJsonWriterFactory<>::Create(&JsonBody);
FJsonSerializer::Serialize(JsonObject.ToSharedRef(), Writer);
// HTTP 요청 생성
TSharedRef<IHttpRequest> Request = FHttpModule::Get().CreateRequest();
Request->SetURL(TEXT("https://service-account.playnanoo.com/api/v20240401/token/withdrawal"));
Request->SetVerb(TEXT("PUT"));
FPlayNANOOHelper::SetCommonHeaders(Request, true); // 인증 토큰 포함
Request->SetContentAsString(JsonBody);
// 응답 처리
Request->OnProcessRequestComplete().BindLambda(
[OnSuccess, OnError](FHttpRequestPtr Req, FHttpResponsePtr Res, bool bSuccess)
{
if (bSuccess && Res.IsValid())
{
FString Response = Res->GetContentAsString();
FRes Result;
if (Result.FromJson(Response))
{
if (Result.ErrorCode.IsEmpty())
{
OnSuccess.ExecuteIfBound(Response);
}
else
{
OnError.ExecuteIfBound(Response);
}
}
else
{
OnError.ExecuteIfBound(TEXT("Failed to parse response"));
}
}
else
{
FString ErrorMsg = Res.IsValid() ? Res->GetContentAsString() : TEXT("Request failed");
OnError.ExecuteIfBound(ErrorMsg);
}
});
Request->ProcessRequest();
}
使用示例
void UYourClass::RequestWithdrawal(const FString& AccessToken, const FString& Reason)
{
FWithDrawal::Send(
7, // 7일 유예 기간
AccessToken,
Reason,
FOnWithDrawalSuccess::CreateLambda([](const FString& Response)
{
FWithDrawal::FRes Result;
if (Result.FromJson(Response))
{
UE_LOG(LogTemp, Log, TEXT("회원 탈퇴 요청 완료: %s"), *Result.Status);
UE_LOG(LogTemp, Log, TEXT("7일 후 계정이 완전히 삭제됩니다."));
}
}),
FOnWithDrawalError::CreateLambda([](const FString& Error)
{
UE_LOG(LogTemp, Error, TEXT("회원 탈퇴 요청 실패: %s"), *Error);
})
);
}
注销宽限期
请求注销后,账号将在指定的宽限期(period)内被保留。在宽限期内登录或调用恢复API可以取消注销。宽限期过后,账号和所有数据将被永久删除。