aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHubert Chathi <hubert@uhoreg.ca>2020-04-29 16:42:25 +0000
committerHubert Chathi <hubert@uhoreg.ca>2020-04-29 16:42:25 +0000
commit9cc23946726df437fd2ec0bf4299605691f0e065 (patch)
treefaee8f3811b88ec01a0a2068b7c6599658dbe466
parent930c4677547ebb3058680a9c3ad88186bb2030da (diff)
parente6f8a99b344cfc73741cec5710ed867aba912276 (diff)
Merge branch 'uhoreg/typescript' into 'master'
Add TypeScript definition file See merge request matrix-org/olm!11
-rw-r--r--javascript/index.d.ts125
-rw-r--r--javascript/package.json1
2 files changed, 126 insertions, 0 deletions
diff --git a/javascript/index.d.ts b/javascript/index.d.ts
new file mode 100644
index 0000000..682041e
--- /dev/null
+++ b/javascript/index.d.ts
@@ -0,0 +1,125 @@
+/*
+Copyright 2020 The Matrix.org Foundation C.I.C.
+
+Licensed under the Apache License, Version 2.0 (the "License");
+you may not use this file except in compliance with the License.
+You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+Unless required by applicable law or agreed to in writing, software
+distributed under the License is distributed on an "AS IS" BASIS,
+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+See the License for the specific language governing permissions and
+limitations under the License.
+*/
+
+export as namespace Olm;
+
+declare class Account {
+ constructor();
+ free();
+ create();
+ identity_keys(): string;
+ sign(message: string): string;
+ one_time_keys(): string;
+ mark_keys_as_published();
+ max_number_of_one_time_keys(): number;
+ generate_one_time_keys(number_of_keys: number);
+ remove_one_time_keys(session: Session);
+ pickle(key: string): string;
+ unpickle(key: string, pickle: string);
+}
+
+declare class Session {
+ constructor();
+ free(): void;
+ pickle(key: string): string;
+ unpickle(key: string, pickle: string);
+ create_outbound(
+ account: Account, their_identity_key: string, their_one_time_key: string,
+ ): void;
+ create_inbound(account: Account, one_time_key_message: string): void;
+ create_inbound_from(
+ account: Account, identity_key: string, one_time_key_message: string,
+ ): void;
+ session_id(): string;
+ has_received_message(): boolean;
+ matches_inbound(one_time_key_message: string): boolean;
+ matches_inbound_from(identity_key: string, one_time_key_message: string): boolean;
+ encrypt(plaintext: string): object;
+ decrypt(message_type: number, message: string): string;
+ describe(): string;
+}
+
+declare class Utility {
+ constructor();
+ free(): void;
+ sha256(input: string): string;
+ ed25519verify(key: string, message: string, signature: string): void;
+}
+
+declare class InboundGroupSession {
+ constructor();
+ free(): void;
+ pickle(key: string): string;
+ unpickle(key: string, pickle: string): string;
+ create(session_key: string): string;
+ import_session(session_key: string): string;
+ decrypt(message: string): object;
+ session_id(): string;
+ first_known_index(): number;
+ export_session(message_index: number): string;
+}
+
+declare class OutboundGroupSession {
+ constructor();
+ free(): void;
+ pickle(key: string): string;
+ unpickle(key: string): string;
+ create(): void;
+ encrypt(plaintext: string): string;
+ session_id(): string;
+ session_key(): string;
+ message_index(): number;
+}
+
+declare class PkEncryption {
+ constructor();
+ free(): void;
+ set_recipient_key(key: string): void;
+ encrypt(plaintext: string): object;
+}
+
+declare class PkDecryption {
+ constructor();
+ free(): void;
+ init_with_private_key(key: Uint8Array): string;
+ generate_key(): string;
+ get_private_key(): Uint8Array;
+ pickle(key: string): string;
+ unpickle(key: string, pickle: string): string;
+ decrypt(ephemeral_key: string, mac: string, ciphertext: string): string;
+}
+
+declare class PkSigning {
+ constructor();
+ free(): void;
+ init_with_seed(seed: Uint8Array): string;
+ generate_seed(): Uint8Array;
+ sign(message: string): string;
+}
+
+declare class SAS {
+ constructor();
+ free(): void;
+ get_pubkey(): string;
+ set_their_key(their_key: string): void;
+ generate_bytes(info: string, length: number): Uint8Array;
+ calculate_mac(input: string, info: string): string;
+ calculate_mac_long_kdf(input: string, info: string): string;
+}
+
+export function init(): Promise<void>;
+
+export function get_library_version(): [number, number, number];
diff --git a/javascript/package.json b/javascript/package.json
index d68020a..5123c8c 100644
--- a/javascript/package.json
+++ b/javascript/package.json
@@ -7,6 +7,7 @@
"olm.js",
"olm.wasm",
"olm_legacy.js",
+ "index.d.ts",
"README.md"
],
"scripts": {