Deployed e3be2c0 to 5.4 with MkDocs 1.1.2 and mike 0.5.5
[GitHub/WoltLab/woltlab.github.io.git] / latest / php / api / user_notifications / index.html
CommitLineData
0c5338dd
TD
1
2<!doctype html>
3<html lang="en" class="no-js">
4 <head>
5
6 <meta charset="utf-8">
7 <meta name="viewport" content="width=device-width,initial-scale=1">
8
9
10
11
fb962f09
WG
12 <link rel="icon" href="../../../assets/default.favicon.ico">
13 <meta name="generator" content="mkdocs-1.1.2, mkdocs-material-7.1.0">
0c5338dd
TD
14
15
16
17 <title>User Notifications - WoltLab Suite Documentation</title>
18
19
20
fb962f09 21 <link rel="stylesheet" href="../../../assets/stylesheets/main.33e2939f.min.css">
0c5338dd
TD
22
23
fb962f09 24 <link rel="stylesheet" href="../../../assets/stylesheets/palette.ef6f36e2.min.css">
0c5338dd
TD
25
26
27
28 <meta name="theme-color" content="#009485">
29
30
31
32
33
fd8430cb
WG
34
35
0c5338dd
TD
36
37
38 <link rel="stylesheet" href="../../../stylesheets/extra.css">
39
40
41
42
43
44 </head>
45
46
47
48
49
50
51
52 <body dir="ltr" data-md-color-scheme="" data-md-color-primary="teal" data-md-color-accent="">
0c5338dd
TD
53
54
fb962f09
WG
55 <script>function __prefix(e){return new URL("../../..",location).pathname+"."+e}function __get(e,t=localStorage){return JSON.parse(t.getItem(__prefix(e)))}</script>
56
0c5338dd
TD
57 <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
58 <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
59 <label class="md-overlay" for="__drawer"></label>
60 <div data-md-component="skip">
61
62
63 <a href="#user-notifications" class="md-skip">
64 Skip to content
65 </a>
66
67 </div>
68 <div data-md-component="announce">
69
70 <aside class="md-announce">
71 <div class="md-announce__inner md-grid md-typeset">
72
73 <a href="https://www.woltlab.com">Back to <strong>woltlab.com</strong></a>
74
75 </div>
76 </aside>
77
78 </div>
79
fb962f09 80 <header class="md-header" data-md-component="header">
0c5338dd 81 <nav class="md-header__inner md-grid" aria-label="Header">
fb962f09 82 <a href="../../.." title="WoltLab Suite Documentation" class="md-header__button md-logo" aria-label="WoltLab Suite Documentation" data-md-component="logo">
0c5338dd
TD
83
84 <img src="../../../assets/logo.png" alt="logo">
85
86 </a>
87 <label class="md-header__button md-icon" for="__drawer">
88 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2z"/></svg>
89 </label>
90 <div class="md-header__title" data-md-component="header-title">
91 <div class="md-header__ellipsis">
92 <div class="md-header__topic">
93 <span class="md-ellipsis">
94 WoltLab Suite Documentation
95 </span>
96 </div>
97 <div class="md-header__topic" data-md-component="header-topic">
98 <span class="md-ellipsis">
99
100 User Notifications
101
102 </span>
103 </div>
104 </div>
0c5338dd
TD
105 </div>
106
fb962f09
WG
107
108
a3639e76
WG
109 <label class="md-header__button md-icon" for="__search">
110 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg>
111 </label>
112
113<div class="md-search" data-md-component="search" role="dialog">
114 <label class="md-search__overlay" for="__search"></label>
115 <div class="md-search__inner" role="search">
116 <form class="md-search__form" name="search">
117 <input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" data-md-state="active" required>
118 <label class="md-search__icon md-icon" for="__search">
119 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg>
120 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg>
121 </label>
122 <button type="reset" class="md-search__icon md-icon" aria-label="Clear" tabindex="-1">
fb962f09 123 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"/></svg>
a3639e76
WG
124 </button>
125 </form>
126 <div class="md-search__output">
127 <div class="md-search__scrollwrap" data-md-scrollfix>
128 <div class="md-search-result" data-md-component="search-result">
129 <div class="md-search-result__meta">
130 Initializing search
131 </div>
132 <ol class="md-search-result__list"></ol>
133 </div>
134 </div>
135 </div>
136 </div>
137</div>
138
0c5338dd 139
7124f4cb
WG
140 <div class="md-header__source">
141
142<a href="https://github.com/WoltLab/docs.woltlab.com/" title="Go to repository" class="md-source" data-md-component="source">
143 <div class="md-source__icon md-icon">
144
fb962f09 145 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05 244 40.45a28.87 28.87 0 0 0-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 0 1-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 0 0 0 40.81l195.61 195.6a28.86 28.86 0 0 0 40.8 0l194.69-194.69a28.86 28.86 0 0 0 0-40.81z"/></svg>
7124f4cb
WG
146 </div>
147 <div class="md-source__repository">
148 GitHub
149 </div>
150</a>
151 </div>
152
0c5338dd
TD
153 </nav>
154</header>
155
156 <div class="md-container" data-md-component="container">
157
158
159
160
161 <main class="md-main" data-md-component="main">
162 <div class="md-main__inner md-grid">
163
164
165
166 <div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
167 <div class="md-sidebar__scrollwrap">
168 <div class="md-sidebar__inner">
169
170
171
0c5338dd
TD
172<nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0">
173 <label class="md-nav__title" for="__drawer">
fb962f09 174 <a href="../../.." title="WoltLab Suite Documentation" class="md-nav__button md-logo" aria-label="WoltLab Suite Documentation" data-md-component="logo">
0c5338dd
TD
175
176 <img src="../../../assets/logo.png" alt="logo">
177
178 </a>
179 WoltLab Suite Documentation
180 </label>
181
7124f4cb
WG
182 <div class="md-nav__source">
183
184<a href="https://github.com/WoltLab/docs.woltlab.com/" title="Go to repository" class="md-source" data-md-component="source">
185 <div class="md-source__icon md-icon">
186
fb962f09 187 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05 244 40.45a28.87 28.87 0 0 0-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 0 1-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 0 0 0 40.81l195.61 195.6a28.86 28.86 0 0 0 40.8 0l194.69-194.69a28.86 28.86 0 0 0 0-40.81z"/></svg>
7124f4cb
WG
188 </div>
189 <div class="md-source__repository">
190 GitHub
191 </div>
192</a>
193 </div>
194
0c5338dd
TD
195 <ul class="md-nav__list" data-md-scrollfix>
196
197
198
199
200
201
202
203
204 <li class="md-nav__item">
205 <a href="../../../getting-started/" class="md-nav__link">
206 Getting Started
207 </a>
208 </li>
209
210
211
212
213
214
215
216
217
218
219
220
221
222 <li class="md-nav__item md-nav__item--active md-nav__item--nested">
223
224
225 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2" type="checkbox" id="__nav_2" checked>
226
227 <label class="md-nav__link" for="__nav_2">
228 PHP API
229 <span class="md-nav__icon md-icon"></span>
230 </label>
231 <nav class="md-nav" aria-label="PHP API" data-md-level="1">
232 <label class="md-nav__title" for="__nav_2">
233 <span class="md-nav__icon md-icon"></span>
234 PHP API
235 </label>
236 <ul class="md-nav__list" data-md-scrollfix>
237
238
239
240
241
242 <li class="md-nav__item">
243 <a href="../../pages/" class="md-nav__link">
244 Pages
245 </a>
246 </li>
247
248
249
250
251
252
253
254 <li class="md-nav__item">
255 <a href="../../database-objects/" class="md-nav__link">
256 Database Objects
257 </a>
258 </li>
259
260
261
262
263
264
265
266 <li class="md-nav__item">
267 <a href="../../database-access/" class="md-nav__link">
268 Database Access
269 </a>
270 </li>
271
272
273
274
275
276
277
278 <li class="md-nav__item">
279 <a href="../../exceptions/" class="md-nav__link">
280 Exceptions
281 </a>
282 </li>
283
284
285
286
287
288
289
290
291
292
293 <li class="md-nav__item md-nav__item--active md-nav__item--nested">
294
295
296 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5" type="checkbox" id="__nav_2_5" checked>
297
298 <label class="md-nav__link" for="__nav_2_5">
299 API
300 <span class="md-nav__icon md-icon"></span>
301 </label>
302 <nav class="md-nav" aria-label="API" data-md-level="2">
303 <label class="md-nav__title" for="__nav_2_5">
304 <span class="md-nav__icon md-icon"></span>
305 API
306 </label>
307 <ul class="md-nav__list" data-md-scrollfix>
308
309
310
311
312
313 <li class="md-nav__item">
314 <a href="../caches/" class="md-nav__link">
315 Caches
316 </a>
317 </li>
318
319
320
321
322
323
324
325 <li class="md-nav__item">
326 <a href="../comments/" class="md-nav__link">
327 Comments
328 </a>
329 </li>
330
331
332
333
334
335
336
337 <li class="md-nav__item">
338 <a href="../cronjobs/" class="md-nav__link">
339 Cronjobs
340 </a>
341 </li>
342
343
344
345
346
347
348
349 <li class="md-nav__item">
350 <a href="../events/" class="md-nav__link">
351 Events
352 </a>
353 </li>
354
355
356
357
358
359
360
361
362 <li class="md-nav__item md-nav__item--nested">
363
364
365 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5_5" type="checkbox" id="__nav_2_5_5" >
366
367 <label class="md-nav__link" for="__nav_2_5_5">
368 Form Builder
369 <span class="md-nav__icon md-icon"></span>
370 </label>
371 <nav class="md-nav" aria-label="Form Builder" data-md-level="3">
372 <label class="md-nav__title" for="__nav_2_5_5">
373 <span class="md-nav__icon md-icon"></span>
374 Form Builder
375 </label>
376 <ul class="md-nav__list" data-md-scrollfix>
377
378
379
380
381
382 <li class="md-nav__item">
383 <a href="../form_builder/overview/" class="md-nav__link">
384 Overview
385 </a>
386 </li>
387
388
389
390
391
392
393
394 <li class="md-nav__item">
395 <a href="../form_builder/structure/" class="md-nav__link">
396 Structure
397 </a>
398 </li>
399
400
401
402
403
404
405
406 <li class="md-nav__item">
407 <a href="../form_builder/form_fields/" class="md-nav__link">
408 Fields
409 </a>
410 </li>
411
412
413
414
415
416
417
418 <li class="md-nav__item">
419 <a href="../form_builder/validation_data/" class="md-nav__link">
420 Validation and Data
421 </a>
422 </li>
423
424
425
426
427
428
429
430 <li class="md-nav__item">
431 <a href="../form_builder/dependencies/" class="md-nav__link">
432 Dependencies
433 </a>
434 </li>
435
436
437
438 </ul>
439 </nav>
440 </li>
441
442
443
444
445
446
447
448 <li class="md-nav__item">
449 <a href="../package_installation_plugins/" class="md-nav__link">
450 Package Installation Plugins
451 </a>
452 </li>
453
454
455
456
457
458
459
460 <li class="md-nav__item">
461 <a href="../user_activity_points/" class="md-nav__link">
462 User Activity Points
463 </a>
464 </li>
465
466
467
468
469
470
471
472
473
474 <li class="md-nav__item md-nav__item--active">
475
476 <input class="md-nav__toggle md-toggle" data-md-toggle="toc" type="checkbox" id="__toc">
477
478
479
480
481 <label class="md-nav__link md-nav__link--active" for="__toc">
482 User Notifications
483 <span class="md-nav__icon md-icon"></span>
484 </label>
485
486 <a href="./" class="md-nav__link md-nav__link--active">
487 User Notifications
488 </a>
489
490
491<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
492
493
494
495
496
497 <label class="md-nav__title" for="__toc">
498 <span class="md-nav__icon md-icon"></span>
499 Table of contents
500 </label>
501 <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
502
503 <li class="md-nav__item">
504 <a href="#objecttypexml" class="md-nav__link">
505 objectType.xml
506 </a>
507
508</li>
509
510 <li class="md-nav__item">
511 <a href="#usernotificationeventxml" class="md-nav__link">
512 userNotificationEvent.xml
513 </a>
514
515</li>
516
517 <li class="md-nav__item">
518 <a href="#firing-events" class="md-nav__link">
519 Firing Events
520 </a>
521
522</li>
523
524 <li class="md-nav__item">
525 <a href="#marking-notifications-as-confirmed" class="md-nav__link">
526 Marking Notifications as Confirmed
527 </a>
528
529</li>
530
531 </ul>
532
533</nav>
534
535 </li>
536
537
538
539
540
541
542
543 <li class="md-nav__item">
544 <a href="../sitemaps/" class="md-nav__link">
545 Sitemaps
546 </a>
547 </li>
548
549
550
551 </ul>
552 </nav>
553 </li>
554
555
556
557
558
559
560
561 <li class="md-nav__item">
562 <a href="../../code-style/" class="md-nav__link">
563 Code Style
564 </a>
565 </li>
566
567
568
569
570
571
572
573 <li class="md-nav__item">
574 <a href="../../apps/" class="md-nav__link">
575 Apps
576 </a>
577 </li>
578
579
580
581
582
583
584
585 <li class="md-nav__item">
586 <a href="../../gdpr/" class="md-nav__link">
587 GDPR
588 </a>
589 </li>
590
591
592
593 </ul>
594 </nav>
595 </li>
596
597
598
599
600
601
602
603
604
605
606
607 <li class="md-nav__item md-nav__item--nested">
608
609
610 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_3" type="checkbox" id="__nav_3" >
611
612 <label class="md-nav__link" for="__nav_3">
613 Languages, Templates & CSS
614 <span class="md-nav__icon md-icon"></span>
615 </label>
616 <nav class="md-nav" aria-label="Languages, Templates & CSS" data-md-level="1">
617 <label class="md-nav__title" for="__nav_3">
618 <span class="md-nav__icon md-icon"></span>
619 Languages, Templates & CSS
620 </label>
621 <ul class="md-nav__list" data-md-scrollfix>
622
623
624
625
626
627 <li class="md-nav__item">
628 <a href="../../../view/languages/" class="md-nav__link">
629 Languages
630 </a>
631 </li>
632
633
634
635
636
637
638
639 <li class="md-nav__item">
640 <a href="../../../view/templates/" class="md-nav__link">
641 Templates
642 </a>
643 </li>
644
645
646
647
648
649
650
651 <li class="md-nav__item">
652 <a href="../../../view/css/" class="md-nav__link">
653 CSS
654 </a>
655 </li>
656
657
658
659 </ul>
660 </nav>
661 </li>
662
663
664
665
666
667
668
669
670
671
672
673 <li class="md-nav__item md-nav__item--nested">
674
675
676 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4" type="checkbox" id="__nav_4" >
677
678 <label class="md-nav__link" for="__nav_4">
679 JavaScript API
680 <span class="md-nav__icon md-icon"></span>
681 </label>
682 <nav class="md-nav" aria-label="JavaScript API" data-md-level="1">
683 <label class="md-nav__title" for="__nav_4">
684 <span class="md-nav__icon md-icon"></span>
685 JavaScript API
686 </label>
687 <ul class="md-nav__list" data-md-scrollfix>
688
689
690
691
692
693 <li class="md-nav__item">
694 <a href="../../../javascript/general-usage/" class="md-nav__link">
695 General Usage
696 </a>
697 </li>
698
699
700
701
702
703
704
705
706 <li class="md-nav__item md-nav__item--nested">
707
708
709 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4_2" type="checkbox" id="__nav_4_2" >
710
711 <label class="md-nav__link" for="__nav_4_2">
712 New API
713 <span class="md-nav__icon md-icon"></span>
714 </label>
715 <nav class="md-nav" aria-label="New API" data-md-level="2">
716 <label class="md-nav__title" for="__nav_4_2">
717 <span class="md-nav__icon md-icon"></span>
718 New API
719 </label>
720 <ul class="md-nav__list" data-md-scrollfix>
721
722
723
724
725
726 <li class="md-nav__item">
727 <a href="../../../javascript/new-api_writing-a-module/" class="md-nav__link">
728 Writing a module
729 </a>
730 </li>
731
732
733
734
735
736
737
738 <li class="md-nav__item">
739 <a href="../../../javascript/new-api_data-structures/" class="md-nav__link">
740 Data Structures
741 </a>
742 </li>
743
744
745
746
747
748
749
750 <li class="md-nav__item">
751 <a href="../../../javascript/new-api_core/" class="md-nav__link">
752 Core Functions
753 </a>
754 </li>
755
756
757
758
759
760
761
762 <li class="md-nav__item">
763 <a href="../../../javascript/new-api_dom/" class="md-nav__link">
764 DOM
765 </a>
766 </li>
767
768
769
770
771
772
773
774 <li class="md-nav__item">
775 <a href="../../../javascript/new-api_events/" class="md-nav__link">
776 Event Handling
777 </a>
778 </li>
779
780
781
782
783
784
785
786 <li class="md-nav__item">
787 <a href="../../../javascript/new-api_ajax/" class="md-nav__link">
788 Ajax
789 </a>
790 </li>
791
792
793
794
795
796
797
798 <li class="md-nav__item">
799 <a href="../../../javascript/new-api_dialogs/" class="md-nav__link">
800 Dialogs
801 </a>
802 </li>
803
804
805
806
807
808
809
810 <li class="md-nav__item">
811 <a href="../../../javascript/new-api_browser/" class="md-nav__link">
812 Browser and Screen Sizes
813 </a>
814 </li>
815
816
817
818
819
820
821
822 <li class="md-nav__item">
823 <a href="../../../javascript/new-api_ui/" class="md-nav__link">
824 User Interface
825 </a>
826 </li>
827
828
829
830 </ul>
831 </nav>
832 </li>
833
834
835
836
837
838
839
840 <li class="md-nav__item">
841 <a href="../../../javascript/legacy-api/" class="md-nav__link">
842 Legacy API
843 </a>
844 </li>
845
846
847
848
849
850
851
852 <li class="md-nav__item">
853 <a href="../../../javascript/helper-functions/" class="md-nav__link">
854 Helper Functions
855 </a>
856 </li>
857
858
859
860
861
862
863
864 <li class="md-nav__item">
865 <a href="../../../javascript/code-snippets/" class="md-nav__link">
866 Code Snippets
867 </a>
868 </li>
869
870
871
872 </ul>
873 </nav>
874 </li>
875
876
877
878
879
880
881
882
883
884
885
886 <li class="md-nav__item md-nav__item--nested">
887
888
889 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5" type="checkbox" id="__nav_5" >
890
891 <label class="md-nav__link" for="__nav_5">
892 Package Components
893 <span class="md-nav__icon md-icon"></span>
894 </label>
895 <nav class="md-nav" aria-label="Package Components" data-md-level="1">
896 <label class="md-nav__title" for="__nav_5">
897 <span class="md-nav__icon md-icon"></span>
898 Package Components
899 </label>
900 <ul class="md-nav__list" data-md-scrollfix>
901
902
903
904
905
906 <li class="md-nav__item">
907 <a href="../../../package/package-xml/" class="md-nav__link">
908 package.xml
909 </a>
910 </li>
911
912
913
914
915
916
917
918
919 <li class="md-nav__item md-nav__item--nested">
920
921
922 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_2" type="checkbox" id="__nav_5_2" >
923
924 <label class="md-nav__link" for="__nav_5_2">
925 PIPs
926 <span class="md-nav__icon md-icon"></span>
927 </label>
928 <nav class="md-nav" aria-label="PIPs" data-md-level="2">
929 <label class="md-nav__title" for="__nav_5_2">
930 <span class="md-nav__icon md-icon"></span>
931 PIPs
932 </label>
933 <ul class="md-nav__list" data-md-scrollfix>
934
935
936
937
938
939 <li class="md-nav__item">
940 <a href="../../../package/pip/" class="md-nav__link">
941 Overview
942 </a>
943 </li>
944
945
946
947
948
949
950
951 <li class="md-nav__item">
952 <a href="../../../package/pip/acl-option/" class="md-nav__link">
953 aclOption
954 </a>
955 </li>
956
957
958
959
960
961
962
963 <li class="md-nav__item">
964 <a href="../../../package/pip/acp-menu/" class="md-nav__link">
965 acpMenu
966 </a>
967 </li>
968
969
970
971
972
973
974
975 <li class="md-nav__item">
976 <a href="../../../package/pip/acp-search-provider/" class="md-nav__link">
977 acpSearchProvider
978 </a>
979 </li>
980
981
982
983
984
985
986
987 <li class="md-nav__item">
988 <a href="../../../package/pip/acp-template/" class="md-nav__link">
989 acpTemplate
990 </a>
991 </li>
992
993
994
995
996
997
998
999 <li class="md-nav__item">
1000 <a href="../../../package/pip/bbcode/" class="md-nav__link">
1001 bbcode
1002 </a>
1003 </li>
1004
1005
1006
1007
1008
1009
1010
1011 <li class="md-nav__item">
1012 <a href="../../../package/pip/box/" class="md-nav__link">
1013 box
1014 </a>
1015 </li>
1016
1017
1018
1019
1020
1021
1022
1023 <li class="md-nav__item">
1024 <a href="../../../package/pip/clipboard-action/" class="md-nav__link">
1025 clipboardAction
1026 </a>
1027 </li>
1028
1029
1030
1031
1032
1033
1034
1035 <li class="md-nav__item">
1036 <a href="../../../package/pip/core-object/" class="md-nav__link">
1037 coreObject
1038 </a>
1039 </li>
1040
1041
1042
1043
1044
1045
1046
1047 <li class="md-nav__item">
1048 <a href="../../../package/pip/cronjob/" class="md-nav__link">
1049 cronjob
1050 </a>
1051 </li>
1052
1053
1054
1055
1056
1057
1058
1059 <li class="md-nav__item">
1060 <a href="../../../package/pip/event-listener/" class="md-nav__link">
1061 eventListener
1062 </a>
1063 </li>
1064
1065
1066
1067
1068
1069
1070
1071 <li class="md-nav__item">
1072 <a href="../../../package/pip/file/" class="md-nav__link">
1073 file
1074 </a>
1075 </li>
1076
1077
1078
1079
1080
1081
1082
1083 <li class="md-nav__item">
1084 <a href="../../../package/pip/language/" class="md-nav__link">
1085 language
1086 </a>
1087 </li>
1088
1089
1090
1091
1092
1093
1094
1095 <li class="md-nav__item">
1096 <a href="../../../package/pip/media-provider/" class="md-nav__link">
1097 mediaProvider
1098 </a>
1099 </li>
1100
1101
1102
1103
1104
1105
1106
1107 <li class="md-nav__item">
1108 <a href="../../../package/pip/menu/" class="md-nav__link">
1109 menu
1110 </a>
1111 </li>
1112
1113
1114
1115
1116
1117
1118
1119 <li class="md-nav__item">
1120 <a href="../../../package/pip/menu-item/" class="md-nav__link">
1121 menuItem
1122 </a>
1123 </li>
1124
1125
1126
1127
1128
1129
1130
1131 <li class="md-nav__item">
1132 <a href="../../../package/pip/object-type/" class="md-nav__link">
1133 objectType
1134 </a>
1135 </li>
1136
1137
1138
1139
1140
1141
1142
1143 <li class="md-nav__item">
1144 <a href="../../../package/pip/object-type-definition/" class="md-nav__link">
1145 objectTypeDefinition
1146 </a>
1147 </li>
1148
1149
1150
1151
1152
1153
1154
1155 <li class="md-nav__item">
1156 <a href="../../../package/pip/option/" class="md-nav__link">
1157 option
1158 </a>
1159 </li>
1160
1161
1162
1163
1164
1165
1166
1167 <li class="md-nav__item">
1168 <a href="../../../package/pip/page/" class="md-nav__link">
1169 page
1170 </a>
1171 </li>
1172
1173
1174
1175
1176
1177
1178
1179 <li class="md-nav__item">
1180 <a href="../../../package/pip/pip/" class="md-nav__link">
1181 pip
1182 </a>
1183 </li>
1184
1185
1186
1187
1188
1189
1190
1191 <li class="md-nav__item">
1192 <a href="../../../package/pip/script/" class="md-nav__link">
1193 script
1194 </a>
1195 </li>
1196
1197
1198
1199
1200
1201
1202
1203 <li class="md-nav__item">
1204 <a href="../../../package/pip/smiley/" class="md-nav__link">
1205 smiley
1206 </a>
1207 </li>
1208
1209
1210
1211
1212
1213
1214
1215 <li class="md-nav__item">
1216 <a href="../../../package/pip/sql/" class="md-nav__link">
1217 sql
1218 </a>
1219 </li>
1220
1221
1222
1223
1224
1225
1226
1227 <li class="md-nav__item">
1228 <a href="../../../package/pip/style/" class="md-nav__link">
1229 style
1230 </a>
1231 </li>
1232
1233
1234
1235
1236
1237
1238
1239 <li class="md-nav__item">
1240 <a href="../../../package/pip/template/" class="md-nav__link">
1241 template
1242 </a>
1243 </li>
1244
1245
1246
1247
1248
1249
1250
1251 <li class="md-nav__item">
1252 <a href="../../../package/pip/template-listener/" class="md-nav__link">
1253 templateListener
1254 </a>
1255 </li>
1256
1257
1258
1259
1260
1261
1262
1263 <li class="md-nav__item">
1264 <a href="../../../package/pip/user-group-option/" class="md-nav__link">
1265 userGroupOption
1266 </a>
1267 </li>
1268
1269
1270
1271
1272
1273
1274
1275 <li class="md-nav__item">
1276 <a href="../../../package/pip/user-menu/" class="md-nav__link">
1277 userMenu
1278 </a>
1279 </li>
1280
1281
1282
1283
1284
1285
1286
1287 <li class="md-nav__item">
1288 <a href="../../../package/pip/user-notification-event/" class="md-nav__link">
1289 userNotificationEvent
1290 </a>
1291 </li>
1292
1293
1294
1295
1296
1297
1298
1299 <li class="md-nav__item">
1300 <a href="../../../package/pip/user-option/" class="md-nav__link">
1301 userOption
1302 </a>
1303 </li>
1304
1305
1306
1307
1308
1309
1310
1311 <li class="md-nav__item">
1312 <a href="../../../package/pip/user-profile-menu/" class="md-nav__link">
1313 userProfileMenu
1314 </a>
1315 </li>
1316
1317
1318
1319 </ul>
1320 </nav>
1321 </li>
1322
1323
1324
1325
1326
1327
1328
1329 <li class="md-nav__item">
1330 <a href="../../../package/database-php-api/" class="md-nav__link">
1331 Database PHP API
1332 </a>
1333 </li>
1334
1335
1336
1337 </ul>
1338 </nav>
1339 </li>
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351 <li class="md-nav__item md-nav__item--nested">
1352
1353
1354 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6" type="checkbox" id="__nav_6" >
1355
1356 <label class="md-nav__link" for="__nav_6">
1357 Migration
1358 <span class="md-nav__icon md-icon"></span>
1359 </label>
1360 <nav class="md-nav" aria-label="Migration" data-md-level="1">
1361 <label class="md-nav__title" for="__nav_6">
1362 <span class="md-nav__icon md-icon"></span>
1363 Migration
1364 </label>
1365 <ul class="md-nav__list" data-md-scrollfix>
1366
1367
1368
1369
1370
1371
1372 <li class="md-nav__item md-nav__item--nested">
1373
1374
1375 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_1" type="checkbox" id="__nav_6_1" >
1376
1377 <label class="md-nav__link" for="__nav_6_1">
1378 Migrating from WSC 5.3
1379 <span class="md-nav__icon md-icon"></span>
1380 </label>
1381 <nav class="md-nav" aria-label="Migrating from WSC 5.3" data-md-level="2">
1382 <label class="md-nav__title" for="__nav_6_1">
1383 <span class="md-nav__icon md-icon"></span>
1384 Migrating from WSC 5.3
1385 </label>
1386 <ul class="md-nav__list" data-md-scrollfix>
1387
1388
1389
1390
1391
1392 <li class="md-nav__item">
1393 <a href="../../../migration/wsc53/php/" class="md-nav__link">
1394 PHP API
1395 </a>
1396 </li>
1397
1398
1399
1400
1401
1402
1403
1404 <li class="md-nav__item">
1405 <a href="../../../migration/wsc53/session/" class="md-nav__link">
1406 Session Handling and Authentication
1407 </a>
1408 </li>
1409
1410
1411
1412
1413
1414
1415
1416 <li class="md-nav__item">
1417 <a href="../../../migration/wsc53/javascript/" class="md-nav__link">
1418 JavaScript
1419 </a>
1420 </li>
1421
1422
1423
1424
1425
1426
1427
1428 <li class="md-nav__item">
1429 <a href="../../../migration/wsc53/templates/" class="md-nav__link">
1430 Templates
1431 </a>
1432 </li>
1433
1434
1435
1436
1437
1438
1439
1440 <li class="md-nav__item">
1441 <a href="../../../migration/wsc53/libraries/" class="md-nav__link">
1442 Third Party Libraries
1443 </a>
1444 </li>
1445
1446
1447
1448 </ul>
1449 </nav>
1450 </li>
1451
1452
1453
1454
1455
1456
1457
1458
1459 <li class="md-nav__item md-nav__item--nested">
1460
1461
1462 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_2" type="checkbox" id="__nav_6_2" >
1463
1464 <label class="md-nav__link" for="__nav_6_2">
1465 Migrating from WSC 5.2
1466 <span class="md-nav__icon md-icon"></span>
1467 </label>
1468 <nav class="md-nav" aria-label="Migrating from WSC 5.2" data-md-level="2">
1469 <label class="md-nav__title" for="__nav_6_2">
1470 <span class="md-nav__icon md-icon"></span>
1471 Migrating from WSC 5.2
1472 </label>
1473 <ul class="md-nav__list" data-md-scrollfix>
1474
1475
1476
1477
1478
1479 <li class="md-nav__item">
1480 <a href="../../../migration/wsc52/php/" class="md-nav__link">
1481 PHP API
1482 </a>
1483 </li>
1484
1485
1486
1487
1488
1489
1490
1491 <li class="md-nav__item">
1492 <a href="../../../migration/wsc52/templates/" class="md-nav__link">
1493 Templates and Languages
1494 </a>
1495 </li>
1496
1497
1498
1499
1500
1501
1502
1503 <li class="md-nav__item">
1504 <a href="../../../migration/wsc52/libraries/" class="md-nav__link">
1505 Third Party Libraries
1506 </a>
1507 </li>
1508
1509
1510
1511 </ul>
1512 </nav>
1513 </li>
1514
1515
1516
1517
1518
1519
1520
1521
1522 <li class="md-nav__item md-nav__item--nested">
1523
1524
1525 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_3" type="checkbox" id="__nav_6_3" >
1526
1527 <label class="md-nav__link" for="__nav_6_3">
1528 Migrating from WSC 3.1
1529 <span class="md-nav__icon md-icon"></span>
1530 </label>
1531 <nav class="md-nav" aria-label="Migrating from WSC 3.1" data-md-level="2">
1532 <label class="md-nav__title" for="__nav_6_3">
1533 <span class="md-nav__icon md-icon"></span>
1534 Migrating from WSC 3.1
1535 </label>
1536 <ul class="md-nav__list" data-md-scrollfix>
1537
1538
1539
1540
1541
1542 <li class="md-nav__item">
1543 <a href="../../../migration/wsc31/php/" class="md-nav__link">
1544 PHP API
1545 </a>
1546 </li>
1547
1548
1549
1550 </ul>
1551 </nav>
1552 </li>
1553
1554
1555
1556
1557
1558
1559
1560
1561 <li class="md-nav__item md-nav__item--nested">
1562
1563
1564 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_4" type="checkbox" id="__nav_6_4" >
1565
1566 <label class="md-nav__link" for="__nav_6_4">
1567 Migrating from WSC 3.0
1568 <span class="md-nav__icon md-icon"></span>
1569 </label>
1570 <nav class="md-nav" aria-label="Migrating from WSC 3.0" data-md-level="2">
1571 <label class="md-nav__title" for="__nav_6_4">
1572 <span class="md-nav__icon md-icon"></span>
1573 Migrating from WSC 3.0
1574 </label>
1575 <ul class="md-nav__list" data-md-scrollfix>
1576
1577
1578
1579
1580
1581 <li class="md-nav__item">
1582 <a href="../../../migration/wsc30/php/" class="md-nav__link">
1583 PHP API
1584 </a>
1585 </li>
1586
1587
1588
1589
1590
1591
1592
1593 <li class="md-nav__item">
1594 <a href="../../../migration/wsc30/javascript/" class="md-nav__link">
1595 JavaScript API
1596 </a>
1597 </li>
1598
1599
1600
1601
1602
1603
1604
1605 <li class="md-nav__item">
1606 <a href="../../../migration/wsc30/templates/" class="md-nav__link">
1607 Templates
1608 </a>
1609 </li>
1610
1611
1612
1613
1614
1615
1616
1617 <li class="md-nav__item">
1618 <a href="../../../migration/wsc30/css/" class="md-nav__link">
1619 CSS
1620 </a>
1621 </li>
1622
1623
1624
1625
1626
1627
1628
1629 <li class="md-nav__item">
1630 <a href="../../../migration/wsc30/package/" class="md-nav__link">
1631 Package Components
1632 </a>
1633 </li>
1634
1635
1636
1637 </ul>
1638 </nav>
1639 </li>
1640
1641
1642
1643
1644
1645
1646
1647
1648 <li class="md-nav__item md-nav__item--nested">
1649
1650
1651 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_5" type="checkbox" id="__nav_6_5" >
1652
1653 <label class="md-nav__link" for="__nav_6_5">
1654 Migrating from WCF 2.1
1655 <span class="md-nav__icon md-icon"></span>
1656 </label>
1657 <nav class="md-nav" aria-label="Migrating from WCF 2.1" data-md-level="2">
1658 <label class="md-nav__title" for="__nav_6_5">
1659 <span class="md-nav__icon md-icon"></span>
1660 Migrating from WCF 2.1
1661 </label>
1662 <ul class="md-nav__list" data-md-scrollfix>
1663
1664
1665
1666
1667
1668 <li class="md-nav__item">
1669 <a href="../../../migration/wcf21/php/" class="md-nav__link">
1670 PHP API
1671 </a>
1672 </li>
1673
1674
1675
1676
1677
1678
1679
1680 <li class="md-nav__item">
1681 <a href="../../../migration/wcf21/templates/" class="md-nav__link">
1682 Templates
1683 </a>
1684 </li>
1685
1686
1687
1688
1689
1690
1691
1692 <li class="md-nav__item">
1693 <a href="../../../migration/wcf21/css/" class="md-nav__link">
1694 CSS
1695 </a>
1696 </li>
1697
1698
1699
1700
1701
1702
1703
1704 <li class="md-nav__item">
1705 <a href="../../../migration/wcf21/package/" class="md-nav__link">
1706 Package Components
1707 </a>
1708 </li>
1709
1710
1711
1712 </ul>
1713 </nav>
1714 </li>
1715
1716
1717
1718 </ul>
1719 </nav>
1720 </li>
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732 <li class="md-nav__item md-nav__item--nested">
1733
1734
1735 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7" type="checkbox" id="__nav_7" >
1736
1737 <label class="md-nav__link" for="__nav_7">
1738 Tutorials
1739 <span class="md-nav__icon md-icon"></span>
1740 </label>
1741 <nav class="md-nav" aria-label="Tutorials" data-md-level="1">
1742 <label class="md-nav__title" for="__nav_7">
1743 <span class="md-nav__icon md-icon"></span>
1744 Tutorials
1745 </label>
1746 <ul class="md-nav__list" data-md-scrollfix>
1747
1748
1749
1750
1751
1752
1753 <li class="md-nav__item md-nav__item--nested">
1754
1755
1756 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7_1" type="checkbox" id="__nav_7_1" >
1757
1758 <label class="md-nav__link" for="__nav_7_1">
1759 Tutorial Series
1760 <span class="md-nav__icon md-icon"></span>
1761 </label>
1762 <nav class="md-nav" aria-label="Tutorial Series" data-md-level="2">
1763 <label class="md-nav__title" for="__nav_7_1">
1764 <span class="md-nav__icon md-icon"></span>
1765 Tutorial Series
1766 </label>
1767 <ul class="md-nav__list" data-md-scrollfix>
1768
1769
1770
1771
1772
1773 <li class="md-nav__item">
1774 <a href="../../../tutorial/series/overview/" class="md-nav__link">
1775 Overview
1776 </a>
1777 </li>
1778
1779
1780
1781
1782
1783
1784
1785 <li class="md-nav__item">
1786 <a href="../../../tutorial/series/part_1/" class="md-nav__link">
1787 Part 1
1788 </a>
1789 </li>
1790
1791
1792
1793
1794
1795
1796
1797 <li class="md-nav__item">
1798 <a href="../../../tutorial/series/part_2/" class="md-nav__link">
1799 Part 2
1800 </a>
1801 </li>
1802
1803
1804
1805
1806
1807
1808
1809 <li class="md-nav__item">
1810 <a href="../../../tutorial/series/part_3/" class="md-nav__link">
1811 Part 3
1812 </a>
1813 </li>
1814
1815
1816
1817 </ul>
1818 </nav>
1819 </li>
1820
1821
1822
1823 </ul>
1824 </nav>
1825 </li>
1826
1827
1828
1829 </ul>
1830</nav>
1831 </div>
1832 </div>
1833 </div>
1834
1835
1836
1837 <div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
1838 <div class="md-sidebar__scrollwrap">
1839 <div class="md-sidebar__inner">
1840
1841<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
1842
1843
1844
1845
1846
1847 <label class="md-nav__title" for="__toc">
1848 <span class="md-nav__icon md-icon"></span>
1849 Table of contents
1850 </label>
1851 <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
1852
1853 <li class="md-nav__item">
1854 <a href="#objecttypexml" class="md-nav__link">
1855 objectType.xml
1856 </a>
1857
1858</li>
1859
1860 <li class="md-nav__item">
1861 <a href="#usernotificationeventxml" class="md-nav__link">
1862 userNotificationEvent.xml
1863 </a>
1864
1865</li>
1866
1867 <li class="md-nav__item">
1868 <a href="#firing-events" class="md-nav__link">
1869 Firing Events
1870 </a>
1871
1872</li>
1873
1874 <li class="md-nav__item">
1875 <a href="#marking-notifications-as-confirmed" class="md-nav__link">
1876 Marking Notifications as Confirmed
1877 </a>
1878
1879</li>
1880
1881 </ul>
1882
1883</nav>
1884 </div>
1885 </div>
1886 </div>
1887
1888
1889 <div class="md-content" data-md-component="content">
1890 <article class="md-content__inner md-typeset">
1891
1892
9b8bddda 1893 <a href="https://github.com/WoltLab/docs.woltlab.com/edit/5.4/docs/php/api/user_notifications.md" title="Edit this page" class="md-content__button md-icon">
7124f4cb
WG
1894 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20.71 7.04c.39-.39.39-1.04 0-1.41l-2.34-2.34c-.37-.39-1.02-.39-1.41 0l-1.84 1.83 3.75 3.75M3 17.25V21h3.75L17.81 9.93l-3.75-3.75L3 17.25z"/></svg>
1895 </a>
1896
0c5338dd
TD
1897
1898 <h1 id="user-notifications">User Notifications<a class="headerlink" href="#user-notifications" title="Permanent link">#</a></h1>
1899<p>WoltLab Suite includes a powerful user notification system that supports notifications directly shown on the website and emails sent immediately or on a daily basis.</p>
1900<h2 id="objecttypexml"><code>objectType.xml</code><a class="headerlink" href="#objecttypexml" title="Permanent link">#</a></h2>
1901<p>For any type of object related to events, you have to define an object type for the object type definition <code>com.woltlab.wcf.notification.objectType</code>:</p>
1902<div class="highlight"><pre><span></span><code><span class="cp">&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;</span>
1903<span class="nt">&lt;data</span> <span class="na">xmlns=</span><span class="s">&quot;http://www.woltlab.com&quot;</span> <span class="na">xmlns:xsi=</span><span class="s">&quot;http://www.w3.org/2001/XMLSchema-instance&quot;</span> <span class="na">xsi:schemaLocation=</span><span class="s">&quot;http://www.woltlab.com http://www.woltlab.com/XSD/2019/objectType.xsd&quot;</span><span class="nt">&gt;</span>
1904 <span class="nt">&lt;import&gt;</span>
1905 <span class="nt">&lt;type&gt;</span>
1906 <span class="nt">&lt;name&gt;</span>com.woltlab.example.foo<span class="nt">&lt;/name&gt;</span>
1907 <span class="nt">&lt;definitionname&gt;</span>com.woltlab.wcf.notification.objectType<span class="nt">&lt;/definitionname&gt;</span>
1908 <span class="nt">&lt;classname&gt;</span>example\system\user\notification\object\type\FooUserNotificationObjectType<span class="nt">&lt;/classname&gt;</span>
1909 <span class="nt">&lt;category&gt;</span>com.woltlab.example<span class="nt">&lt;/category&gt;</span>
1910 <span class="nt">&lt;/type&gt;</span>
1911 <span class="nt">&lt;/import&gt;</span>
1912<span class="nt">&lt;/data&gt;</span>
1913</code></pre></div>
0c5338dd
TD
1914<p>The referenced class <code>FooUserNotificationObjectType</code> has to implement the <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/user/notification/object/type/IUserNotificationObjectType.class.php">IUserNotificationObjectType</a> interface, which should be done by extending <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/user/notification/object/type/AbstractUserNotificationObjectType.class.php">AbstractUserNotificationObjectType</a>.</p>
1915<div class="highlight"><pre><span></span><code><span class="o">&lt;?</span><span class="nx">php</span>
1916<span class="k">namespace</span> <span class="nx">example\system\user\notification\object\type</span><span class="p">;</span>
1917<span class="k">use</span> <span class="nx">example\data\foo\Foo</span><span class="p">;</span>
1918<span class="k">use</span> <span class="nx">example\data\foo\FooList</span><span class="p">;</span>
1919<span class="k">use</span> <span class="nx">example\system\user\notification\object\FooUserNotificationObject</span><span class="p">;</span>
1920<span class="k">use</span> <span class="nx">wcf\system\user\notification\object\type\AbstractUserNotificationObjectType</span><span class="p">;</span>
1921
1922<span class="sd">/**</span>
1923<span class="sd"> * Represents a foo as a notification object type.</span>
1924<span class="sd"> * </span>
1925<span class="sd"> * @author Matthias Schmidt</span>
1926<span class="sd"> * @copyright 2001-2017 WoltLab GmbH</span>
1927<span class="sd"> * @license WoltLab License &lt;http://www.woltlab.com/license-agreement.html&gt;</span>
1928<span class="sd"> * @package WoltLabSuite\Example\System\User\Notification\Object\Type</span>
1929<span class="sd"> */</span>
1930<span class="k">class</span> <span class="nc">FooUserNotificationObjectType</span> <span class="k">extends</span> <span class="nx">AbstractUserNotificationObjectType</span> <span class="p">{</span>
1931 <span class="sd">/**</span>
1932<span class="sd"> * @inheritDoc</span>
1933<span class="sd"> */</span>
1934 <span class="k">protected</span> <span class="k">static</span> <span class="nv">$decoratorClassName</span> <span class="o">=</span> <span class="nx">FooUserNotificationObject</span><span class="o">::</span><span class="na">class</span><span class="p">;</span>
1935
1936 <span class="sd">/**</span>
1937<span class="sd"> * @inheritDoc</span>
1938<span class="sd"> */</span>
1939 <span class="k">protected</span> <span class="k">static</span> <span class="nv">$objectClassName</span> <span class="o">=</span> <span class="nx">Foo</span><span class="o">::</span><span class="na">class</span><span class="p">;</span>
1940
1941 <span class="sd">/**</span>
1942<span class="sd"> * @inheritDoc</span>
1943<span class="sd"> */</span>
1944 <span class="k">protected</span> <span class="k">static</span> <span class="nv">$objectListClassName</span> <span class="o">=</span> <span class="nx">FooList</span><span class="o">::</span><span class="na">class</span><span class="p">;</span>
1945<span class="p">}</span>
1946</code></pre></div>
0c5338dd
TD
1947<p>You have to set the class names of the database object (<code>$objectClassName</code>) and the related list (<code>$objectListClassName</code>).
1948Additionally, you have to create a class that implements the <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/user/notification/object/IUserNotificationObject.class.php">IUserNotificationObject</a> whose name you have to set as the value of the <code>$decoratorClassName</code> property. </p>
1949<div class="highlight"><pre><span></span><code><span class="o">&lt;?</span><span class="nx">php</span>
1950<span class="k">namespace</span> <span class="nx">example\system\user\notification\object</span><span class="p">;</span>
1951<span class="k">use</span> <span class="nx">example\data\foo\Foo</span><span class="p">;</span>
1952<span class="k">use</span> <span class="nx">wcf\data\DatabaseObjectDecorator</span><span class="p">;</span>
1953<span class="k">use</span> <span class="nx">wcf\system\user\notification\object\IUserNotificationObject</span><span class="p">;</span>
1954
1955<span class="sd">/**</span>
1956<span class="sd"> * Represents a foo as a notification object.</span>
1957<span class="sd"> * </span>
1958<span class="sd"> * @author Matthias Schmidt</span>
1959<span class="sd"> * @copyright 2001-2017 WoltLab GmbH</span>
1960<span class="sd"> * @license WoltLab License &lt;http://www.woltlab.com/license-agreement.html&gt;</span>
1961<span class="sd"> * @package WoltLabSuite\Example\System\User\Notification\Object</span>
1962<span class="sd"> * </span>
1963<span class="sd"> * @method Foo getDecoratedObject()</span>
1964<span class="sd"> * @mixin Foo</span>
1965<span class="sd"> */</span>
1966<span class="k">class</span> <span class="nc">FooUserNotificationObject</span> <span class="k">extends</span> <span class="nx">DatabaseObjectDecorator</span> <span class="k">implements</span> <span class="nx">IUserNotificationObject</span> <span class="p">{</span>
1967 <span class="sd">/**</span>
1968<span class="sd"> * @inheritDoc</span>
1969<span class="sd"> */</span>
1970 <span class="k">protected</span> <span class="k">static</span> <span class="nv">$baseClass</span> <span class="o">=</span> <span class="nx">Foo</span><span class="o">::</span><span class="na">class</span><span class="p">;</span>
1971
1972 <span class="sd">/**</span>
1973<span class="sd"> * @inheritDoc</span>
1974<span class="sd"> */</span>
1975 <span class="k">public</span> <span class="k">function</span> <span class="nf">getTitle</span><span class="p">()</span> <span class="p">{</span>
1976 <span class="k">return</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getDecoratedObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">getTitle</span><span class="p">();</span>
1977 <span class="p">}</span>
1978
1979 <span class="sd">/**</span>
1980<span class="sd"> * @inheritDoc</span>
1981<span class="sd"> */</span>
1982 <span class="k">public</span> <span class="k">function</span> <span class="nf">getURL</span><span class="p">()</span> <span class="p">{</span>
1983 <span class="k">return</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getDecoratedObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">getLink</span><span class="p">();</span>
1984 <span class="p">}</span>
1985
1986 <span class="sd">/**</span>
1987<span class="sd"> * @inheritDoc</span>
1988<span class="sd"> */</span>
1989 <span class="k">public</span> <span class="k">function</span> <span class="nf">getAuthorID</span><span class="p">()</span> <span class="p">{</span>
1990 <span class="k">return</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getDecoratedObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">userID</span><span class="p">;</span>
1991 <span class="p">}</span>
1992<span class="p">}</span>
1993</code></pre></div>
0c5338dd
TD
1994<ul>
1995<li>The <code>getTitle()</code> method returns the title of the object.
1996 In this case, we assume that the <code>Foo</code> class has implemented the <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/data/ITitledObject.class.php">ITitledObject</a> interface so that the decorated <code>Foo</code> can handle this method call itself.</li>
1997<li>The <code>getURL()</code> method returns the link to the object.
1998 As for the <code>getTitle()</code>, we assume that the <code>Foo</code> class has implemented the <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/data/ILinkableObject.class.php">ILinkableObject</a> interface so that the decorated <code>Foo</code> can also handle this method call itself.</li>
1999<li>The <code>getAuthorID()</code> method returns the id of the user who created the decorated <code>Foo</code> object.
2000 We assume that <code>Foo</code> objects have a <code>userID</code> property that contains this id.</li>
2001</ul>
2002<h2 id="usernotificationeventxml"><code>userNotificationEvent.xml</code><a class="headerlink" href="#usernotificationeventxml" title="Permanent link">#</a></h2>
2003<p>Each event that you fire in your package needs to be registered using the <a href="../../../package/pip/user-notification-event/">user notification event package installation plugin</a>.
2004An example file might look like this:</p>
2005<div class="highlight"><pre><span></span><code><span class="cp">&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;</span>
2006<span class="nt">&lt;data</span> <span class="na">xmlns=</span><span class="s">&quot;http://www.woltlab.com&quot;</span> <span class="na">xmlns:xsi=</span><span class="s">&quot;http://www.w3.org/2001/XMLSchema-instance&quot;</span> <span class="na">xsi:schemaLocation=</span><span class="s">&quot;http://www.woltlab.com http://www.woltlab.com/XSD/2019/userNotificationEvent.xsd&quot;</span><span class="nt">&gt;</span>
2007 <span class="nt">&lt;import&gt;</span>
2008 <span class="nt">&lt;event&gt;</span>
2009 <span class="nt">&lt;name&gt;</span>bar<span class="nt">&lt;/name&gt;</span>
2010 <span class="nt">&lt;objecttype&gt;</span>com.woltlab.example.foo<span class="nt">&lt;/objecttype&gt;</span>
2011 <span class="nt">&lt;classname&gt;</span>example\system\user\notification\event\FooUserNotificationEvent<span class="nt">&lt;/classname&gt;</span>
2012 <span class="nt">&lt;preset&gt;</span>1<span class="nt">&lt;/preset&gt;</span>
2013 <span class="nt">&lt;/event&gt;</span>
2014 <span class="nt">&lt;/import&gt;</span>
2015<span class="nt">&lt;/data&gt;</span>
2016</code></pre></div>
0c5338dd
TD
2017<p>Here, you reference the user notification object type created via <code>objectType.xml</code>.
2018The referenced class in the <code>&lt;classname&gt;</code> element has to implement the <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/user/notification/event/IUserNotificationEvent.class.php">IUserNotificationEvent</a> interface by extending the <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/user/notification/event/AbstractUserNotificationEvent.class.php">AbstractUserNotificationEvent</a> class or the <a href="https://github.com/WoltLab/WCF/blob/master/wcfsetup/install/files/lib/system/user/notification/event/AbstractSharedUserNotificationEvent.class.php">AbstractSharedUserNotificationEvent</a> class if you want to pre-load additional data before processing notifications.
2019In <code>AbstractSharedUserNotificationEvent::prepare()</code>, you can, for example, tell runtime caches to prepare to load certain objects which then are loaded all at once when the objects are needed.</p>
2020<div class="highlight"><pre><span></span><code><span class="o">&lt;?</span><span class="nx">php</span>
2021<span class="k">namespace</span> <span class="nx">example\system\user\notification\event</span><span class="p">;</span>
2022<span class="k">use</span> <span class="nx">example\system\cache\runtime\BazRuntimeCache</span><span class="p">;</span>
2023<span class="k">use</span> <span class="nx">example\system\user\notification\object\FooUserNotificationObject</span><span class="p">;</span>
2024<span class="k">use</span> <span class="nx">wcf\system\email\Email</span><span class="p">;</span>
2025<span class="k">use</span> <span class="nx">wcf\system\request\LinkHandler</span><span class="p">;</span>
2026<span class="k">use</span> <span class="nx">wcf\system\user\notification\event\AbstractSharedUserNotificationEvent</span><span class="p">;</span>
2027
2028<span class="sd">/**</span>
2029<span class="sd"> * Notification event for foos.</span>
2030<span class="sd"> * </span>
2031<span class="sd"> * @author Matthias Schmidt</span>
2032<span class="sd"> * @copyright 2001-2017 WoltLab GmbH</span>
2033<span class="sd"> * @license WoltLab License &lt;http://www.woltlab.com/license-agreement.html&gt;</span>
2034<span class="sd"> * @package WoltLabSuite\Example\System\User\Notification\Event</span>
2035<span class="sd"> * </span>
2036<span class="sd"> * @method FooUserNotificationObject getUserNotificationObject()</span>
2037<span class="sd"> */</span>
2038<span class="k">class</span> <span class="nc">FooUserNotificationEvent</span> <span class="k">extends</span> <span class="nx">AbstractSharedUserNotificationEvent</span> <span class="p">{</span>
2039 <span class="sd">/**</span>
2040<span class="sd"> * @inheritDoc</span>
2041<span class="sd"> */</span>
2042 <span class="k">protected</span> <span class="nv">$stackable</span> <span class="o">=</span> <span class="k">true</span><span class="p">;</span>
2043
2044 <span class="sd">/** @noinspection PhpMissingParentCallCommonInspection */</span>
2045 <span class="sd">/**</span>
2046<span class="sd"> * @inheritDoc</span>
2047<span class="sd"> */</span>
2048 <span class="k">public</span> <span class="k">function</span> <span class="nf">checkAccess</span><span class="p">()</span> <span class="p">{</span>
2049 <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">setBaz</span><span class="p">(</span><span class="nx">BazRuntimeCache</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">getObject</span><span class="p">(</span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">bazID</span><span class="p">));</span>
2050
2051 <span class="k">if</span> <span class="p">(</span><span class="o">!</span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">isAccessible</span><span class="p">())</span> <span class="p">{</span>
2052 <span class="c1">// do some cleanup, if necessary</span>
2053
2054 <span class="k">return</span> <span class="k">false</span><span class="p">;</span>
2055 <span class="p">}</span>
2056
2057 <span class="k">return</span> <span class="k">true</span><span class="p">;</span>
2058 <span class="p">}</span>
2059
2060 <span class="sd">/** @noinspection PhpMissingParentCallCommonInspection */</span>
2061 <span class="sd">/**</span>
2062<span class="sd"> * @inheritDoc</span>
2063<span class="sd"> */</span>
2064 <span class="k">public</span> <span class="k">function</span> <span class="nf">getEmailMessage</span><span class="p">(</span><span class="nv">$notificationType</span> <span class="o">=</span> <span class="s1">&#39;instant&#39;</span><span class="p">)</span> <span class="p">{</span>
2065 <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">setBaz</span><span class="p">(</span><span class="nx">BazRuntimeCache</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">getObject</span><span class="p">(</span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">bazID</span><span class="p">));</span>
2066
2067 <span class="nv">$messageID</span> <span class="o">=</span> <span class="s1">&#39;&lt;com.woltlab.example.baz/&#39;</span><span class="o">.</span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">bazID</span><span class="o">.</span><span class="s1">&#39;@&#39;</span><span class="o">.</span><span class="nx">Email</span><span class="o">::</span><span class="na">getHost</span><span class="p">()</span><span class="o">.</span><span class="s1">&#39;&gt;&#39;</span><span class="p">;</span>
2068
2069 <span class="k">return</span> <span class="p">[</span>
2070 <span class="s1">&#39;application&#39;</span> <span class="o">=&gt;</span> <span class="s1">&#39;example&#39;</span><span class="p">,</span>
2071 <span class="s1">&#39;in-reply-to&#39;</span> <span class="o">=&gt;</span> <span class="p">[</span><span class="nv">$messageID</span><span class="p">],</span>
2072 <span class="s1">&#39;message-id&#39;</span> <span class="o">=&gt;</span> <span class="s1">&#39;com.woltlab.example.foo/&#39;</span><span class="o">.</span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">fooID</span><span class="p">,</span>
2073 <span class="s1">&#39;references&#39;</span> <span class="o">=&gt;</span> <span class="p">[</span><span class="nv">$messageID</span><span class="p">],</span>
2074 <span class="s1">&#39;template&#39;</span> <span class="o">=&gt;</span> <span class="s1">&#39;email_notification_foo&#39;</span>
2075 <span class="p">];</span>
2076 <span class="p">}</span>
2077
2078 <span class="sd">/**</span>
2079<span class="sd"> * @inheritDoc</span>
2080<span class="sd"> * @since 5.0</span>
2081<span class="sd"> */</span>
2082 <span class="k">public</span> <span class="k">function</span> <span class="nf">getEmailTitle</span><span class="p">()</span> <span class="p">{</span>
2083 <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">setBaz</span><span class="p">(</span><span class="nx">BazRuntimeCache</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">getObject</span><span class="p">(</span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">bazID</span><span class="p">));</span>
2084
2085 <span class="k">return</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getLanguage</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">getDynamicVariable</span><span class="p">(</span><span class="s1">&#39;example.foo.notification.mail.title&#39;</span><span class="p">,</span> <span class="p">[</span>
2086 <span class="s1">&#39;userNotificationObject&#39;</span> <span class="o">=&gt;</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span>
2087 <span class="p">]);</span>
2088 <span class="p">}</span>
2089
2090 <span class="sd">/** @noinspection PhpMissingParentCallCommonInspection */</span>
2091 <span class="sd">/**</span>
2092<span class="sd"> * @inheritDoc</span>
2093<span class="sd"> */</span>
2094 <span class="k">public</span> <span class="k">function</span> <span class="nf">getEventHash</span><span class="p">()</span> <span class="p">{</span>
2095 <span class="k">return</span> <span class="nb">sha1</span><span class="p">(</span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">eventID</span> <span class="o">.</span> <span class="s1">&#39;-&#39;</span> <span class="o">.</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">bazID</span><span class="p">);</span>
2096 <span class="p">}</span>
2097
2098 <span class="sd">/**</span>
2099<span class="sd"> * @inheritDoc</span>
2100<span class="sd"> */</span>
2101 <span class="k">public</span> <span class="k">function</span> <span class="nf">getLink</span><span class="p">()</span> <span class="p">{</span>
2102 <span class="k">return</span> <span class="nx">LinkHandler</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">getLink</span><span class="p">(</span><span class="s1">&#39;Foo&#39;</span><span class="p">,</span> <span class="p">[</span>
2103 <span class="s1">&#39;application&#39;</span> <span class="o">=&gt;</span> <span class="s1">&#39;example&#39;</span><span class="p">,</span>
2104 <span class="s1">&#39;object&#39;</span> <span class="o">=&gt;</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">getDecoratedObject</span><span class="p">()</span>
2105 <span class="p">]);</span>
2106 <span class="p">}</span>
2107
2108 <span class="sd">/**</span>
2109<span class="sd"> * @inheritDoc</span>
2110<span class="sd"> */</span>
2111 <span class="k">public</span> <span class="k">function</span> <span class="nf">getMessage</span><span class="p">()</span> <span class="p">{</span>
2112 <span class="nv">$authors</span> <span class="o">=</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getAuthors</span><span class="p">();</span>
2113 <span class="nv">$count</span> <span class="o">=</span> <span class="nb">count</span><span class="p">(</span><span class="nv">$authors</span><span class="p">);</span>
2114
2115 <span class="k">if</span> <span class="p">(</span><span class="nv">$count</span> <span class="o">&gt;</span> <span class="mi">1</span><span class="p">)</span> <span class="p">{</span>
2116 <span class="k">if</span> <span class="p">(</span><span class="nb">isset</span><span class="p">(</span><span class="nv">$authors</span><span class="p">[</span><span class="mi">0</span><span class="p">]))</span> <span class="p">{</span>
2117 <span class="nb">unset</span><span class="p">(</span><span class="nv">$authors</span><span class="p">[</span><span class="mi">0</span><span class="p">]);</span>
2118 <span class="p">}</span>
2119 <span class="nv">$count</span> <span class="o">=</span> <span class="nb">count</span><span class="p">(</span><span class="nv">$authors</span><span class="p">);</span>
2120
2121 <span class="k">return</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getLanguage</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">getDynamicVariable</span><span class="p">(</span><span class="s1">&#39;example.foo.notification.message.stacked&#39;</span><span class="p">,</span> <span class="p">[</span>
2122 <span class="s1">&#39;author&#39;</span> <span class="o">=&gt;</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">author</span><span class="p">,</span>
2123 <span class="s1">&#39;authors&#39;</span> <span class="o">=&gt;</span> <span class="nb">array_values</span><span class="p">(</span><span class="nv">$authors</span><span class="p">),</span>
2124 <span class="s1">&#39;count&#39;</span> <span class="o">=&gt;</span> <span class="nv">$count</span><span class="p">,</span>
2125 <span class="s1">&#39;guestTimesTriggered&#39;</span> <span class="o">=&gt;</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">notification</span><span class="o">-&gt;</span><span class="na">guestTimesTriggered</span><span class="p">,</span>
2126 <span class="s1">&#39;message&#39;</span> <span class="o">=&gt;</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">(),</span>
2127 <span class="s1">&#39;others&#39;</span> <span class="o">=&gt;</span> <span class="nv">$count</span> <span class="o">-</span> <span class="mi">1</span>
2128 <span class="p">]);</span>
2129 <span class="p">}</span>
2130
2131 <span class="k">return</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getLanguage</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">getDynamicVariable</span><span class="p">(</span><span class="s1">&#39;example.foo.notification.message&#39;</span><span class="p">,</span> <span class="p">[</span>
2132 <span class="s1">&#39;author&#39;</span> <span class="o">=&gt;</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">author</span><span class="p">,</span>
2133 <span class="s1">&#39;userNotificationObject&#39;</span> <span class="o">=&gt;</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span>
2134 <span class="p">]);</span>
2135 <span class="p">}</span>
2136
2137 <span class="sd">/**</span>
2138<span class="sd"> * @inheritDoc</span>
2139<span class="sd"> */</span>
2140 <span class="k">public</span> <span class="k">function</span> <span class="nf">getTitle</span><span class="p">()</span> <span class="p">{</span>
2141 <span class="nv">$count</span> <span class="o">=</span> <span class="nb">count</span><span class="p">(</span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getAuthors</span><span class="p">());</span>
2142 <span class="k">if</span> <span class="p">(</span><span class="nv">$count</span> <span class="o">&gt;</span> <span class="mi">1</span><span class="p">)</span> <span class="p">{</span>
2143 <span class="k">return</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getLanguage</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">getDynamicVariable</span><span class="p">(</span><span class="s1">&#39;example.foo.notification.title.stacked&#39;</span><span class="p">,</span> <span class="p">[</span>
2144 <span class="s1">&#39;count&#39;</span> <span class="o">=&gt;</span> <span class="nv">$count</span><span class="p">,</span>
2145 <span class="s1">&#39;timesTriggered&#39;</span> <span class="o">=&gt;</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">notification</span><span class="o">-&gt;</span><span class="na">timesTriggered</span>
2146 <span class="p">]);</span>
2147 <span class="p">}</span>
2148
2149 <span class="k">return</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getLanguage</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">get</span><span class="p">(</span><span class="s1">&#39;example.foo.notification.title&#39;</span><span class="p">);</span>
2150 <span class="p">}</span>
2151
2152 <span class="sd">/**</span>
2153<span class="sd"> * @inheritDoc</span>
2154<span class="sd"> */</span>
2155 <span class="k">protected</span> <span class="k">function</span> <span class="nf">prepare</span><span class="p">()</span> <span class="p">{</span>
2156 <span class="nx">BazRuntimeCache</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">cacheObjectID</span><span class="p">(</span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">getUserNotificationObject</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">bazID</span><span class="p">);</span>
2157 <span class="p">}</span>
2158<span class="p">}</span>
2159</code></pre></div>
0c5338dd
TD
2160<ul>
2161<li>The <code>$stackable</code> property is <code>false</code> by default and has to be explicitly set to <code>true</code> if stacking of notifications should be enabled.
2162 Stacking of notification does not create new notifications for the same event for a certain object if the related action as been triggered by different users.
2163 For example, if something is liked by one user and then liked again by another user before the recipient of the notification has confirmed it, the existing notification will be amended to include both users who liked the content.
2164 Stacking can thus be used to avoid cluttering the notification list of users.</li>
2165<li>The <code>checkAccess()</code> method makes sure that the active user still has access to the object related to the notification.
2166 If that is not the case, the user notification system will automatically deleted the user notification based on the return value of the method.
2167 If you have any cached values related to notifications, you should also reset these values here.</li>
2168<li>The <code>getEmailMessage()</code> method return data to create the instant email or the daily summary email.
2169 For instant emails (<code>$notificationType = 'instant'</code>), you have to return an array like the one shown in the code above with the following components:</li>
2170<li><code>application</code>:
2171 abbreviation of application</li>
2172<li><code>in-reply-to</code> (optional):
2173 message id of the notification for the parent item and used to improve the ordering in threaded email clients</li>
2174<li><code>message-id</code> (optional):
2175 message id of the notification mail and has to be used in <code>in-reply-to</code> and <code>references</code> for follow up mails</li>
2176<li><code>references</code> (optional):
2177 all of the message ids of parent items (i.e. recursive in-reply-to)</li>
2178<li><code>template</code>:
2179 name of the template used to render the email body, should start with <code>email_</code></li>
2180<li><code>variables</code> (optional):
2181 template variables passed to the email template where they can be accessed via <code>$notificationContent[variables]</code></li>
2182</ul>
2183<p>For daily emails (<code>$notificationType = 'daily'</code>), only <code>application</code>, <code>template</code>, and <code>variables</code> are supported.
2184- The <code>getEmailTitle()</code> returns the title of the instant email sent to the user.
2185 By default, <code>getEmailTitle()</code> simply calls <code>getTitle()</code>.
2186- The <code>getEventHash()</code> method returns a hash by which user notifications are grouped.
2187 Here, we want to group them not by the actual <code>Foo</code> object but by its parent <code>Baz</code> object and thus overwrite the default implementation provided by <code>AbstractUserNotificationEvent</code>.
2188- The <code>getLink()</code> returns the link to the <code>Foo</code> object the notification belongs to.
2189- The <code>getMessage()</code> method and the <code>getTitle()</code> return the message and the title of the user notification respectively.
2190 By checking the value of <code>count($this-&gt;getAuthors())</code>, we check if the notification is stacked, thus if the event has been triggered for multiple users so that different languages items are used.
2191 If your notification event does not support stacking, this distinction is not necessary.
2192- The <code>prepare()</code> method is called for each user notification before all user notifications are rendered.
2193 This allows to tell runtime caches to prepare to load objects later on (see <a href="../caches_runtime-caches/">Runtime Caches</a>).</p>
2194<h2 id="firing-events">Firing Events<a class="headerlink" href="#firing-events" title="Permanent link">#</a></h2>
2195<p>When the action related to a user notification is executed, you can use <code>UserNotificationHandler::fireEvent()</code> to create the notifications:</p>
2196<div class="highlight"><pre><span></span><code><span class="nv">$recipientIDs</span> <span class="o">=</span> <span class="p">[];</span> <span class="c1">// fill with user ids of the recipients of the notification</span>
2197<span class="nx">UserNotificationHandler</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">fireEvent</span><span class="p">(</span>
2198 <span class="s1">&#39;bar&#39;</span><span class="p">,</span> <span class="c1">// event name</span>
2199 <span class="s1">&#39;com.woltlab.example.foo&#39;</span><span class="p">,</span> <span class="c1">// event object type name</span>
2200 <span class="k">new</span> <span class="nx">FooUserNotificationObject</span><span class="p">(</span><span class="k">new</span> <span class="nx">Foo</span><span class="p">(</span><span class="nv">$fooID</span><span class="p">)),</span> <span class="c1">// object related to the event</span>
2201 <span class="nv">$recipientIDs</span>
2202<span class="p">);</span>
2203</code></pre></div>
0c5338dd
TD
2204<h2 id="marking-notifications-as-confirmed">Marking Notifications as Confirmed<a class="headerlink" href="#marking-notifications-as-confirmed" title="Permanent link">#</a></h2>
2205<p>In some instances, you might want to manually mark user notifications as confirmed without the user manually confirming them, for example when they visit the page that is related to the user notification.
2206In this case, you can use <code>UserNotificationHandler::markAsConfirmed()</code>:</p>
2207<div class="highlight"><pre><span></span><code><span class="nv">$recipientIDs</span> <span class="o">=</span> <span class="p">[];</span> <span class="c1">// fill with user ids of the recipients of the notification</span>
2208<span class="nv">$fooIDs</span> <span class="o">=</span> <span class="p">[];</span> <span class="c1">// fill with ids of related foo objects</span>
2209<span class="nx">UserNotificationHandler</span><span class="o">::</span><span class="na">getInstance</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">markAsConfirmed</span><span class="p">(</span>
2210 <span class="s1">&#39;bar&#39;</span><span class="p">,</span> <span class="c1">// event name</span>
2211 <span class="s1">&#39;com.woltlab.example.foo&#39;</span><span class="p">,</span> <span class="c1">// event object type name</span>
2212 <span class="nv">$recipientIDs</span><span class="p">,</span>
2213 <span class="nv">$fooIDs</span>
2214<span class="p">);</span>
2215</code></pre></div>
2216
4a5c32e1
WG
2217
2218
2219
2220<hr>
2221<div class="md-source-date">
2222 <small>
2223
2224 Last update: 2021-01-08
2225
2226 </small>
2227</div>
2228
2229
0c5338dd
TD
2230
2231
2232
2233
2234
2235
2236 </article>
2237 </div>
2238 </div>
fb962f09 2239
0c5338dd
TD
2240 </main>
2241
2242
2243<footer class="md-footer">
2244
2245 <nav class="md-footer__inner md-grid" aria-label="Footer">
2246
2247 <a href="../user_activity_points/" class="md-footer__link md-footer__link--prev" rel="prev">
2248 <div class="md-footer__button md-icon">
2249 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg>
2250 </div>
2251 <div class="md-footer__title">
2252 <div class="md-ellipsis">
2253 <span class="md-footer__direction">
2254 Previous
2255 </span>
2256 User Activity Points
2257 </div>
2258 </div>
2259 </a>
2260
2261
2262 <a href="../sitemaps/" class="md-footer__link md-footer__link--next" rel="next">
2263 <div class="md-footer__title">
2264 <div class="md-ellipsis">
2265 <span class="md-footer__direction">
2266 Next
2267 </span>
2268 Sitemaps
2269 </div>
2270 </div>
2271 <div class="md-footer__button md-icon">
2272 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 11v2h12l-5.5 5.5 1.42 1.42L19.84 12l-7.92-7.92L10.5 5.5 16 11H4z"/></svg>
2273 </div>
2274 </a>
2275
2276 </nav>
2277
2278 <div class="md-footer-meta md-typeset">
2279 <div class="md-footer-meta__inner md-grid">
2280 <div class="md-footer-copyright">
2281
2282 <div class="md-footer-copyright__highlight">
2283 Copyright © 2020 WoltLab GmbH
2284 </div>
2285
2286 Made with
2287 <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
2288 Material for MkDocs
2289 </a>
fb88dc6e 2290
0c5338dd
TD
2291 </div>
2292 <div class="md-footer-copyright">
2293 <a href="https://www.woltlab.com/legal-notice/">Legal Notice</a>
2294 <a href="https://www.woltlab.com/privacy-policy/">Privacy Policy</a>
2295</div>
2296 </div>
2297 </div>
2298</footer>
2299
2300 </div>
2301 <div class="md-dialog" data-md-component="dialog">
2302 <div class="md-dialog__inner md-typeset"></div>
2303 </div>
fb962f09 2304 <script id="__config" type="application/json">{"base": "../../..", "features": [], "translations": {"clipboard.copy": "Copy to clipboard", "clipboard.copied": "Copied to clipboard", "search.config.lang": "en", "search.config.pipeline": "trimmer, stopWordFilter", "search.config.separator": "[\\s\\-]+", "search.placeholder": "Search", "search.result.placeholder": "Type to start searching", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.term.missing": "Missing"}, "search": "../../../assets/javascripts/workers/search.fe42c31b.min.js", "version": {"provider": "mike"}}</script>
0c5338dd
TD
2305
2306
fb962f09 2307 <script src="../../../assets/javascripts/bundle.d892486b.min.js"></script>
0c5338dd
TD
2308
2309
2310 </body>
2311</html>