Skip to content

Commit

Permalink
Add backup and restore plugin
Browse files Browse the repository at this point in the history
  • Loading branch information
qianlifeng committed Dec 18, 2023
1 parent fa307d4 commit 91a5218
Showing 1 changed file with 123 additions and 0 deletions.
123 changes: 123 additions & 0 deletions Wox/plugin/system/backup.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,123 @@
package system

import (
"context"
"fmt"
"slices"
"wox/plugin"
"wox/setting"
"wox/util"
)

var backupIcon = plugin.NewWoxImageBase64(``)

func init() {
plugin.AllSystemPlugin = append(plugin.AllSystemPlugin, &BackupPlugin{})
}

type BackupPlugin struct {
api plugin.API
}

func (c *BackupPlugin) GetMetadata() plugin.Metadata {
return plugin.Metadata{
Id: "0feebaec-1a66-45af-9856-566343518638",
Name: "Backup and restore Wox settings",
Author: "Wox Launcher",
Website: "https://github.com/Wox-launcher/Wox",
Version: "1.0.0",
MinWoxVersion: "2.0.0",
Runtime: "Nodejs",
Description: "Backup and restore Wox settings",
Icon: backupIcon.String(),
Entry: "",
TriggerKeywords: []string{
"restore",
"backup",
},
Commands: []plugin.MetadataCommand{},
SupportedOS: []string{
"Windows",
"Macos",
"Linux",
},
}
}

func (c *BackupPlugin) Init(ctx context.Context, initParams plugin.InitParams) {
c.api = initParams.API
}

func (c *BackupPlugin) Query(ctx context.Context, query plugin.Query) []plugin.QueryResult {
if query.TriggerKeyword == "restore" {
return c.restore(ctx, query)
} else {
return c.backup(ctx, query)
}
}

func (c *BackupPlugin) backup(ctx context.Context, query plugin.Query) []plugin.QueryResult {
return []plugin.QueryResult{
{
Title: "Backup now",
SubTitle: "Backup Wox settings",
Icon: backupIcon,
Actions: []plugin.QueryResultAction{
{
Name: "Backup",
Action: func(actionContext plugin.ActionContext) {
backupErr := setting.GetSettingManager().Backup(ctx, setting.BackupTypeManual)
if backupErr != nil {
c.api.ShowMsg(ctx, "Error", backupErr.Error(), "")
} else {
c.api.ShowMsg(ctx, "Success", "Wox settings backed up", "")
}
},
},
},
},
}
}

func (c *BackupPlugin) restore(ctx context.Context, query plugin.Query) []plugin.QueryResult {
backups, err := setting.GetSettingManager().FindAllBackups(ctx)
if err != nil {
return []plugin.QueryResult{
{
Title: "Error",
SubTitle: err.Error(),
Icon: backupIcon,
},
}
}

//sort backups by timestamp desc
slices.SortFunc(backups, func(i, j setting.Backup) int {
return int(j.Timestamp - i.Timestamp)
})

var results []plugin.QueryResult
for index, backup := range backups {
backupDummy := backup
results = append(results, plugin.QueryResult{
Title: fmt.Sprintf("#%d", index+1),
SubTitle: fmt.Sprintf("%s - %s", backupDummy.Type, util.FormatTimestamp(backupDummy.Timestamp)),
Icon: backupIcon,
Actions: []plugin.QueryResultAction{
{
Name: "Restore",
Action: func(actionContext plugin.ActionContext) {
restoreErr := setting.GetSettingManager().Restore(ctx, backupDummy.Id)
if restoreErr != nil {
c.api.ShowMsg(ctx, "Error", restoreErr.Error(), "")
} else {
c.api.ShowMsg(ctx, "Success", "Wox settings restored", "")
}
},
},
},
})
}

return results
}

0 comments on commit 91a5218

Please sign in to comment.