2018-10-23 05:57:42 +03:00
// Copyright 2018 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 models
package models
import (
"code.gitea.io/gitea/modules/setting"
2019-08-15 17:46:21 +03:00
"code.gitea.io/gitea/modules/timeutil"
2018-10-23 05:57:42 +03:00
)
// UserHeatmapData represents the data needed to create a heatmap
type UserHeatmapData struct {
2019-08-15 17:46:21 +03:00
Timestamp timeutil . TimeStamp ` json:"timestamp" `
Contributions int64 ` json:"contributions" `
2018-10-23 05:57:42 +03:00
}
// GetUserHeatmapDataByUser returns an array of UserHeatmapData
2018-10-24 16:17:21 +03:00
func GetUserHeatmapDataByUser ( user * User ) ( [ ] * UserHeatmapData , error ) {
hdata := make ( [ ] * UserHeatmapData , 0 )
2020-06-05 23:01:53 +03:00
if user . KeepActivityPrivate {
return hdata , nil
}
2018-10-23 05:57:42 +03:00
var groupBy string
2018-11-01 21:12:17 +03:00
var groupByName = "timestamp" // We need this extra case because mssql doesn't allow grouping by alias
2018-10-23 05:57:42 +03:00
switch {
2019-08-24 12:24:45 +03:00
case setting . Database . UseSQLite3 :
2018-10-23 05:57:42 +03:00
groupBy = "strftime('%s', strftime('%Y-%m-%d', created_unix, 'unixepoch'))"
2019-08-24 12:24:45 +03:00
case setting . Database . UseMySQL :
2018-10-31 23:56:32 +03:00
groupBy = "UNIX_TIMESTAMP(DATE(FROM_UNIXTIME(created_unix)))"
2019-08-24 12:24:45 +03:00
case setting . Database . UsePostgreSQL :
2018-10-23 05:57:42 +03:00
groupBy = "extract(epoch from date_trunc('day', to_timestamp(created_unix)))"
2019-08-24 12:24:45 +03:00
case setting . Database . UseMSSQL :
2018-12-11 05:05:24 +03:00
groupBy = "datediff(SECOND, '19700101', dateadd(DAY, 0, datediff(day, 0, dateadd(s, created_unix, '19700101'))))"
2018-11-01 21:12:17 +03:00
groupByName = groupBy
2018-10-23 05:57:42 +03:00
}
2019-01-06 22:29:05 +03:00
sess := x . Select ( groupBy + " AS timestamp, count(user_id) as contributions" ) .
2018-10-23 05:57:42 +03:00
Table ( "action" ) .
Where ( "user_id = ?" , user . ID ) .
2019-08-15 17:46:21 +03:00
And ( "created_unix > ?" , ( timeutil . TimeStampNow ( ) - 31536000 ) )
2019-01-06 22:29:05 +03:00
// * Heatmaps for individual users only include actions that the user themself
// did.
// * For organizations actions by all users that were made in owned
// repositories are counted.
if user . Type == UserTypeIndividual {
sess = sess . And ( "act_user_id = ?" , user . ID )
}
err := sess . GroupBy ( groupByName ) .
2018-10-23 05:57:42 +03:00
OrderBy ( "timestamp" ) .
Find ( & hdata )
2019-01-06 22:29:05 +03:00
2018-10-24 16:17:21 +03:00
return hdata , err
2018-10-23 05:57:42 +03:00
}