summaryrefslogtreecommitdiff
path: root/doClean.go
blob: e4c97832fb666306d72408e68154fe663d7a3094 (plain)
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
package main

import (
	"os"
	"path/filepath"
	"strings"

	"go.wit.com/log"
)

func doClean() {
	log.Info("find all files")
	scanTmp()
}

func scanTmp() {
	var count int
	filepath.WalkDir("/tmp", func(path string, d os.DirEntry, err error) error {
		if err != nil {
			// Handle possible errors, like permission issues
			// fmt.Fprintf(os.Stderr, "error accessing path %q: %v\n", path, err)
			// ignore all these problems
			return err
		}

		/*
			if d.IsDir() {
				// log.Info("path is dir", path)
				return nil
			}
		*/

		_, fname := filepath.Split(path)
		if !strings.HasPrefix(fname, "regex.") {
			return nil
		}
		if count > 5 {
			return log.Errorf("count exceeded")
		}
		if strings.HasPrefix(fname, "regex.gemini-api-response") {
			// log.Info("response file:", fname)
			return nil
		}
		if strings.Contains(fname, "gemini-api-request") {
			// log.Info("response file:", fname)
			if err := cleanGeminiFile(path); err == nil {
				count += 1
				return nil
			} else {
				return nil
			}
		}
		if strings.HasSuffix(fname, ".stats") {
			cleanStatsFile(path)
			return nil
		}
		log.Info("check file:", path)
		return nil
	})
}

func cleanStatsFile(fullname string) {
	log.Info("stats file", fullname)
}

func cleanGeminiFile(fullname string) error {
	_, fname := filepath.Split(fullname)
	if !strings.HasSuffix(fname, ".json") {
		return log.Errorf("not really gemini-api-request .json")
	}
	parts := strings.Split(fname, ".")
	if len(parts) == 5 {
		if parts[2] != "gemini-api-request" {
			return log.Errorf("not really gemini-api-request")
		}
	}
	uuid := parts[1]
	for _, chat := range me.chats.GetChats() {
		// log.Info(i, chat.Uuid)
		if chat.Uuid == uuid {
			log.Info("found uuid", uuid)
			return nil
		}
	}
	log.Info("gemini JSON file uuid not found", uuid)
	return log.Errorf("gemini JSON file uuid %s not found", uuid)
}