mirror of
https://github.com/casdoor/casdoor.git
synced 2025-05-24 08:20:31 +08:00
feat: speed up GetDashboard() by only fetching last 30 days data (#3458)
* feat: only check 30 days data * refactor: refactor GetDashboard to reduce code line * refactor: refactor GetDashboard to reduce code line * refactor: remove unused where * fix: fix error code
This commit is contained in:
parent
0636069584
commit
8927e08217
@ -19,299 +19,81 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Dashboard struct {
|
|
||||||
OrganizationCounts []int `json:"organizationCounts"`
|
|
||||||
UserCounts []int `json:"userCounts"`
|
|
||||||
ProviderCounts []int `json:"providerCounts"`
|
|
||||||
ApplicationCounts []int `json:"applicationCounts"`
|
|
||||||
SubscriptionCounts []int `json:"subscriptionCounts"`
|
|
||||||
RoleCounts []int `json:"roleCounts"`
|
|
||||||
GroupCounts []int `json:"groupCounts"`
|
|
||||||
ResourceCounts []int `json:"resourceCounts"`
|
|
||||||
CertCounts []int `json:"certCounts"`
|
|
||||||
PermissionCounts []int `json:"permissionCounts"`
|
|
||||||
TransactionCounts []int `json:"transactionCounts"`
|
|
||||||
ModelCounts []int `json:"modelCounts"`
|
|
||||||
AdapterCounts []int `json:"adapterCounts"`
|
|
||||||
EnforcerCounts []int `json:"enforcerCounts"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type DashboardDateItem struct {
|
type DashboardDateItem struct {
|
||||||
CreatedTime string `json:"createTime"`
|
CreatedTime string `json:"createTime"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetDashboard(owner string) (*Dashboard, error) {
|
type DashboardMapItem struct {
|
||||||
|
dashboardDateItems []DashboardDateItem
|
||||||
|
itemCount int64
|
||||||
|
}
|
||||||
|
|
||||||
|
func GetDashboard(owner string) (*map[string][]int64, error) {
|
||||||
if owner == "All" {
|
if owner == "All" {
|
||||||
owner = ""
|
owner = ""
|
||||||
}
|
}
|
||||||
|
|
||||||
dashboard := &Dashboard{
|
dashboard := make(map[string][]int64)
|
||||||
OrganizationCounts: make([]int, 31),
|
dashboardMap := sync.Map{}
|
||||||
UserCounts: make([]int, 31),
|
tableNames := []string{"organization", "user", "provider", "application", "subscription", "role", "group", "resource", "cert", "permission", "transaction", "model", "adapter", "enforcer"}
|
||||||
ProviderCounts: make([]int, 31),
|
|
||||||
ApplicationCounts: make([]int, 31),
|
time30day := time.Now().AddDate(0, 0, -30)
|
||||||
SubscriptionCounts: make([]int, 31),
|
var wg sync.WaitGroup
|
||||||
RoleCounts: make([]int, 31),
|
var err error
|
||||||
GroupCounts: make([]int, 31),
|
wg.Add(len(tableNames))
|
||||||
ResourceCounts: make([]int, 31),
|
|
||||||
CertCounts: make([]int, 31),
|
for _, tableName := range tableNames {
|
||||||
PermissionCounts: make([]int, 31),
|
dashboard[tableName+"Counts"] = make([]int64, 31)
|
||||||
TransactionCounts: make([]int, 31),
|
tableName := tableName
|
||||||
ModelCounts: make([]int, 31),
|
go func() {
|
||||||
AdapterCounts: make([]int, 31),
|
defer wg.Done()
|
||||||
EnforcerCounts: make([]int, 31),
|
dashboardDateItems := []DashboardDateItem{}
|
||||||
|
var countResult int64
|
||||||
|
|
||||||
|
dbQueryBefore := ormer.Engine.Cols("created_time")
|
||||||
|
dbQueryAfter := ormer.Engine.Cols("created_time")
|
||||||
|
|
||||||
|
if owner != "" {
|
||||||
|
dbQueryAfter = dbQueryAfter.And("owner = ?", owner)
|
||||||
|
dbQueryBefore = dbQueryBefore.And("owner = ?", owner)
|
||||||
|
}
|
||||||
|
|
||||||
|
if countResult, err = dbQueryBefore.And("created_time < ?", time30day).Table(tableName).Count(); err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
if err = dbQueryAfter.And("created_time >= ?", time30day).Table(tableName).Find(&dashboardDateItems); err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
dashboardMap.Store(tableName, DashboardMapItem{
|
||||||
|
dashboardDateItems: dashboardDateItems,
|
||||||
|
itemCount: countResult,
|
||||||
|
})
|
||||||
|
}()
|
||||||
}
|
}
|
||||||
|
|
||||||
organizations := []DashboardDateItem{}
|
|
||||||
users := []DashboardDateItem{}
|
|
||||||
providers := []DashboardDateItem{}
|
|
||||||
applications := []DashboardDateItem{}
|
|
||||||
subscriptions := []DashboardDateItem{}
|
|
||||||
roles := []DashboardDateItem{}
|
|
||||||
groups := []DashboardDateItem{}
|
|
||||||
resources := []DashboardDateItem{}
|
|
||||||
certs := []DashboardDateItem{}
|
|
||||||
permissions := []DashboardDateItem{}
|
|
||||||
transactions := []DashboardDateItem{}
|
|
||||||
models := []DashboardDateItem{}
|
|
||||||
adapters := []DashboardDateItem{}
|
|
||||||
enforcers := []DashboardDateItem{}
|
|
||||||
|
|
||||||
var wg sync.WaitGroup
|
|
||||||
wg.Add(14)
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
if err := ormer.Engine.Table(&Organization{}).Select("created_time").Find(&organizations, &Organization{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
|
|
||||||
if err := ormer.Engine.Table(&User{}).Select("created_time").Find(&users, &User{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
|
|
||||||
if err := ormer.Engine.Table(&Provider{}).Select("created_time").Find(&providers, &Provider{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
|
|
||||||
if err := ormer.Engine.Table(&Application{}).Select("created_time").Find(&applications, &Application{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
|
|
||||||
if err := ormer.Engine.Table(&Subscription{}).Select("created_time").Find(&subscriptions, &Subscription{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
|
|
||||||
if err := ormer.Engine.Table(&Role{}).Select("created_time").Find(&roles, &Role{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
|
|
||||||
if err := ormer.Engine.Table(&Group{}).Find(&groups, &Group{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
if err := ormer.Engine.Table(&Resource{}).Select("created_time").Find(&resources, &Resource{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
if err := ormer.Engine.Table(&Cert{}).Select("created_time").Find(&certs, &Cert{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
if err := ormer.Engine.Table(&Permission{}).Select("created_time").Find(&permissions, &Permission{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
if err := ormer.Engine.Table(&Transaction{}).Select("created_time").Find(&transactions, &Transaction{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
if err := ormer.Engine.Table(&Model{}).Select("created_time").Find(&models, &Model{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
if err := ormer.Engine.Table(&Adapter{}).Select("created_time").Find(&adapters, &Adapter{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
go func() {
|
|
||||||
defer wg.Done()
|
|
||||||
if err := ormer.Engine.Table(&Enforcer{}).Select("created_time").Find(&enforcers, &Enforcer{Owner: owner}); err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
|
|
||||||
nowTime := time.Now()
|
nowTime := time.Now()
|
||||||
for i := 30; i >= 0; i-- {
|
for i := 30; i >= 0; i-- {
|
||||||
cutTime := nowTime.AddDate(0, 0, -i)
|
cutTime := nowTime.AddDate(0, 0, -i)
|
||||||
dashboard.OrganizationCounts[30-i] = countCreatedBefore(organizations, cutTime)
|
for _, tableName := range tableNames {
|
||||||
dashboard.UserCounts[30-i] = countCreatedBefore(users, cutTime)
|
item, exist := dashboardMap.Load(tableName)
|
||||||
dashboard.ProviderCounts[30-i] = countCreatedBefore(providers, cutTime)
|
if !exist {
|
||||||
dashboard.ApplicationCounts[30-i] = countCreatedBefore(applications, cutTime)
|
continue
|
||||||
dashboard.SubscriptionCounts[30-i] = countCreatedBefore(subscriptions, cutTime)
|
}
|
||||||
dashboard.RoleCounts[30-i] = countCreatedBefore(roles, cutTime)
|
dashboard[tableName+"Counts"][30-i] = countCreatedBefore(item.(DashboardMapItem), cutTime)
|
||||||
dashboard.GroupCounts[30-i] = countCreatedBefore(groups, cutTime)
|
}
|
||||||
dashboard.ResourceCounts[30-i] = countCreatedBefore(resources, cutTime)
|
|
||||||
dashboard.CertCounts[30-i] = countCreatedBefore(certs, cutTime)
|
|
||||||
dashboard.PermissionCounts[30-i] = countCreatedBefore(permissions, cutTime)
|
|
||||||
dashboard.TransactionCounts[30-i] = countCreatedBefore(transactions, cutTime)
|
|
||||||
dashboard.ModelCounts[30-i] = countCreatedBefore(models, cutTime)
|
|
||||||
dashboard.AdapterCounts[30-i] = countCreatedBefore(adapters, cutTime)
|
|
||||||
dashboard.EnforcerCounts[30-i] = countCreatedBefore(enforcers, cutTime)
|
|
||||||
}
|
}
|
||||||
return dashboard, nil
|
return &dashboard, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func countCreatedBefore(objects interface{}, before time.Time) int {
|
func countCreatedBefore(dashboardMapItem DashboardMapItem, before time.Time) int64 {
|
||||||
count := 0
|
count := dashboardMapItem.itemCount
|
||||||
switch obj := objects.(type) {
|
for _, e := range dashboardMapItem.dashboardDateItems {
|
||||||
case []Organization:
|
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", e.CreatedTime)
|
||||||
for _, o := range obj {
|
if createdTime.Before(before) {
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", o.CreatedTime)
|
count++
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []User:
|
|
||||||
for _, u := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", u.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []Provider:
|
|
||||||
for _, p := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", p.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []Application:
|
|
||||||
for _, a := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", a.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []Subscription:
|
|
||||||
for _, s := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", s.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []Role:
|
|
||||||
for _, r := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", r.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []Group:
|
|
||||||
for _, g := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", g.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []Resource:
|
|
||||||
for _, r := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", r.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []Cert:
|
|
||||||
for _, c := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", c.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []Permission:
|
|
||||||
for _, p := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", p.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []Transaction:
|
|
||||||
for _, t := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", t.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []Model:
|
|
||||||
for _, m := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", m.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []Adapter:
|
|
||||||
for _, a := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", a.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []Enforcer:
|
|
||||||
for _, e := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", e.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case []DashboardDateItem:
|
|
||||||
for _, e := range obj {
|
|
||||||
createdTime, _ := time.Parse("2006-01-02T15:04:05-07:00", e.CreatedTime)
|
|
||||||
if createdTime.Before(before) {
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return count
|
return count
|
||||||
|
Loading…
x
Reference in New Issue
Block a user