forked from eclipse-theia/theia
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webview-protocol.ts
48 lines (44 loc) · 2 KB
/
webview-protocol.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
/********************************************************************************
* Copyright (C) 2019 TypeFox and others.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the Eclipse
* Public License v. 2.0 are satisfied: GNU General Public License, version 2
* with the GNU Classpath Exception which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
********************************************************************************/
/**
* Each webview should be deployed on a unique origin (https://developer.mozilla.org/en-US/docs/Web/Security/Same-origin_policy)
* to ensure isolation from browser shared state as cookies, local storage and so on.
*
* Use `THEIA_WEBVIEW_EXTERNAL_ENDPOINT` to customize the hostname pattern of a origin.
* By default is `{{uuid}}.webview.{{hostname}}`. Where `{{uuid}}` is a placeholder for a webview global id.
*/
export namespace WebviewExternalEndpoint {
export const pattern = 'THEIA_WEBVIEW_EXTERNAL_ENDPOINT';
export const defaultPattern = '{{uuid}}.webview.{{hostname}}';
}
export interface LoadWebviewResourceParams {
uri: string
eTag?: string
}
export interface LoadWebviewResourceResult {
buffer: number[]
eTag: string
}
export const WebviewResourceLoader = Symbol('WebviewResourceLoader');
export interface WebviewResourceLoader {
/**
* Loads initial webview resource data.
* Returns `undefined` if a resource has not beed modified.
* Throws if a resource cannot be loaded.
*/
load(params: LoadWebviewResourceParams): Promise<LoadWebviewResourceResult | undefined>
}
export const WebviewResourceLoaderPath = '/services/webview-resource-loader';