microsoft/vscode-react-native

Public

mirrored fromhttps://github.com/microsoft/vscode-react-nativeAvailable

CodeCommitsIssuesPull requestsActionsInsightsSecurity
1.7.0

Branches

Tags

  • No tags available.
0Branches0Tags
Go to file
Add file
Code

Clone

HTTPS

Download ZIP

src/extension/exponent/xdlInterface.ts

150lines · modecode

1// Copyright (c) Microsoft Corporation. All rights reserved.
2// Licensed under the MIT license. See LICENSE file in the project root for details.
3
4import { join as pathJoin } from "path";
5import * as XDLPackage from "xdl";
6import * as MetroConfigPackage from "metro-config";
7import { PackageLoader, PackageConfig } from "../../common/packageLoader";
8import { removeModuleFromRequireCacheByName } from "../../common/utils";
9import { SettingsHelper } from "../settingsHelper";
10
11const XDL_PACKAGE = "xdl";
12const METRO_CONFIG_PACKAGE = "@expo/metro-config";
13
14const xdlPackageConfig = new PackageConfig(
15 XDL_PACKAGE,
16 SettingsHelper.getExpoDependencyVersion(XDL_PACKAGE),
17);
18const metroConfigPackageConfig = new PackageConfig(
19 METRO_CONFIG_PACKAGE,
20 SettingsHelper.getExpoDependencyVersion(METRO_CONFIG_PACKAGE),
21);
22
23const ngrokPackageConfig = new PackageConfig(
24 xdlPackageConfig.getPackageName(),
25 xdlPackageConfig.getVersion(),
26 "build/start/resolveNgrok",
27);
28
29// There is the problem with '--no-save' flag for 'npm install' command for npm v6.
30// Installing npm dependencies with the `--no-save` flag will remove
31// other dependencies that were installed previously in the same manner (https://github.com/npm/cli/issues/1460).
32// So we should workaround it passing all packages for install to only one npm install command
33const EXPO_DEPS: PackageConfig[] = [xdlPackageConfig, metroConfigPackageConfig];
34
35export const getXDLPackage: () => Promise<
36 typeof XDLPackage
37> = PackageLoader.getInstance().generateGetPackageFunction<typeof XDLPackage>(
38 xdlPackageConfig,
39 ...EXPO_DEPS,
40);
41export const getMetroConfigPackage: () => Promise<
42 typeof MetroConfigPackage
43> = PackageLoader.getInstance().generateGetPackageFunction<typeof MetroConfigPackage>(
44 metroConfigPackageConfig,
45 ...EXPO_DEPS,
46);
47export const getNgrokResolver: () => Promise<XDLPackage.ResolveNgrok> = PackageLoader.getInstance().generateGetPackageFunction<XDLPackage.ResolveNgrok>(
48 ngrokPackageConfig,
49 ...EXPO_DEPS,
50);
51
52export type IUser = XDLPackage.IUser;
53
54export async function configReactNativeVersionWarnings(): Promise<void> {
55 (await getXDLPackage()).Config.validation.reactNativeVersionWarnings = false;
56}
57
58export async function attachLoggerStream(
59 rootPath: string,
60 options?: XDLPackage.IBunyanStream | any,
61): Promise<void> {
62 (await getXDLPackage()).ProjectUtils.attachLoggerStream(rootPath, options);
63}
64
65export async function currentUser(): Promise<XDLPackage.IUser> {
66 const xdl = await getXDLPackage();
67 return await (xdl.User
68 ? xdl.User.getCurrentUserAsync()
69 : xdl.UserManager.getCurrentUserAsync());
70}
71
72export async function login(username: string, password: string): Promise<XDLPackage.IUser> {
73 const xdl = await getXDLPackage();
74 return await (xdl.User
75 ? xdl.User.loginAsync("user-pass", { username: username, password: password })
76 : xdl.UserManager.loginAsync("user-pass", {
77 username: username,
78 password: password,
79 }));
80}
81
82export async function getExpoSdkVersions(): Promise<XDLPackage.SDKVersions> {
83 return (await getXDLPackage()).Versions.sdkVersionsAsync();
84}
85
86export async function getReleasedExpoSdkVersions(): Promise<XDLPackage.SDKVersions> {
87 return (await getXDLPackage()).Versions.releasedSdkVersionsAsync();
88}
89
90export async function publish(
91 projectRoot: string,
92 options?: XDLPackage.IPublishOptions,
93): Promise<XDLPackage.IPublishResponse> {
94 return (await getXDLPackage()).Project.publishAsync(projectRoot, options);
95}
96
97export async function setOptions(projectRoot: string, options: XDLPackage.IOptions): Promise<void> {
98 await (await getXDLPackage()).ProjectSettings.setPackagerInfoAsync(projectRoot, options);
99}
100
101export async function startExponentServer(projectRoot: string): Promise<void> {
102 await (await getXDLPackage()).Project.startExpoServerAsync(projectRoot);
103}
104
105export async function startTunnels(projectRoot: string): Promise<void> {
106 await (await getXDLPackage()).Project.startTunnelsAsync(projectRoot);
107}
108
109export async function getUrl(
110 projectRoot: string,
111 options?: XDLPackage.IUrlOptions,
112): Promise<string> {
113 return (await getXDLPackage()).UrlUtils.constructManifestUrlAsync(projectRoot, options);
114}
115
116export async function stopAll(projectRoot: string): Promise<void> {
117 await (await getXDLPackage()).Project.stopAsync(projectRoot);
118}
119
120export async function startAdbReverse(projectRoot: string): Promise<boolean> {
121 return (await getXDLPackage()).Android.startAdbReverseAsync(projectRoot);
122}
123
124export async function stopAdbReverse(projectRoot: string): Promise<void> {
125 await (await getXDLPackage()).Android.stopAdbReverseAsync(projectRoot);
126}
127
128export async function getMetroConfig(
129 projectRoot: string,
130): Promise<MetroConfigPackage.IMetroConfig> {
131 return (await getMetroConfigPackage()).loadAsync(projectRoot);
132}
133
134export async function isNgrokInstalled(projectRoot: string): Promise<boolean> {
135 const ngrokResolver = await getNgrokResolver();
136 try {
137 const ngrok = await ngrokResolver.resolveNgrokAsync(projectRoot, {
138 shouldPrompt: false,
139 autoInstall: false,
140 });
141 return !!ngrok;
142 } catch (err) {
143 // If unsupported version of the "@expo/ngrok" package was detected, we need to update the package.
144 // Since the "require" method used to parse the "ngrok⁄package.json" file in the "xdl" package caches
145 // all processed modules, we have to remove this file from cache to be able to require a new version
146 // of that file after the update of the "@expo/ngrok" package
147 removeModuleFromRequireCacheByName(pathJoin("ngrok", "package.json"));
148 throw err;
149 }
150}
151