Skip to content

Commit

Permalink
Merge branch 'dev' into liuqi/mintlsVersionAndHttp20
Browse files Browse the repository at this point in the history
  • Loading branch information
liuqidake authored Nov 25, 2024
2 parents 21bb49e + c174141 commit 11c166a
Show file tree
Hide file tree
Showing 5 changed files with 49 additions and 21 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,7 @@ export const DestinationPlanDetails: React.FC<DestinationPlanDetailsProps> = ({
'P3V3',
'P2V3',
'P1V3',
'P0V3',
'WS1',
'WS2',
'WS3',
Expand Down
41 changes: 30 additions & 11 deletions client-react/src/pages/container-app/console/ConsoleDataLoader.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,19 @@ import { KeyBoard } from '../../../utils/CommonConstants';
import { containerAppStyles } from '../ContainerApp.styles';
import { getTerminalDimensions } from '../xtermHelper';
import { consoleStyles, dialogFooterStyles, dialogTitleStyles } from './ConsoleDataLoader.styles';
import { Text } from '@fluentui/react/lib/Text';

export interface ConsoleDataLoaderProps {
resourceId: string;
execEndpoint?: string;
execEndpoint?: string; // To be deprecated
mode?: 'exec' | 'debug';
endpoint?: string;
}

const ConsoleDataLoader: React.FC<ConsoleDataLoaderProps> = props => {
const portalCommunicator = useContext(PortalContext);
const endpoint = !!props.mode ? props.endpoint : props.execEndpoint;
const isDebug = props.mode === 'debug';

const { width, height } = useWindowSize();
const { t } = useTranslation();
Expand Down Expand Up @@ -67,10 +72,10 @@ const ConsoleDataLoader: React.FC<ConsoleDataLoaderProps> = props => {
resizeHandler(width, height);
}

toggleHideDialog(!props.execEndpoint);
toggleHideDialog(!endpoint);
setSelectedKey(options[0]);
setCustomTextField('');
}, [props.execEndpoint]);
}, [endpoint]);

