Realm.io を内部データベースとして使用してチャット メッセージを保存し、PubNub を使用してメッセージを送受信し、アプリケーションにチャット機能を実装しようとしています。メッセージが送信されるチャネルを定義する ChatSessions と、メッセージ自体を表し、メッセージのテキスト、メッセージが送信された日付、メッセージの送信者の名前、およびメッセージへの参照を保持する ChatMessages があります。メッセージが含まれる ChatSession。
次のコードでは、すべてのフィールドを指定して、チャネル経由で受信した PNMessage から ChatMessage を初期化しています。私が抱えている問題は、レルムがメッセージをデータベースに書き込もうとすると、書き込みメソッドが呼び出される直前に、セッション フィールドに有効な ChatSession が指定されているという事実にもかかわらず、ChatMessage のセッション フィールドが nil に設定されることです。
- (void)createChatMessageFromMessage:(PNMessage *)message
{
NSDictionary *msgDict = message.message;
ChatMessage *chatMessage = [[ChatMessage alloc] init];
chatMessage.text = [msgDict objectForKey:@"text"];
chatMessage.dateSent = [NSDate dateWithTimeIntervalSinceReferenceDate:[[msgDict objectForKey:@"dateSent"] floatValue]];
chatMessage.sender = [msgDict objectForKey:@"sender"];
NSPredicate *sessionPredicate = [NSPredicate predicateWithFormat:@"sessionName = %@", [msgDict objectForKey:@"session"]];
RLMArray *matches = [ChatSession objectsWithPredicate:sessionPredicate];
if ([matches count] == 1) {
chatMessage.session = [matches firstObject];
NSLog(@"Added chatMessage with session name: %@", chatMessage.session.sessionName);
} else {
NSLog(@"Error: ChatSession with name %@ not found in db.", [msgDict objectForKey:@"session"]);
return;
}
[NSThread detachNewThreadSelector:@selector(writeToDefaultRealm:) toTarget:self withObject:chatMessage];
}
#pragma mark - Saving to Realm
- (void)writeToDefaultRealm:(RLMObject *)object
{
RLMRealm *defaultRealm = [RLMRealm defaultRealm];
[defaultRealm beginWriteTransaction];
[defaultRealm addObject:object];
if ([object isKindOfClass:[ChatMessage class]]) {
[((ChatMessage *)object).session.messages addObject:object];
NSLog(@"Wrtiting message with text: %@ with session name: %@", ((ChatMessage *)object).text, ((ChatMessage *)object).session.sessionName);
} else {
NSLog(@"Writing session with name: %@", ((ChatSession *)object).sessionName);
}
[defaultRealm commitWriteTransaction];
}
chatMessage.session を設定した直後の NSLog は、必要なものを正しくログに記録します。chatMessage には正しいセッション名があります。ただし、writeToDefaultRealm: 内の NSLog はメッセージ テキストを正しくログに記録しますが、session.sessionName の nil 値をログに記録します。
このセッション フィールドが nil に設定されている理由を知っている人はいますか? ありがとうございました
編集
ChatMessage.h
#import <Realm/Realm.h>
@class ChatSession;
@interface ChatMessage : RLMObject
// Add properties here to define the model
@property NSString *text;
@property NSDate *dateSent;
@property NSString *sender;
@property ChatSession *session;
@end
// This protocol enables typed collections. i.e.:
// RLMArray<ChatMessage>
RLM_ARRAY_TYPE(ChatMessage)
ChatSession.h
#import "ChatMessage.h"
#import <Realm/Realm.h>
@interface ChatSession : RLMObject
// Add properties here to define the model
@property NSDate *dateOpened;
@property NSDate *dateUpdated;
@property NSString *sessionName;
@property NSString *myAlias;
@property NSString *theirAlias;
@property RLMArray<ChatMessage> *messages;
@end
// This protocol enables typed collections. i.e.:
// RLMArray<ChatSession>
RLM_ARRAY_TYPE(ChatSession)