package healthcheck

import (
	"fmt"
	"log/slog"
	"os"
	"path/filepath"
	"regexp"
	"strings"
)

// getForbiddens retrieves a list of forbidden files in the specified root directory.
// It searches for files that do not match the specified regex patterns in the given file list.
func getForbiddens(root string, fileList []string) ([]string, error) {
	var matches []string

	var regexList []*regexp.Regexp
	regexList, err := getRegex(fileList)
	if err != nil {
		return nil, err
	}

	err = filepath.Walk(root, func(path string, info os.FileInfo, err error) error {
		if err != nil {
			return err
		}

		if info.IsDir() {
			if info.Name() == ".git" || info.Name() == ".gitea" || info.Name() == "ci" {
				return filepath.SkipDir
			} else {
				return nil
			}
		}

		match := false
		for _, regex := range regexList {
			if regex.MatchString(info.Name()) {
				match = true
				break
			}
		}

		if !match {
			matches = append(matches, path)
		}
		return nil
	})

	return matches, err
}

// forbiddenCheck checks for forbidden files in the specified root directory.
// It prints the list of forbidden files found, along with instructions on how to fix them.
func ForbiddenCheck(rootDir string, regexList []string, repo string, droneBranch string) error {
	forbids, err := getForbiddens(rootDir, regexList)
	if err != nil {
		slog.Error("getting forbiddens", "error", err)
		return fmt.Errorf("error getting forbiddens: %w", err)
	}

	var message string

	if len(forbids) > 0 {
		message = "The following forbidden files were found: " +
			strings.Join(forbids, ", ") +
			"\n\nTo fix it, first make a backup of your repository and then run the following commands:\nfor i in " +
			strings.Join(forbids, " ") +
			fmt.Sprint("; do git filter-repo --force --invert-paths --path \"$i\"; done\ngit remote add origin ",
				repo, "\ngit push --set-upstream origin ", droneBranch, " --force")
		return fmt.Errorf(message)
	}
	return nil
}