~ubuntu-branches/ubuntu/vivid/golang/vivid

« back to all changes in this revision

Viewing changes to misc/dashboard/codereview/dashboard/gc.go

  • Committer: Package Import Robot
  • Author(s): James Page
  • Date: 2013-08-20 14:06:23 UTC
  • mfrom: (14.1.23 saucy-proposed)
  • Revision ID: package-import@ubuntu.com-20130820140623-b414jfxi3m0qkmrq
Tags: 2:1.1.2-2ubuntu1
* Merge from Debian unstable (LP: #1211749, #1202027). Remaining changes:
  - 016-armhf-elf-header.patch: Use correct ELF header for armhf binaries.
  - d/control,control.cross: Update Breaks/Replaces for Ubuntu
    versions to ensure smooth upgrades, regenerate control file.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
// Copyright 2012 The Go Authors. All rights reserved.
 
2
// Use of this source code is governed by a BSD-style
 
3
// license that can be found in the LICENSE file.
 
4
 
 
5
package dashboard
 
6
 
 
7
// This file handles garbage collection of old CLs.
 
8
 
 
9
import (
 
10
        "net/http"
 
11
        "time"
 
12
 
 
13
        "appengine"
 
14
        "appengine/datastore"
 
15
)
 
16
 
 
17
func init() {
 
18
        http.HandleFunc("/gc", handleGC)
 
19
}
 
20
 
 
21
func handleGC(w http.ResponseWriter, r *http.Request) {
 
22
        c := appengine.NewContext(r)
 
23
 
 
24
        // Delete closed CLs that haven't been modified in 168 hours (7 days).
 
25
        cutoff := time.Now().Add(-168 * time.Hour)
 
26
        q := datastore.NewQuery("CL").
 
27
                Filter("Closed =", true).
 
28
                Filter("Modified <", cutoff).
 
29
                Limit(100).
 
30
                KeysOnly()
 
31
        keys, err := q.GetAll(c, nil)
 
32
        if err != nil {
 
33
                c.Errorf("GetAll failed for old CLs: %v", err)
 
34
                http.Error(w, err.Error(), http.StatusInternalServerError)
 
35
                return
 
36
        }
 
37
        if len(keys) == 0 {
 
38
                return
 
39
        }
 
40
 
 
41
        if err := datastore.DeleteMulti(c, keys); err != nil {
 
42
                c.Errorf("DeleteMulti failed for old CLs: %v", err)
 
43
                http.Error(w, err.Error(), http.StatusInternalServerError)
 
44
                return
 
45
        }
 
46
        c.Infof("Deleted %d old CLs", len(keys))
 
47
}