mirror of
https://github.com/cupcakearmy/autorestic.git
synced 2025-09-09 20:10:39 +00:00
Compare commits
2 Commits
v1.8.2
...
c152eeb652
Author | SHA1 | Date | |
---|---|---|---|
|
c152eeb652 | ||
|
0a48d13d6c |
@@ -1,81 +0,0 @@
|
|||||||
package cmd
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"fmt"
|
|
||||||
"os"
|
|
||||||
"os/exec"
|
|
||||||
"strings"
|
|
||||||
|
|
||||||
"github.com/cupcakearmy/autorestic/internal"
|
|
||||||
"github.com/cupcakearmy/autorestic/internal/colors"
|
|
||||||
"github.com/cupcakearmy/autorestic/internal/lock"
|
|
||||||
"github.com/spf13/cobra"
|
|
||||||
)
|
|
||||||
|
|
||||||
var unlockCmd = &cobra.Command{
|
|
||||||
Use: "unlock",
|
|
||||||
Short: "Unlock autorestic only if you are sure that no other instance is running",
|
|
||||||
Long: `Unlock autorestic only if you are sure that no other instance is running.
|
|
||||||
To check you can run "ps aux | grep autorestic".`,
|
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
|
||||||
internal.GetConfig()
|
|
||||||
|
|
||||||
force, _ := cmd.Flags().GetBool("force")
|
|
||||||
|
|
||||||
if !force && isAutoresticRunning() {
|
|
||||||
colors.Error.Print("Another autorestic instance is running. Are you sure you want to unlock? (yes/no): ")
|
|
||||||
var response string
|
|
||||||
fmt.Scanln(&response)
|
|
||||||
if strings.ToLower(response) != "yes" {
|
|
||||||
colors.Primary.Println("Unlocking aborted.")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
err := lock.Unlock()
|
|
||||||
if err != nil {
|
|
||||||
colors.Error.Println("Could not unlock:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
colors.Success.Println("Unlock successful")
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
rootCmd.AddCommand(unlockCmd)
|
|
||||||
unlockCmd.Flags().Bool("force", false, "force unlock")
|
|
||||||
}
|
|
||||||
|
|
||||||
// isAutoresticRunning checks if autorestic is running
|
|
||||||
// and returns true if it is.
|
|
||||||
// It also prints the processes to stdout.
|
|
||||||
func isAutoresticRunning() bool {
|
|
||||||
cmd := exec.Command("sh", "-c", "ps aux | grep autorestic")
|
|
||||||
var out bytes.Buffer
|
|
||||||
cmd.Stdout = &out
|
|
||||||
err := cmd.Run()
|
|
||||||
if err != nil {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
lines := strings.Split(out.String(), "\n")
|
|
||||||
autoresticProcesses := []string{}
|
|
||||||
currentPid := fmt.Sprint(os.Getpid())
|
|
||||||
|
|
||||||
for _, line := range lines {
|
|
||||||
if strings.Contains(line, "autorestic") && !strings.Contains(line, "grep autorestic") && !strings.Contains(line, currentPid) {
|
|
||||||
autoresticProcesses = append(autoresticProcesses, line)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(autoresticProcesses) > 0 {
|
|
||||||
colors.Faint.Println("Found autorestic processes:")
|
|
||||||
for _, proc := range autoresticProcesses {
|
|
||||||
colors.Faint.Println(proc)
|
|
||||||
}
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
return false
|
|
||||||
}
|
|
@@ -1,32 +0,0 @@
|
|||||||
# Unlock
|
|
||||||
|
|
||||||
In case autorestic throws the error message `an instance is already running. exiting`, but there is no instance running you can unlock the lock.
|
|
||||||
|
|
||||||
To verify that there is no instance running you can use `ps aux | grep autorestic`.
|
|
||||||
|
|
||||||
Example with no instance running:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
> ps aux | grep autorestic
|
|
||||||
root 39260 0.0 0.0 6976 2696 pts/11 S+ 19:41 0:00 grep autorestic
|
|
||||||
```
|
|
||||||
|
|
||||||
Example with an instance running:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
> ps aux | grep autorestic
|
|
||||||
root 29465 0.0 0.0 1162068 7380 pts/7 Sl+ 19:28 0:00 autorestic --ci backup -a
|
|
||||||
root 39260 0.0 0.0 6976 2696 pts/11 S+ 19:41 0:00 grep autorestic
|
|
||||||
```
|
|
||||||
|
|
||||||
**If an instance is running you should not unlock as it could lead to data loss!**
|
|
||||||
|
|
||||||
```bash
|
|
||||||
autorestic unlock
|
|
||||||
```
|
|
||||||
|
|
||||||
Use the `--force` to prevent the confirmation prompt if an instance is running.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
autorestic unlock --force
|
|
||||||
```
|
|
@@ -5,7 +5,7 @@ Linux & macOS. Windows is not supported. If you have problems installing please
|
|||||||
Autorestic requires `bash`, `wget` and `bzip2` to be installed. For most systems these should be already installed.
|
Autorestic requires `bash`, `wget` and `bzip2` to be installed. For most systems these should be already installed.
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
wget -qO - https://raw.githubusercontent.com/cupcakearmy/autorestic/master/install.sh | bash
|
sudo bash -c "$(wget -qO - https://raw.githubusercontent.com/cupcakearmy/autorestic/master/install.sh)"
|
||||||
```
|
```
|
||||||
|
|
||||||
## Alternatives
|
## Alternatives
|
||||||
|
10
docs/pnpm-lock.yaml
generated
10
docs/pnpm-lock.yaml
generated
@@ -1332,8 +1332,8 @@ packages:
|
|||||||
resolution: {integrity: sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==}
|
resolution: {integrity: sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==}
|
||||||
dev: false
|
dev: false
|
||||||
|
|
||||||
/katex@0.16.10:
|
/katex@0.16.8:
|
||||||
resolution: {integrity: sha512-ZiqaC04tp2O5utMsl2TEZTXxa6WSC4yo0fv5ML++D3QZv/vx2Mct0mTlRx3O+uUkjfuAgOkzsCmq5MiUEsDDdA==}
|
resolution: {integrity: sha512-ftuDnJbcbOckGY11OO+zg3OofESlbR5DRl2cmN8HeWeeFIV7wTXvAOx8kEjZjobhA+9wh2fbKeO6cdcA9Mnovg==}
|
||||||
hasBin: true
|
hasBin: true
|
||||||
dependencies:
|
dependencies:
|
||||||
commander: 8.3.0
|
commander: 8.3.0
|
||||||
@@ -1811,7 +1811,7 @@ packages:
|
|||||||
dependencies:
|
dependencies:
|
||||||
'@types/katex': 0.16.3
|
'@types/katex': 0.16.3
|
||||||
devlop: 1.1.0
|
devlop: 1.1.0
|
||||||
katex: 0.16.10
|
katex: 0.16.8
|
||||||
micromark-factory-space: 2.0.0
|
micromark-factory-space: 2.0.0
|
||||||
micromark-util-character: 2.0.1
|
micromark-util-character: 2.0.1
|
||||||
micromark-util-symbol: 2.0.0
|
micromark-util-symbol: 2.0.0
|
||||||
@@ -2354,7 +2354,7 @@ packages:
|
|||||||
github-slugger: 2.0.0
|
github-slugger: 2.0.0
|
||||||
graceful-fs: 4.2.11
|
graceful-fs: 4.2.11
|
||||||
gray-matter: 4.0.3
|
gray-matter: 4.0.3
|
||||||
katex: 0.16.10
|
katex: 0.16.8
|
||||||
lodash.get: 4.4.2
|
lodash.get: 4.4.2
|
||||||
next: 13.5.3(react-dom@18.2.0)(react@18.2.0)
|
next: 13.5.3(react-dom@18.2.0)(react@18.2.0)
|
||||||
next-mdx-remote: 4.4.1(react-dom@18.2.0)(react@18.2.0)
|
next-mdx-remote: 4.4.1(react-dom@18.2.0)(react@18.2.0)
|
||||||
@@ -2510,7 +2510,7 @@ packages:
|
|||||||
'@types/katex': 0.16.3
|
'@types/katex': 0.16.3
|
||||||
hast-util-from-html-isomorphic: 2.0.0
|
hast-util-from-html-isomorphic: 2.0.0
|
||||||
hast-util-to-text: 4.0.0
|
hast-util-to-text: 4.0.0
|
||||||
katex: 0.16.10
|
katex: 0.16.8
|
||||||
unist-util-visit-parents: 6.0.1
|
unist-util-visit-parents: 6.0.1
|
||||||
vfile: 6.0.1
|
vfile: 6.0.1
|
||||||
dev: false
|
dev: false
|
||||||
|
2
go.mod
2
go.mod
@@ -32,5 +32,5 @@ require (
|
|||||||
golang.org/x/text v0.3.8 // indirect
|
golang.org/x/text v0.3.8 // indirect
|
||||||
gopkg.in/ini.v1 v1.66.4 // indirect
|
gopkg.in/ini.v1 v1.66.4 // indirect
|
||||||
gopkg.in/yaml.v2 v2.4.0 // indirect
|
gopkg.in/yaml.v2 v2.4.0 // indirect
|
||||||
gopkg.in/yaml.v3 v3.0.0 // indirect
|
gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b // indirect
|
||||||
)
|
)
|
||||||
|
4
go.sum
4
go.sum
@@ -487,8 +487,8 @@ gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
|
|||||||
gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY=
|
gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY=
|
||||||
gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ=
|
gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ=
|
||||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
gopkg.in/yaml.v3 v3.0.0 h1:hjy8E9ON/egN1tAYqKb61G10WtihqetD4sz2H+8nIeA=
|
gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b h1:h8qDotaEPuJATrMmW04NCwg7v22aHH28wwpauUhK9Oo=
|
||||||
gopkg.in/yaml.v3 v3.0.0/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
|
honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
|
||||||
honnef.co/go/tools v0.0.0-20190106161140-3f1c8253044a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
|
honnef.co/go/tools v0.0.0-20190106161140-3f1c8253044a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
|
||||||
honnef.co/go/tools v0.0.0-20190418001031-e561f6794a2a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
|
honnef.co/go/tools v0.0.0-20190418001031-e561f6794a2a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
|
||||||
|
@@ -183,7 +183,6 @@ func (b Backend) ExecDocker(l Location, args []string) (int, string, error) {
|
|||||||
case "s3":
|
case "s3":
|
||||||
case "azure":
|
case "azure":
|
||||||
case "gs":
|
case "gs":
|
||||||
case "rest":
|
|
||||||
// No additional setup needed
|
// No additional setup needed
|
||||||
case "rclone":
|
case "rclone":
|
||||||
// Read host rclone config and mount it into the container
|
// Read host rclone config and mount it into the container
|
||||||
|
@@ -17,7 +17,7 @@ import (
|
|||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
)
|
)
|
||||||
|
|
||||||
const VERSION = "1.8.2"
|
const VERSION = "1.7.11"
|
||||||
|
|
||||||
type OptionMap map[string][]interface{}
|
type OptionMap map[string][]interface{}
|
||||||
type Options map[string]OptionMap
|
type Options map[string]OptionMap
|
||||||
|
Reference in New Issue
Block a user