Skip to content

Commit

Permalink
feat: add innerClientName for inner-rsdoctor
Browse files Browse the repository at this point in the history
  • Loading branch information
easy1090 committed Mar 20, 2024
1 parent 44c6a12 commit 1ebd293
Show file tree
Hide file tree
Showing 10 changed files with 48 additions and 13 deletions.
2 changes: 1 addition & 1 deletion packages/client/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@
"@types/webpack": "5.28.0",
"antd": "5.8.3",
"normalize.css": "8.0.1",
"react": "^18",
"react": "18.2.0",
"react-dom": "18.2.0",
"react-error-boundary": "^4.0.11",
"react-router-dom": "6.4.3",
Expand Down
2 changes: 2 additions & 0 deletions packages/core/src/inner-plugins/utils/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ export function normalizeUserConfig<Rules extends Linter.ExtendRuleData[]>(
sdkInstance,
reportCodeType = { noModuleSource: false, noAssetsAndModuleSource: false },
disableTOSUpload = false,
innerClientName = '',
} = config;

assert(linter && typeof linter === 'object');
Expand Down Expand Up @@ -89,6 +90,7 @@ export function normalizeUserConfig<Rules extends Linter.ExtendRuleData[]>(
? SDK.ToDataType.Lite
: SDK.ToDataType.Normal,
disableTOSUpload,
innerClientName,
};

return res;
Expand Down
11 changes: 8 additions & 3 deletions packages/core/src/types/plugin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,7 @@ import { ChunkGraph, ModuleGraph } from '@rsdoctor/graph';
import { rules } from '@/rules/rules';
import { RuleData } from '@rsdoctor/types/dist/linter';


type InternalRules = typeof rules[number] & RuleData[];
type InternalRules = (typeof rules)[number] & RuleData[];

export interface RsdoctorWebpackPluginOptions<
Rules extends LinterType.ExtendRuleData[],
Expand Down Expand Up @@ -49,10 +48,16 @@ export interface RsdoctorWebpackPluginOptions<
| { noModuleSource?: boolean; noAssetsAndModuleSource?: boolean }
| undefined;
/**
* control the Rsdoctor upload data to TOS.
* control the Rsdoctor upload data to TOS, used by inner-rsdoctor.
* @default false
*/
disableTOSUpload?: boolean;

/**
* The name of inner rsdoctor's client package, used by inner-rsdoctor.
* @default false
*/
innerClientName?: string;
}

export interface RsdoctorWebpackMultiplePluginOptions<
Expand Down
1 change: 1 addition & 0 deletions packages/rspack-plugin/src/plugin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ export class RsdoctorRspackPlugin<Rules extends Linter.ExtendRuleData[]>
root: process.cwd(),
type: SDK.ToDataType.Normal,
config: { disableTOSUpload: this.options.disableTOSUpload },
innerClientName: this.options.innerClientName,
});
this.modulesGraph = new ModuleGraph();
}
Expand Down
1 change: 1 addition & 0 deletions packages/sdk/src/sdk/sdk/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ export interface RsdoctorBuilderSDK extends RsdoctorSDKOptions {
port?: number;
noServer?: boolean;
config?: SDK.SDKOptionsType;
innerClientName?: string;
}

export interface RsdoctorWebpackSDKOptions extends RsdoctorBuilderSDK {}
Expand Down
8 changes: 5 additions & 3 deletions packages/sdk/src/sdk/sdk/webpack.ts
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ export class RsdoctorWebpackSDK<
super(options);
this.server = options.noServer
? new RsdoctorFakeServer(this, undefined)
: new RsdoctorServer(this, options.port);
: new RsdoctorServer(this, options.port, options.innerClientName);
this.type = options.type || SDK.ToDataType.Normal;
this.extraConfig = options.config;
}
Expand Down Expand Up @@ -224,13 +224,15 @@ export class RsdoctorWebpackSDK<
this._loaderStart.push(data);
} else if (_builtinLoader.endAt) {
const matchLoaderStart = this._loaderStart.find(
(e) => (e.resource.path === data.resource.path && e.loaders[0].loader === _builtinLoader.loader),
(e) =>
e.resource.path === data.resource.path &&
e.loaders[0].loader === _builtinLoader.loader,
);

if (matchLoaderStart) {
matchLoaderStart.loaders[0].result = _builtinLoader.result;
matchLoaderStart.loaders[0].endAt = _builtinLoader.endAt;
this.reportLoader([matchLoaderStart])
this.reportLoader([matchLoaderStart]);
}
}
}
Expand Down
13 changes: 10 additions & 3 deletions packages/sdk/src/sdk/server/apis/renderer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,17 +4,24 @@ import path from 'path';
import { File } from '@rsdoctor/utils/build';
import { BaseAPI } from './base';
import { Router } from '../router';
import { Algorithm } from '@rsdoctor/utils/common';

