| OLD | NEW |
| 1 // Copyright 2016 The LUCI Authors. All rights reserved. | 1 // Copyright 2016 The LUCI Authors. All rights reserved. |
| 2 // Use of this source code is governed under the Apache License, Version 2.0 | 2 // Use of this source code is governed under the Apache License, Version 2.0 |
| 3 // that can be found in the LICENSE file. | 3 // that can be found in the LICENSE file. |
| 4 | 4 |
| 5 package buildbucket | 5 package buildbucket |
| 6 | 6 |
| 7 import ( | 7 import ( |
| 8 "errors" |
| 8 "net/http" | 9 "net/http" |
| 9 | 10 |
| 10 "github.com/julienschmidt/httprouter" | 11 "github.com/julienschmidt/httprouter" |
| 11 » "golang.org/x/net/context" | 12 » "github.com/luci/luci-go/milo/appengine/common" |
| 12 | 13 » "github.com/luci/luci-go/server/router" |
| 13 » "github.com/luci/luci-go/milo/appengine/settings" | |
| 14 » "github.com/luci/luci-go/milo/common/miloerror" | |
| 15 "github.com/luci/luci-go/server/templates" | 14 "github.com/luci/luci-go/server/templates" |
| 16 ) | 15 ) |
| 17 | 16 |
| 18 // TODO(nodir): move this value to luci-config. | 17 // TODO(nodir): move this value to luci-config. |
| 19 const defaultServer = "cr-buildbucket.appspot.com" | 18 const defaultServer = "cr-buildbucket.appspot.com" |
| 20 | 19 |
| 21 // Builder displays builder view by fetching builds from buildbucket. | 20 func parseBuilderQuery(r *http.Request, p httprouter.Params) (query builderQuery
, err error) { |
| 22 type Builder struct{} | 21 » query.Server = r.FormValue("server") |
| 23 | 22 » if query.Server == "" { |
| 24 // GetTemplateName for Builder returns the template name for builder pages. | 23 » » query.Server = defaultServer |
| 25 func (b Builder) GetTemplateName(t settings.Theme) string { | |
| 26 » return "builder.html" | |
| 27 } | |
| 28 | |
| 29 // Render renders builder view page. | |
| 30 // Note: The builder html template contains self links to "?limit=123", which co
uld | |
| 31 // potentially override any other request parameters set. | |
| 32 func (b Builder) Render(c context.Context, r *http.Request, p httprouter.Params)
(*templates.Args, error) { | |
| 33 » // Parse URL parameters. | |
| 34 » server := r.FormValue("server") | |
| 35 » if server == "" { | |
| 36 » » server = defaultServer | |
| 37 } | 24 } |
| 38 | 25 |
| 39 » bucket := p.ByName("bucket") | 26 » query.Bucket = p.ByName("bucket") |
| 40 » if bucket == "" { | 27 » if query.Bucket == "" { |
| 41 » » return nil, &miloerror.Error{ | 28 » » err = errors.New("No bucket") |
| 42 » » » Message: "No bucket", | 29 » » return |
| 43 » » » Code: http.StatusBadRequest, | |
| 44 » » } | |
| 45 } | 30 } |
| 46 | 31 |
| 47 builder := p.ByName("builder") | 32 builder := p.ByName("builder") |
| 48 if builder == "" { | 33 if builder == "" { |
| 49 » » return nil, &miloerror.Error{ | 34 » » err = errors.New("No builder") |
| 50 » » » Message: "No builder", | 35 » » return |
| 51 » » » Code: http.StatusBadRequest, | |
| 52 » » } | |
| 53 } | 36 } |
| 54 | 37 |
| 55 // limit is a name of the query string parameter for specifying | 38 // limit is a name of the query string parameter for specifying |
| 56 // maximum number of builds to show. | 39 // maximum number of builds to show. |
| 57 » limit, err := settings.GetLimit(r) | 40 » query.Limit, err = common.GetLimit(r) |
| 41 » return |
| 42 } |
| 43 |
| 44 // BuilderHandler renders the builder view page. |
| 45 // Note: The builder html template contains self links to "?limit=123", which co
uld |
| 46 // potentially override any other request parameters set. |
| 47 func BuilderHandler(c *router.Context) { |
| 48 » query, err := parseBuilderQuery(c.Request, c.Params) |
| 58 if err != nil { | 49 if err != nil { |
| 59 » » return nil, err | 50 » » common.ErrorPage(c, http.StatusBadRequest, err.Error()) |
| 51 » » return |
| 60 } | 52 } |
| 61 | 53 |
| 62 » result, err := builderImpl(c, server, bucket, builder, limit) | 54 » result, err := builderImpl(c.Context, query) |
| 63 if err != nil { | 55 if err != nil { |
| 64 » » return nil, err | 56 » » common.ErrorPage(c, http.StatusInternalServerError, err.Error()) |
| 57 » » return |
| 65 } | 58 } |
| 66 | 59 |
| 67 » // Render into the template | 60 » templates.MustRender(c.Context, c.Writer, "pages/builder.html", template
s.Args{ |
| 68 » args := &templates.Args{ | |
| 69 "Builder": result, | 61 "Builder": result, |
| 70 » } | 62 » }) |
| 71 » return args, nil | |
| 72 } | 63 } |
| OLD | NEW |