Browse Source

fixed ui components and commands, flash mcu

master
Valentin D. Pinkman 7 years ago
parent
commit
d879f9bb39
No known key found for this signature in database GPG Key ID: E7D110669FFB8D3E
  1. 14
      src/commands/getIsGenuine.js
  2. 9
      src/commands/installMcu.js
  3. 11
      src/commands/installOsuFirmware.js
  4. 4
      src/components/ManagerPage/AppsList.js
  5. 12
      src/components/ManagerPage/FirmwareUpdate.js
  6. 25
      src/components/ManagerPage/FlashMcu.js
  7. 2
      src/components/Workflow/EnsureGenuine.js
  8. 9
      src/helpers/apps/listApps.js
  9. 13
      src/helpers/devices/getIsGenuine.js
  10. 26
      src/helpers/devices/getNextMCU.js
  11. 15
      src/helpers/firmware/installMcu.js
  12. 15
      src/helpers/firmware/installOsuFirmware.js
  13. 8
      src/helpers/urls.js
  14. 1
      static/i18n/en/errors.yml

14
src/commands/getIsGenuine.js

@ -6,11 +6,19 @@ import { fromPromise } from 'rxjs/observable/fromPromise'
import getIsGenuine from 'helpers/devices/getIsGenuine' import getIsGenuine from 'helpers/devices/getIsGenuine'
import { withDevice } from 'helpers/deviceAccess' import { withDevice } from 'helpers/deviceAccess'
type Input = * // FIXME ! type Input = {
devicePath: string,
targetId: string | number,
version: string,
}
type Result = string type Result = string
const cmd: Command<Input, Result> = createCommand('getIsGenuine', ({ devicePath, targetId }) => const cmd: Command<Input, Result> = createCommand(
fromPromise(withDevice(devicePath)(transport => getIsGenuine(transport, { targetId }))), 'getIsGenuine',
({ devicePath, targetId, version }) =>
fromPromise(
withDevice(devicePath)(transport => getIsGenuine(transport, { targetId, version })),
),
) )
export default cmd export default cmd

9
src/commands/installMcu.js

@ -9,14 +9,15 @@ import installMcu from 'helpers/firmware/installMcu'
type Input = { type Input = {
devicePath: string, devicePath: string,
targetId: string | number, targetId: string | number,
version: string,
} }
type Result = * type Result = *
const cmd: Command<Input, Result> = createCommand('installMcu', ({ devicePath, targetId }) => const cmd: Command<Input, Result> = createCommand(
fromPromise( 'installMcu',
withDevice(devicePath)(transport => installMcu(transport, { targetId, version: '1.5' })), ({ devicePath, targetId, version }) =>
), fromPromise(withDevice(devicePath)(transport => installMcu(transport, { targetId, version }))),
) )
export default cmd export default cmd

11
src/commands/installOsuFirmware.js

@ -6,17 +6,22 @@ import { fromPromise } from 'rxjs/observable/fromPromise'
import { withDevice } from 'helpers/deviceAccess' import { withDevice } from 'helpers/deviceAccess'
import installOsuFirmware from 'helpers/firmware/installOsuFirmware' import installOsuFirmware from 'helpers/firmware/installOsuFirmware'
import type { LedgerScriptParams } from 'helpers/common'
type Input = { type Input = {
devicePath: string, devicePath: string,
firmware: Object, targetId: string | number,
firmware: LedgerScriptParams,
} }
type Result = * type Result = *
const cmd: Command<Input, Result> = createCommand( const cmd: Command<Input, Result> = createCommand(
'installOsuFirmware', 'installOsuFirmware',
({ devicePath, firmware }) => ({ devicePath, firmware, targetId }) =>
fromPromise(withDevice(devicePath)(transport => installOsuFirmware(transport, firmware))), fromPromise(
withDevice(devicePath)(transport => installOsuFirmware(transport, targetId, firmware)),
),
) )
export default cmd export default cmd

4
src/components/ManagerPage/AppsList.js