export class RendererAPI extends BaseAPI {
private isClientServed = false;

/** sdk manifest api */
@Router.get(SDK.ServerAPI.API.EntryHtml)
public async entryHtml(): Promise<SDK.ServerAPI.InferResponseType<SDK.ServerAPI.API.EntryHtml>> {
const { server, res } = this.ctx;
public async entryHtml(): Promise<
SDK.ServerAPI.InferResponseType<SDK.ServerAPI.API.EntryHtml>
> {
const { server, res, req } = this.ctx;
const name = req.url && req.url.match(/innerClientName=([\w-|\=]+)/)?.[1];

// dynamic serve client:
// require.resolve will failed due to the dist will remove when execute "npm run build" of client.
const clientHtmlPath = require.resolve('@rsdoctor/client');
const clientHtmlPath = name
? require.resolve(`${Algorithm.decompressText(name)}/react-client`)
: require.resolve('@rsdoctor/client');
if (!this.isClientServed) {
this.isClientServed = true;
const clientDistPath = path.resolve(clientHtmlPath, '..');
Expand Down
17 changes: 15 additions & 2 deletions packages/sdk/src/sdk/server/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,13 +11,16 @@ import { Router } from './router';
import * as APIs from './apis';
import { chalk, logger } from '@rsdoctor/utils/logger';
import { openBrowser } from '@/sdk/utils/openBrowser';
import { Algorithm } from '@rsdoctor/utils/common';
export * from './utils';

export class RsdoctorServer implements SDK.RsdoctorServerInstance {
private _server!: Common.PromiseReturnType<typeof Server.createServer>;

public port: number;

public innerClientName: string;

private _socket?: Socket;

private disposed = true;
Expand All @@ -27,11 +30,13 @@ export class RsdoctorServer implements SDK.RsdoctorServerInstance {
constructor(
protected sdk: SDK.RsdoctorBuilderSDKInstance,
port = Server.defaultPort,
innerClientName = '',
) {
assert(typeof port === 'number');
// maybe the port will be rewrite in bootstrap()
this.port = port;
this._router = new Router({ sdk, server: this, apis: Object.values(APIs) });
this.innerClientName = innerClientName;
}

public get app(): SDK.RsdoctorServerInstance['app'] {
Expand Down Expand Up @@ -161,13 +166,21 @@ export class RsdoctorServer implements SDK.RsdoctorServerInstance {
public getClientUrl(route?: 'homepage'): string;

public getClientUrl(route = 'homepage', ...args: unknown[]) {
const relativeUrl = SDK.ServerAPI.API.EntryHtml;
const relativeUrl = this.innerClientName
? `${
SDK.ServerAPI.API.EntryHtml
}?innerClientName=${Algorithm.compressText(this.innerClientName)}`
: SDK.ServerAPI.API.EntryHtml;

switch (route) {
case Client.RsdoctorClientRoutes.BundleDiff: {
const [baseline, current] = args as string[];
const qs = Bundle.getBundleDiffPageQueryString([baseline, current]);
return `${relativeUrl}${qs}#${Client.RsdoctorClientRoutes.BundleDiff}`;
return this.innerClientName
? `${relativeUrl}${qs.replace('?', '&')}#${
Client.RsdoctorClientRoutes.BundleDiff
}`
: `${relativeUrl}${qs}#${Client.RsdoctorClientRoutes.BundleDiff}`;
}
default:
return relativeUrl;
Expand Down
1 change: 1 addition & 0 deletions packages/webpack-plugin/src/plugin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ export class RsdoctorWebpackPlugin<Rules extends Linter.ExtendRuleData[]>
root: process.cwd(),
type: this.options.reportCodeType,
config: { disableTOSUpload: this.options.disableTOSUpload },
innerClientName: this.options.innerClientName,
});
this.outsideInstance = Boolean(this.options.sdkInstance);
this.modulesGraph = new ModuleGraph();
Expand Down
5 changes: 4 additions & 1 deletion pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit 1ebd293

Please sign in to comment.