-
Notifications
You must be signed in to change notification settings - Fork 227
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
refactor: migrate spaces:vpn:wait to oclif/core (#2877)
* refactor: initial spaces:vpn:wait command migration * refactor: complete migration of vpn:wait command * refactor: fix errors, add json printing, and replace spinner with ux.action * refactor: migrate tests for spaces:vpn:wait * remove spaces:vpn:wait command from spaces package * fix: remove .only
- Loading branch information
Showing
4 changed files
with
130 additions
and
115 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
import color from '@heroku-cli/color' | ||
import {Command, flags} from '@heroku-cli/command' | ||
import {ux} from '@oclif/core' | ||
import * as Heroku from '@heroku-cli/schema' | ||
import {displayVPNConfigInfo} from '../../../lib/spaces/vpn-connections' | ||
|
||
const wait = (ms: number) => new Promise(resolve => { | ||
setTimeout(resolve, ms) | ||
}) | ||
|
||
export default class Wait extends Command { | ||
static topic = 'spaces'; | ||
static description = 'wait for VPN Connection to be created'; | ||
static flags = { | ||
space: flags.string({char: 's', description: 'space the vpn connection belongs to', required: true}), | ||
name: flags.string({char: 'n', description: 'name or id of the vpn connection to wait for', required: true}), | ||
json: flags.boolean({description: 'output in json format'}), | ||
interval: flags.string({char: 'i', description: 'seconds to wait between poll intervals'}), | ||
timeout: flags.string({char: 't', description: 'maximum number of seconds to wait'}), | ||
}; | ||
|
||
public async run(): Promise<void> { | ||
const {flags} = await this.parse(Wait) | ||
const {name, space, json} = flags | ||
const interval = (flags.interval ? Number.parseInt(flags.interval, 10) : 10) * 1000 | ||
const timeout = (flags.timeout ? Number.parseInt(flags.timeout, 10) : 20 * 60) * 1000 | ||
const deadline = new Date(Date.now() + timeout) | ||
let {body: vpnConnection} = await this.heroku.get<Heroku.PrivateSpacesVpn>(`/spaces/${space}/vpn-connections/${name}`) | ||
if (vpnConnection.status === 'active') { | ||
ux.log('VPN has been allocated.') | ||
return | ||
} | ||
|
||
ux.action.start(`Waiting for VPN Connection ${color.green(name)} to allocate...`) | ||
while (vpnConnection.status !== 'active') { | ||
if (new Date() > deadline) { | ||
ux.error('Timeout waiting for VPN to become allocated.', {exit: 1}) | ||
} | ||
|
||
if (vpnConnection.status === 'failed') { | ||
ux.error(vpnConnection.status_message || '', {exit: 1}) | ||
} | ||
|
||
await wait(interval) | ||
const {body: updatedVpnConnection} = await this.heroku.get<Heroku.PrivateSpacesVpn>(`/spaces/${space}/vpn-connections/${name}`) | ||
vpnConnection = updatedVpnConnection | ||
} | ||
|
||
ux.action.stop() | ||
const {body: newVpnConnection} = await this.heroku.get<Heroku.PrivateSpacesVpn>(`/spaces/${space}/vpn-connections/${name}`) | ||
if (json) { | ||
ux.styledJSON(newVpnConnection) | ||
} else { | ||
displayVPNConfigInfo(space, name, newVpnConnection) | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,5 +7,4 @@ exports.topics = [ | |
|
||
exports.commands = [ | ||
require('./commands/vpn/index'), | ||
require('./commands/vpn/wait'), | ||
] |