mattermost/server/public/pluginapi/cluster/job_once_example_test.go
Ben Schumacher 3ee5432664
[MM-53968] Includes mattermost-plugin-api into the mono repo (#24235)
Include https://github.com/mattermost/mattermost-plugin-api into the mono repo

Co-authored-by: Jesse Hallam <jesse.hallam@gmail.com>
Co-authored-by: Michael Kochell <mjkochell@gmail.com>
Co-authored-by: Alejandro García Montoro <alejandro.garciamontoro@gmail.com>
Co-authored-by: Ben Schumacher <ben.schumacher@mattermost.com>
Co-authored-by: Alex Dovenmuehle <alex.dovenmuehle@mattermost.com>
Co-authored-by: Michael Kochell <6913320+mickmister@users.noreply.github.com>
Co-authored-by: Christopher Poile <cpoile@gmail.com>
Co-authored-by: İlker Göktuğ Öztürk <ilkergoktugozturk@gmail.com>
Co-authored-by: Shota Gvinepadze <wineson@gmail.com>
Co-authored-by: Ali Farooq <ali.farooq0@pm.me>
Co-authored-by: Maria A Nunez <maria.nunez@mattermost.com>
Co-authored-by: Daniel Espino García <larkox@gmail.com>
Co-authored-by: Christopher Speller <crspeller@gmail.com>
Co-authored-by: Alex Dovenmuehle <adovenmuehle@gmail.com>
Co-authored-by: Szymon Gibała <szymongib@gmail.com>
Co-authored-by: Lev <1187448+levb@users.noreply.github.com>
Co-authored-by: Jason Frerich <jason.frerich@mattermost.com>
Co-authored-by: Agniva De Sarker <agnivade@yahoo.co.in>
Co-authored-by: Artur M. Wolff <artur.m.wolff@gmail.com>
Co-authored-by: Madhav Hugar <16546715+madhavhugar@users.noreply.github.com>
Co-authored-by: Joe <security.joe@pm.me>
Co-authored-by: Ibrahim Serdar Acikgoz <serdaracikgoz86@gmail.com>
Co-authored-by: José Peso <trilopin@users.noreply.github.com>
2023-08-21 09:50:30 +02:00

45 lines
1.2 KiB
Go

package cluster
import (
"log"
"time"
"github.com/mattermost/mattermost/server/public/plugin"
)
func HandleJobOnceCalls(key string, props any) {
if key == "the key i'm watching for" {
log.Println(props)
// Work to do only once per cluster
}
}
func ExampleJobOnceScheduler_ScheduleOnce() {
// Use p.API from your plugin instead.
pluginAPI := plugin.API(nil)
// Get the scheduler, which you can pass throughout the plugin...
scheduler := GetJobOnceScheduler(pluginAPI)
// Set the plugin's callback handler
_ = scheduler.SetCallback(HandleJobOnceCalls)
// Now start the scheduler, which starts the poller and schedules all waiting jobs.
_ = scheduler.Start()
// main thread...
// add a job
_, _ = scheduler.ScheduleOnce("the key i'm watching for", time.Now().Add(2*time.Hour), struct{ foo string }{"aasd"})
// Maybe you want to check the scheduled jobs, or cancel them. This is completely optional--there
// is no need to cancel jobs, even if you are shutting down. Call Cancel only when you want to
// cancel a future job. Cancelling a job will prevent it from running in the future on this or
// any server.
jobs, _ := scheduler.ListScheduledJobs()
defer func() {
for _, j := range jobs {
scheduler.Cancel(j.Key)
}
}()
}