[feat] add unmigration when logout

This commit is contained in:
kwaroran
2023-07-04 05:40:16 +09:00
parent 75271eddab
commit e0a700ce9e
4 changed files with 65 additions and 16 deletions

View File

@@ -2,8 +2,9 @@ import { get } from "svelte/store"
import { DataBase } from "./database"
import { hubURL } from "../characterCards"
import localforage from "localforage"
import { alertLogin } from "../alert"
import { getUnpargeables } from "./globalApi"
import { alertLogin, alertStore } from "../alert"
import { forageStorage, getUnpargeables, replaceDbResources } from "./globalApi"
import { encodeRisuSave } from "./risuSave"
export class AccountStorage{
auth:string
@@ -89,4 +90,34 @@ export class AccountStorage{
listItem = this.keys
}
export async function unMigrationAccount() {
const keys = await forageStorage.keys()
let db = get(DataBase)
db.account = null
let i = 0;
const MigrationStorage = localforage.createInstance({name: "risuai"})
for(const key of keys){
alertStore.set({
type: "wait",
msg: `Migrating your data...(${i}/${keys.length})`
})
await MigrationStorage.setItem(key,await forageStorage.getItem(key))
i += 1
}
await MigrationStorage.setItem('database/database.bin', encodeRisuSave(db))
this.realStorage = MigrationStorage
alertStore.set({
type: "none",
msg: ""
})
localStorage.removeItem('dosync')
localStorage.removeItem('accountst')
localStorage.removeItem('fallbackRisuToken')
location.reload()
}

View File

@@ -11,7 +11,7 @@ import { checkOldDomain, checkUpdate } from "../update";
import { selectedCharID } from "../stores";
import { Body, ResponseType, fetch as TauriFetch } from "@tauri-apps/api/http";
import { loadPlugins } from "../plugins/plugins";
import { alertError } from "../alert";
import { alertConfirm, alertError } from "../alert";
import { checkDriverInit, syncDrive } from "../drive/drive";
import { hasher } from "../parser";
import { characterHubImport, hubURL } from "../characterCards";
@@ -211,23 +211,36 @@ export async function saveDb(){
DataBase.subscribe(() => {
changed = true
})
let savetrys = 0
while(true){
if(changed){
changed = false
const dbData = encodeRisuSave(get(DataBase))
if(isTauri){
await writeBinaryFile('database/database.bin', dbData, {dir: BaseDirectory.AppData})
await writeBinaryFile(`database/dbbackup-${(Date.now()/100).toFixed()}.bin`, dbData, {dir: BaseDirectory.AppData})
try {
if(changed){
changed = false
const dbData = encodeRisuSave(get(DataBase))
if(isTauri){
await writeBinaryFile('database/database.bin', dbData, {dir: BaseDirectory.AppData})
await writeBinaryFile(`database/dbbackup-${(Date.now()/100).toFixed()}.bin`, dbData, {dir: BaseDirectory.AppData})
}
else{
await forageStorage.setItem('database/database.bin', dbData)
if(!forageStorage.isAccount){
await forageStorage.setItem(`database/dbbackup-${(Date.now()/100).toFixed()}.bin`, dbData)
}
}
if(!forageStorage.isAccount){
await getDbBackups()
}
savetrys = 0
}
await sleep(500)
} catch (error) {
if(savetrys > 4){
await alertConfirm(`DBSaveError: ${error.message ?? error}. report to the developer.`)
}
else{
await forageStorage.setItem('database/database.bin', dbData)
if(!forageStorage.isAccount){
await forageStorage.setItem(`database/dbbackup-${(Date.now()/100).toFixed()}.bin`, dbData)
}
}
await getDbBackups()
}
await sleep(500)
}
}