alert: use new url format

pull/10715/head
bergquist 8 years ago
parent d8d82c1769
commit 992fd37010
  1. 17
      pkg/models/dashboards.go
  2. 47
      pkg/services/alerting/eval_context.go
  3. 4
      pkg/services/alerting/notifier.go
  4. 21
      pkg/services/sqlstore/dashboard.go

@ -171,11 +171,16 @@ func GetDashboardFolderUrl(isFolder bool, uid string, slug string) string {
return GetDashboardUrl(uid, slug) return GetDashboardUrl(uid, slug)
} }
// GetDashboardUrl return the html url for a dashboard // Return the html url for a dashboard
func GetDashboardUrl(uid string, slug string) string { func GetDashboardUrl(uid string, slug string) string {
return fmt.Sprintf("%s/d/%s/%s", setting.AppSubUrl, uid, slug) return fmt.Sprintf("%s/d/%s/%s", setting.AppSubUrl, uid, slug)
} }
// Return the full url for a dashboard
func GetFullDashboardUrl(uid string, slug string) string {
return fmt.Sprintf("%s%s", setting.AppUrl, GetDashboardUrl(uid, slug))
}
// GetFolderUrl return the html url for a folder // GetFolderUrl return the html url for a folder
func GetFolderUrl(folderUid string, slug string) string { func GetFolderUrl(folderUid string, slug string) string {
return fmt.Sprintf("%s/dashboards/f/%s/%s", setting.AppSubUrl, folderUid, slug) return fmt.Sprintf("%s/dashboards/f/%s/%s", setting.AppSubUrl, folderUid, slug)
@ -277,3 +282,13 @@ type DashboardPermissionForUser struct {
Permission PermissionType `json:"permission"` Permission PermissionType `json:"permission"`
PermissionName string `json:"permissionName"` PermissionName string `json:"permissionName"`
} }
type DashboardRef struct {
Uid string
Slug string
}
type GetDashboardUIDByIdQuery struct {
Id int64
Result *DashboardRef
}

@ -12,17 +12,19 @@ import (
) )
type EvalContext struct { type EvalContext struct {
Firing bool Firing bool
IsTestRun bool IsTestRun bool
EvalMatches []*EvalMatch EvalMatches []*EvalMatch
Logs []*ResultLogEntry Logs []*ResultLogEntry
Error error Error error
ConditionEvals string ConditionEvals string
StartTime time.Time StartTime time.Time
EndTime time.Time EndTime time.Time
Rule *Rule Rule *Rule
log log.Logger log log.Logger
dashboardSlug string
dashboardRef *m.DashboardRef
ImagePublicUrl string ImagePublicUrl string
ImageOnDiskPath string ImageOnDiskPath string
NoDataFound bool NoDataFound bool
@ -83,29 +85,30 @@ func (c *EvalContext) GetNotificationTitle() string {
return "[" + c.GetStateModel().Text + "] " + c.Rule.Name return "[" + c.GetStateModel().Text + "] " + c.Rule.Name
} }
func (c *EvalContext) GetDashboardSlug() (string, error) { func (c *EvalContext) GetDashboardUID() (*m.DashboardRef, error) {
if c.dashboardSlug != "" { if c.dashboardRef != nil {
return c.dashboardSlug, nil return c.dashboardRef, nil
} }
slugQuery := &m.GetDashboardSlugByIdQuery{Id: c.Rule.DashboardId} uidQuery := &m.GetDashboardUIDByIdQuery{Id: c.Rule.DashboardId}
if err := bus.Dispatch(slugQuery); err != nil { if err := bus.Dispatch(uidQuery); err != nil {
return "", err return nil, err
} }
c.dashboardSlug = slugQuery.Result c.dashboardRef = uidQuery.Result
return c.dashboardSlug, nil return c.dashboardRef, nil
} }
const urlFormat = "%s?fullscreen=true&edit=true&tab=alert&panelId=%d&orgId=%d"
func (c *EvalContext) GetRuleUrl() (string, error) { func (c *EvalContext) GetRuleUrl() (string, error) {
if c.IsTestRun { if c.IsTestRun {
return setting.AppUrl, nil return setting.AppUrl, nil
} }
if slug, err := c.GetDashboardSlug(); err != nil { if ref, err := c.GetDashboardUID(); err != nil {
return "", err return "", err
} else { } else {
ruleUrl := fmt.Sprintf("%sdashboard/db/%s?fullscreen&edit&tab=alert&panelId=%d&orgId=%d", setting.AppUrl, slug, c.Rule.PanelId, c.Rule.OrgId) return fmt.Sprintf(urlFormat, m.GetFullDashboardUrl(ref.Uid, ref.Slug), c.Rule.PanelId, c.Rule.OrgId), nil
return ruleUrl, nil
} }
} }

@ -87,10 +87,10 @@ func (n *notificationService) uploadImage(context *EvalContext) (err error) {
IsAlertContext: true, IsAlertContext: true,
} }
if slug, err := context.GetDashboardSlug(); err != nil { if ref, err := context.GetDashboardUID(); err != nil {
return err return err
} else { } else {
renderOpts.Path = fmt.Sprintf("dashboard-solo/db/%s?&panelId=%d", slug, context.Rule.PanelId) renderOpts.Path = fmt.Sprintf("d-solo/%s/%s?panelId=%d", ref.Uid, ref.Slug, context.Rule.PanelId)
} }
if imagePath, err := renderer.RenderToPng(renderOpts); err != nil { if imagePath, err := renderer.RenderToPng(renderOpts); err != nil {

@ -19,6 +19,7 @@ func init() {
bus.AddHandler("sql", SearchDashboards) bus.AddHandler("sql", SearchDashboards)
bus.AddHandler("sql", GetDashboardTags) bus.AddHandler("sql", GetDashboardTags)
bus.AddHandler("sql", GetDashboardSlugById) bus.AddHandler("sql", GetDashboardSlugById)
bus.AddHandler("sql", GetDashboardUIDById)
bus.AddHandler("sql", GetDashboardsByPluginId) bus.AddHandler("sql", GetDashboardsByPluginId)
bus.AddHandler("sql", GetFoldersForSignedInUser) bus.AddHandler("sql", GetFoldersForSignedInUser)
bus.AddHandler("sql", GetDashboardPermissionsForUser) bus.AddHandler("sql", GetDashboardPermissionsForUser)
@ -159,6 +160,7 @@ func SaveDashboard(cmd *m.SaveDashboardCommand) error {
return err return err
}) })
} }
func generateNewDashboardUid(sess *DBSession, orgId int64) (string, error) { func generateNewDashboardUid(sess *DBSession, orgId int64) (string, error) {
for i := 0; i < 3; i++ { for i := 0; i < 3; i++ {
uid := generateNewUid() uid := generateNewUid()
@ -539,7 +541,7 @@ func GetDashboardSlugById(query *m.GetDashboardSlugByIdQuery) error {
var rawSql = `SELECT slug from dashboard WHERE Id=?` var rawSql = `SELECT slug from dashboard WHERE Id=?`
var slug = DashboardSlugDTO{} var slug = DashboardSlugDTO{}
exists, err := x.Sql(rawSql, query.Id).Get(&slug) exists, err := x.SQL(rawSql, query.Id).Get(&slug)
if err != nil { if err != nil {
return err return err
@ -561,3 +563,20 @@ func GetDashboardsBySlug(query *m.GetDashboardsBySlugQuery) error {
query.Result = dashboards query.Result = dashboards
return nil return nil
} }
func GetDashboardUIDById(query *m.GetDashboardUIDByIdQuery) error {
var rawSql = `SELECT uid, slug from dashboard WHERE Id=?`
us := &m.DashboardRef{}
exists, err := x.SQL(rawSql, query.Id).Get(us)
if err != nil {
return err
} else if exists == false {
return m.ErrDashboardNotFound
}
query.Result = us
return nil
}

Loading…
Cancel
Save