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
2021-03-14 21:52:12 +03:00
func GetUserHeatmapDataByUser ( user , doer * User ) ( [ ] * UserHeatmapData , error ) {
2020-12-27 22:58:03 +03:00
return getUserHeatmapData ( user , nil , doer )
}
// GetUserHeatmapDataByUserTeam returns an array of UserHeatmapData
func GetUserHeatmapDataByUserTeam ( user * User , team * Team , doer * User ) ( [ ] * UserHeatmapData , error ) {
return getUserHeatmapData ( user , team , doer )
}
func getUserHeatmapData ( user * User , team * Team , doer * User ) ( [ ] * UserHeatmapData , error ) {
2018-10-24 16:17:21 +03:00
hdata := make ( [ ] * UserHeatmapData , 0 )
2020-06-05 23:01:53 +03:00
2020-12-22 05:53:37 +03:00
if ! activityReadable ( user , doer ) {
2020-06-05 23:01:53 +03:00
return hdata , nil
}
2021-06-25 19:59:25 +03:00
// Group by 15 minute intervals which will allow the client to accurately shift the timestamp to their timezone.
// The interval is based on the fact that there are timezones such as UTC +5:30 and UTC +12:45.
groupBy := "created_unix / 900 * 900"
2021-03-14 21:52:12 +03:00
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 . UseMySQL :
2021-06-25 19:59:25 +03:00
groupBy = "created_unix DIV 900 * 900"
2019-08-24 12:24:45 +03:00
case setting . Database . UseMSSQL :
2018-11-01 21:12:17 +03:00
groupByName = groupBy
2018-10-23 05:57:42 +03:00
}
2020-12-22 05:53:37 +03:00
cond , err := activityQueryCondition ( GetFeedsOptions {
RequestedUser : user ,
2020-12-27 22:58:03 +03:00
RequestedTeam : team ,
2020-12-22 05:53:37 +03:00
Actor : doer ,
IncludePrivate : true , // don't filter by private, as we already filter by repo access
IncludeDeleted : true ,
// * 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.
OnlyPerformedBy : ! user . IsOrganization ( ) ,
} )
if err != nil {
return nil , err
2019-01-06 22:29:05 +03:00
}
2020-12-22 05:53:37 +03:00
return hdata , x .
Select ( groupBy + " AS timestamp, count(user_id) as contributions" ) .
Table ( "action" ) .
Where ( cond ) .
2021-04-09 10:40:34 +03:00
And ( "created_unix > ?" , timeutil . TimeStampNow ( ) - 31536000 ) .
2020-12-22 05:53:37 +03:00
GroupBy ( groupByName ) .
2018-10-23 05:57:42 +03:00
OrderBy ( "timestamp" ) .
Find ( & hdata )
}