Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add missing vscode api in env namespace #11446

Merged
merged 3 commits into from
Jul 28, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions packages/plugin-ext/src/common/plugin-api-rpc.ts
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,7 @@ export interface EnvInit {
shell: string;
uiKind: UIKind,
appName: string;
appHost: string;
}

export interface PluginAPI {
Expand Down
6 changes: 4 additions & 2 deletions packages/plugin-ext/src/hosted/browser/hosted-plugin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -488,6 +488,7 @@ export class HostedPluginSupport {
return undefined;
}

const isElectron = environment.electron.is();
await manager.$init({
preferences: getPreferences(this.preferenceProviderProvider, this.workspaceService.tryGetRoots()),
globalState,
Expand All @@ -496,8 +497,9 @@ export class HostedPluginSupport {
queryParams: getQueryParameters(),
language: nls.locale || 'en',
shell: defaultShell,
uiKind: environment.electron.is() ? UIKind.Desktop : UIKind.Web,
appName: FrontendApplicationConfigProvider.get().applicationName
uiKind: isElectron ? UIKind.Desktop : UIKind.Web,
appName: FrontendApplicationConfigProvider.get().applicationName,
appHost: isElectron ? 'desktop' : 'web' // TODO: 'web' could be the embedder's name, e.g. 'github.dev'
},
extApi,
webview: {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,4 +34,8 @@ export class WorkerEnvExtImpl extends EnvExtImpl {
throw new Error('There is no app root in worker context');
}

get isNewAppInstall(): boolean {
return false;
}

}
30 changes: 30 additions & 0 deletions packages/plugin-ext/src/plugin/env.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
// *****************************************************************************

import { Emitter, Event } from '@theia/core/lib/common/event';
import * as theia from '@theia/plugin';
import { RPCProtocol } from '../common/rpc-protocol';
import { EnvMain, PLUGIN_RPC_CONTEXT } from '../common/plugin-api-rpc';
Expand All @@ -29,11 +30,18 @@ export abstract class EnvExtImpl {
private ui: theia.UIKind;
private envMachineId: string;
private envSessionId: string;
private host: string;
private _isTelemetryEnabled: boolean;
private _remoteName: string | undefined;
private onDidChangeTelemetryEnabledEmitter = new Emitter<boolean>();

constructor(rpc: RPCProtocol) {
this.proxy = rpc.getProxy(PLUGIN_RPC_CONTEXT.ENV_MAIN);
this.envSessionId = v4();
this.envMachineId = v4();
// we don't support telemetry at the moment
this._isTelemetryEnabled = false;
this._remoteName = undefined;
}

getEnvVariable(envVarName: string): Promise<string | undefined> {
Expand Down Expand Up @@ -73,6 +81,10 @@ export abstract class EnvExtImpl {
this.ui = uiKind;
}

setAppHost(appHost: string): void {
this.host = appHost;
}

getClientOperatingSystem(): Promise<theia.OperatingSystem> {
return this.proxy.$getClientOperatingSystem();
}
Expand All @@ -83,6 +95,24 @@ export abstract class EnvExtImpl {

abstract get appRoot(): string;

abstract get isNewAppInstall(): boolean;

get appHost(): string {
return this.host;
}

get isTelemetryEnabled(): boolean {
return this._isTelemetryEnabled;
}

get onDidChangeTelemetryEnabled(): Event<boolean> {
return this.onDidChangeTelemetryEnabledEmitter.event;
}

get remoteName(): string | undefined {
return this._remoteName;
}

get language(): string {
return this.lang;
}
Expand Down
14 changes: 13 additions & 1 deletion packages/plugin-ext/src/plugin/node/env-node-ext.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import { EnvExtImpl } from '../env';
import { RPCProtocol } from '../../common/rpc-protocol';
import { createHash } from 'crypto';
import { v4 } from 'uuid';
import fs = require('fs');

/**
* Provides machineId using mac address. It's only possible on node side
Expand All @@ -27,6 +28,7 @@ import { v4 } from 'uuid';
export class EnvNodeExtImpl extends EnvExtImpl {

private macMachineId: string;
private _isNewAppInstall: boolean;

constructor(rpc: RPCProtocol) {
super(rpc);
Expand All @@ -37,7 +39,7 @@ export class EnvNodeExtImpl extends EnvExtImpl {
this.macMachineId = createHash('sha256').update(macAddress, 'utf8').digest('hex');
}
});

this._isNewAppInstall = this.computeIsNewAppInstall();
}

/**
Expand All @@ -54,4 +56,14 @@ export class EnvNodeExtImpl extends EnvExtImpl {
return __dirname;
}

get isNewAppInstall(): boolean {
return this._isNewAppInstall;
}

private computeIsNewAppInstall(): boolean {
const creation = fs.statSync(__filename).birthtimeMs;
const current = Date.now();
const dayMs = 24 * 3600 * 1000;
return (current - creation) < dayMs;
}
}
7 changes: 7 additions & 0 deletions packages/plugin-ext/src/plugin/plugin-context.ts
Original file line number Diff line number Diff line change
Expand Up @@ -639,7 +639,14 @@ export function createAPIFactory(
const env: typeof theia.env = Object.freeze({
get appName(): string { return envExt.appName; },
get appRoot(): string { return envExt.appRoot; },
get appHost(): string { return envExt.appHost; },
get language(): string { return envExt.language; },
get isNewAppInstall(): boolean { return envExt.isNewAppInstall; },
get isTelemetryEnabled(): boolean { return envExt.isTelemetryEnabled; },
get onDidChangeTelemetryEnabled(): theia.Event<boolean> {
return envExt.onDidChangeTelemetryEnabled;
},
get remoteName(): string | undefined { return envExt.remoteName; },
get machineId(): string { return envExt.machineId; },
get sessionId(): string { return envExt.sessionId; },
get uriScheme(): string { return envExt.uriScheme; },
Expand Down
1 change: 1 addition & 0 deletions packages/plugin-ext/src/plugin/plugin-manager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -201,6 +201,7 @@ export class PluginManagerExtImpl implements PluginManagerExt, PluginManager {
this.envExt.setShell(params.env.shell);
this.envExt.setUIKind(params.env.uiKind);
this.envExt.setApplicationName(params.env.appName);
this.envExt.setAppHost(params.env.appHost);

this.preferencesManager.init(params.preferences);

Expand Down
37 changes: 37 additions & 0 deletions packages/plugin/src/theia.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6473,6 +6473,14 @@ export module '@theia/plugin' {
*/
export const appRoot: string;

/**
* The hosted location of the application
* On desktop this is 'desktop'
* In the web this is the specified embedder i.e. 'github.dev', 'codespaces', or 'web' if the embedder
* does not provide that information
*/
export const appHost: string;

/**
* The custom uri scheme the editor registers to in the operating system.
*/
Expand All @@ -6483,6 +6491,35 @@ export module '@theia/plugin' {
*/
export const language: string;

/**
* Indicates that this is a fresh install of the application.
* `true` if within the first day of installation otherwise `false`.
*/
export const isNewAppInstall: boolean;

/**
* Indicates whether the users has telemetry enabled.
* Can be observed to determine if the extension should send telemetry.
*/
export const isTelemetryEnabled: boolean;

/**
* An {@link Event} which fires when the user enabled or disables telemetry.
* `true` if the user has enabled telemetry or `false` if the user has disabled telemetry.
*/
export const onDidChangeTelemetryEnabled: Event<boolean>;

/**
* The name of a remote. Defined by extensions, popular samples are `wsl` for the Windows
* Subsystem for Linux or `ssh-remote` for remotes using a secure shell.
*
* *Note* that the value is `undefined` when there is no remote extension host but that the
* value is defined in all extension hosts (local and remote) in case a remote extension host
* exists. Use {@link Extension.extensionKind} to know if
* a specific extension runs remote or not.
*/
export const remoteName: string | undefined;

/**
* The detected default shell for the extension host.
*/
Expand Down