summaryrefslogtreecommitdiffstats
path: root/modules/middleware/repo.go
diff options
context:
space:
mode:
authorFernando San Julián <fjsanjulian@hotmail.com>2015-08-03 21:27:07 +0200
committerFernando San Julián <fjsanjulian@hotmail.com>2015-08-03 21:27:07 +0200
commit6a89eeedf3e2130031ac75b8329037424f936013 (patch)
tree8cc2a45ff69c2d8f394717734ba78ccaabd4fcd8 /modules/middleware/repo.go
parent03011e31fe3afebeca78ccd31a891cbba69f06d5 (diff)
downloadgitea-6a89eeedf3e2130031ac75b8329037424f936013.tar.gz
gitea-6a89eeedf3e2130031ac75b8329037424f936013.zip
browser supports copy detection
Diffstat (limited to 'modules/middleware/repo.go')
-rw-r--r--modules/middleware/repo.go26
1 files changed, 26 insertions, 0 deletions
diff --git a/modules/middleware/repo.go b/modules/middleware/repo.go
index a200d6d66f..e8a362bd4d 100644
--- a/modules/middleware/repo.go
+++ b/modules/middleware/repo.go
@@ -16,6 +16,14 @@ import (
"github.com/gogits/gogs/modules/git"
"github.com/gogits/gogs/modules/log"
"github.com/gogits/gogs/modules/setting"
+
+ "github.com/hashicorp/go-version"
+ "github.com/mssola/user_agent"
+)
+
+const (
+ FIREFOX_COPY_SUPPORT = "41.0"
+ CHROME_COPY_SUPPORT = "43.0.2356"
)
func ApiRepoAssignment() macaron.Handler {
@@ -345,6 +353,24 @@ func RepoAssignment(redirect bool, args ...bool) macaron.Handler {
ctx.Data["BranchName"] = ctx.Repo.BranchName
ctx.Data["CommitId"] = ctx.Repo.CommitId
+
+ userAgent := ctx.Req.Header.Get("User-Agent")
+ ua := user_agent.New(userAgent);
+ browserName, browserVer := ua.Browser()
+
+ sliceVer := strings.Split(browserVer, ".")
+ var max int
+ if max = len(sliceVer); 3 < max {
+ max = 3
+ }
+ browserVer = strings.Join(sliceVer[:max], ".")
+
+ browserVersion, err := version.NewVersion(browserVer)
+ chromeConstraint, err := version.NewConstraint(">= " + CHROME_COPY_SUPPORT)
+ firefoxConstraint, err := version.NewConstraint(">= " + FIREFOX_COPY_SUPPORT)
+
+ ctx.Data["BrowserSupportsCopy"] = (browserName == "Chrome" && chromeConstraint.Check(browserVersion)) || (browserName == "Firefox" && firefoxConstraint.Check(browserVersion))
+
}
}