mirror of
https://github.com/Start9Labs/start-os.git
synced 2026-03-31 04:23:40 +00:00
* wip * restructure backend for new ui structure * new patchdb bootstrap, single websocket api, local storage migration, more * update db websocket * init apis * update patch-db * setup progress * feat: implement state service, alert and routing Signed-off-by: waterplea <alexander@inkin.ru> * update setup wizard for new types * feat: add init page Signed-off-by: waterplea <alexander@inkin.ru> * chore: refactor message, patch-db source stream and connection service Signed-off-by: waterplea <alexander@inkin.ru> * fix method not found on state * fix backend bugs * fix compat assets * address comments * remove unneeded styling * cleaner progress * bugfixes * fix init logs * fix progress reporting * fix navigation by getting state after init * remove patch dependency from live api * fix caching * re-add patchDB to live api * fix metrics values * send close frame * add bootId and fix polling --------- Signed-off-by: waterplea <alexander@inkin.ru> Co-authored-by: Aiden McClelland <me@drbonez.dev> Co-authored-by: waterplea <alexander@inkin.ru>
75 lines
2.6 KiB
TypeScript
75 lines
2.6 KiB
TypeScript
import { Inject, Injectable } from '@angular/core'
|
|
import { ModalController } from '@ionic/angular'
|
|
import { Observable } from 'rxjs'
|
|
import { filter, map, share, switchMap, take, tap } from 'rxjs/operators'
|
|
import { PatchDB } from 'patch-db-client'
|
|
import { DataModel } from 'src/app/services/patch-db/data-model'
|
|
import { EOSService } from 'src/app/services/eos.service'
|
|
import { OSWelcomePage } from 'src/app/modals/os-welcome/os-welcome.page'
|
|
import { ConfigService } from 'src/app/services/config.service'
|
|
import { ApiService } from 'src/app/services/api/embassy-api.service'
|
|
import { MarketplaceService } from 'src/app/services/marketplace.service'
|
|
import { AbstractMarketplaceService } from '@start9labs/marketplace'
|
|
import { ConnectionService } from 'src/app/services/connection.service'
|
|
import { LocalStorageBootstrap } from './patch-db/local-storage-bootstrap'
|
|
|
|
// Get data from PatchDb after is starts and act upon it
|
|
@Injectable({
|
|
providedIn: 'root',
|
|
})
|
|
export class PatchDataService extends Observable<void> {
|
|
private readonly stream$ = this.connection$.pipe(
|
|
filter(Boolean),
|
|
switchMap(() => this.patch.watch$()),
|
|
map((cache, index) => {
|
|
this.bootstrapper.update(cache)
|
|
|
|
if (index === 0) {
|
|
// check for updates to StartOS and services
|
|
this.checkForUpdates()
|
|
// show eos welcome message
|
|
this.showEosWelcome(cache.ui.ackWelcome)
|
|
}
|
|
}),
|
|
share(),
|
|
)
|
|
|
|
constructor(
|
|
private readonly patch: PatchDB<DataModel>,
|
|
private readonly eosService: EOSService,
|
|
private readonly config: ConfigService,
|
|
private readonly modalCtrl: ModalController,
|
|
private readonly embassyApi: ApiService,
|
|
@Inject(AbstractMarketplaceService)
|
|
private readonly marketplaceService: MarketplaceService,
|
|
private readonly connection$: ConnectionService,
|
|
private readonly bootstrapper: LocalStorageBootstrap,
|
|
) {
|
|
super(subscriber => this.stream$.subscribe(subscriber))
|
|
}
|
|
|
|
private checkForUpdates(): void {
|
|
this.eosService.loadEos()
|
|
this.marketplaceService.getMarketplace$().pipe(take(1)).subscribe()
|
|
}
|
|
|
|
private async showEosWelcome(ackVersion: string): Promise<void> {
|
|
if (this.config.skipStartupAlerts || ackVersion === this.config.version) {
|
|
return
|
|
}
|
|
|
|
const modal = await this.modalCtrl.create({
|
|
component: OSWelcomePage,
|
|
presentingElement: await this.modalCtrl.getTop(),
|
|
backdropDismiss: false,
|
|
})
|
|
modal.onWillDismiss().then(() => {
|
|
this.embassyApi
|
|
.setDbValue<string>(['ackWelcome'], this.config.version)
|
|
.catch()
|
|
})
|
|
|
|
await modal.present()
|
|
}
|
|
}
|