@fluidframework/file-driver 2.0.0-dev.7.4.0.215930 → 2.0.0-dev.7.4.0.217212

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.
Files changed (32) hide show
  1. package/api-extractor-lint.json +13 -0
  2. package/api-extractor.json +0 -4
  3. package/api-report/file-driver.api.md +10 -10
  4. package/dist/file-driver-alpha.d.ts +14 -152
  5. package/dist/file-driver-beta.d.ts +46 -173
  6. package/dist/file-driver-public.d.ts +46 -173
  7. package/dist/file-driver-untrimmed.d.ts +22 -0
  8. package/dist/fileDeltaStorageService.d.ts +1 -0
  9. package/dist/fileDeltaStorageService.d.ts.map +1 -1
  10. package/dist/fileDeltaStorageService.js +1 -0
  11. package/dist/fileDeltaStorageService.js.map +1 -1
  12. package/dist/fileDocumentDeltaConnection.d.ts +4 -0
  13. package/dist/fileDocumentDeltaConnection.d.ts.map +1 -1
  14. package/dist/fileDocumentDeltaConnection.js +4 -0
  15. package/dist/fileDocumentDeltaConnection.js.map +1 -1
  16. package/dist/fileDocumentServiceFactory.d.ts +1 -0
  17. package/dist/fileDocumentServiceFactory.d.ts.map +1 -1
  18. package/dist/fileDocumentServiceFactory.js +1 -0
  19. package/dist/fileDocumentServiceFactory.js.map +1 -1
  20. package/dist/fileDocumentStorageService.d.ts +16 -0
  21. package/dist/fileDocumentStorageService.d.ts.map +1 -1
  22. package/dist/fileDocumentStorageService.js +10 -0
  23. package/dist/fileDocumentStorageService.js.map +1 -1
  24. package/lib/file-driver-alpha.d.ts +14 -152
  25. package/lib/file-driver-beta.d.ts +46 -173
  26. package/lib/file-driver-public.d.ts +46 -173
  27. package/lib/file-driver-untrimmed.d.ts +22 -0
  28. package/package.json +9 -8
  29. package/src/fileDeltaStorageService.ts +1 -0
  30. package/src/fileDocumentDeltaConnection.ts +4 -0
  31. package/src/fileDocumentServiceFactory.ts +1 -0
  32. package/src/fileDocumentStorageService.ts +16 -0
@@ -2,186 +2,59 @@ import * as api from '@fluidframework/protocol-definitions';
2
2
  import { ConnectionMode } from '@fluidframework/protocol-definitions';
3
3
  import { IClientConfiguration } from '@fluidframework/protocol-definitions';
4
4
  import { IConnected } from '@fluidframework/protocol-definitions';
5
- import { IDisposable } from '@fluidframework/core-interfaces';
6
- import { IDocumentDeltaConnection } from '@fluidframework/driver-definitions';
7
- import { IDocumentDeltaConnectionEvents } from '@fluidframework/driver-definitions';
8
- import { IDocumentDeltaStorageService } from '@fluidframework/driver-definitions';
9
5
  import { IDocumentMessage } from '@fluidframework/protocol-definitions';
10
- import { IDocumentService } from '@fluidframework/driver-definitions';
11
- import { IDocumentServiceFactory } from '@fluidframework/driver-definitions';
12
- import { IDocumentStorageService } from '@fluidframework/driver-definitions';
13
6
  import { IDocumentStorageServicePolicies } from '@fluidframework/driver-definitions';
14
- import { IFileSnapshot } from '@fluidframework/replay-driver';
15
- import { IResolvedUrl } from '@fluidframework/driver-definitions';
16
7
  import { ISequencedDocumentMessage } from '@fluidframework/protocol-definitions';
17
8
  import { ISignalClient } from '@fluidframework/protocol-definitions';
18
9
  import { ISignalMessage } from '@fluidframework/protocol-definitions';
19
- import { IStream } from '@fluidframework/driver-definitions';
20
- import { ISummaryContext } from '@fluidframework/driver-definitions';
21
10
  import { ISummaryTree } from '@fluidframework/protocol-definitions';
