| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | // GoToSocial | 
					
						
							|  |  |  | // Copyright (C) GoToSocial Authors admin@gotosocial.org | 
					
						
							|  |  |  | // SPDX-License-Identifier: AGPL-3.0-or-later | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  | // it under the terms of the GNU Affero General Public License as published by | 
					
						
							|  |  |  | // the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  | // (at your option) any later version. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  | // GNU Affero General Public License for more details. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  | // along with this program.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package cache | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2024-09-23 11:53:42 +00:00
										 |  |  | 	"sync/atomic" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-26 15:34:10 +02:00
										 |  |  | 	"code.superseriousbusiness.org/gotosocial/internal/cache/domain" | 
					
						
							|  |  |  | 	"code.superseriousbusiness.org/gotosocial/internal/config" | 
					
						
							|  |  |  | 	"code.superseriousbusiness.org/gotosocial/internal/gtsmodel" | 
					
						
							|  |  |  | 	"code.superseriousbusiness.org/gotosocial/internal/log" | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	"codeberg.org/gruf/go-structr" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | type DBCaches struct { | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	// Account provides access to the gtsmodel Account database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Account StructCache[*gtsmodel.Account] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// AccountNote provides access to the gtsmodel Note database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	AccountNote StructCache[*gtsmodel.AccountNote] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-22 14:03:46 +01:00
										 |  |  | 	// AccountSettings provides access to the gtsmodel AccountSettings database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	AccountSettings StructCache[*gtsmodel.AccountSettings] | 
					
						
							| 
									
										
										
										
											2024-03-22 14:03:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-16 13:10:13 +02:00
										 |  |  | 	// AccountStats provides access to the gtsmodel AccountStats database cache. | 
					
						
							|  |  |  | 	AccountStats StructCache[*gtsmodel.AccountStats] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	// Application provides access to the gtsmodel Application database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Application StructCache[*gtsmodel.Application] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Block provides access to the gtsmodel Block (account) database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Block StructCache[*gtsmodel.Block] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-06 09:38:02 -07:00
										 |  |  | 	// BlockIDs provides access to the block IDs database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	BlockIDs SliceCache[string] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// BoostOfIDs provides access to the boost of IDs list database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	BoostOfIDs SliceCache[string] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-23 12:44:31 -07:00
										 |  |  | 	// Conversation provides access to the gtsmodel Conversation database cache. | 
					
						
							|  |  |  | 	Conversation StructCache[*gtsmodel.Conversation] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// ConversationLastStatusIDs provides access to the conversation last status IDs database cache. | 
					
						
							|  |  |  | 	ConversationLastStatusIDs SliceCache[string] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	// DomainAllow provides access to the domain allow database cache. | 
					
						
							|  |  |  | 	DomainAllow *domain.Cache | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// DomainBlock provides access to the domain block database cache. | 
					
						
							|  |  |  | 	DomainBlock *domain.Cache | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 14:09:58 +01:00
										 |  |  | 	// DomainPermissionDraft provides access to the domain permission draft database cache. | 
					
						
							|  |  |  | 	DomainPermissionDraft StructCache[*gtsmodel.DomainPermissionDraft] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-05 13:20:33 +01:00
										 |  |  | 	// DomainPermissionSubscription provides access to the domain permission subscription database cache. | 
					
						
							|  |  |  | 	DomainPermissionSubscription StructCache[*gtsmodel.DomainPermissionSubscription] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 14:09:58 +01:00
										 |  |  | 	// DomainPermissionExclude provides access to the domain permission exclude database cache. | 
					
						
							|  |  |  | 	DomainPermissionExclude *domain.Cache | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	// Emoji provides access to the gtsmodel Emoji database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Emoji StructCache[*gtsmodel.Emoji] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// EmojiCategory provides access to the gtsmodel EmojiCategory database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	EmojiCategory StructCache[*gtsmodel.EmojiCategory] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 02:15:58 -08:00
										 |  |  | 	// Filter provides access to the gtsmodel Filter database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Filter StructCache[*gtsmodel.Filter] | 
					
						
							| 
									
										
										
										
											2024-03-06 02:15:58 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// FilterKeyword provides access to the gtsmodel FilterKeyword database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	FilterKeyword StructCache[*gtsmodel.FilterKeyword] | 
					
						
							| 
									
										
										
										
											2024-03-06 02:15:58 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// FilterStatus provides access to the gtsmodel FilterStatus database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	FilterStatus StructCache[*gtsmodel.FilterStatus] | 
					
						
							| 
									
										
										
										
											2024-03-06 02:15:58 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	// Follow provides access to the gtsmodel Follow database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Follow StructCache[*gtsmodel.Follow] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// FollowIDs provides access to the follower / following IDs database cache. | 
					
						
							|  |  |  | 	// THIS CACHE IS KEYED AS THE FOLLOWING {prefix}{accountID} WHERE PREFIX IS: | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | 	// | 
					
						
							|  |  |  | 	// - '>{$accountID}'  for following IDs | 
					
						
							|  |  |  | 	//   e.g. FollowIDs.Load(">" + account.ID, func() {}) | 
					
						
							|  |  |  | 	//   which will load a slice of follows IDs FROM account. | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	// - 'l>{$accountID}' for local following IDs | 
					
						
							|  |  |  | 	//   e.g. FollowIDs.Load("l>" + account.ID, func() {}) | 
					
						
							|  |  |  | 	//   which will load a slice of LOCAL follows IDs FROM account. | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	// - '<{$accountID}' for follower IDs | 
					
						
							|  |  |  | 	//   e.g. FollowIDs.Load("<" + account.ID, func() {}) | 
					
						
							|  |  |  | 	//   which will load a slice of follows IDs TARGETTING account. | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	// - 'l<{$accountID}' for local follower IDs | 
					
						
							|  |  |  | 	//   e.g. FollowIDs.Load("l<" + account.ID, func() {}) | 
					
						
							|  |  |  | 	//   which will load a slice of LOCAL follows IDs TARGETTING account. | 
					
						
							|  |  |  | 	// | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	FollowIDs SliceCache[string] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// FollowRequest provides access to the gtsmodel FollowRequest database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	FollowRequest StructCache[*gtsmodel.FollowRequest] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// FollowRequestIDs provides access to the follow requester / requesting IDs database | 
					
						
							|  |  |  | 	// cache. THIS CACHE IS KEYED AS THE FOLLOWING {prefix}{accountID} WHERE PREFIX IS: | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | 	// | 
					
						
							|  |  |  | 	// - '>{$accountID}'  for follow request IDs | 
					
						
							|  |  |  | 	//   e.g. FollowRequestIDs.Load(">" + account.ID, func() {}) | 
					
						
							|  |  |  | 	//   which will load a slice of follow request IDs TARGETTING account. | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	// - '<{$accountID}'  for follow request IDs | 
					
						
							|  |  |  | 	//   e.g. FollowRequestIDs.Load("<" + account.ID, func() {}) | 
					
						
							|  |  |  | 	//   which will load a slice of follow request IDs FROM account. | 
					
						
							|  |  |  | 	// | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	FollowRequestIDs SliceCache[string] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | 	// FollowingTagIDs provides access to account IDs following / tag IDs followed by | 
					
						
							|  |  |  | 	// account db cache. THIS CACHE IS KEYED AS THE FOLLOWING {prefix}{id} WHERE: | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	// - '>{$accountID}' for tag IDs followed by account | 
					
						
							|  |  |  | 	//   e.g. FollowingTagIDs.Load(">" + account.ID, func() {}) | 
					
						
							|  |  |  | 	//   which will load a slice of tag IDs followed by account. | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	// - '<{$tagIDs}' for account IDs following tag | 
					
						
							|  |  |  | 	//   e.g. FollowingTagIDs.Load("<" + tag.ID, func() {}) | 
					
						
							|  |  |  | 	//   which will load a slice of account IDs following tag. | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	FollowingTagIDs SliceCache[string] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	// Instance provides access to the gtsmodel Instance database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Instance StructCache[*gtsmodel.Instance] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-23 11:53:42 +00:00
										 |  |  | 	// LocalInstance provides caching for | 
					
						
							|  |  |  | 	// simple + common local instance queries. | 
					
						
							|  |  |  | 	LocalInstance struct { | 
					
						
							|  |  |  | 		Domains  atomic.Pointer[int] | 
					
						
							|  |  |  | 		Statuses atomic.Pointer[int] | 
					
						
							|  |  |  | 		Users    atomic.Pointer[int] | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-24 11:49:37 +02:00
										 |  |  | 	// InteractionRequest provides access to the gtsmodel InteractionRequest database cache. | 
					
						
							|  |  |  | 	InteractionRequest StructCache[*gtsmodel.InteractionRequest] | 
					
						
							| 
									
										
										
										
											2024-07-11 16:44:29 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	// InReplyToIDs provides access to the status in reply to IDs list database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	InReplyToIDs SliceCache[string] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// List provides access to the gtsmodel List database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	List StructCache[*gtsmodel.List] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | 	// ListIDs provides access to the list IDs owned by account / list IDs follow | 
					
						
							|  |  |  | 	// contained in db cache. THIS CACHE IS KEYED AS FOLLOWING {prefix}{id} WHERE: | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	// - 'a{$accountID}' for list IDs owned by account | 
					
						
							|  |  |  | 	//   e.g. ListIDs.Load("a" + account.ID, func() {}) | 
					
						
							|  |  |  | 	//   which will load a slice of list IDs owned by account. | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	// - 'f{$followID}' for list IDs follow contained in | 
					
						
							|  |  |  | 	//   e.g. ListIDs.Load("f" + follow.ID, func() {}) | 
					
						
							|  |  |  | 	//   which will load a slice of list IDs containing follow. | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	ListIDs SliceCache[string] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// ListedIDs provides access to the account IDs in list / follow IDs in | 
					
						
							|  |  |  | 	// list db cache. THIS CACHE IS KEYED AS FOLLOWING {prefix}{id} WHERE: | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	// - 'a{listID}' for account IDs in list ID | 
					
						
							|  |  |  | 	//   e.g. ListedIDs.Load("a" + list.ID, func() {}) | 
					
						
							|  |  |  | 	//   which will load a slice of account IDs in list. | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	// - 'f{listID}' for follow IDs in list ID | 
					
						
							|  |  |  | 	//   e.g. ListedIDs.Load("f" + list.ID, func() {}) | 
					
						
							|  |  |  | 	//   which will load a slice of follow IDs in list. | 
					
						
							|  |  |  | 	// | 
					
						
							|  |  |  | 	ListedIDs SliceCache[string] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Marker provides access to the gtsmodel Marker database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Marker StructCache[*gtsmodel.Marker] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Media provides access to the gtsmodel Media database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Media StructCache[*gtsmodel.MediaAttachment] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Mention provides access to the gtsmodel Mention database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Mention StructCache[*gtsmodel.Mention] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 11:18:57 +01:00
										 |  |  | 	// Move provides access to the gtsmodel Move database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Move StructCache[*gtsmodel.Move] | 
					
						
							| 
									
										
										
										
											2024-03-06 11:18:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	// Notification provides access to the gtsmodel Notification database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Notification StructCache[*gtsmodel.Notification] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Poll provides access to the gtsmodel Poll database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Poll StructCache[*gtsmodel.Poll] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// PollVote provides access to the gtsmodel PollVote database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	PollVote StructCache[*gtsmodel.PollVote] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// PollVoteIDs provides access to the poll vote IDs list database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	PollVoteIDs SliceCache[string] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Report provides access to the gtsmodel Report database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Report StructCache[*gtsmodel.Report] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 14:34:49 +02:00
										 |  |  | 	// SinBinStatus provides access to the gtsmodel SinBinStatus database cache. | 
					
						
							|  |  |  | 	SinBinStatus StructCache[*gtsmodel.SinBinStatus] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	// Status provides access to the gtsmodel Status database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Status StructCache[*gtsmodel.Status] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | 	// StatusBookmark provides access to the gtsmodel StatusBookmark database cache. | 
					
						
							| 
									
										
										
										
											2024-06-06 10:44:43 +00:00
										 |  |  | 	StatusBookmark StructCache[*gtsmodel.StatusBookmark] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | 	// StatusBookmarkIDs provides access to the status bookmark IDs list database cache. | 
					
						
							| 
									
										
										
										
											2024-06-06 10:44:43 +00:00
										 |  |  | 	StatusBookmarkIDs SliceCache[string] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-05 13:35:07 +00:00
										 |  |  | 	// StatusEdit provides access to the gtsmodel StatusEdit database cache. | 
					
						
							|  |  |  | 	StatusEdit StructCache[*gtsmodel.StatusEdit] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	// StatusFave provides access to the gtsmodel StatusFave database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	StatusFave StructCache[*gtsmodel.StatusFave] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// StatusFaveIDs provides access to the status fave IDs list database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	StatusFaveIDs SliceCache[string] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Tag provides access to the gtsmodel Tag database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Tag StructCache[*gtsmodel.Tag] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-06 21:29:31 +00:00
										 |  |  | 	// ThreadMute provides access to the gtsmodel ThreadMute database cache. | 
					
						
							|  |  |  | 	ThreadMute StructCache[*gtsmodel.ThreadMute] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-15 14:22:21 +01:00
										 |  |  | 	// Token provides access to the gtsmodel Token database cache. | 
					
						
							|  |  |  | 	Token StructCache[*gtsmodel.Token] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	// Tombstone provides access to the gtsmodel Tombstone database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	Tombstone StructCache[*gtsmodel.Tombstone] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// User provides access to the gtsmodel User database cache. | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 	User StructCache[*gtsmodel.User] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-06 09:38:02 -07:00
										 |  |  | 	// UserMute provides access to the gtsmodel UserMute database cache. | 
					
						
							|  |  |  | 	UserMute StructCache[*gtsmodel.UserMute] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// UserMuteIDs provides access to the user mute IDs database cache. | 
					
						
							|  |  |  | 	UserMuteIDs SliceCache[string] | 
					
						
							| 
									
										
										
										
											2025-01-23 16:47:30 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// VAPIDKeyPair caches the server's VAPID key pair. | 
					
						
							|  |  |  | 	VAPIDKeyPair atomic.Pointer[gtsmodel.VAPIDKeyPair] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// WebPushSubscription provides access to the gtsmodel WebPushSubscription database cache. | 
					
						
							|  |  |  | 	WebPushSubscription StructCache[*gtsmodel.WebPushSubscription] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// WebPushSubscriptionIDs provides access to the Web Push subscription IDs database cache. | 
					
						
							|  |  |  | 	WebPushSubscriptionIDs SliceCache[string] | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // NOTE: | 
					
						
							|  |  |  | // all of the below init functions | 
					
						
							|  |  |  | // are receivers to the main cache | 
					
						
							|  |  |  | // struct type, not the database cache | 
					
						
							|  |  |  | // struct type, in order to get access | 
					
						
							|  |  |  | // to the full suite of caches for | 
					
						
							|  |  |  | // our invalidate function hooks. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initAccount() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofAccount(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheAccountMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(a1 *gtsmodel.Account) *gtsmodel.Account { | 
					
						
							|  |  |  | 		a2 := new(gtsmodel.Account) | 
					
						
							|  |  |  | 		*a2 = *a1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/account.go. | 
					
						
							|  |  |  | 		a2.AvatarMediaAttachment = nil | 
					
						
							|  |  |  | 		a2.HeaderMediaAttachment = nil | 
					
						
							|  |  |  | 		a2.Emojis = nil | 
					
						
							| 
									
										
										
										
											2024-03-06 11:18:57 +01:00
										 |  |  | 		a2.AlsoKnownAs = nil | 
					
						
							|  |  |  | 		a2.Move = nil | 
					
						
							| 
									
										
										
										
											2024-05-28 15:39:45 +02:00
										 |  |  | 		a2.MovedTo = nil | 
					
						
							| 
									
										
										
										
											2024-03-22 14:03:46 +01:00
										 |  |  | 		a2.Settings = nil | 
					
						
							| 
									
										
										
										
											2024-04-16 13:10:13 +02:00
										 |  |  | 		a2.Stats = nil | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		return a2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Account.Init(structr.CacheConfig[*gtsmodel.Account]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "URI"}, | 
					
						
							|  |  |  | 			{Fields: "PublicKeyURI"}, | 
					
						
							| 
									
										
										
										
											2025-04-06 14:39:40 +02:00
										 |  |  | 			{Fields: "Username,Domain", AllowZero: true}, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:       copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Invalidate: c.OnInvalidateAccount, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initAccountNote() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofAccountNote(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheAccountNoteMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(n1 *gtsmodel.AccountNote) *gtsmodel.AccountNote { | 
					
						
							|  |  |  | 		n2 := new(gtsmodel.AccountNote) | 
					
						
							|  |  |  | 		*n2 = *n1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/relationship_note.go. | 
					
						
							|  |  |  | 		n2.Account = nil | 
					
						
							|  |  |  | 		n2.TargetAccount = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return n2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.AccountNote.Init(structr.CacheConfig[*gtsmodel.AccountNote]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID,TargetAccountID"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:      copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-22 14:03:46 +01:00
										 |  |  | func (c *Caches) initAccountSettings() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofAccountSettings(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheAccountSettingsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.AccountSettings.Init(structr.CacheConfig[*gtsmodel.AccountSettings]{ | 
					
						
							| 
									
										
										
										
											2024-03-22 14:03:46 +01:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "AccountID"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy: func(s1 *gtsmodel.AccountSettings) *gtsmodel.AccountSettings { | 
					
						
							| 
									
										
										
										
											2024-03-22 14:03:46 +01:00
										 |  |  | 			s2 := new(gtsmodel.AccountSettings) | 
					
						
							|  |  |  | 			*s2 = *s1 | 
					
						
							|  |  |  | 			return s2 | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-16 13:10:13 +02:00
										 |  |  | func (c *Caches) initAccountStats() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofAccountStats(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheAccountStatsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.AccountStats.Init(structr.CacheConfig[*gtsmodel.AccountStats]{ | 
					
						
							| 
									
										
										
										
											2024-04-16 13:10:13 +02:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "AccountID"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							|  |  |  | 		Copy: func(s1 *gtsmodel.AccountStats) *gtsmodel.AccountStats { | 
					
						
							|  |  |  | 			s2 := new(gtsmodel.AccountStats) | 
					
						
							|  |  |  | 			*s2 = *s1 | 
					
						
							|  |  |  | 			return s2 | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | func (c *Caches) initApplication() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofApplication(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheApplicationMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(a1 *gtsmodel.Application) *gtsmodel.Application { | 
					
						
							|  |  |  | 		a2 := new(gtsmodel.Application) | 
					
						
							|  |  |  | 		*a2 = *a1 | 
					
						
							|  |  |  | 		return a2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Application.Init(structr.CacheConfig[*gtsmodel.Application]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "ClientID"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2024-04-15 14:22:21 +01:00
										 |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							|  |  |  | 		Copy:       copyF, | 
					
						
							|  |  |  | 		Invalidate: c.OnInvalidateApplication, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initBlock() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofBlock(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheBlockMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(b1 *gtsmodel.Block) *gtsmodel.Block { | 
					
						
							|  |  |  | 		b2 := new(gtsmodel.Block) | 
					
						
							|  |  |  | 		*b2 = *b1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/relationship_block.go. | 
					
						
							|  |  |  | 		b2.Account = nil | 
					
						
							|  |  |  | 		b2.TargetAccount = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return b2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Block.Init(structr.CacheConfig[*gtsmodel.Block]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "URI"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID,TargetAccountID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "TargetAccountID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:       copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Invalidate: c.OnInvalidateBlock, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initBlockIDs() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheBlockIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.BlockIDs.Init(0, cap) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initBoostOfIDs() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheBoostOfIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.BoostOfIDs.Init(0, cap) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-23 12:44:31 -07:00
										 |  |  | func (c *Caches) initConversation() { | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofConversation(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheConversationMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(c1 *gtsmodel.Conversation) *gtsmodel.Conversation { | 
					
						
							|  |  |  | 		c2 := new(gtsmodel.Conversation) | 
					
						
							|  |  |  | 		*c2 = *c1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/conversation.go. | 
					
						
							|  |  |  | 		c2.Account = nil | 
					
						
							|  |  |  | 		c2.OtherAccounts = nil | 
					
						
							|  |  |  | 		c2.LastStatus = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return c2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Conversation.Init(structr.CacheConfig[*gtsmodel.Conversation]{ | 
					
						
							| 
									
										
										
										
											2024-07-23 12:44:31 -07:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "ThreadID,AccountID,OtherAccountsKey"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID,LastStatusID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							|  |  |  | 		Copy:       copyF, | 
					
						
							|  |  |  | 		Invalidate: c.OnInvalidateConversation, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initConversationLastStatusIDs() { | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheConversationLastStatusIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.ConversationLastStatusIDs.Init(0, cap) | 
					
						
							| 
									
										
										
										
											2024-07-23 12:44:31 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | func (c *Caches) initDomainAllow() { | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.DomainAllow = new(domain.Cache) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initDomainBlock() { | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.DomainBlock = new(domain.Cache) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 14:09:58 +01:00
										 |  |  | func (c *Caches) initDomainPermissionDraft() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofDomainPermissionDraft(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheDomainPermissionDraftMemRation(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(d1 *gtsmodel.DomainPermissionDraft) *gtsmodel.DomainPermissionDraft { | 
					
						
							|  |  |  | 		d2 := new(gtsmodel.DomainPermissionDraft) | 
					
						
							|  |  |  | 		*d2 = *d1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		d2.CreatedByAccount = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return d2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.DB.DomainPermissionDraft.Init(structr.CacheConfig[*gtsmodel.DomainPermissionDraft]{ | 
					
						
							|  |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "Domain", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "SubscriptionID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							|  |  |  | 		Copy:      copyF, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-05 13:20:33 +01:00
										 |  |  | func (c *Caches) initDomainPermissionSubscription() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofDomainPermissionSubscription(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheDomainPermissionSubscriptionMemRation(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(d1 *gtsmodel.DomainPermissionSubscription) *gtsmodel.DomainPermissionSubscription { | 
					
						
							|  |  |  | 		d2 := new(gtsmodel.DomainPermissionSubscription) | 
					
						
							|  |  |  | 		*d2 = *d1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		d2.CreatedByAccount = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return d2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.DB.DomainPermissionSubscription.Init(structr.CacheConfig[*gtsmodel.DomainPermissionSubscription]{ | 
					
						
							|  |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "URI"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							|  |  |  | 		Copy:      copyF, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 14:09:58 +01:00
										 |  |  | func (c *Caches) initDomainPermissionExclude() { | 
					
						
							|  |  |  | 	c.DB.DomainPermissionExclude = new(domain.Cache) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | func (c *Caches) initEmoji() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofEmoji(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheEmojiMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(e1 *gtsmodel.Emoji) *gtsmodel.Emoji { | 
					
						
							|  |  |  | 		e2 := new(gtsmodel.Emoji) | 
					
						
							|  |  |  | 		*e2 = *e1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/emoji.go. | 
					
						
							|  |  |  | 		e2.Category = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return e2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Emoji.Init(structr.CacheConfig[*gtsmodel.Emoji]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "URI"}, | 
					
						
							|  |  |  | 			{Fields: "Shortcode,Domain", AllowZero: true}, | 
					
						
							|  |  |  | 			{Fields: "ImageStaticURL"}, | 
					
						
							|  |  |  | 			{Fields: "CategoryID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:      copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initEmojiCategory() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofEmojiCategory(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheEmojiCategoryMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(c1 *gtsmodel.EmojiCategory) *gtsmodel.EmojiCategory { | 
					
						
							|  |  |  | 		c2 := new(gtsmodel.EmojiCategory) | 
					
						
							|  |  |  | 		*c2 = *c1 | 
					
						
							|  |  |  | 		return c2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.EmojiCategory.Init(structr.CacheConfig[*gtsmodel.EmojiCategory]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "Name"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:       copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Invalidate: c.OnInvalidateEmojiCategory, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 02:15:58 -08:00
										 |  |  | func (c *Caches) initFilter() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofFilter(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheFilterMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(filter1 *gtsmodel.Filter) *gtsmodel.Filter { | 
					
						
							|  |  |  | 		filter2 := new(gtsmodel.Filter) | 
					
						
							|  |  |  | 		*filter2 = *filter1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/filter.go. | 
					
						
							|  |  |  | 		filter2.Keywords = nil | 
					
						
							|  |  |  | 		filter2.Statuses = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return filter2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Filter.Init(structr.CacheConfig[*gtsmodel.Filter]{ | 
					
						
							| 
									
										
										
										
											2024-03-06 02:15:58 -08:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:      copyF, | 
					
						
							| 
									
										
										
										
											2024-03-06 02:15:58 -08:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initFilterKeyword() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofFilterKeyword(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheFilterKeywordMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(filterKeyword1 *gtsmodel.FilterKeyword) *gtsmodel.FilterKeyword { | 
					
						
							|  |  |  | 		filterKeyword2 := new(gtsmodel.FilterKeyword) | 
					
						
							|  |  |  | 		*filterKeyword2 = *filterKeyword1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/filter.go. | 
					
						
							|  |  |  | 		filterKeyword2.Filter = nil | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-21 13:20:19 +00:00
										 |  |  | 		// We specifically DO NOT unset | 
					
						
							|  |  |  | 		// the regexp field here, as any | 
					
						
							|  |  |  | 		// regexp.Regexp instance is safe | 
					
						
							|  |  |  | 		// for concurrent access. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 02:15:58 -08:00
										 |  |  | 		return filterKeyword2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.FilterKeyword.Init(structr.CacheConfig[*gtsmodel.FilterKeyword]{ | 
					
						
							| 
									
										
										
										
											2024-03-06 02:15:58 -08:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "FilterID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:      copyF, | 
					
						
							| 
									
										
										
										
											2024-03-06 02:15:58 -08:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initFilterStatus() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofFilterStatus(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheFilterStatusMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(filterStatus1 *gtsmodel.FilterStatus) *gtsmodel.FilterStatus { | 
					
						
							|  |  |  | 		filterStatus2 := new(gtsmodel.FilterStatus) | 
					
						
							|  |  |  | 		*filterStatus2 = *filterStatus1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/filter.go. | 
					
						
							|  |  |  | 		filterStatus2.Filter = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return filterStatus2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.FilterStatus.Init(structr.CacheConfig[*gtsmodel.FilterStatus]{ | 
					
						
							| 
									
										
										
										
											2024-03-06 02:15:58 -08:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "FilterID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:      copyF, | 
					
						
							| 
									
										
										
										
											2024-03-06 02:15:58 -08:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | func (c *Caches) initFollow() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofFollow(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheFollowMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(f1 *gtsmodel.Follow) *gtsmodel.Follow { | 
					
						
							|  |  |  | 		f2 := new(gtsmodel.Follow) | 
					
						
							|  |  |  | 		*f2 = *f1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/relationship_follow.go. | 
					
						
							|  |  |  | 		f2.Account = nil | 
					
						
							|  |  |  | 		f2.TargetAccount = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return f2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Follow.Init(structr.CacheConfig[*gtsmodel.Follow]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "URI"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID,TargetAccountID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "TargetAccountID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:       copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Invalidate: c.OnInvalidateFollow, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initFollowIDs() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheFollowIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.FollowIDs.Init(0, cap) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initFollowRequest() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofFollowRequest(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheFollowRequestMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(f1 *gtsmodel.FollowRequest) *gtsmodel.FollowRequest { | 
					
						
							|  |  |  | 		f2 := new(gtsmodel.FollowRequest) | 
					
						
							|  |  |  | 		*f2 = *f1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/relationship_follow_req.go. | 
					
						
							|  |  |  | 		f2.Account = nil | 
					
						
							|  |  |  | 		f2.TargetAccount = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return f2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.FollowRequest.Init(structr.CacheConfig[*gtsmodel.FollowRequest]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "URI"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID,TargetAccountID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "TargetAccountID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:       copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Invalidate: c.OnInvalidateFollowRequest, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initFollowRequestIDs() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheFollowRequestIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.FollowRequestIDs.Init(0, cap) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | func (c *Caches) initFollowingTagIDs() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheFollowingTagIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.DB.FollowingTagIDs.Init(0, cap) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | func (c *Caches) initInReplyToIDs() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheInReplyToIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.InReplyToIDs.Init(0, cap) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initInstance() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofInstance(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheInstanceMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(i1 *gtsmodel.Instance) *gtsmodel.Instance { | 
					
						
							|  |  |  | 		i2 := new(gtsmodel.Instance) | 
					
						
							|  |  |  | 		*i2 = *i1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/instance.go. | 
					
						
							|  |  |  | 		i2.DomainBlock = nil | 
					
						
							|  |  |  | 		i2.ContactAccount = nil | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-28 16:43:00 +02:00
										 |  |  | 		return i2 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Instance.Init(structr.CacheConfig[*gtsmodel.Instance]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "Domain"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2024-09-23 11:53:42 +00:00
										 |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							|  |  |  | 		Copy:       copyF, | 
					
						
							|  |  |  | 		Invalidate: c.OnInvalidateInstance, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-24 11:49:37 +02:00
										 |  |  | func (c *Caches) initInteractionRequest() { | 
					
						
							| 
									
										
										
										
											2024-07-11 16:44:29 +02:00
										 |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							| 
									
										
										
										
											2024-08-24 11:49:37 +02:00
										 |  |  | 		sizeofInteractionRequest(), | 
					
						
							|  |  |  | 		config.GetCacheInteractionRequestMemRatio(), | 
					
						
							| 
									
										
										
										
											2024-07-11 16:44:29 +02:00
										 |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-24 11:49:37 +02:00
										 |  |  | 	copyF := func(i1 *gtsmodel.InteractionRequest) *gtsmodel.InteractionRequest { | 
					
						
							|  |  |  | 		i2 := new(gtsmodel.InteractionRequest) | 
					
						
							| 
									
										
										
										
											2024-07-11 16:44:29 +02:00
										 |  |  | 		*i2 = *i1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/interaction.go. | 
					
						
							| 
									
										
										
										
											2024-08-24 11:49:37 +02:00
										 |  |  | 		i2.Status = nil | 
					
						
							|  |  |  | 		i2.TargetAccount = nil | 
					
						
							| 
									
										
										
										
											2024-07-11 16:44:29 +02:00
										 |  |  | 		i2.InteractingAccount = nil | 
					
						
							| 
									
										
										
										
											2024-08-24 11:49:37 +02:00
										 |  |  | 		i2.Like = nil | 
					
						
							|  |  |  | 		i2.Reply = nil | 
					
						
							|  |  |  | 		i2.Announce = nil | 
					
						
							| 
									
										
										
										
											2024-07-11 16:44:29 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		return i2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-24 11:49:37 +02:00
										 |  |  | 	c.DB.InteractionRequest.Init(structr.CacheConfig[*gtsmodel.InteractionRequest]{ | 
					
						
							| 
									
										
										
										
											2024-07-11 16:44:29 +02:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							| 
									
										
										
										
											2024-08-24 11:49:37 +02:00
										 |  |  | 			{Fields: "InteractionURI"}, | 
					
						
							| 
									
										
										
										
											2024-07-11 16:44:29 +02:00
										 |  |  | 			{Fields: "URI"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							|  |  |  | 		Copy:      copyF, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | func (c *Caches) initList() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofList(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheListMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(l1 *gtsmodel.List) *gtsmodel.List { | 
					
						
							|  |  |  | 		l2 := new(gtsmodel.List) | 
					
						
							|  |  |  | 		*l2 = *l1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/list.go. | 
					
						
							|  |  |  | 		l2.Account = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return l2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.List.Init(structr.CacheConfig[*gtsmodel.List]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:       copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Invalidate: c.OnInvalidateList, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | func (c *Caches) initListIDs() { | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	// Calculate maximum cache size. | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheListIDsMemRatio(), | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | 	c.DB.ListIDs.Init(0, cap) | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | func (c *Caches) initListedIDs() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheListedIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-16 16:46:09 +00:00
										 |  |  | 	c.DB.ListedIDs.Init(0, cap) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initMarker() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofMarker(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheMarkerMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(m1 *gtsmodel.Marker) *gtsmodel.Marker { | 
					
						
							|  |  |  | 		m2 := new(gtsmodel.Marker) | 
					
						
							|  |  |  | 		*m2 = *m1 | 
					
						
							|  |  |  | 		return m2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Marker.Init(structr.CacheConfig[*gtsmodel.Marker]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "AccountID,Name"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:      copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initMedia() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofMedia(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheMediaMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(m1 *gtsmodel.MediaAttachment) *gtsmodel.MediaAttachment { | 
					
						
							|  |  |  | 		m2 := new(gtsmodel.MediaAttachment) | 
					
						
							|  |  |  | 		*m2 = *m1 | 
					
						
							|  |  |  | 		return m2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Media.Init(structr.CacheConfig[*gtsmodel.MediaAttachment]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:       copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Invalidate: c.OnInvalidateMedia, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initMention() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofMention(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheMentionMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(m1 *gtsmodel.Mention) *gtsmodel.Mention { | 
					
						
							|  |  |  | 		m2 := new(gtsmodel.Mention) | 
					
						
							|  |  |  | 		*m2 = *m1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/mention.go. | 
					
						
							|  |  |  | 		m2.Status = nil | 
					
						
							|  |  |  | 		m2.OriginAccount = nil | 
					
						
							|  |  |  | 		m2.TargetAccount = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return m2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Mention.Init(structr.CacheConfig[*gtsmodel.Mention]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:      copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 11:18:57 +01:00
										 |  |  | func (c *Caches) initMove() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofMove(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheMoveMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Move.Init(structr.CacheConfig[*gtsmodel.Move]{ | 
					
						
							| 
									
										
										
										
											2024-03-06 11:18:57 +01:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "URI"}, | 
					
						
							|  |  |  | 			{Fields: "OriginURI,TargetURI"}, | 
					
						
							|  |  |  | 			{Fields: "OriginURI", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "TargetURI", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy: func(m1 *gtsmodel.Move) *gtsmodel.Move { | 
					
						
							| 
									
										
										
										
											2024-03-06 11:18:57 +01:00
										 |  |  | 			m2 := new(gtsmodel.Move) | 
					
						
							|  |  |  | 			*m2 = *m1 | 
					
						
							|  |  |  | 			return m2 | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | func (c *Caches) initNotification() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofNotification(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheNotificationMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(n1 *gtsmodel.Notification) *gtsmodel.Notification { | 
					
						
							|  |  |  | 		n2 := new(gtsmodel.Notification) | 
					
						
							|  |  |  | 		*n2 = *n1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/notification.go. | 
					
						
							|  |  |  | 		n2.Status = nil | 
					
						
							|  |  |  | 		n2.OriginAccount = nil | 
					
						
							|  |  |  | 		n2.TargetAccount = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return n2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Notification.Init(structr.CacheConfig[*gtsmodel.Notification]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "NotificationType,TargetAccountID,OriginAccountID,StatusID", AllowZero: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:      copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initPoll() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofPoll(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCachePollMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(p1 *gtsmodel.Poll) *gtsmodel.Poll { | 
					
						
							|  |  |  | 		p2 := new(gtsmodel.Poll) | 
					
						
							|  |  |  | 		*p2 = *p1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/poll.go. | 
					
						
							|  |  |  | 		p2.Status = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ephemeral fields | 
					
						
							|  |  |  | 		// which are only expected to be | 
					
						
							|  |  |  | 		// set on ONE poll instance. | 
					
						
							|  |  |  | 		p2.Closing = false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return p2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Poll.Init(structr.CacheConfig[*gtsmodel.Poll]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "StatusID"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:       copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Invalidate: c.OnInvalidatePoll, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initPollVote() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofPollVote(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCachePollVoteMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(v1 *gtsmodel.PollVote) *gtsmodel.PollVote { | 
					
						
							|  |  |  | 		v2 := new(gtsmodel.PollVote) | 
					
						
							|  |  |  | 		*v2 = *v1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/poll.go. | 
					
						
							|  |  |  | 		v2.Account = nil | 
					
						
							|  |  |  | 		v2.Poll = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return v2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.PollVote.Init(structr.CacheConfig[*gtsmodel.PollVote]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "PollID", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "PollID,AccountID"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:       copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Invalidate: c.OnInvalidatePollVote, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initPollVoteIDs() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCachePollVoteIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.PollVoteIDs.Init(0, cap) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initReport() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofReport(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheReportMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(r1 *gtsmodel.Report) *gtsmodel.Report { | 
					
						
							|  |  |  | 		r2 := new(gtsmodel.Report) | 
					
						
							|  |  |  | 		*r2 = *r1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/report.go. | 
					
						
							|  |  |  | 		r2.Account = nil | 
					
						
							|  |  |  | 		r2.TargetAccount = nil | 
					
						
							|  |  |  | 		r2.Statuses = nil | 
					
						
							|  |  |  | 		r2.Rules = nil | 
					
						
							|  |  |  | 		r2.ActionTakenByAccount = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return r2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Report.Init(structr.CacheConfig[*gtsmodel.Report]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:      copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-10 14:34:49 +02:00
										 |  |  | func (c *Caches) initSinBinStatus() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofSinBinStatus(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheSinBinStatusMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(s1 *gtsmodel.SinBinStatus) *gtsmodel.SinBinStatus { | 
					
						
							|  |  |  | 		s2 := new(gtsmodel.SinBinStatus) | 
					
						
							|  |  |  | 		*s2 = *s1 | 
					
						
							|  |  |  | 		return s2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.DB.SinBinStatus.Init(structr.CacheConfig[*gtsmodel.SinBinStatus]{ | 
					
						
							|  |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "URI"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							|  |  |  | 		Copy:      copyF, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | func (c *Caches) initStatus() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofStatus(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheStatusMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(s1 *gtsmodel.Status) *gtsmodel.Status { | 
					
						
							|  |  |  | 		s2 := new(gtsmodel.Status) | 
					
						
							|  |  |  | 		*s2 = *s1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/status.go. | 
					
						
							|  |  |  | 		s2.Account = nil | 
					
						
							|  |  |  | 		s2.InReplyTo = nil | 
					
						
							|  |  |  | 		s2.InReplyToAccount = nil | 
					
						
							|  |  |  | 		s2.BoostOf = nil | 
					
						
							|  |  |  | 		s2.BoostOfAccount = nil | 
					
						
							|  |  |  | 		s2.Poll = nil | 
					
						
							|  |  |  | 		s2.Attachments = nil | 
					
						
							|  |  |  | 		s2.Tags = nil | 
					
						
							|  |  |  | 		s2.Mentions = nil | 
					
						
							|  |  |  | 		s2.Emojis = nil | 
					
						
							|  |  |  | 		s2.CreatedWithApplication = nil | 
					
						
							| 
									
										
										
										
											2024-12-31 09:44:07 +00:00
										 |  |  | 		s2.Edits = nil | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		return s2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Status.Init(structr.CacheConfig[*gtsmodel.Status]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "URI"}, | 
					
						
							|  |  |  | 			{Fields: "URL"}, | 
					
						
							|  |  |  | 			{Fields: "PollID"}, | 
					
						
							|  |  |  | 			{Fields: "BoostOfID,AccountID"}, | 
					
						
							|  |  |  | 			{Fields: "ThreadID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:       copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Invalidate: c.OnInvalidateStatus, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-06 10:44:43 +00:00
										 |  |  | func (c *Caches) initStatusBookmark() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofStatusBookmark(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheStatusBookmarkMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(s1 *gtsmodel.StatusBookmark) *gtsmodel.StatusBookmark { | 
					
						
							|  |  |  | 		s2 := new(gtsmodel.StatusBookmark) | 
					
						
							|  |  |  | 		*s2 = *s1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		s2.Account = nil | 
					
						
							|  |  |  | 		s2.TargetAccount = nil | 
					
						
							|  |  |  | 		s2.Status = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return s2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.StatusBookmark.Init(structr.CacheConfig[*gtsmodel.StatusBookmark]{ | 
					
						
							| 
									
										
										
										
											2024-06-06 10:44:43 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID,StatusID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "TargetAccountID", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "StatusID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							|  |  |  | 		Copy:       copyF, | 
					
						
							|  |  |  | 		Invalidate: c.OnInvalidateStatusBookmark, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initStatusBookmarkIDs() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheStatusBookmarkIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.StatusBookmarkIDs.Init(0, cap) | 
					
						
							| 
									
										
										
										
											2024-06-06 10:44:43 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-05 13:35:07 +00:00
										 |  |  | func (c *Caches) initStatusEdit() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofStatusEdit(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheStatusEditMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(s1 *gtsmodel.StatusEdit) *gtsmodel.StatusEdit { | 
					
						
							|  |  |  | 		s2 := new(gtsmodel.StatusEdit) | 
					
						
							|  |  |  | 		*s2 = *s1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		s2.Attachments = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return s2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.DB.StatusEdit.Init(structr.CacheConfig[*gtsmodel.StatusEdit]{ | 
					
						
							|  |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "StatusID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							|  |  |  | 		Copy:       copyF, | 
					
						
							|  |  |  | 		Invalidate: c.OnInvalidateStatusEdit, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | func (c *Caches) initStatusFave() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofStatusFave(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheStatusFaveMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(f1 *gtsmodel.StatusFave) *gtsmodel.StatusFave { | 
					
						
							|  |  |  | 		f2 := new(gtsmodel.StatusFave) | 
					
						
							|  |  |  | 		*f2 = *f1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/statusfave.go. | 
					
						
							|  |  |  | 		f2.Account = nil | 
					
						
							|  |  |  | 		f2.TargetAccount = nil | 
					
						
							|  |  |  | 		f2.Status = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return f2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.StatusFave.Init(structr.CacheConfig[*gtsmodel.StatusFave]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							| 
									
										
										
										
											2024-07-11 16:44:29 +02:00
										 |  |  | 			{Fields: "URI"}, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 			{Fields: "AccountID,StatusID"}, | 
					
						
							|  |  |  | 			{Fields: "StatusID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:       copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Invalidate: c.OnInvalidateStatusFave, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initStatusFaveIDs() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheStatusFaveIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.StatusFaveIDs.Init(0, cap) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initTag() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofTag(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheTagMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(m1 *gtsmodel.Tag) *gtsmodel.Tag { | 
					
						
							|  |  |  | 		m2 := new(gtsmodel.Tag) | 
					
						
							|  |  |  | 		*m2 = *m1 | 
					
						
							|  |  |  | 		return m2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Tag.Init(structr.CacheConfig[*gtsmodel.Tag]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "Name"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:      copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initThreadMute() { | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							| 
									
										
										
										
											2024-04-15 14:22:21 +01:00
										 |  |  | 		sizeofThreadMute(), // model in-mem size. | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		config.GetCacheThreadMuteMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(t1 *gtsmodel.ThreadMute) *gtsmodel.ThreadMute { | 
					
						
							|  |  |  | 		t2 := new(gtsmodel.ThreadMute) | 
					
						
							|  |  |  | 		*t2 = *t1 | 
					
						
							|  |  |  | 		return t2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.ThreadMute.Init(structr.CacheConfig[*gtsmodel.ThreadMute]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "ThreadID", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "AccountID", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "ThreadID,AccountID"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:      copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-15 14:22:21 +01:00
										 |  |  | func (c *Caches) initToken() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofToken(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheTokenMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(t1 *gtsmodel.Token) *gtsmodel.Token { | 
					
						
							|  |  |  | 		t2 := new(gtsmodel.Token) | 
					
						
							|  |  |  | 		*t2 = *t1 | 
					
						
							|  |  |  | 		return t2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Token.Init(structr.CacheConfig[*gtsmodel.Token]{ | 
					
						
							| 
									
										
										
										
											2024-04-15 14:22:21 +01:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "Code"}, | 
					
						
							|  |  |  | 			{Fields: "Access"}, | 
					
						
							|  |  |  | 			{Fields: "Refresh"}, | 
					
						
							|  |  |  | 			{Fields: "ClientID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2025-01-23 16:47:30 -08:00
										 |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							|  |  |  | 		Copy:       copyF, | 
					
						
							|  |  |  | 		Invalidate: c.OnInvalidateToken, | 
					
						
							| 
									
										
										
										
											2024-04-15 14:22:21 +01:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | func (c *Caches) initTombstone() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofTombstone(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheTombstoneMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(t1 *gtsmodel.Tombstone) *gtsmodel.Tombstone { | 
					
						
							|  |  |  | 		t2 := new(gtsmodel.Tombstone) | 
					
						
							|  |  |  | 		*t2 = *t1 | 
					
						
							|  |  |  | 		return t2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.Tombstone.Init(structr.CacheConfig[*gtsmodel.Tombstone]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "URI"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:   cap, | 
					
						
							|  |  |  | 		IgnoreErr: ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:      copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initUser() { | 
					
						
							|  |  |  | 	// Calculate maximum cache size. | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofUser(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheUserMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(u1 *gtsmodel.User) *gtsmodel.User { | 
					
						
							|  |  |  | 		u2 := new(gtsmodel.User) | 
					
						
							|  |  |  | 		*u2 = *u1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/user.go. | 
					
						
							|  |  |  | 		u2.Account = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return u2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.User.Init(structr.CacheConfig[*gtsmodel.User]{ | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID"}, | 
					
						
							|  |  |  | 			{Fields: "Email"}, | 
					
						
							|  |  |  | 			{Fields: "ConfirmationToken"}, | 
					
						
							|  |  |  | 			{Fields: "ExternalID"}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							| 
									
										
										
										
											2024-04-02 11:03:40 +01:00
										 |  |  | 		Copy:       copyF, | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | 		Invalidate: c.OnInvalidateUser, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-06 09:38:02 -07:00
										 |  |  | func (c *Caches) initUserMute() { | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofUserMute(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheUserMuteMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(u1 *gtsmodel.UserMute) *gtsmodel.UserMute { | 
					
						
							|  |  |  | 		u2 := new(gtsmodel.UserMute) | 
					
						
							|  |  |  | 		*u2 = *u1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Don't include ptr fields that | 
					
						
							|  |  |  | 		// will be populated separately. | 
					
						
							|  |  |  | 		// See internal/db/bundb/relationship_mute.go. | 
					
						
							|  |  |  | 		u2.Account = nil | 
					
						
							|  |  |  | 		u2.TargetAccount = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return u2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.UserMute.Init(structr.CacheConfig[*gtsmodel.UserMute]{ | 
					
						
							| 
									
										
										
										
											2024-06-06 09:38:02 -07:00
										 |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID,TargetAccountID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID", Multiple: true}, | 
					
						
							|  |  |  | 			{Fields: "TargetAccountID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							|  |  |  | 		Copy:       copyF, | 
					
						
							|  |  |  | 		Invalidate: c.OnInvalidateUserMute, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initUserMuteIDs() { | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheUserMuteIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-24 09:41:43 +01:00
										 |  |  | 	c.DB.UserMuteIDs.Init(0, cap) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:57:29 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2025-01-23 16:47:30 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initWebPushSubscription() { | 
					
						
							|  |  |  | 	cap := calculateResultCacheMax( | 
					
						
							|  |  |  | 		sizeofWebPushSubscription(), // model in-mem size. | 
					
						
							|  |  |  | 		config.GetCacheWebPushSubscriptionMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	copyF := func(s1 *gtsmodel.WebPushSubscription) *gtsmodel.WebPushSubscription { | 
					
						
							|  |  |  | 		s2 := new(gtsmodel.WebPushSubscription) | 
					
						
							|  |  |  | 		*s2 = *s1 | 
					
						
							|  |  |  | 		return s2 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.DB.WebPushSubscription.Init(structr.CacheConfig[*gtsmodel.WebPushSubscription]{ | 
					
						
							|  |  |  | 		Indices: []structr.IndexConfig{ | 
					
						
							|  |  |  | 			{Fields: "ID"}, | 
					
						
							|  |  |  | 			{Fields: "TokenID"}, | 
					
						
							|  |  |  | 			{Fields: "AccountID", Multiple: true}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		MaxSize:    cap, | 
					
						
							|  |  |  | 		IgnoreErr:  ignoreErrors, | 
					
						
							|  |  |  | 		Invalidate: c.OnInvalidateWebPushSubscription, | 
					
						
							|  |  |  | 		Copy:       copyF, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (c *Caches) initWebPushSubscriptionIDs() { | 
					
						
							|  |  |  | 	cap := calculateSliceCacheMax( | 
					
						
							|  |  |  | 		config.GetCacheWebPushSubscriptionIDsMemRatio(), | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	log.Infof(nil, "cache size = %d", cap) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.DB.WebPushSubscriptionIDs.Init(0, cap) | 
					
						
							|  |  |  | } |