@ -175,8 +175,8 @@ class AppsList extends PureComponent<Props, State> {
} }
renderList() { renderList() {
const { appsList } = this.state const { appsList, status } = this.state
return appsList.length > 0 ? ( return status === 'idle' ? (
<Box> <Box>
<AppSearchBar list={appsList}> <AppSearchBar list={appsList}>
{items => ( {items => (

12
src/components/ManagerPage/FirmwareUpdate.js

@ -10,6 +10,8 @@ import logger from 'logger'
import type { Device, T } from 'types/common' import type { Device, T } from 'types/common'
import type { LedgerScriptParams } from 'helpers/common'
import getLatestFirmwareForDevice from 'commands/getLatestFirmwareForDevice' import getLatestFirmwareForDevice from 'commands/getLatestFirmwareForDevice'
import installOsuFirmware from 'commands/installOsuFirmware' import installOsuFirmware from 'commands/installOsuFirmware'
@ -23,11 +25,6 @@ import UpdateFirmwareButton from './UpdateFirmwareButton'
let CACHED_LATEST_FIRMWARE = null let CACHED_LATEST_FIRMWARE = null
type FirmwareInfos = {
name: string,
notes: string,
}
type DeviceInfos = { type DeviceInfos = {
targetId: number | string, targetId: number | string,
version: string, version: string,
@ -40,7 +37,7 @@ type Props = {
} }
type State = { type State = {
latestFirmware: ?FirmwareInfos, latestFirmware: ?LedgerScriptParams,
} }
class FirmwareUpdate extends PureComponent<Props, State> { class FirmwareUpdate extends PureComponent<Props, State> {
@ -84,12 +81,13 @@ class FirmwareUpdate extends PureComponent<Props, State> {
installFirmware = async () => { installFirmware = async () => {
try { try {
const { latestFirmware } = this.state const { latestFirmware } = this.state
const { infos } = this.props
invariant(latestFirmware, 'did not find a new firmware or firmware is not set') invariant(latestFirmware, 'did not find a new firmware or firmware is not set')
const { const {
device: { path: devicePath }, device: { path: devicePath },
} = this.props } = this.props
const { success } = await installOsuFirmware const { success } = await installOsuFirmware
.send({ devicePath, firmware: latestFirmware }) .send({ devicePath, firmware: latestFirmware, targetId: infos.targetId })
.toPromise() .toPromise()
if (success) { if (success) {
this.fetchLatestFirmware() this.fetchLatestFirmware()

25
src/components/ManagerPage/FlashMcu.js

@ -25,23 +25,30 @@ class FlashMcu extends PureComponent<Props, State> {
flashing: false, flashing: false,
} }
componentDidMount() { flashMCU = async () => {
this.flasMCU()
}
flasMCU = async () => {
const { device, deviceInfo } = this.props const { device, deviceInfo } = this.props
const { flashing } = this.state const { flashing } = this.state
if (!flashing) { if (!flashing) {
this.setState(state => ({ ...state, flashing: true })) this.setState({ flashing: true })
await installMcu.send({ devicePath: device.path, targetId: deviceInfo.targetId }).toPromise() await installMcu
this.setState(state => ({ ...state, flashing: false })) .send({
devicePath: device.path,
targetId: deviceInfo.targetId,
version: deviceInfo.version,
})
.toPromise()
this.setState({ flashing: false })
} }
} }
render() { render() {
return <div>Flashing MCU</div> return (
<div>
<h1>Flashing MCU</h1>
<button onClick={this.flashMCU}>flash</button>
</div>
)
} }
} }

2
src/components/Workflow/EnsureGenuine.js

@ -61,7 +61,7 @@ class EnsureGenuine extends PureComponent<Props, State> {
this._checking = true this._checking = true
try { try {
const res = await getIsGenuine const res = await getIsGenuine
.send({ devicePath: device.path, targetId: infos.targetId }) .send({ devicePath: device.path, targetId: infos.targetId, version: infos.version })
.pipe(timeout(GENUINE_TIMEOUT)) .pipe(timeout(GENUINE_TIMEOUT))
.toPromise() .toPromise()
if (this._unmounting) return if (this._unmounting) return

9
src/helpers/apps/listApps.js

@ -10,13 +10,14 @@ export default async (targetId: string | number, version: string) => {
const provider = 1 const provider = 1
const deviceData = await getDeviceVersion(targetId) const deviceData = await getDeviceVersion(targetId)
const firmwareData = await getCurrentFirmware({ deviceId: deviceData.id, version }) const firmwareData = await getCurrentFirmware({ deviceId: deviceData.id, version })
const { const params = {
data: { application_versions },
} = await axios.post(APPLICATIONS_BY_DEVICE, {
provider, provider,
current_se_firmware_final_version: firmwareData.id, current_se_firmware_final_version: firmwareData.id,
device_version: deviceData.id, device_version: deviceData.id,
}) }
const {
data: { application_versions },
} = await axios.post(APPLICATIONS_BY_DEVICE, params)
return application_versions.length > 0 ? application_versions : [] return application_versions.length > 0 ? application_versions : []
} catch (err) { } catch (err) {
const error = Error(err.message) const error = Error(err.message)

13
src/helpers/devices/getIsGenuine.js

@ -1,15 +1,24 @@
// @flow // @flow
import qs from 'qs'
import type Transport from '@ledgerhq/hw-transport' import type Transport from '@ledgerhq/hw-transport'
import { SKIP_GENUINE } from 'config/constants' import { SKIP_GENUINE } from 'config/constants'
import { WS_GENUINE } from 'helpers/urls' import { WS_GENUINE } from 'helpers/urls'
import { createDeviceSocket } from 'helpers/socket' import { createDeviceSocket } from 'helpers/socket'
import getCurrentFirmware from './getCurrentFirmware'
import getDeviceVersion from './getDeviceVersion'
export default async ( export default async (
transport: Transport<*>, transport: Transport<*>,
params: { targetId: string | number }, app: { targetId: string | number, version: string },
): Promise<string> => { ): Promise<string> => {
const { targetId, version } = app
const device = await getDeviceVersion(app.targetId)
const firmware = await getCurrentFirmware({ deviceId: device.id, version })
const params = {
targetId,
version,
perso: firmware.perso,
}
const url = WS_GENUINE(params) const url = WS_GENUINE(params)
return SKIP_GENUINE return SKIP_GENUINE
? new Promise(resolve => setTimeout(() => resolve('0000'), 1000)) ? new Promise(resolve => setTimeout(() => resolve('0000'), 1000))

26
src/helpers/devices/getNextMCU.js

@ -0,0 +1,26 @@
// @flow
import axios from 'axios'
import { GET_NEXT_MCU } from 'helpers/urls'
import createCustomErrorClass from 'helpers/createCustomErrorClass'
const LatestMCUInstalledError = createCustomErrorClass('LatestMCUInstalledError')
export default async (bootloaderVersion: string): Promise<*> => {
try {
const { data } = await axios.post(GET_NEXT_MCU, {
bootloader_version: bootloaderVersion,
})
// FIXME: nextVersion will not be able to "default" when Error
// handling is standardize on the API side
if (data === 'default' || !data.name) {
throw new LatestMCUInstalledError('there is no next mcu version to install')
}
return data
} catch (err) {
const error = Error(err.message)
error.stack = err.stack
throw err
}
}

15
src/helpers/firmware/installMcu.js

@ -1,16 +1,23 @@
// @flow // @flow
import qs from 'qs'
import type Transport from '@ledgerhq/hw-transport' import type Transport from '@ledgerhq/hw-transport'
import { MANAGER_API_BASE } from 'config/constants' import { WS_MCU } from 'helpers/urls'
import { createDeviceSocket } from 'helpers/socket' import { createDeviceSocket } from 'helpers/socket'
import getNextMCU from 'helpers/devices/getNextMCU'
type Result = Promise<*> type Result = Promise<*>
export default async ( export default async (
transport: Transport<*>, transport: Transport<*>,
params: { targetId: string | number, version: string }, args: { targetId: string | number, version: string },
): Result => { ): Result => {
const url = `${MANAGER_API_BASE}/mcu?${qs.stringify(params)}` const { version } = args
const nextVersion = await getNextMCU(version)
const params = {
targetId: args.targetId,
version: nextVersion.name,
}
const url = WS_MCU(params)
return createDeviceSocket(transport, url).toPromise() return createDeviceSocket(transport, url).toPromise()
} }

15
src/helpers/firmware/installOsuFirmware.js

@ -4,13 +4,22 @@ import type Transport from '@ledgerhq/hw-transport'
import { WS_INSTALL } from 'helpers/urls' import { WS_INSTALL } from 'helpers/urls'
import { createDeviceSocket } from 'helpers/socket' import { createDeviceSocket } from 'helpers/socket'
type Input = Object import type { LedgerScriptParams } from 'helpers/common'
type Result = Promise<{ success: boolean, error?: any }> type Result = Promise<{ success: boolean, error?: any }>
export default async (transport: Transport<*>, firmware: Input): Result => { export default async (
transport: Transport<*>,
targetId: string | number,
firmware: LedgerScriptParams,
): Result => {
try { try {
const url = WS_INSTALL(firmware) const params = {
targetId,
...firmware,
firmwareKey: firmware.firmware_key,
}
const url = WS_INSTALL(params)
await createDeviceSocket(transport, url).toPromise() await createDeviceSocket(transport, url).toPromise()
return { success: true } return { success: true }
} catch (err) { } catch (err) {

8
src/helpers/urls.js

@ -11,11 +11,17 @@ const managerUrlbuilder = urlBuilder(MANAGER_API_BASE)
const wsURLBuilder = (endpoint: string) => (params?: Object) => const wsURLBuilder = (endpoint: string) => (params?: Object) =>
`${BASE_SOCKET_URL_SECURE}/${endpoint}${params ? `?${qs.stringify(params)}` : ''}` `${BASE_SOCKET_URL_SECURE}/${endpoint}${params ? `?${qs.stringify(params)}` : ''}`
// const wsURLBuilderProxy = (endpoint: string) => (params?: Object) =>
// `ws://manager.ledger.fr:3501/${endpoint}${params ? `?${qs.stringify(params)}` : ''}`
export const GET_DEVICE_VERSION: string = managerUrlbuilder('get_device_version') export const GET_DEVICE_VERSION: string = managerUrlbuilder('get_device_version')
export const APPLICATIONS_BY_DEVICE: string = managerUrlbuilder('get_apps') export const APPLICATIONS_BY_DEVICE: string = managerUrlbuilder('get_apps')
export const GET_CURRENT_FIRMWARE: string = managerUrlbuilder('get_firmware_version') export const GET_CURRENT_FIRMWARE: string = managerUrlbuilder('get_firmware_version')
export const GET_LATEST_FIRMWARE: string = managerUrlbuilder('get_latest_firmware') export const GET_LATEST_FIRMWARE: string = managerUrlbuilder('get_latest_firmware')
export const GET_NEXT_MCU: string = managerUrlbuilder('mcu_versions_bootloader')
export const WS_INSTALL: (arg: LedgerScriptParams) => string = wsURLBuilder('install') export const WS_INSTALL: (arg: LedgerScriptParams) => string = wsURLBuilder('install')
export const WS_GENUINE: (arg: { targetId: string | number }) => string = wsURLBuilder('genuine') export const WS_GENUINE: (arg: { targetId: string | number }) => string = wsURLBuilder('genuine')
export const WS_MCU: (arg: LedgerScriptParams) => string = wsURLBuilder('genuine') export const WS_MCU: (arg: { targetId: string | number, version: string }) => string = wsURLBuilder(
'mcu',
)

1
static/i18n/en/errors.yml

@ -19,3 +19,4 @@ WebsocketConnectionFailed: Failed to establish a socket connection
DeviceSocketFail: Device socket failure DeviceSocketFail: Device socket failure
DeviceSocketNoBulkStatus: Device socket failure (bulk) DeviceSocketNoBulkStatus: Device socket failure (bulk)
DeviceSocketNoHandler: Device socket failure (handler {{query}}) DeviceSocketNoHandler: Device socket failure (handler {{query}})
LatestMCUInstalledError: The latest MCU is already installed on the Device

Loading…
Cancel
Save