From 81c6488b8020894e6a2a46372fcb2c06ecd8fb32 Mon Sep 17 00:00:00 2001 From: Nicolas Chaulet Date: Thu, 29 Apr 2021 16:45:46 -0400 Subject: [PATCH] [Fleet] Add sudo to fleet managed instructions (#98803) --- .../enrollment_instructions/manual/index.tsx | 100 ++++++++++-------- .../fleet_server_requirement_page.tsx | 11 +- .../fleet/sections/agents/hooks/index.tsx | 8 ++ .../sections/agents/hooks/use_platform.tsx | 24 +++++ .../translations/translations/ja-JP.json | 2 - .../translations/translations/zh-CN.json | 2 - 6 files changed, 90 insertions(+), 57 deletions(-) create mode 100644 x-pack/plugins/fleet/public/applications/fleet/sections/agents/hooks/index.tsx create mode 100644 x-pack/plugins/fleet/public/applications/fleet/sections/agents/hooks/use_platform.tsx diff --git a/x-pack/plugins/fleet/public/applications/fleet/components/enrollment_instructions/manual/index.tsx b/x-pack/plugins/fleet/public/applications/fleet/components/enrollment_instructions/manual/index.tsx index 7a7e42b9d634f..c9f011c59504b 100644 --- a/x-pack/plugins/fleet/public/applications/fleet/components/enrollment_instructions/manual/index.tsx +++ b/x-pack/plugins/fleet/public/applications/fleet/components/enrollment_instructions/manual/index.tsx @@ -7,10 +7,13 @@ import React from 'react'; import styled from 'styled-components'; -import { EuiText, EuiSpacer, EuiLink, EuiTitle, EuiCodeBlock } from '@elastic/eui'; +import { EuiText, EuiSpacer, EuiLink, EuiCodeBlock, EuiSelect } from '@elastic/eui'; import { FormattedMessage } from '@kbn/i18n/react'; +import { i18n } from '@kbn/i18n'; import type { EnrollmentAPIKey } from '../../../types'; +import { PLATFORM_OPTIONS, usePlatform } from '../../../sections/agents/hooks/use_platform'; +import type { PLATFORM_TYPE } from '../../../sections/agents/hooks/use_platform'; interface Props { fleetServerHosts: string[]; @@ -30,9 +33,11 @@ export const ManualInstructions: React.FunctionComponent = ({ apiKey, fleetServerHosts, }) => { + const { platform, setPlatform } = usePlatform(); + const enrollArgs = getfleetServerHostsEnrollArgs(apiKey, fleetServerHosts); - const linuxMacCommand = `./elastic-agent install -f ${enrollArgs}`; + const linuxMacCommand = `sudo ./elastic-agent install -f ${enrollArgs}`; const windowsCommand = `.\\elastic-agent.exe install -f ${enrollArgs}`; @@ -45,53 +50,58 @@ export const ManualInstructions: React.FunctionComponent = ({ /> - -

- -

-
+ + + + } + options={PLATFORM_OPTIONS} + value={platform} + onChange={(e) => setPlatform(e.target.value as PLATFORM_TYPE)} + aria-label={i18n.translate('xpack.fleet.enrollmentInstructions.platformSelectAriaLabel', { + defaultMessage: 'Platform', + })} + /> - - {linuxMacCommand} - - - -

+ {platform === 'linux-mac' && ( + + {linuxMacCommand} + + )} + {platform === 'windows' && ( + + {windowsCommand} + + )} + + {platform === 'rpm-deb' && ( + + + + ), + }} /> -

