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

GetReceivedMessageList

public BackendReturnObject GetReceivedMessageList();

설명

받은 쪽지 리스트를 조회합니다.
해당 리스트는 보낸 쪽지의 리스트(GetSentMessageList)와 공통된 값을 공유합니다.(쪽지 받은 사람/보낸 사람의 정보로 구별)

[콘솔 - 프로젝트 설정 - 소셜 설정]에서 설정한 최대 보유수만큼 리스트를 보유할 수 있으며, 쪽지가 가득 찬 경우 쪽지를 받을 수 없습니다.

Example

동기

Backend.Message.GetReceivedMessageList();

비동기

Backend.Message.GetReceivedMessageList((callback) => {
// 이후 처리
});

SendQueue

SendQueue.Enqueue(Backend.Message.GetReceivedMessageList, (callback) => {
// 이후 처리
});

ReturnCase

Success cases

조회에 성공한 경우
statusCode : 200
message : Success
returnValue : GetReturnValuetoJSON 참조

GetReturnValuetoJSON

보낸 쪽지 리스트를 조회하는 함수(GetSentMessageList)와 공통된 값을 공유하며 receiver과 sender를 통해 구분해야 합니다.

{
rows: [
{
// 쪽지 받은 사람의 inDate
receiver: { S: "2018-12-18T01:58:18.722Z" },
// 쪽지 보낸 사람의 inDate
sender: { S: "2018-12-27T00:21:31.322Z" },
// 쪽지 내용
content: { S: "hello this is user7. How are you doing?" },
// 쪽지의 inDate
inDate: { S: "2018-12-27T00:26:22.083Z" },
// 쪽지 보낸 사람의 닉네임
senderNickname: { S: "user7" },
// 받은 사람이 읽었는지 판단하는 기준
isRead: { BOOL: false },
// 쪽지 받은 사람의 닉네임
receiverNickname: { S: "ryan" },
// 쪽지 받은 사람의 쪽지 삭제 여부
isReceiverDelete: { BOOL: false },
// 쪽지 보낸 사람의 쪽지 삭제 여부
isSenderDelete: { BOOL: false },
},
{
receiver: [Object],
sender: [Object],
content: [Object],
inDate: [Object],
senderNickname: [Object],
isRead: [Object],
receiverNickname: [Object],
isReceiverDelete: [Object],
isSenderDelete: [Object],
},
];
}

Sample Code

public class MessageItem
{
public string receiver;
public string sender;
public string content;
public string inDate;
public string senderNickname;
public bool isRead;
public string receiverNickname;
public bool isReceiverDelete;
public bool isSenderDelete;

public override string ToString()
{
return $"receiver : {receiver}\n" +
$"sender : {sender}\n" +
$"content : {content}\n" +
$"inDate : {inDate}\n" +
$"senderNickname : {senderNickname}\n" +
$"isRead : {isRead}\n" +
$"receiverNickname : {receiverNickname}\n" +
$"isReceiverDelete : {isReceiverDelete}\n" +
$"isSenderDelete : {isSenderDelete}\n";
}
};
public void GetReceivedMessageListTest()
{
var bro = Backend.Message.GetReceivedMessageList();

if(!bro.IsSuccess())
return;

LitJson.JsonData json = bro.FlattenRows();

List<MessageItem> messageList = new List<MessageItem>();

for(int i = 0; i < json.Count; i++)
{
MessageItem messageItem = new MessageItem();

messageItem.receiver = json[i]["receiver"].ToString();
messageItem.sender = json[i]["sender"].ToString();
messageItem.content = json[i]["content"].ToString();
messageItem.inDate = json[i]["inDate"].ToString();
messageItem.senderNickname = json[i]["senderNickname"].ToString();
messageItem.isRead = json[i]["isRead"].ToString() == "true" ? true : false;
messageItem.receiverNickname = json[i]["receiverNickname"].ToString();
messageItem.isReceiverDelete = json[i]["isReceiverDelete"].ToString() == "true" ? true : false;
messageItem.isSenderDelete = json[i]["isSenderDelete"].ToString() == "true" ? true : false;

messageList.Add(messageItem);
Debug.Log(messageItem.ToString());
}
}

GetReceivedMessage

public BackendReturnObject GetReceivedMessage(string messageIndate);

파라미터

ValueTypeDescription
messageIndatestring읽고자 하는 받은 쪽지의 indate

설명

받은 쪽지 한 개를 읽습니다.

