mirror of
https://github.com/Start9Labs/start-os.git
synced 2026-03-26 02:11:53 +00:00
* remove product key flow from setup * feat: backend turned off encryption + new Id + no package id * implement new encryption scheme in FE * decode response string * crypto not working * update setup wizard closes #1762 * feat: Get the encryption key * fix: Get to recovery * remove old code * fix build * fix: Install works for now * fix bug in config for adding new list items * dismiss action modal on success * clear button in config * wip: Currently broken in avahi mdns * include headers with req/res and refactor patchDB init and usage * fix: Can now run in the main * flatline on failed init * update patch DB * add last-wifi-region to data model even though not used by FE * chore: Fix the start. * wip: Fix wrong order for getting hostname before sql has been created * fix edge case where union keys displayed as new when not new * fix: Can start * last backup color, markdown links always new tab, fix bug with login * refactor to remove WithRevision * resolve circular dep issue * update submodule * fix patch-db * update patchDB * update patch again * escape error * decodeuricomponent * increase proxy buffer size * increase proxy buffer size * fix nginx Co-authored-by: BluJ <mogulslayer@gmail.com> Co-authored-by: BluJ <dragondef@gmail.com> Co-authored-by: Aiden McClelland <me@drbonez.dev>
155 lines
4.3 KiB
TypeScript
155 lines
4.3 KiB
TypeScript
import { Component } from '@angular/core'
|
|
import {
|
|
AlertController,
|
|
LoadingController,
|
|
ModalController,
|
|
NavController,
|
|
} from '@ionic/angular'
|
|
import {
|
|
ApiService,
|
|
DiskInfo,
|
|
DiskRecoverySource,
|
|
} from 'src/app/services/api/api.service'
|
|
import { ErrorToastService } from '@start9labs/shared'
|
|
import { StateService } from 'src/app/services/state.service'
|
|
import { PasswordPage } from '../../modals/password/password.page'
|
|
|
|
@Component({
|
|
selector: 'app-embassy',
|
|
templateUrl: 'embassy.page.html',
|
|
styleUrls: ['embassy.page.scss'],
|
|
})
|
|
export class EmbassyPage {
|
|
storageDrives: DiskInfo[] = []
|
|
loading = true
|
|
|
|
constructor(
|
|
private readonly apiService: ApiService,
|
|
private readonly navCtrl: NavController,
|
|
private readonly modalController: ModalController,
|
|
private readonly alertCtrl: AlertController,
|
|
private readonly stateService: StateService,
|
|
private readonly loadingCtrl: LoadingController,
|
|
private readonly errorToastService: ErrorToastService,
|
|
) {}
|
|
|
|
async ngOnInit() {
|
|
await this.getDrives()
|
|
}
|
|
|
|
tooSmall(drive: DiskInfo) {
|
|
return drive.capacity < 34359738368
|
|
}
|
|
|
|
async refresh() {
|
|
this.loading = true
|
|
await this.getDrives()
|
|
}
|
|
|
|
async getDrives() {
|
|
this.loading = true
|
|
try {
|
|
const { disks, reconnect } = await this.apiService.getDrives()
|
|
this.storageDrives = disks.filter(
|
|
d =>
|
|
!d.partitions
|
|
.map(p => p.logicalname)
|
|
.includes(
|
|
(this.stateService.recoverySource as DiskRecoverySource)
|
|
?.logicalname,
|
|
),
|
|
)
|
|
if (!this.storageDrives.length && reconnect.length) {
|
|
const list = `<ul>${reconnect.map(recon => `<li>${recon}</li>`)}</ul>`
|
|
const alert = await this.alertCtrl.create({
|
|
header: 'Warning',
|
|
message: `One or more devices you connected had to be reconfigured to support the current hardware platform. Please unplug and replug the following device(s), then refresh the page:<br> ${list}`,
|
|
buttons: ['OK'],
|
|
})
|
|
await alert.present()
|
|
}
|
|
} catch (e: any) {
|
|
this.errorToastService.present(e)
|
|
} finally {
|
|
this.loading = false
|
|
}
|
|
}
|
|
|
|
async chooseDrive(drive: DiskInfo) {
|
|
if (!!drive.partitions.find(p => p.used) || !!drive.guid) {
|
|
const alert = await this.alertCtrl.create({
|
|
header: 'Warning',
|
|
subHeader: 'Drive contains data!',
|
|
message: 'All data stored on this drive will be permanently deleted.',
|
|
buttons: [
|
|
{
|
|
role: 'cancel',
|
|
text: 'Cancel',
|
|
},
|
|
{
|
|
text: 'Continue',
|
|
handler: () => {
|
|
if (this.stateService.recoveryPassword) {
|
|
this.setupEmbassy(
|
|
drive.logicalname,
|
|
this.stateService.recoveryPassword,
|
|
)
|
|
} else {
|
|
this.presentModalPassword(drive.logicalname)
|
|
}
|
|
},
|
|
},
|
|
],
|
|
})
|
|
await alert.present()
|
|
} else {
|
|
if (this.stateService.recoveryPassword) {
|
|
this.setupEmbassy(drive.logicalname, this.stateService.recoveryPassword)
|
|
} else {
|
|
this.presentModalPassword(drive.logicalname)
|
|
}
|
|
}
|
|
}
|
|
|
|
private async presentModalPassword(logicalname: string): Promise<void> {
|
|
const modal = await this.modalController.create({
|
|
component: PasswordPage,
|
|
componentProps: {
|
|
storageDrive: true,
|
|
},
|
|
})
|
|
modal.onDidDismiss().then(async ret => {
|
|
if (!ret.data || !ret.data.password) return
|
|
this.setupEmbassy(logicalname, ret.data.password)
|
|
})
|
|
await modal.present()
|
|
}
|
|
|
|
private async setupEmbassy(
|
|
logicalname: string,
|
|
password: string,
|
|
): Promise<void> {
|
|
const loader = await this.loadingCtrl.create({
|
|
message: 'Initializing data drive. This could take a while...',
|
|
})
|
|
|
|
await loader.present()
|
|
|
|
try {
|
|
await this.stateService.setupEmbassy(logicalname, password)
|
|
if (!!this.stateService.recoverySource) {
|
|
await this.navCtrl.navigateForward(`/loading`)
|
|
} else {
|
|
await this.navCtrl.navigateForward(`/success`)
|
|
}
|
|
} catch (e: any) {
|
|
this.errorToastService.present({
|
|
message: `${e.message}\n\nRestart Embassy to try again.`,
|
|
})
|
|
console.error(e)
|
|
} finally {
|
|
loader.dismiss()
|
|
}
|
|
}
|
|
}
|