|
|
@@ -3,14 +3,12 @@ package api
|
|
|
import (
|
|
|
"github.com/grafana/grafana/pkg/bus"
|
|
|
"github.com/grafana/grafana/pkg/middleware"
|
|
|
- m "github.com/grafana/grafana/pkg/models"
|
|
|
"github.com/grafana/grafana/pkg/services/search"
|
|
|
)
|
|
|
|
|
|
func Search(c *middleware.Context) {
|
|
|
query := c.Query("query")
|
|
|
tag := c.Query("tag")
|
|
|
- tagcloud := c.Query("tagcloud")
|
|
|
starred := c.Query("starred")
|
|
|
limit := c.QueryInt("limit")
|
|
|
|
|
|
@@ -18,41 +16,20 @@ func Search(c *middleware.Context) {
|
|
|
limit = 200
|
|
|
}
|
|
|
|
|
|
- result := m.SearchResult{
|
|
|
- Dashboards: []*m.DashboardSearchHit{},
|
|
|
- Tags: []*m.DashboardTagCloudItem{},
|
|
|
+ searchQuery := search.Query{
|
|
|
+ Title: query,
|
|
|
+ Tag: tag,
|
|
|
+ UserId: c.UserId,
|
|
|
+ Limit: limit,
|
|
|
+ IsStarred: starred == "true",
|
|
|
+ OrgId: c.OrgId,
|
|
|
}
|
|
|
|
|
|
- if tagcloud == "true" {
|
|
|
-
|
|
|
- query := m.GetDashboardTagsQuery{OrgId: c.OrgId}
|
|
|
- err := bus.Dispatch(&query)
|
|
|
- if err != nil {
|
|
|
- c.JsonApiErr(500, "Failed to get tags from database", err)
|
|
|
- return
|
|
|
- }
|
|
|
- result.Tags = query.Result
|
|
|
- result.TagsOnly = true
|
|
|
-
|
|
|
- } else {
|
|
|
-
|
|
|
- query := search.Query{
|
|
|
- Title: query,
|
|
|
- Tag: tag,
|
|
|
- UserId: c.UserId,
|
|
|
- Limit: limit,
|
|
|
- IsStarred: starred == "true",
|
|
|
- OrgId: c.OrgId,
|
|
|
- }
|
|
|
-
|
|
|
- err := bus.Dispatch(&query)
|
|
|
- if err != nil {
|
|
|
- c.JsonApiErr(500, "Search failed", err)
|
|
|
- return
|
|
|
- }
|
|
|
-
|
|
|
- result.Dashboards = query.Result
|
|
|
+ err := bus.Dispatch(&searchQuery)
|
|
|
+ if err != nil {
|
|
|
+ c.JsonApiErr(500, "Search failed", err)
|
|
|
+ return
|
|
|
}
|
|
|
|
|
|
- c.JSON(200, result)
|
|
|
+ c.JSON(200, searchQuery.Result)
|
|
|
}
|