22
- import { ITelemetryBaseLogger } from '@fluidframework/core-interfaces';
23
11
  import { ITokenClaims } from '@fluidframework/protocol-definitions';
24
- import { ReadDocumentStorageServiceBase } from '@fluidframework/replay-driver';
25
-
26
- /**
27
- * Provides access to the underlying delta storage on the local file storage for file driver.
28
- */
29
- export declare class FileDeltaStorageService implements IDocumentDeltaStorageService {
30
- private readonly path;
31
- private readonly messages;
32
- private lastOps;
33
- constructor(path: string);
34
- fetchMessages(from: number, to: number | undefined, abortSignal?: AbortSignal, cachedOnly?: boolean): IStream<api.ISequencedDocumentMessage[]>;
35
- get ops(): readonly Readonly<api.ISequencedDocumentMessage>[];
36
- /**
37
- * Retrieve ops within the exclusive sequence number range.
38
- *
39
- * @param from - First op to be fetched.
40
- * @param to - Last op to be fetched. This is exclusive.
41
- */
42
- getFromWebSocket(from: number, to: number): api.ISequencedDocumentMessage[];
43
- }
44
-
45
- /**
46
- * Factory for creating the file document service. Use this if you want to
47
- * use the local file storage as underlying storage.
48
- */
49
- export declare class FileDocumentServiceFactory implements IDocumentServiceFactory {
50
- private readonly storage;
51
- private readonly deltaStorage;
52
- private readonly deltaConnection;
53
- constructor(storage: IDocumentStorageService, deltaStorage: FileDeltaStorageService, deltaConnection: IDocumentDeltaConnection);
54
- /**
55
- * Creates the file document service if the path exists.
56
- *
57
- * @param fileURL - Path of directory containing ops/snapshots.
58
- * @returns file document service.
59
- */
60
- createDocumentService(resolvedUrl: IResolvedUrl, logger?: ITelemetryBaseLogger, clientIsSummarizer?: boolean): Promise<IDocumentService>;
61
- createContainer(createNewSummary: ISummaryTree, resolvedUrl: IResolvedUrl, logger?: ITelemetryBaseLogger, clientIsSummarizer?: boolean): Promise<IDocumentService>;
62
- }
63
-
64
- export declare const FileSnapshotWriterClassFactory: <TBase extends ReaderConstructor>(Base: TBase) => {
65
- new (...args: any[]): {
66
- blobsWriter: Map<string, ArrayBufferLike>;
67
- latestWriterTree?: api.ISnapshotTree | undefined;
68
- docId?: string | undefined;
69
- reset(): void;
70
- onSnapshotHandler(snapshot: IFileSnapshot): void;
71
- readBlob(sha: string): Promise<ArrayBufferLike>;
72
- getVersions(versionId: string | null, count: number): Promise<api.IVersion[]>;
73
- getSnapshotTree(version?: api.IVersion): Promise<api.ISnapshotTree | null>;
74
- uploadSummaryWithContext(summary: api.ISummaryTree, context: ISummaryContext): Promise<string>;
75
- buildTree(snapshotTree: api.ISnapshotTree): Promise<api.ITree>;
76
- repositoryUrl: string;
77
- readonly policies?: IDocumentStorageServicePolicies | undefined;
78
- createBlob(file: ArrayBufferLike): Promise<api.ICreateBlobResponse>;
79
- downloadSummary(handle: api.ISummaryHandle): Promise<api.ISummaryTree>;
80
- readonly disposed?: boolean | undefined;
81
- dispose?: ((error?: Error | undefined) => void) | undefined;
82
- };
83
- } & TBase;
84
-
85
- export declare const FileStorageDocumentName = "FileStorageDocId";
86
-
87
- /**
88
- * Document storage service for the file driver.
89
- */
90
- export declare class FluidFetchReader extends ReadDocumentStorageServiceBase implements IDocumentStorageService {
91
- private readonly path;
92
- private readonly versionName?;
93
- protected docTree: api.ISnapshotTree | null;
94
- constructor(path: string, versionName?: string | undefined);
95
- /**
96
- * Read the file and returns the snapshot tree.
97
- * @param version - The version contains the path of the file which contains the snapshot tree.
98
- */
99
- getSnapshotTree(version?: api.IVersion): Promise<api.ISnapshotTree | null>;
100
- /**
101
- * Gets the path of the snapshot tree to be read.
102
- * @param versionId - version ID.
103
- * @param count - Number of versions to be returned.
104
- */
105
- getVersions(versionId: string | null, count: number): Promise<api.IVersion[]>;
106
- readBlob(sha: string): Promise<ArrayBufferLike>;
107
- }
108
-
109
- export declare const FluidFetchReaderFileSnapshotWriter: {
110
- new (...args: any[]): {
111
- blobsWriter: Map<string, ArrayBufferLike>;
112
- latestWriterTree?: api.ISnapshotTree | undefined;
113
- docId?: string | undefined;
114
- reset(): void;
115
- onSnapshotHandler(snapshot: IFileSnapshot): void;
116
- readBlob(sha: string): Promise<ArrayBufferLike>;
117
- getVersions(versionId: string | null, count: number): Promise<api.IVersion[]>;
118
- getSnapshotTree(version?: api.IVersion): Promise<api.ISnapshotTree | null>;
119
- uploadSummaryWithContext(summary: api.ISummaryTree, context: ISummaryContext): Promise<string>;
120
- buildTree(snapshotTree: api.ISnapshotTree): Promise<api.ITree>;
121
- repositoryUrl: string;
122
- readonly policies?: IDocumentStorageServicePolicies | undefined;
123
- createBlob(file: ArrayBufferLike): Promise<api.ICreateBlobResponse>;
124
- downloadSummary(handle: api.ISummaryHandle): Promise<api.ISummaryTree>;
125
- readonly disposed?: boolean | undefined;
126
- dispose?: ((error?: Error | undefined) => void) | undefined;
127
- };
128
- } & typeof FluidFetchReader;
129
-
130
- export declare interface ISnapshotWriterStorage extends IDocumentStorageService {
131
- onSnapshotHandler(snapshot: IFileSnapshot): void;
132
- reset(): void;
133
- }
134
-
135
- export declare type ReaderConstructor = new (...args: any[]) => IDocumentStorageService;
136
-
137
- /**
138
- * Replay service used to play ops using the delta connection.
139
- */
140
- export declare class Replayer {
141
- private readonly deltaConnection;
142
- private readonly documentStorageService;
143
- private currentReplayOp;
144
- constructor(deltaConnection: ReplayFileDeltaConnection, documentStorageService: FileDeltaStorageService);
145
- get currentReplayedOp(): number;
146
- set currentReplayedOp(op: number);
147
- get ops(): readonly Readonly<ISequencedDocumentMessage>[];
148
- /**
149
- * Replay the ops upto a certain number.
150
- * @param replayTo - The last op number to be replayed.
151
- */
152
- replay(replayTo: number): number;
153
- private isDoneFetch;
154
- private emit;
155
- }
156
-
157
- export declare class ReplayFileDeltaConnection extends TypedEventEmitter<IDocumentDeltaConnectionEvents> implements IDocumentDeltaConnection, IDisposable {
158
- details: IConnected;
159
- /**
160
- * Mimic the delta connection to replay ops on it.
161
- *
162
- * @param documentDeltaStorageService - The delta storage service to get ops from.
163
- * @returns Document delta connection.
164
- */
165
- static create(documentDeltaStorageService: FileDeltaStorageService): Promise<ReplayFileDeltaConnection>;
166
- readonly maxMessageSize: number;
167
- private readonly replayer;
168
- constructor(details: IConnected, documentDeltaStorageService: FileDeltaStorageService);
169
- getReplayer(): Replayer;
170
- get clientId(): string;
171
- get mode(): ConnectionMode;
172
- get claims(): ITokenClaims;
173
- get existing(): boolean;
174
- get version(): string;
175
- get initialMessages(): ISequencedDocumentMessage[];
176
- get initialSignals(): ISignalMessage[];
177
- get initialClients(): ISignalClient[];
178
- get serviceConfiguration(): IClientConfiguration;
179
- submit(documentMessages: IDocumentMessage[]): void;
180
- submitSignal(message: any): Promise<void>;
181
- private _disposed;
182
- get disposed(): boolean;
183
- dispose(): void;
184
- }
12
+
13
+ /* Excluded from this release type: FileDeltaStorageService */
14
+
15
+ /* Excluded from this release type: FileDocumentServiceFactory */
16
+
17
+ /* Excluded from this release type: FileSnapshotWriterClassFactory */
18
+
19
+ /* Excluded from this release type: FileStorageDocumentName */
20
+
21
+ /* Excluded from this release type: FluidFetchReader */
22
+
23
+ /* Excluded from this release type: FluidFetchReaderFileSnapshotWriter */
24
+
25
+ /* Excluded from this release type: IDisposable */
26
+
27
+ /* Excluded from this release type: IDocumentDeltaConnection */
28
+
29
+ /* Excluded from this release type: IDocumentDeltaConnectionEvents */
30
+
31
+ /* Excluded from this release type: IDocumentDeltaStorageService */
32
+
33
+ /* Excluded from this release type: IDocumentService */
34
+
35
+ /* Excluded from this release type: IDocumentServiceFactory */
36
+
37
+ /* Excluded from this release type: IDocumentStorageService */
38
+
39
+ /* Excluded from this release type: IFileSnapshot */
40
+
41
+ /* Excluded from this release type: IResolvedUrl */
42
+
43
+ /* Excluded from this release type: ISnapshotWriterStorage */
44
+
45
+ /* Excluded from this release type: IStream */
46
+
47
+ /* Excluded from this release type: ISummaryContext */
48
+
49
+ /* Excluded from this release type: ITelemetryBaseLogger */
50
+
51
+ /* Excluded from this release type: ReadDocumentStorageServiceBase */
52
+
53
+ /* Excluded from this release type: ReaderConstructor */
54
+
55
+ /* Excluded from this release type: Replayer */
56
+
57
+ /* Excluded from this release type: ReplayFileDeltaConnection */
185
58
 
