forked from D13GOOOO/BlogEngine
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcli.go
More file actions
179 lines (162 loc) · 4.5 KB
/
cli.go
File metadata and controls
179 lines (162 loc) · 4.5 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
package main
import (
"blog/models"
"fmt"
"io"
"log"
"os"
"os/exec"
"runtime"
"time"
"gorm.io/driver/sqlite"
"gorm.io/gorm"
)
func main() {
if len(os.Args) < 2 {
fmt.Println("Usa: blogctl [start|shutdown|restart|dbreset|backup]")
return
}
switch os.Args[1] {
case "start":
runGoModTidyIfNeeded()
startServer()
case "shutdown":
shutdownServer()
case "restart":
shutdownServer()
time.Sleep(2 * time.Second) // Pausa tra stop e start
runGoModTidyIfNeeded()
startServer()
case "dbreset":
shutdownServer()
dbclean_updated()
runGoModTidyIfNeeded()
startServer()
case "backup":
shutdownServer()
dbBackup()
runGoModTidyIfNeeded()
startServer()
default:
fmt.Println("Comando non valido.")
}
}
func runGoModTidyIfNeeded() { // Se le dipendenze non sono installate, esegui 'go mod tidy'
// Controlla se il file go.sum esiste. Se non esiste, esegue 'go mod tidy'
if _, err := os.Stat("go.sum"); os.IsNotExist(err) {
fmt.Println("Prima esecuzione rilevata, eseguo 'go mod tidy'...")
cmd := exec.Command("go", "mod", "tidy")
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
if err := cmd.Run(); err != nil {
log.Fatalf("Errore durante 'go mod tidy': %v", err)
}
}
}
func startServer() { // Avvia il server Go
// Controlla se il file main.go esiste. Se non esiste, mostra un messaggio di errore
fmt.Println("Avvio del server...")
switch runtime.GOOS {
case "windows":
// Su Windows, avvia il server in una nuova finestra di terminale usando cmd.exe
cmd := exec.Command("cmd", "/c", "start", "go", "run", "main.go")
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
cmd.Stdin = os.Stdin
if err := cmd.Run(); err != nil {
log.Fatalf("Errore durante l'avvio del server: %v", err)
}
fmt.Println("Server avviato in una nuova finestra del terminale.")
default:
// Su Linux/macOS avvia il server in background
cmd := exec.Command("nohup", "go", "run", "main.go", "&")
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
cmd.Stdin = os.Stdin
if err := cmd.Run(); err != nil {
log.Fatalf("Errore durante l'avvio del server: %v", err)
}
fmt.Println("Server avviato in background.")
}
}
func shutdownServer() { // Spegne il server Go
// Per Windows, usa taskkill
if runtime.GOOS == "windows" {
cmd := exec.Command("taskkill", "/F", "/IM", "main.exe") // Assicurati che il nome dell'eseguibile sia corretto
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
err := cmd.Run()
if err != nil {
log.Println("Errore durante lo spegnimento del server:", err)
} else {
fmt.Println("Server spento.")
}
} else {
// Per Linux/macOS, usa pkill
cmd := exec.Command("pkill", "-f", "main.go") // Questo funziona su Linux/macOS
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
err := cmd.Run()
if err != nil {
log.Println("Errore durante lo spegnimento del server:", err)
} else {
fmt.Println("Server spento.")
}
}
}
func dbclean() {
if runtime.GOOS == "windows" {
err := os.Remove("blog.db")
if err != nil {
log.Println("Errore durante la cancellazione del database:", err)
} else {
fmt.Println("Database cancellato con successo")
}
} else {
cmd := exec.Command("rm", "blog.db")
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
err := cmd.Run()
if err != nil {
log.Println("Errore durante la cancellazione del database:", err)
} else {
fmt.Println("Database cancellato con successo")
}
}
}
func dbBackup() {
source, err := os.Open("blog.db")
if err != nil {
fmt.Println("Errore nell'apertura del database")
}
date := time.Now()
formatted_date := date.Format("01-02-2006 15-04-05")
formatted_date = formatted_date + ".db"
fmt.Println(formatted_date)
dest, err := os.Create(formatted_date)
if err != nil {
fmt.Println("Errore nella creazione del file di destinazione")
}
_, err = io.Copy(dest, source)
if err != nil {
fmt.Println("Errore nella creazione del backup")
} else {
fmt.Println("Backup creato con successo")
}
}
func dbclean_updated() {
var err error
db, err := gorm.Open(sqlite.Open("blog.db"), &gorm.Config{})
if err != nil {
log.Fatal("Errore in apertura database", err)
}
err = db.AutoMigrate(&models.Post{}, &models.Comment{})
if err != nil {
log.Fatal("Errore nella migrazione", err)
}
var MaxId int
db.Model(&models.Post{}).Select("MAX(id)").Scan(&MaxId)
for i := 1; i <= MaxId; i++ {
db.Delete(models.Post{}, i)
}
}