Example

동기

// 읽고자 하는 쪽지의 inDate를 얻습니다.  
BackendReturnObject bro = Backend.Message.GetReceivedMessageList();
string messageIndate = bro.Rows()[0]["inDate"]["S"].ToString();

// 읽고자 하는 쪽지의 내용(content)를 얻습니다.
BackendReturnObject bro2 = Backend.Message.GetReceivedMessage(messageIndate);
string content = bro2.GetReturnValuetoJSON()["row"]["content"]["S"].ToString();

비동기

// 읽고자 하는 쪽지의 inDate를 얻습니다.  
Backend.Message.GetReceivedMessageList(callback =>
{
string messageIndate = callback.Rows()[0]["inDate"]["S"].ToString();

// 읽고자 하는 쪽지의 내용(content)를 얻습니다.
Backend.Message.GetReceivedMessage(messageIndate, callback2 =>
{
string content = callback2.GetReturnValuetoJSON()["row"]["content"]["S"].ToString();
});

});

SendQueue

// 읽고자 하는 쪽지의 inDate를 얻습니다.  
SendQueue.Enqueue(Backend.Message.GetReceivedMessageList, callback =>
{
string messageIndate = callback.Rows()[0]["inDate"]["S"].ToString();

// 읽고자 하는 쪽지의 내용(content)를 얻습니다.
SendQueue.Enqueue(Backend.Message.GetReceivedMessage, messageIndate, callback2 =>
{
string content = callback2.GetReturnValuetoJSON()["row"]["content"]["S"].ToString();
});

});

ReturnCase

Success cases

조회에 성공한 경우
statusCode : 200
message : Success
returnValue : GetReturnValuetoJSON 참조

GetReturnValuetoJSON

{
row:
{
receiver: // 쪽지 받은 사람의 inDate
{ S : "2018-12-18T01:58:18.722Z" },
sender: // 쪽지 보낸 사람의 inDate
{ S : "2018-12-27T00:21:31.322Z" },
content: // 쪽지 내용
{ S : "hello this is user7. How are you doing?" },
inDate: // 쪽지의 inDate
{ S : "2018-12-27T00:26:22.083Z" },
senderNickname: // 쪽지 보낸 사람의 닉네임
{ S : "user7" },
isRead: // 받은 사람이 읽었는지 판단하는 기준
{ BOOL : false },
receiverNickname: // 쪽지 받은 사람의 닉네임
{ S : "ryan" },
isReceiverDelete: // 쪽지 받은 사람의 쪽지 삭제 여부
{ BOOL : false },
isSenderDelete: // 쪽지 보낸 사람의 쪽지 삭제 여부
{ BOOL : false }
}
}

Sample Code

public class MessageItem
{
public string receiver;
public string sender;
public string content;
public string inDate;
public string senderNickname;
public bool isRead;
public string receiverNickname;
public bool isReceiverDelete;
public bool isSenderDelete;

public override string ToString()
{
return $"receiver : {receiver}\n" +
$"sender : {sender}\n" +
$"content : {content}\n" +
$"inDate : {inDate}\n" +
$"senderNickname : {senderNickname}\n" +
$"isRead : {isRead}\n" +
$"receiverNickname : {receiverNickname}\n" +
$"isReceiverDelete : {isReceiverDelete}\n" +
$"isSenderDelete : {isSenderDelete}\n";
}
};
public void GetReceivedMessageTest()
{
var bro = Backend.Message.GetReceivedMessage("2022-03-14T07:21:01.953Z");

if(!bro.IsSuccess())
return;

LitJson.JsonData json = bro.GetFlattenJSON();

MessageItem messageItem = new MessageItem();

messageItem.receiver = json["row"]["receiver"].ToString();
messageItem.sender = json["row"]["sender"].ToString();
messageItem.content = json["row"]["content"].ToString();
messageItem.inDate = json["row"]["inDate"].ToString();
messageItem.senderNickname = json["row"]["senderNickname"].ToString();
messageItem.isRead = json["row"]["isRead"].ToString() == "true" ? true : false;
messageItem.receiverNickname = json["row"]["receiverNickname"].ToString();
messageItem.isReceiverDelete = json["row"]["isReceiverDelete"].ToString() == "true" ? true : false;
messageItem.isSenderDelete = json["row"]["isSenderDelete"].ToString() == "true" ? true : false;

Debug.Log(messageItem.ToString());
}