186
59
  /* Excluded from this release type: TypedEventEmitter */
187
60
 
@@ -26,6 +26,7 @@ import { TypedEventEmitter } from '@fluid-internal/client-utils';
26
26
 
27
27
  /**
28
28
  * Provides access to the underlying delta storage on the local file storage for file driver.
29
+ * @internal
29
30
  */
30
31
  export declare class FileDeltaStorageService implements IDocumentDeltaStorageService {
31
32
  private readonly path;
@@ -46,6 +47,7 @@ export declare class FileDeltaStorageService implements IDocumentDeltaStorageSer
46
47
  /**
47
48
  * Factory for creating the file document service. Use this if you want to
48
49
  * use the local file storage as underlying storage.
50
+ * @internal
49
51
  */
50
52
  export declare class FileDocumentServiceFactory implements IDocumentServiceFactory {
51
53
  private readonly storage;
@@ -62,6 +64,9 @@ export declare class FileDocumentServiceFactory implements IDocumentServiceFacto
62
64
  createContainer(createNewSummary: ISummaryTree, resolvedUrl: IResolvedUrl, logger?: ITelemetryBaseLogger, clientIsSummarizer?: boolean): Promise<IDocumentService>;
63
65
  }
64
66
 
67
+ /**
68
+ * @internal
69
+ */
65
70
  export declare const FileSnapshotWriterClassFactory: <TBase extends ReaderConstructor>(Base: TBase) => {
66
71
  new (...args: any[]): {
67
72
  blobsWriter: Map<string, ArrayBufferLike>;
@@ -83,10 +88,14 @@ export declare const FileSnapshotWriterClassFactory: <TBase extends ReaderConstr
83
88
  };
84
89
  } & TBase;
85
90
 
91
+ /**
92
+ * @internal
93
+ */
86
94
  export declare const FileStorageDocumentName = "FileStorageDocId";
87
95
 
88
96
  /**
89
97
  * Document storage service for the file driver.
98
+ * @internal
90
99
  */
91
100
  export declare class FluidFetchReader extends ReadDocumentStorageServiceBase implements IDocumentStorageService {
92
101
  private readonly path;
@@ -107,6 +116,9 @@ export declare class FluidFetchReader extends ReadDocumentStorageServiceBase imp
107
116
  readBlob(sha: string): Promise<ArrayBufferLike>;
108
117
  }
109
118
 
119
+ /**
120
+ * @internal
121
+ */
110
122
  export declare const FluidFetchReaderFileSnapshotWriter: {
111
123
  new (...args: any[]): {
112
124
  blobsWriter: Map<string, ArrayBufferLike>;
@@ -128,15 +140,22 @@ export declare const FluidFetchReaderFileSnapshotWriter: {
128
140
  };
129
141
  } & typeof FluidFetchReader;
130
142
 
143
+ /**
144
+ * @internal
145
+ */
131
146
  export declare interface ISnapshotWriterStorage extends IDocumentStorageService {
132
147
  onSnapshotHandler(snapshot: IFileSnapshot): void;
133
148
  reset(): void;
134
149
  }
135
150
 
151
+ /**
152
+ * @internal
153
+ */
136
154
  export declare type ReaderConstructor = new (...args: any[]) => IDocumentStorageService;
137
155
 
138
156
  /**
139
157
  * Replay service used to play ops using the delta connection.
158
+ * @internal
140
159
  */
141
160
  export declare class Replayer {
142
161
  private readonly deltaConnection;
@@ -155,6 +174,9 @@ export declare class Replayer {
155
174
  private emit;
156
175
  }
157
176
 
177
+ /**
178
+ * @internal
179
+ */
158
180
  export declare class ReplayFileDeltaConnection extends TypedEventEmitter<IDocumentDeltaConnectionEvents> implements IDocumentDeltaConnection, IDisposable {
159
181
  details: IConnected;
160
182
  /**
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fluidframework/file-driver",
3
- "version": "2.0.0-dev.7.4.0.215930",
3
+ "version": "2.0.0-dev.7.4.0.217212",
4
4
  "description": "A driver that reads/write from/to local file storage.",
5
5
  "homepage": "https://fluidframework.com",
6
6
  "repository": {
@@ -15,13 +15,13 @@
15
15
  "main": "dist/index.js",
16
16
  "types": "dist/index.d.ts",
17
17
  "dependencies": {
18
- "@fluid-internal/client-utils": "2.0.0-dev.7.4.0.215930",
19
- "@fluidframework/core-interfaces": "2.0.0-dev.7.4.0.215930",
20
- "@fluidframework/core-utils": "2.0.0-dev.7.4.0.215930",
21
- "@fluidframework/driver-definitions": "2.0.0-dev.7.4.0.215930",
22
- "@fluidframework/driver-utils": "2.0.0-dev.7.4.0.215930",
18
+ "@fluid-internal/client-utils": "2.0.0-dev.7.4.0.217212",
19
+ "@fluidframework/core-interfaces": "2.0.0-dev.7.4.0.217212",
20
+ "@fluidframework/core-utils": "2.0.0-dev.7.4.0.217212",
21
+ "@fluidframework/driver-definitions": "2.0.0-dev.7.4.0.217212",
22
+ "@fluidframework/driver-utils": "2.0.0-dev.7.4.0.217212",
23
23
  "@fluidframework/protocol-definitions": "^3.0.0",
24
- "@fluidframework/replay-driver": "2.0.0-dev.7.4.0.215930"
24
+ "@fluidframework/replay-driver": "2.0.0-dev.7.4.0.217212"
25
25
  },
26
26
  "devDependencies": {
27
27
  "@fluid-tools/build-cli": "^0.28.0",
@@ -63,12 +63,13 @@
63
63
  "build": "fluid-build . --task build",
64
64
  "build:compile": "fluid-build . --task compile",
65
65
  "build:docs": "fluid-build . --task api",
66
+ "check:release-tags": "api-extractor run --local --config ./api-extractor-lint.json",
66
67
  "ci:build:docs": "api-extractor run",
67
68
  "clean": "rimraf --glob dist lib \"**/*.tsbuildinfo\" \"**/*.build.log\" _api-extractor-temp",
68
69
  "eslint": "eslint --format stylish src",
69
70
  "eslint:fix": "eslint --format stylish src --fix --fix-type problem,suggestion,layout",
70
71
  "format": "npm run prettier:fix",
71
- "lint": "npm run prettier && npm run eslint",
72
+ "lint": "npm run prettier && npm run check:release-tags && npm run eslint",
72
73
  "lint:fix": "npm run prettier:fix && npm run eslint:fix",
73
74
  "prettier": "prettier --check . --cache --ignore-path ../../../.prettierignore",
74
75
  "prettier:fix": "prettier --write . --cache --ignore-path ../../../.prettierignore",
@@ -11,6 +11,7 @@ import * as api from "@fluidframework/protocol-definitions";
11
11
 
12
12
  /**
13
13
  * Provides access to the underlying delta storage on the local file storage for file driver.
14
+ * @internal
14
15
  */
15
16
  export class FileDeltaStorageService implements IDocumentDeltaStorageService {
16
17
  private readonly messages: api.ISequencedDocumentMessage[];
@@ -45,6 +45,7 @@ const Claims: ITokenClaims = {
45
45
 
46
46
  /**
47
47
  * Replay service used to play ops using the delta connection.
48
+ * @internal
48
49
  */
49
50
  export class Replayer {
50
51
  private currentReplayOp = 0;
@@ -110,6 +111,9 @@ export class Replayer {
110
111
  }
111
112
  }
112
113
 
114
+ /**
115
+ * @internal
116
+ */
113
117
  export class ReplayFileDeltaConnection
114
118
  extends TypedEventEmitter<IDocumentDeltaConnectionEvents>
115
119
  implements IDocumentDeltaConnection, IDisposable
@@ -18,6 +18,7 @@ import { FileDocumentService } from "./fileDocumentService";
18
18
  /**
19
19
  * Factory for creating the file document service. Use this if you want to
20
20
  * use the local file storage as underlying storage.
21
+ * @internal
21
22
  */
22
23
  export class FileDocumentServiceFactory implements IDocumentServiceFactory {
23
24
  constructor(
@@ -13,6 +13,9 @@ import { IFileSnapshot, ReadDocumentStorageServiceBase } from "@fluidframework/r
13
13
 
14
14
  // This ID is used by replay tool as Document Id.
15
15
  // We leverage it to figure out when container is asking for root document tree.
16
+ /**
17
+ * @internal
18
+ */
16
19
  export const FileStorageDocumentName = "FileStorageDocId"; // Some unique document name
17
20
 
18
21
  // Tree ID use to communicate between getVersions() & getSnapshotTree() that IVersion is ours.
@@ -20,6 +23,7 @@ const FileStorageVersionTreeId = "FileStorageTreeId";
20
23
 
21
24
  /**
22
25
  * Document storage service for the file driver.
26
+ * @internal
23
27
  */
24
28
  export class FluidFetchReader
25
29
  extends ReadDocumentStorageServiceBase
@@ -110,12 +114,21 @@ export class FluidFetchReader
110
114
  }
111
115
  }
112
116
 
117
+ /**
118
+ * @internal
119
+ */
113
120
  export interface ISnapshotWriterStorage extends IDocumentStorageService {
114
121
  onSnapshotHandler(snapshot: IFileSnapshot): void;
115
122
  reset(): void;
116
123
  }
117
124
 
125
+ /**
126
+ * @internal
127
+ */
118
128
  export type ReaderConstructor = new (...args: any[]) => IDocumentStorageService;
129
+ /**
130
+ * @internal
131
+ */
119
132
  export const FileSnapshotWriterClassFactory = <TBase extends ReaderConstructor>(Base: TBase) =>
120
133
  class extends Base implements ISnapshotWriterStorage {
121
134
  // Note: if variable name has same name as in base class, it overrides it!
@@ -228,4 +241,7 @@ function removeNullTreeIds(tree: api.ITree) {
228
241
  );
229
242
  delete tree.id;
230
243
  }
244
+ /**
245
+ * @internal
246
+ */
231
247
  export const FluidFetchReaderFileSnapshotWriter = FileSnapshotWriterClassFactory(FluidFetchReader);