useEffect(() => {
return () => debouncedResizeHandler.cancel();
Expand All @@ -80,8 +85,13 @@ const ConsoleDataLoader: React.FC<ConsoleDataLoaderProps> = props => {
debouncedResizeHandler(width, height);
}, [width, height]);

const getServerEndpoint = (execEndpoint: string, token: string, startUpCommand: string) => {
return `${execEndpoint}?token=${token}&command=${startUpCommand}`;
const getWsUrl = (endpoint: string, token: string, startUpCommand?: string) => {
const url = new URL(endpoint);
url.searchParams.append('token', token);
if (startUpCommand) {
url.searchParams.append('command', startUpCommand);
}
return url.toString();
};

const processMessageBlob = async (data: Blob) => {
Expand Down Expand Up @@ -157,7 +167,7 @@ const ConsoleDataLoader: React.FC<ConsoleDataLoaderProps> = props => {

const dialogContentProps: IDialogContentProps = {
type: DialogType.normal,
title: t('containerApp_console_chooseStartUpCommand'),
title: isDebug ? t('containerApp_console_connectToDebugConsole') : t('containerApp_console_chooseStartUpCommand'),
styles: dialogTitleStyles(),
showCloseButton: false,
};
Expand All @@ -173,12 +183,17 @@ const ConsoleDataLoader: React.FC<ConsoleDataLoaderProps> = props => {
}

toggleHideDialog();
if (isDebug) {
// Not using i18n because this is a console message
updateConsoleText('Connecting to debug console...\r\n');
}

const execEndpointBefore = props.execEndpoint;
const endpointBefore = endpoint;
ContainerAppService.getAuthToken(props.resourceId).then(authTokenResponse => {
if (execEndpointBefore === props.execEndpoint) {
const serverEndpoint = getServerEndpoint(props.execEndpoint || '', authTokenResponse.data.properties.token, command);
ws.current = new WebSocket(serverEndpoint);
if (endpointBefore === endpoint) {
const token = authTokenResponse.data.properties.token;
const wsUrl = isDebug ? getWsUrl(endpoint || '', token) : getWsUrl(endpoint || '', token, command);
ws.current = new WebSocket(wsUrl);

ws.current.onmessage = async (event: MessageEvent) => {
if (event.data instanceof Blob) {
Expand Down Expand Up @@ -254,7 +269,11 @@ const ConsoleDataLoader: React.FC<ConsoleDataLoaderProps> = props => {
<div className={containerAppStyles.divContainer}>
<XTerm ref={terminalRef} onData={onData} onKey={onKey} />
<Dialog hidden={hideDialog} dialogContentProps={dialogContentProps} modalProps={modalProps} forceFocusInsideTrap={false}>
<ChoiceGroup selectedKey={selectedKey.key} onChange={(_, option) => setSelectedKey(option!)} options={options} />
{isDebug ? (
<Text>{t('containerApp_console_debugConsoleDescription')}</Text>
) : (
<ChoiceGroup selectedKey={selectedKey.key} onChange={(_, option) => setSelectedKey(option!)} options={options} />
)}
<DialogFooter styles={dialogFooterStyles()}>
<PrimaryButton
onClick={onConnectClick}
Expand Down
2 changes: 2 additions & 0 deletions client/src/app/shared/models/portal-resources.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2539,6 +2539,8 @@ export class PortalResources {
public static connectedAndFilteredMessage = 'connectedAndFilteredMessage';
public static containerApp_console_chooseStartUpCommand = 'containerApp_console_chooseStartUpCommand';
public static containerApp_console_failedToConnect = 'containerApp_console_failedToConnect';
public static containerApp_console_connectToDebugConsole = 'containerApp_console_connectToDebugConsole';
public static containerApp_console_debugConsoleDescription = 'containerApp_console_debugConsoleDescription';
public static containerApp_console_connect = 'containerApp_console_connect';
public static containerApp_console_custom = 'containerApp_console_custom';
public static new_parenthesized = 'new_parenthesized';
Expand Down
7 changes: 7 additions & 0 deletions server/Resources/Resources.resx
Original file line number Diff line number Diff line change
Expand Up @@ -7777,6 +7777,13 @@ Set to "External URL" to use an API definition that is hosted elsewhere.</value>
<data name="containerApp_console_failedToConnect" xml:space="preserve">
<value>Failed to connect to replica.</value>
</data>
<data name="containerApp_console_connectToDebugConsole" xml:space="preserve">
<value>Connect to debug console</value>
</data>
<data name="containerApp_console_debugConsoleDescription" xml:space="preserve">
<value>In this console, enter 'exit' to terminate the debug session.</value>
<comment>'exit' is a command that should not be translated to other languages</comment>
</data>
<data name="containerApp_console_connect" xml:space="preserve">
<value>Connect</value>
</data>
Expand Down
19 changes: 9 additions & 10 deletions server/src/workflows/2022-10-01/WorkflowService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,19 +35,9 @@ export class WorkflowService20221001 {
const permssions = `permissions:
id-token: write #This is required for requesting the JWT
contents: read #This is required for actions/checkout\n`;
const environment = `environment:
name: '__slotname__'
url: \${{ steps.deploy-to-webapp.outputs.webapp-url }}`;

workflowFile = workflowFile.replace(new RegExp(publishProfilePlaceholder, 'gi'), '');
workflowFile = workflowFile.replace(new RegExp(loginToAzureStepPlaceholder, 'gi'), loginToAzureStep);
workflowFile = workflowFile.replace(new RegExp(permissionsPlaceholder, 'gi'), permssions);

if (variables?.isRemoveEnvEnabled) {
workflowFile = workflowFile.replace(new RegExp(environmentPlaceholder, 'gi'), '');
} else {
workflowFile = workflowFile.replace(new RegExp(environmentPlaceholder, 'gi'), environment);
}
} else {
if (variables?.isFlexConsumption) {
const flexConsumptionPublishProfile = `publish-profile: \${{ secrets.__publishingprofilesecretname__ }}
Expand All @@ -64,6 +54,15 @@ export class WorkflowService20221001 {
workflowFile = workflowFile.replace(new RegExp(permissionsPlaceholder, 'gi'), '');
}

const environment = `environment:
name: '__slotname__'
url: \${{ steps.deploy-to-webapp.outputs.webapp-url }}`;
if (variables?.isRemoveEnvEnabled) {
workflowFile = workflowFile.replace(new RegExp(environmentPlaceholder, 'gi'), '');
} else {
workflowFile = workflowFile.replace(new RegExp(environmentPlaceholder, 'gi'), environment);
}

Object.keys(variables).forEach(variableKey => {
const replaceKey = `__${variableKey}__`;
workflowFile = workflowFile.replace(new RegExp(replaceKey, 'gi'), variables[variableKey]);
Expand Down

0 comments on commit 11c166a

Please sign in to comment.