-
- - - {windowsCommand} - + + )} + - - - - - ), - }} - /> - - = [ - { text: 'Linux / macOS', value: 'linux-mac' }, - { text: 'Windows', value: 'windows' }, - { text: 'RPM / DEB', value: 'rpm-deb' }, -]; - export const ServiceTokenStep = ({ serviceToken, getServiceToken, @@ -237,7 +232,7 @@ export const useFleetServerInstructions = (policyId?: string) => { const { notifications } = useStartServices(); const [serviceToken, setServiceToken] = useState(); const [isLoadingServiceToken, setIsLoadingServiceToken] = useState(false); - const [platform, setPlatform] = useState('linux-mac'); + const { platform, setPlatform } = usePlatform(); const output = outputsRequest.data?.items?.[0]; const esHost = output?.hosts?.[0]; diff --git a/x-pack/plugins/fleet/public/applications/fleet/sections/agents/hooks/index.tsx b/x-pack/plugins/fleet/public/applications/fleet/sections/agents/hooks/index.tsx new file mode 100644 index 0000000000000..d9b3bcd80752d --- /dev/null +++ b/x-pack/plugins/fleet/public/applications/fleet/sections/agents/hooks/index.tsx @@ -0,0 +1,8 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export * from './use_platform'; diff --git a/x-pack/plugins/fleet/public/applications/fleet/sections/agents/hooks/use_platform.tsx b/x-pack/plugins/fleet/public/applications/fleet/sections/agents/hooks/use_platform.tsx new file mode 100644 index 0000000000000..c9ab7106696e1 --- /dev/null +++ b/x-pack/plugins/fleet/public/applications/fleet/sections/agents/hooks/use_platform.tsx @@ -0,0 +1,24 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { useState } from 'react'; + +export type PLATFORM_TYPE = 'linux-mac' | 'windows' | 'rpm-deb'; +export const PLATFORM_OPTIONS: Array<{ text: string; value: PLATFORM_TYPE }> = [ + { text: 'Linux / macOS', value: 'linux-mac' }, + { text: 'Windows', value: 'windows' }, + { text: 'RPM / DEB', value: 'rpm-deb' }, +]; + +export function usePlatform() { + const [platform, setPlatform] = useState('linux-mac'); + + return { + platform, + setPlatform, + }; +} diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index e883675247e27..f3f7793aaaa09 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -8432,10 +8432,8 @@ "xpack.fleet.enrollemntAPIKeyList.emptyMessage": "登録トークンが見つかりません。", "xpack.fleet.enrollemntAPIKeyList.loadingTokensMessage": "登録トークンを読み込んでいます...", "xpack.fleet.enrollmentInstructions.descriptionText": "エージェントのディレクトリから、該当するコマンドを実行し、Elasticエージェントをインストール、登録、起動します。これらのコマンドを再利用すると、複数のホストでエージェントを設定できます。管理者権限が必要です。", - "xpack.fleet.enrollmentInstructions.linuxMacOSTitle": "Linux、MacOS", "xpack.fleet.enrollmentInstructions.moreInstructionsLink": "Elastic エージェントドキュメント", "xpack.fleet.enrollmentInstructions.moreInstructionsText": "RPM/DEB デプロイの手順については、{link}を参照してください。", - "xpack.fleet.enrollmentInstructions.windowsTitle": "Windows", "xpack.fleet.enrollmentStepAgentPolicy.enrollmentTokenSelectLabel": "登録トークン", "xpack.fleet.enrollmentStepAgentPolicy.policySelectAriaLabel": "エージェントポリシー", "xpack.fleet.enrollmentStepAgentPolicy.policySelectLabel": "エージェントポリシー", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index b246a36a3df06..eb771859bbf0d 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -8516,10 +8516,8 @@ "xpack.fleet.enrollemntAPIKeyList.emptyMessage": "未找到任何注册令牌。", "xpack.fleet.enrollemntAPIKeyList.loadingTokensMessage": "正在加载注册令牌......", "xpack.fleet.enrollmentInstructions.descriptionText": "从代理目录运行相应命令,以安装、注册并启动 Elastic 代理。您可以重复使用这些命令在多个主机上设置代理。需要管理员权限。", - "xpack.fleet.enrollmentInstructions.linuxMacOSTitle": "Linux、macOS", "xpack.fleet.enrollmentInstructions.moreInstructionsLink": "Elastic 代理文档", "xpack.fleet.enrollmentInstructions.moreInstructionsText": "有关 RPM/DEB 部署说明,请参见 {link}。", - "xpack.fleet.enrollmentInstructions.windowsTitle": "Windows", "xpack.fleet.enrollmentStepAgentPolicy.enrollmentTokenSelectLabel": "注册令牌", "xpack.fleet.enrollmentStepAgentPolicy.policySelectAriaLabel": "代理策略", "xpack.fleet.enrollmentStepAgentPolicy.policySelectLabel": "代理策略",