본문으로 건너뛰기
버전: 5.11.0

사전 준비

우편 기능을 구현하기 위해서는 다음과 같은 작업들이 사전에 준비되어 있어야 합니다.

  1. 우편 이용이 가능한 차트
  2. 완성된 로그인 함수 로직
  3. 완성된 게임 정보 관리 함수 로직
  4. 우편 전용 스크립트 생성

1. 우편 이용이 가능한 차트

우편을 수령한 후에 지급되는 아이템을 구현하기 위해서는 우편 이용이 가능한 차트의 정보가 필요합니다.
뒤끝 콘솔 뒤끝 베이스 > 차트 관리에서 쿠폰 보상으로 지급할 아이템이 담긴 차트의 우편 사용 여부를 사용으로 변경해주세요.
만약 등록된 차트가 없을 경우에는 4. 차트 기능 구현하기Step 2. 콘솔에 차트 등록하기를 진행해 주세요.

차트 우측의 편집 버튼을 클릭합니다.

우편 사용 여부를 사용으로 변경합니다.

변경이 완료되면 우편 기능이 사용으로 표시됩니다.

2. 완성된 로그인 함수 로직

로그인/회원가입 외에 모든 뒤끝 기능은 로그인이 진행된 이후에 정상적으로 함수를 호출할 수 있습니다.
만약 로그인 로직이 구현되지 않으셨을 경우 1. 로그인/회원가입 구현하기 가이드에 따라 로그인 로직을 모두 구현해주시기 바랍니다.

3. 완성된 게임 정보 관리 함수 로직

해당 예제에서는 우편 수령 후, 반환되는 아이템을 저장하는 로직까지 구현되어있습니다.
따라서 우편 데이터를 저장하기 위한 2. 게임 정보 기능 구현하기가 필수로 구현되어 있어야 합니다.
만약 게임 정보 기능 로직이 구현되지 않으셨을 경우 2. 게임 정보 기능 구현하기 가이드에 따라 게임 정보 로직을 모두 구현해주시기 바랍니다.

4. 우편 전용 스크립트 생성

새로운 스크립트를 생성하고 이름을 BackendPost으로 수정합니다.
이후 BackendPost.cs 스크립트를 열어 내용을 다음과 같이 수정합니다.

BackendPost.cs

using System.Collections.Generic;
using System.Text;
using UnityEngine;

// 뒤끝 SDK namespace 추가
using BackEnd;

public class Post {
public bool isCanReceive = false;

public string title; // 우편 제목
public string content; // 우편 내용
public string inDate; // 우편 inDate

// string은 우편 아이템 이름, int는 갯수
public Dictionary<string, int> postReward = new Dictionary<string, int>();

public override string ToString() {
string result = string.Empty;
result += $"title : {title}\n";
result += $"content : {content}\n";
result += $"inDate : {inDate}\n";

if(isCanReceive) {
result += "우편 아이템\n";

foreach(string itemKey in postReward.Keys) {
result += $"| {itemKey} : {postReward[itemKey]}개\n";
}
}
else {
result += "지원하지 않는 우편 아이템입니다.";
}

return result;
}
}

public class BackendPost {
private static BackendPost _instance = null;

public static BackendPost Instance {
get {
if(_instance == null) {
_instance = new BackendPost();
}

return _instance;
}
}

private List<Post> _postList = new List<Post>();

public void SavePostToLocal(LitJson.JsonData item) {
foreach(LitJson.JsonData itemJson in item) {
if(itemJson["item"].ContainsKey("itemType")) {
int itemId = int.Parse(itemJson["item"]["itemId"].ToString());
string itemType = itemJson["item"]["itemType"].ToString();
string itemName = itemJson["item"]["itemName"].ToString();
int itemCount = int.Parse(itemJson["itemCount"].ToString());

if(BackendGameData.userData.inventory.ContainsKey(itemName)) {
BackendGameData.userData.inventory[itemName] += itemCount;
}
else {
BackendGameData.userData.inventory.Add(itemName, itemCount);
}

Debug.Log($"아이템을 수령했습니다. : {itemName} - {itemCount}개");
}
else {
Debug.LogError("지원하지 않는 item입니다.");
}
}
}

public void PostListGet(PostType postType) {
// Step 3. 우편 불러오기
}

public void PostReceive(PostType postType, int index) {
// Step 4. 우편 개별 수령 및 저장하기
}

public void PostReceiveAll(PostType postType) {
// Step 5. 우편 전체 수령 및 저장하기
}
}

BackendManager.cs

using UnityEngine;
using System.Threading.Tasks;

// 뒤끝 SDK namespace 추가
using BackEnd;

public class BackendManager : MonoBehaviour {
void Start() {
var bro = Backend.Initialize(true); // 뒤끝 초기화

// 뒤끝 초기화에 대한 응답값
if(bro.IsSuccess()) {
Debug.Log("초기화 성공 : " + bro); // 성공일 경우 statusCode 204 Success
} else {
Debug.LogError("초기화 실패 : " + bro); // 실패일 경우 statusCode 400대 에러 발생
}

Test();
}

// 동기 함수를 비동기에서 호출하게 해주는 함수(유니티 UI 접근 불가)
async void Test() {
await Task.Run(() => {
BackendLogin.Instance.CustomLogin("user1", "1234"); // 뒤끝 로그인 함수

// 우편 로직 추가

Debug.Log("테스트를 종료합니다.");
});
}
}