summaryrefslogtreecommitdiff
blob: 9b3d32ee33926e5bcc9e288f8cf014fefb1b63dd (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
package glsa

import (
	"glsamaker/pkg/app/handler/authentication"
	"glsamaker/pkg/app/handler/authentication/utils"
	"glsamaker/pkg/database/connection"
	"glsamaker/pkg/logger"
	"glsamaker/pkg/models"
	"glsamaker/pkg/models/bugzilla"
	"net/http"
	"strconv"
)

// Show renders a template to show the landing page of the application
func UpdateBugs(w http.ResponseWriter, r *http.Request) {

	user := utils.GetAuthenticatedUser(r)

	if !user.Permissions.Glsa.UpdateBugs {
		authentication.AccessDenied(w, r)
		return
	}

	go bugUpdate()

	http.Redirect(w, r, "/", 301)
}

func bugUpdate() {

	var allBugs []*bugzilla.Bug
	connection.DB.Model(&allBugs).Select()

	var bugIdsLists [][]string
	bugIdsLists = append(bugIdsLists, []string{})
	for _, bug := range allBugs {
		lastElem := bugIdsLists[len(bugIdsLists)-1]

		if len(lastElem) < 100 {
			bugIdsLists[len(bugIdsLists)-1] = append(lastElem, strconv.FormatInt(bug.Id, 10))
		} else {
			bugIdsLists = append(bugIdsLists, []string{strconv.FormatInt(bug.Id, 10)})
		}
	}

	for _, bugIdsList := range bugIdsLists {
		updatedBugs := bugzilla.GetBugsByIds(bugIdsList)

		for _, updatedBug := range updatedBugs {
			_, err := connection.DB.Model(&updatedBug).WherePK().Update()
			if err != nil {
				logger.Error.Println("Error during bug data update")
				logger.Error.Println(err)
			}
		}
	}

	// Possibly delete deleted bugs
	// Do we even delete bugs?

	// update the time of the last bug update
	models.SetApplicationValue("LastBugUpdate", "")
}