From d1a4e899d87e4bf900fbdb29fc45c8713fa0b132 Mon Sep 17 00:00:00 2001 From: Thomas Goyne Date: Fri, 2 Mar 2018 15:21:43 -0800 Subject: [PATCH] Fix the Permissions typescript definitions --- lib/index.d.ts | 69 +++++++++++++++++++++--------------- tests/js/permission-tests.js | 2 +- 2 files changed, 42 insertions(+), 29 deletions(-) diff --git a/lib/index.d.ts b/lib/index.d.ts index 3358b83d..21f0e93a 100644 --- a/lib/index.d.ts +++ b/lib/index.d.ts @@ -81,7 +81,7 @@ declare namespace Realm { path?: string; readOnly?: boolean; inMemory?: boolean; - schema?: ObjectClass[] | ObjectSchema[]; + schema?: (ObjectClass | ObjectSchema)[]; schemaVersion?: number; sync?: Realm.Sync.SyncConfiguration; deleteRealmIfMigrationNeeded?: boolean; @@ -483,6 +483,42 @@ declare namespace Realm.Sync { } } +declare namespace Realm.Permissions { + class Permission { + static schema: ObjectSchema; + + identity: string; + canRead: boolean; + canUpdate: boolean; + canDelete: boolean; + canSetPermissions: boolean; + canQuery: boolean; + canCreate: boolean; + canModifySchema: boolean; + } + + class User { + static schema: ObjectSchema; + identity: string; + } + + class Role { + static schema: ObjectSchema; + name: string; + members: User[]; + } + + class Class { + static schema: ObjectSchema; + class_name: string; + permissions: Permission[]; + } + + class Realm { + static schema: ObjectSchema; + permissions: Permission[]; + } +} interface ProgressPromise extends Promise { progress(callback: Realm.Sync.ProgressNotificationCallback): Promise @@ -552,7 +588,7 @@ declare class Realm { * @param {boolean} update? * @returns T */ - create(type: string | Realm.ObjectClass | Function, properties: T & Realm.ObjectPropsType, update?: boolean): T; + create(type: string | Realm.ObjectClass | Function, properties: T | Realm.ObjectPropsType, update?: boolean): T; /** * @param {Realm.Object|Realm.Object[]|Realm.List|Realm.Results|any} object @@ -628,33 +664,10 @@ declare class Realm { * @returns boolean */ compact(): boolean; -} -declare namespace Realm.Permissions { - interface Permission { - identity: string; - canRead: boolean; - canUpdate: boolean; - canDelete: boolean; - canSetPermissions: boolean; - canQuery: boolean; - canCreate: boolean; - canModifySchema: boolean; - } - interface User { - identity: string; - } - interface Role { - name: string; - members: User[]; - } - interface Class { - class_name: string; - permissions: Permission[]; - } - interface Realm { - permissions: Permission[]; - } + privileges() : Realm.Permissions.Realm; + privileges(objectType: string | Realm.ObjectSchema | Function) : Realm.Permissions.Class; + privileges(obj: Realm.Object) : Realm.Permissions.Class; } declare module 'realm' { diff --git a/tests/js/permission-tests.js b/tests/js/permission-tests.js index b92fb031..8378dfbc 100644 --- a/tests/js/permission-tests.js +++ b/tests/js/permission-tests.js @@ -147,7 +147,7 @@ module.exports = { .then(t => { token = t; return user1.invalidatePermissionOffer(token); }) // Since we don't yet support notification when the invalidation has gone through, // wait for a bit and hope the server is done processing. - .then(wait(100)) + .then(() => wait(100)) .then(() => user2.acceptPermissionOffer(token)) // We want the call to fail, i.e. the catch() below should be called. .then(() => { throw new Error("User was able to accept an invalid permission offer token"); })