aboutsummaryrefslogtreecommitdiff
path: root/xcode/OLMKit/OLMSession.h
diff options
context:
space:
mode:
authormanuroe <manu@matrix.org>2016-09-27 08:30:33 +0200
committermanuroe <manu@matrix.org>2016-09-27 08:30:33 +0200
commit1d06f2a4d9565c332081bc685edd8fd61d6507ef (patch)
treece61f13c9347786276238fc36e34dde4d5d32f5a /xcode/OLMKit/OLMSession.h
parent8a8d100ee5be5961861e53f8b3b5702e8902af74 (diff)
parentdaab2a58af947cddd67fe9f30dd3a9fc327650c0 (diff)
Merge remote-tracking branch 'OLMKit/olmkit' into olmkit
# Conflicts: # .gitignore # include/olm/olm.hh # javascript/README.md
Diffstat (limited to 'xcode/OLMKit/OLMSession.h')
-rw-r--r--xcode/OLMKit/OLMSession.h34
1 files changed, 34 insertions, 0 deletions
diff --git a/xcode/OLMKit/OLMSession.h b/xcode/OLMKit/OLMSession.h
new file mode 100644
index 0000000..c209564
--- /dev/null
+++ b/xcode/OLMKit/OLMSession.h
@@ -0,0 +1,34 @@
+//
+// OLMSession.h
+// olm
+//
+// Created by Chris Ballinger on 4/8/16.
+//
+//
+
+#import <Foundation/Foundation.h>
+#import "OLMSerializable.h"
+#import "OLMAccount.h"
+#import "OLMMessage.h"
+
+@interface OLMSession : NSObject <OLMSerializable, NSSecureCoding>
+
+- (instancetype) initOutboundSessionWithAccount:(OLMAccount*)account theirIdentityKey:(NSString*)theirIdentityKey theirOneTimeKey:(NSString*)theirOneTimeKey;
+
+- (instancetype) initInboundSessionWithAccount:(OLMAccount*)account oneTimeKeyMessage:(NSString*)oneTimeKeyMessage;
+
+- (instancetype) initInboundSessionWithAccount:(OLMAccount*)account theirIdentityKey:(NSString*)theirIdentityKey oneTimeKeyMessage:(NSString*)oneTimeKeyMessage;
+
+- (NSString*) sessionIdentifier;
+
+- (BOOL) matchesInboundSession:(NSString*)oneTimeKeyMessage;
+
+- (BOOL) matchesInboundSessionFrom:(NSString*)theirIdentityKey oneTimeKeyMessage:(NSString *)oneTimeKeyMessage;
+
+/** UTF-8 plaintext -> base64 ciphertext */
+- (OLMMessage*) encryptMessage:(NSString*)message;
+
+/** base64 ciphertext -> UTF-8 plaintext */
+- (NSString*) decryptMessage:(OLMMessage*)message;
+
+@end