// Copyright 2017 The Gitea Authors. All rights reserved. // Use of this source code is governed by a MIT-style // license that can be found in the LICENSE file. package repo import ( "net/http" "code.gitea.io/gitea/models" "code.gitea.io/gitea/modules/context" ) // IssueStopwatch creates or stops a stopwatch for the given issue. func IssueStopwatch(c *context.Context) { issue := GetActionIssue(c) if c.Written() { return } var showSuccessMessage bool if !models.StopwatchExists(c.User.ID, issue.ID) { showSuccessMessage = true } if !c.Repo.CanUseTimetracker(issue, c.User) { c.NotFound("CanUseTimetracker", nil) return } if err := models.CreateOrStopIssueStopwatch(c.User, issue); err != nil { c.ServerError("CreateOrStopIssueStopwatch", err) return } if showSuccessMessage { c.Flash.Success(c.Tr("repo.issues.tracker_auto_close")) } url := issue.HTMLURL() c.Redirect(url, http.StatusSeeOther) } // CancelStopwatch cancel the stopwatch func CancelStopwatch(c *context.Context) { issue := GetActionIssue(c) if c.Written() { return } if !c.Repo.CanUseTimetracker(issue, c.User) { c.NotFound("CanUseTimetracker", nil) return } if err := models.CancelStopwatch(c.User, issue); err != nil { c.ServerError("CancelStopwatch", err) return } url := issue.HTMLURL() c.Redirect(url, http.StatusSeeOther) }