mirror of
https://github.com/ProtonMail/proton-bridge.git
synced 2025-12-18 16:17:03 +00:00
- GODT-1302: Change maximum resty retries from 0 to 30 - GODT-1302: Make sure we are closing GetAttachmen io.ReadCloser on error - GODT-1356: Do not use attachmentPool - it was useless anyway - GODT-1356: Increase cache watcher limit to 10min - GODT-1356: Start cache watcher right after start (do not wait first 10 min) - GODT-1356: Limit number of buildJobs (memory allocation) in BuildAndCacheMessage - Other: Pass context from job options (message builder) to fetcher (both message and attachments) - Other: BuildJob contains same function as returned buildDone (proper map locking)
65 lines
1.4 KiB
Go
65 lines
1.4 KiB
Go
// Copyright (c) 2021 Proton Technologies AG
|
|
//
|
|
// This file is part of ProtonMail Bridge.
|
|
//
|
|
// ProtonMail Bridge is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// ProtonMail Bridge 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 General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with ProtonMail Bridge. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
package store
|
|
|
|
import "time"
|
|
|
|
func (store *Store) StartWatcher() {
|
|
store.done = make(chan struct{})
|
|
|
|
go func() {
|
|
ticker := time.NewTicker(10 * time.Minute)
|
|
defer ticker.Stop()
|
|
|
|
for {
|
|
// NOTE(GODT-1158): Race condition here? What if DB was already closed?
|
|
messageIDs, err := store.getAllMessageIDs()
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
for _, messageID := range messageIDs {
|
|
if !store.IsCached(messageID) {
|
|
store.cacher.newJob(messageID)
|
|
}
|
|
}
|
|
|
|
select {
|
|
case <-store.done:
|
|
return
|
|
case <-ticker.C:
|
|
continue
|
|
}
|
|
}
|
|
}()
|
|
}
|
|
|
|
func (store *Store) stopWatcher() {
|
|
if store.done == nil {
|
|
return
|
|
}
|
|
|
|
select {
|
|
default:
|
|
close(store.done)
|
|
|
|
case <-store.done:
|
|
return
|
|
}
|
|
}
|