2018-10-23 04:57:42 +02: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
2022-08-25 10:31:57 +08:00
package activities
2018-10-23 04:57:42 +02:00
import (
2021-09-19 19:49:59 +08:00
"code.gitea.io/gitea/models/db"
2022-03-29 14:29:02 +08:00
"code.gitea.io/gitea/models/organization"
2021-11-24 17:49:20 +08:00
user_model "code.gitea.io/gitea/models/user"
2018-10-23 04:57:42 +02:00
"code.gitea.io/gitea/modules/setting"
2019-08-15 22:46:21 +08:00
"code.gitea.io/gitea/modules/timeutil"
2018-10-23 04:57:42 +02:00
)
// UserHeatmapData represents the data needed to create a heatmap
type UserHeatmapData struct {
2019-08-15 22:46:21 +08:00
Timestamp timeutil . TimeStamp ` json:"timestamp" `
Contributions int64 ` json:"contributions" `
2018-10-23 04:57:42 +02:00
}
// GetUserHeatmapDataByUser returns an array of UserHeatmapData
2021-11-24 17:49:20 +08:00
func GetUserHeatmapDataByUser ( user , doer * user_model . User ) ( [ ] * UserHeatmapData , error ) {
2020-12-27 20:58:03 +01:00
return getUserHeatmapData ( user , nil , doer )
}
// GetUserHeatmapDataByUserTeam returns an array of UserHeatmapData
2022-03-29 14:29:02 +08:00
func GetUserHeatmapDataByUserTeam ( user * user_model . User , team * organization . Team , doer * user_model . User ) ( [ ] * UserHeatmapData , error ) {
2020-12-27 20:58:03 +01:00
return getUserHeatmapData ( user , team , doer )
}
2022-03-29 14:29:02 +08:00
func getUserHeatmapData ( user * user_model . User , team * organization . Team , doer * user_model . User ) ( [ ] * UserHeatmapData , error ) {
2018-10-24 15:17:21 +02:00
hdata := make ( [ ] * UserHeatmapData , 0 )
2020-06-05 22:01:53 +02:00
2022-08-25 10:31:57 +08:00
if ! ActivityReadable ( user , doer ) {
2020-06-05 22:01:53 +02:00
return hdata , nil
}
2021-06-25 12:59:25 -04: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-15 02:52:12 +08:00
groupByName := "timestamp" // We need this extra case because mssql doesn't allow grouping by alias
2018-10-23 04:57:42 +02:00
switch {
2019-08-24 17:24:45 +08:00
case setting . Database . UseMySQL :
2021-06-25 12:59:25 -04:00
groupBy = "created_unix DIV 900 * 900"
2019-08-24 17:24:45 +08:00
case setting . Database . UseMSSQL :
2018-11-01 19:12:17 +01:00
groupByName = groupBy
2018-10-23 04:57:42 +02:00
}
2020-12-22 02:53:37 +00:00
cond , err := activityQueryCondition ( GetFeedsOptions {
RequestedUser : user ,
2020-12-27 20:58:03 +01:00
RequestedTeam : team ,
2020-12-22 02:53:37 +00: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 20:29:05 +01:00
}
2021-09-23 16:45:36 +01:00
return hdata , db . GetEngine ( db . DefaultContext ) .
2020-12-22 02:53:37 +00:00
Select ( groupBy + " AS timestamp, count(user_id) as contributions" ) .
Table ( "action" ) .
Where ( cond ) .
2021-04-09 09:40:34 +02:00
And ( "created_unix > ?" , timeutil . TimeStampNow ( ) - 31536000 ) .
2020-12-22 02:53:37 +00:00
GroupBy ( groupByName ) .
2018-10-23 04:57:42 +02:00
OrderBy ( "timestamp" ) .
Find ( & hdata )
}