-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmintlify.go
80 lines (65 loc) · 1.85 KB
/
mintlify.go
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
package main
import (
"fmt"
"mintlify-previewer-backend/log"
"os"
"os/exec"
"strconv"
"sync"
"syscall"
)
var activeServers = make(map[string]*os.Process)
var mu sync.Mutex
func ensureMintlifyInstalled() error {
if _, err := exec.LookPath("mintlify"); err != nil {
log.Errorln("Mintlify not found, installing...")
cmd := exec.Command("npm", "install", "-g", "mintlify")
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
return cmd.Run()
}
return nil
}
func startMintlifyDev(uuid string, port int, dir string) {
cmd := exec.Command("mintlify", "dev", "--no-open", "--port", strconv.Itoa(port))
cmd.Dir = dir
if err := cmd.Start(); err != nil {
log.Errorf("Failed to start Mintlify: %v", err)
_, _ = db.Exec("UPDATE deployments SET status = ? WHERE uuid = ?", "failed", uuid)
return
}
mu.Lock()
activeServers[uuid] = cmd.Process
mu.Unlock()
log.Infof("Mintlify running for UUID %s on port %d", uuid, port)
_, err := db.Exec("UPDATE deployments SET status = ? WHERE uuid = ?", "running", uuid)
if err != nil {
log.Errorf("Failed to update running status: %v", err)
}
err = cmd.Wait()
if err != nil {
log.Errorf("Failed to start Mintlify: %v", err)
}
mu.Lock()
delete(activeServers, uuid)
mu.Unlock()
}
func stopMintlifyServer(uuid string) error {
mu.Lock()
process, exists := activeServers[uuid]
mu.Unlock()
if !exists {
log.Errorf("server for UUID %s not found", uuid)
return fmt.Errorf("server for UUID %s not found", uuid)
}
if err := process.Signal(syscall.SIGTERM); err != nil {
log.Errorf("Failed to stop Mintlify server: %v", err)
return fmt.Errorf("failed to stop server for UUID %s: %v", uuid, err)
}
mu.Lock()
delete(activeServers, uuid)
mu.Unlock()
log.Infof("Mintlify server for UUID %s stopped", uuid)
_, err := db.Exec("UPDATE deployments SET status = ? WHERE uuid = ?", "stopped", uuid)
return err
}