@tblabs/storage 5.2.8 → 5.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -7,6 +7,7 @@ export declare class MessageBus {
7
7
  constructor(serverUrl: string, sender?: ISender | undefined);
8
8
  get Sender(): ISender | undefined;
9
9
  SetSender(sender: ISender): this;
10
+ SetServer(server: string): this;
10
11
  SendMessage(message: IMessage): Promise<MessageBusResponse>;
11
12
  private PostJSON;
12
13
  Ping(): Promise<boolean>;
@@ -31,6 +31,10 @@ export class MessageBus {
31
31
  this.sender = sender;
32
32
  return this;
33
33
  }
34
+ SetServer(server) {
35
+ this.serverUrl = server;
36
+ return this;
37
+ }
34
38
  async SendMessage(message) {
35
39
  let messagePackage = {
36
40
  Sender: this.sender || { Id: "Anonymous" },
@@ -0,0 +1,5 @@
1
+ import { Message } from '../MessageBus/Message';
2
+ import { dir } from '../Types/dir';
3
+ export declare class ListDatasetsQuery extends Message {
4
+ constructor(Database: dir);
5
+ }
@@ -0,0 +1,6 @@
1
+ import { Message } from '../MessageBus/Message';
2
+ export class ListDatasetsQuery extends Message {
3
+ constructor(Database) {
4
+ super("ListDatasets", { Database });
5
+ }
6
+ }
@@ -0,0 +1,5 @@
1
+ import { Message } from '../MessageBus/Message';
2
+ import { dir } from '../Types/dir';
3
+ export declare class ListUsersQuery extends Message {
4
+ constructor(Database: dir);
5
+ }
@@ -0,0 +1,6 @@
1
+ import { Message } from '../MessageBus/Message';
2
+ export class ListUsersQuery extends Message {
3
+ constructor(Database) {
4
+ super("ListUsers", { Database });
5
+ }
6
+ }
@@ -13,9 +13,13 @@ export declare class OnlineStorage {
13
13
  private logEnabled;
14
14
  private readonly _bus;
15
15
  private onUserChange;
16
- private readonly USER_LOCAL_STORAGE_KEY;
16
+ private USER_LOCAL_STORAGE_KEY;
17
17
  get DatabaseDir(): dir;
18
18
  constructor(server: url, database: dir, sender?: ISender, bus?: MessageBus);
19
+ SetServer(server: url): this;
20
+ SetDatabase(database: dir): this;
21
+ ListDatasets(): Promise<string[]>;
22
+ ListUsers(): Promise<IStorageUser[]>;
19
23
  GetDataset<T extends object>(datasetName: string, converter: IConverter<any, T>): Dataset<T>;
20
24
  private IsBrowserEnvironment;
21
25
  private LoadUserFromLocalStorage;
package/OnlineStorage.js CHANGED
@@ -3,6 +3,8 @@ import { CreateCommand, ExistsCommand, RemoveCommand } from "./Messages/AddDirCo
3
3
  import { Dataset } from "./Dataset";
4
4
  import { MoveCommand } from "./Messages/MoveCommand";
5
5
  import { LoginQuery } from "./Messages/LoginQuery";
6
+ import { ListUsersQuery } from "./Messages/ListUsersQuery";
7
+ import { ListDatasetsQuery } from "./Messages/ListDatabasesQuery";
6
8
  export class OnlineStorage {
7
9
  database;
8
10
  ANONYMOUS_USER = { Id: "Anonymous" };
@@ -10,7 +12,7 @@ export class OnlineStorage {
10
12
  logEnabled = false;
11
13
  _bus;
12
14
  onUserChange = [];
13
- USER_LOCAL_STORAGE_KEY;
15
+ USER_LOCAL_STORAGE_KEY = "";
14
16
  get DatabaseDir() {
15
17
  return this.database;
16
18
  }
@@ -22,6 +24,29 @@ export class OnlineStorage {
22
24
  this.CallOnUserChanged(true);
23
25
  }
24
26
  }
27
+ SetServer(server) {
28
+ this._bus.SetServer(server);
29
+ return this;
30
+ }
31
+ SetDatabase(database) {
32
+ this.database = database;
33
+ this.USER_LOCAL_STORAGE_KEY = "OnlineStorage:User:" + this.database;
34
+ return this;
35
+ }
36
+ async ListDatasets() {
37
+ const result = await this._bus.SendMessage(new ListDatasetsQuery(this.DatabaseDir));
38
+ if (!result.IsSuccess) {
39
+ throw new Error(`Could not list datasets: ${result.ErrorMessage}`);
40
+ }
41
+ return result.Result;
42
+ }
43
+ async ListUsers() {
44
+ const result = await this._bus.SendMessage(new ListUsersQuery(this.DatabaseDir));
45
+ if (!result.IsSuccess) {
46
+ throw new Error(`Could not list users: ${result.ErrorMessage}`);
47
+ }
48
+ return result.Result;
49
+ }
25
50
  GetDataset(datasetName, converter) {
26
51
  return new Dataset(this, converter, datasetName);
27
52
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tblabs/storage",
3
- "version": "5.2.8",
3
+ "version": "5.3.1",
4
4
  "description": "online storage module with auth",
5
5
  "license": "beerware",
6
6
  "main": "index.js",
Binary file
@@ -1,4 +0,0 @@
1
- import { Message } from '../MessageBus/Message';
2
- export declare class SearchQuery extends Message {
3
- constructor(Database: string, Id: string);
4
- }
@@ -1,6 +0,0 @@
1
- import { Message } from '../MessageBus/Message';
2
- export class SearchQuery extends Message {
3
- constructor(Database, Id) {
4
- super("Search", { Database, Id });
5
- }
6
- }
@@ -1,6 +0,0 @@
1
- import { IStorageUserPrivileges } from "../IStorageUserPrivileges";
2
- import { Message } from "../MessageBus/Message";
3
- import { dir } from "../Types/dir";
4
- export declare class RegisterCommand extends Message {
5
- constructor(Database: dir, Id: string, Role: string, Name: string, Login: string, Password: string, Email: string, Privileges: IStorageUserPrivileges, Icon?: string, Tags?: string[], CreatedAt?: Date);
6
- }
@@ -1,6 +0,0 @@
1
- import { Message } from "../MessageBus/Message";
2
- export class RegisterCommand extends Message {
3
- constructor(Database, Id, Role, Name, Login, Password, Email, Privileges, Icon, Tags, CreatedAt) {
4
- super("Register", { Database, Id, Role, Name, Login, Password, Email, Privileges, Icon, Tags, CreatedAt });
5
- }
6
- }
Binary file