34e984a7e59f26c1cc74502fbef8597b4f8ffb1b
[GitHub/WoltLab/woltlab.github.io.git] / latest / php / api / caches / index.html
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
12 <link rel="shortcut icon" href="../../../assets/default.favicon.ico">
13 <meta name="generator" content="mkdocs-1.1.2, mkdocs-material-7.0.5">
14
15
16
17 <title>Caches - WoltLab Suite Documentation</title>
18
19
20
21 <link rel="stylesheet" href="../../../assets/stylesheets/main.77f3fd56.min.css">
22
23
24 <link rel="stylesheet" href="../../../assets/stylesheets/palette.7fa14f5b.min.css">
25
26
27
28 <meta name="theme-color" content="#009485">
29
30
31
32
33
34
35
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="">
53
54
55
56 <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
57 <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
58 <label class="md-overlay" for="__drawer"></label>
59 <div data-md-component="skip">
60
61
62 <a href="#caches" class="md-skip">
63 Skip to content
64 </a>
65
66 </div>
67 <div data-md-component="announce">
68
69 <aside class="md-announce">
70 <div class="md-announce__inner md-grid md-typeset">
71
72 <a href="https://www.woltlab.com">Back to <strong>woltlab.com</strong></a>
73
74 </div>
75 </aside>
76
77 </div>
78
79
80
81 <header class="md-header" data-md-component="header">
82 <nav class="md-header__inner md-grid" aria-label="Header">
83 <a href="../../.." title="WoltLab Suite Documentation" class="md-header__button md-logo" aria-label="WoltLab Suite Documentation">
84
85 <img src="../../../assets/logo.png" alt="logo">
86
87 </a>
88 <label class="md-header__button md-icon" for="__drawer">
89 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2z"/></svg>
90 </label>
91 <div class="md-header__title" data-md-component="header-title">
92 <div class="md-header__ellipsis">
93 <div class="md-header__topic">
94 <span class="md-ellipsis">
95 WoltLab Suite Documentation
96 </span>
97 </div>
98 <div class="md-header__topic" data-md-component="header-topic">
99 <span class="md-ellipsis">
100
101 Caches
102
103 </span>
104 </div>
105 </div>
106 </div>
107 <div class="md-header__options">
108
109 </div>
110
111 <label class="md-header__button md-icon" for="__search">
112 <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>
113 </label>
114
115 <div class="md-search" data-md-component="search" role="dialog">
116 <label class="md-search__overlay" for="__search"></label>
117 <div class="md-search__inner" role="search">
118 <form class="md-search__form" name="search">
119 <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>
120 <label class="md-search__icon md-icon" for="__search">
121 <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>
122 <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>
123 </label>
124 <button type="reset" class="md-search__icon md-icon" aria-label="Clear" tabindex="-1">
125 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41L17.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>
126 </button>
127 </form>
128 <div class="md-search__output">
129 <div class="md-search__scrollwrap" data-md-scrollfix>
130 <div class="md-search-result" data-md-component="search-result">
131 <div class="md-search-result__meta">
132 Initializing search
133 </div>
134 <ol class="md-search-result__list"></ol>
135 </div>
136 </div>
137 </div>
138 </div>
139 </div>
140
141
142 <div class="md-header__source">
143
144 <a href="https://github.com/WoltLab/docs.woltlab.com/" title="Go to repository" class="md-source" data-md-component="source">
145 <div class="md-source__icon md-icon">
146
147 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05L244 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>
148 </div>
149 <div class="md-source__repository">
150 GitHub
151 </div>
152 </a>
153 </div>
154
155 </nav>
156 </header>
157
158 <div class="md-container" data-md-component="container">
159
160
161
162
163 <main class="md-main" data-md-component="main">
164 <div class="md-main__inner md-grid">
165
166
167
168 <div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
169 <div class="md-sidebar__scrollwrap">
170 <div class="md-sidebar__inner">
171
172
173
174
175
176 <nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0">
177 <label class="md-nav__title" for="__drawer">
178 <a href="../../.." title="WoltLab Suite Documentation" class="md-nav__button md-logo" aria-label="WoltLab Suite Documentation">
179
180 <img src="../../../assets/logo.png" alt="logo">
181
182 </a>
183 WoltLab Suite Documentation
184 </label>
185
186 <div class="md-nav__source">
187
188 <a href="https://github.com/WoltLab/docs.woltlab.com/" title="Go to repository" class="md-source" data-md-component="source">
189 <div class="md-source__icon md-icon">
190
191 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05L244 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>
192 </div>
193 <div class="md-source__repository">
194 GitHub
195 </div>
196 </a>
197 </div>
198
199 <ul class="md-nav__list" data-md-scrollfix>
200
201
202
203
204
205
206
207
208 <li class="md-nav__item">
209 <a href="../../../getting-started/" class="md-nav__link">
210 Getting Started
211 </a>
212 </li>
213
214
215
216
217
218
219
220
221
222
223
224
225
226 <li class="md-nav__item md-nav__item--active md-nav__item--nested">
227
228
229 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2" type="checkbox" id="__nav_2" checked>
230
231 <label class="md-nav__link" for="__nav_2">
232 PHP API
233 <span class="md-nav__icon md-icon"></span>
234 </label>
235 <nav class="md-nav" aria-label="PHP API" data-md-level="1">
236 <label class="md-nav__title" for="__nav_2">
237 <span class="md-nav__icon md-icon"></span>
238 PHP API
239 </label>
240 <ul class="md-nav__list" data-md-scrollfix>
241
242
243
244
245
246 <li class="md-nav__item">
247 <a href="../../pages/" class="md-nav__link">
248 Pages
249 </a>
250 </li>
251
252
253
254
255
256
257
258 <li class="md-nav__item">
259 <a href="../../database-objects/" class="md-nav__link">
260 Database Objects
261 </a>
262 </li>
263
264
265
266
267
268
269
270 <li class="md-nav__item">
271 <a href="../../database-access/" class="md-nav__link">
272 Database Access
273 </a>
274 </li>
275
276
277
278
279
280
281
282 <li class="md-nav__item">
283 <a href="../../exceptions/" class="md-nav__link">
284 Exceptions
285 </a>
286 </li>
287
288
289
290
291
292
293
294
295
296
297 <li class="md-nav__item md-nav__item--active md-nav__item--nested">
298
299
300 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5" type="checkbox" id="__nav_2_5" checked>
301
302 <label class="md-nav__link" for="__nav_2_5">
303 API
304 <span class="md-nav__icon md-icon"></span>
305 </label>
306 <nav class="md-nav" aria-label="API" data-md-level="2">
307 <label class="md-nav__title" for="__nav_2_5">
308 <span class="md-nav__icon md-icon"></span>
309 API
310 </label>
311 <ul class="md-nav__list" data-md-scrollfix>
312
313
314
315
316
317
318
319 <li class="md-nav__item md-nav__item--active">
320
321 <input class="md-nav__toggle md-toggle" data-md-toggle="toc" type="checkbox" id="__toc">
322
323
324
325
326 <label class="md-nav__link md-nav__link--active" for="__toc">
327 Caches
328 <span class="md-nav__icon md-icon"></span>
329 </label>
330
331 <a href="./" class="md-nav__link md-nav__link--active">
332 Caches
333 </a>
334
335
336 <nav class="md-nav md-nav--secondary" aria-label="Table of contents">
337
338
339
340
341
342 <label class="md-nav__title" for="__toc">
343 <span class="md-nav__icon md-icon"></span>
344 Table of contents
345 </label>
346 <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
347
348 <li class="md-nav__item">
349 <a href="#understanding-caching" class="md-nav__link">
350 Understanding Caching
351 </a>
352
353 <nav class="md-nav" aria-label="Understanding Caching">
354 <ul class="md-nav__list">
355
356 <li class="md-nav__item">
357 <a href="#when-to-use-a-cache" class="md-nav__link">
358 When to Use a Cache
359 </a>
360
361 </li>
362
363 <li class="md-nav__item">
364 <a href="#when-not-to-use-a-cache" class="md-nav__link">
365 When not to Use a Cache
366 </a>
367
368 </li>
369
370 </ul>
371 </nav>
372
373 </li>
374
375 </ul>
376
377 </nav>
378
379 </li>
380
381
382
383
384
385
386
387 <li class="md-nav__item">
388 <a href="../comments/" class="md-nav__link">
389 Comments
390 </a>
391 </li>
392
393
394
395
396
397
398
399 <li class="md-nav__item">
400 <a href="../cronjobs/" class="md-nav__link">
401 Cronjobs
402 </a>
403 </li>
404
405
406
407
408
409
410
411 <li class="md-nav__item">
412 <a href="../events/" class="md-nav__link">
413 Events
414 </a>
415 </li>
416
417
418
419
420
421
422
423
424 <li class="md-nav__item md-nav__item--nested">
425
426
427 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5_5" type="checkbox" id="__nav_2_5_5" >
428
429 <label class="md-nav__link" for="__nav_2_5_5">
430 Form Builder
431 <span class="md-nav__icon md-icon"></span>
432 </label>
433 <nav class="md-nav" aria-label="Form Builder" data-md-level="3">
434 <label class="md-nav__title" for="__nav_2_5_5">
435 <span class="md-nav__icon md-icon"></span>
436 Form Builder
437 </label>
438 <ul class="md-nav__list" data-md-scrollfix>
439
440
441
442
443
444 <li class="md-nav__item">
445 <a href="../form_builder/overview/" class="md-nav__link">
446 Overview
447 </a>
448 </li>
449
450
451
452
453
454
455
456 <li class="md-nav__item">
457 <a href="../form_builder/structure/" class="md-nav__link">
458 Structure
459 </a>
460 </li>
461
462
463
464
465
466
467
468 <li class="md-nav__item">
469 <a href="../form_builder/form_fields/" class="md-nav__link">
470 Fields
471 </a>
472 </li>
473
474
475
476
477
478
479
480 <li class="md-nav__item">
481 <a href="../form_builder/validation_data/" class="md-nav__link">
482 Validation and Data
483 </a>
484 </li>
485
486
487
488
489
490
491
492 <li class="md-nav__item">
493 <a href="../form_builder/dependencies/" class="md-nav__link">
494 Dependencies
495 </a>
496 </li>
497
498
499
500 </ul>
501 </nav>
502 </li>
503
504
505
506
507
508
509
510 <li class="md-nav__item">
511 <a href="../package_installation_plugins/" class="md-nav__link">
512 Package Installation Plugins
513 </a>
514 </li>
515
516
517
518
519
520
521
522 <li class="md-nav__item">
523 <a href="../user_activity_points/" class="md-nav__link">
524 User Activity Points
525 </a>
526 </li>
527
528
529
530
531
532
533
534 <li class="md-nav__item">
535 <a href="../user_notifications/" class="md-nav__link">
536 User Notifications
537 </a>
538 </li>
539
540
541
542
543
544
545
546 <li class="md-nav__item">
547 <a href="../sitemaps/" class="md-nav__link">
548 Sitemaps
549 </a>
550 </li>
551
552
553
554 </ul>
555 </nav>
556 </li>
557
558
559
560
561
562
563
564 <li class="md-nav__item">
565 <a href="../../code-style/" class="md-nav__link">
566 Code Style
567 </a>
568 </li>
569
570
571
572
573
574
575
576 <li class="md-nav__item">
577 <a href="../../apps/" class="md-nav__link">
578 Apps
579 </a>
580 </li>
581
582
583
584
585
586
587
588 <li class="md-nav__item">
589 <a href="../../gdpr/" class="md-nav__link">
590 GDPR
591 </a>
592 </li>
593
594
595
596 </ul>
597 </nav>
598 </li>
599
600
601
602
603
604
605
606
607
608
609
610 <li class="md-nav__item md-nav__item--nested">
611
612
613 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_3" type="checkbox" id="__nav_3" >
614
615 <label class="md-nav__link" for="__nav_3">
616 Languages, Templates & CSS
617 <span class="md-nav__icon md-icon"></span>
618 </label>
619 <nav class="md-nav" aria-label="Languages, Templates & CSS" data-md-level="1">
620 <label class="md-nav__title" for="__nav_3">
621 <span class="md-nav__icon md-icon"></span>
622 Languages, Templates & CSS
623 </label>
624 <ul class="md-nav__list" data-md-scrollfix>
625
626
627
628
629
630 <li class="md-nav__item">
631 <a href="../../../view/languages/" class="md-nav__link">
632 Languages
633 </a>
634 </li>
635
636
637
638
639
640
641
642 <li class="md-nav__item">
643 <a href="../../../view/templates/" class="md-nav__link">
644 Templates
645 </a>
646 </li>
647
648
649
650
651
652
653
654 <li class="md-nav__item">
655 <a href="../../../view/css/" class="md-nav__link">
656 CSS
657 </a>
658 </li>
659
660
661
662 </ul>
663 </nav>
664 </li>
665
666
667
668
669
670
671
672
673
674
675
676 <li class="md-nav__item md-nav__item--nested">
677
678
679 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4" type="checkbox" id="__nav_4" >
680
681 <label class="md-nav__link" for="__nav_4">
682 JavaScript API
683 <span class="md-nav__icon md-icon"></span>
684 </label>
685 <nav class="md-nav" aria-label="JavaScript API" data-md-level="1">
686 <label class="md-nav__title" for="__nav_4">
687 <span class="md-nav__icon md-icon"></span>
688 JavaScript API
689 </label>
690 <ul class="md-nav__list" data-md-scrollfix>
691
692
693
694
695
696 <li class="md-nav__item">
697 <a href="../../../javascript/general-usage/" class="md-nav__link">
698 General Usage
699 </a>
700 </li>
701
702
703
704
705
706
707
708
709 <li class="md-nav__item md-nav__item--nested">
710
711
712 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4_2" type="checkbox" id="__nav_4_2" >
713
714 <label class="md-nav__link" for="__nav_4_2">
715 New API
716 <span class="md-nav__icon md-icon"></span>
717 </label>
718 <nav class="md-nav" aria-label="New API" data-md-level="2">
719 <label class="md-nav__title" for="__nav_4_2">
720 <span class="md-nav__icon md-icon"></span>
721 New API
722 </label>
723 <ul class="md-nav__list" data-md-scrollfix>
724
725
726
727
728
729 <li class="md-nav__item">
730 <a href="../../../javascript/new-api_writing-a-module/" class="md-nav__link">
731 Writing a module
732 </a>
733 </li>
734
735
736
737
738
739
740
741 <li class="md-nav__item">
742 <a href="../../../javascript/new-api_data-structures/" class="md-nav__link">
743 Data Structures
744 </a>
745 </li>
746
747
748
749
750
751
752
753 <li class="md-nav__item">
754 <a href="../../../javascript/new-api_core/" class="md-nav__link">
755 Core Functions
756 </a>
757 </li>
758
759
760
761
762
763
764
765 <li class="md-nav__item">
766 <a href="../../../javascript/new-api_dom/" class="md-nav__link">
767 DOM
768 </a>
769 </li>
770
771
772
773
774
775
776
777 <li class="md-nav__item">
778 <a href="../../../javascript/new-api_events/" class="md-nav__link">
779 Event Handling
780 </a>
781 </li>
782
783
784
785
786
787
788
789 <li class="md-nav__item">
790 <a href="../../../javascript/new-api_ajax/" class="md-nav__link">
791 Ajax
792 </a>
793 </li>
794
795
796
797
798
799
800
801 <li class="md-nav__item">
802 <a href="../../../javascript/new-api_dialogs/" class="md-nav__link">
803 Dialogs
804 </a>
805 </li>
806
807
808
809
810
811
812
813 <li class="md-nav__item">
814 <a href="../../../javascript/new-api_browser/" class="md-nav__link">
815 Browser and Screen Sizes
816 </a>
817 </li>
818
819
820
821
822
823
824
825 <li class="md-nav__item">
826 <a href="../../../javascript/new-api_ui/" class="md-nav__link">
827 User Interface
828 </a>
829 </li>
830
831
832
833 </ul>
834 </nav>
835 </li>
836
837
838
839
840
841
842
843 <li class="md-nav__item">
844 <a href="../../../javascript/legacy-api/" class="md-nav__link">
845 Legacy API
846 </a>
847 </li>
848
849
850
851
852
853
854
855 <li class="md-nav__item">
856 <a href="../../../javascript/helper-functions/" class="md-nav__link">
857 Helper Functions
858 </a>
859 </li>
860
861
862
863
864
865
866
867 <li class="md-nav__item">
868 <a href="../../../javascript/code-snippets/" class="md-nav__link">
869 Code Snippets
870 </a>
871 </li>
872
873
874
875 </ul>
876 </nav>
877 </li>
878
879
880
881
882
883
884
885
886
887
888
889 <li class="md-nav__item md-nav__item--nested">
890
891
892 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5" type="checkbox" id="__nav_5" >
893
894 <label class="md-nav__link" for="__nav_5">
895 Package Components
896 <span class="md-nav__icon md-icon"></span>
897 </label>
898 <nav class="md-nav" aria-label="Package Components" data-md-level="1">
899 <label class="md-nav__title" for="__nav_5">
900 <span class="md-nav__icon md-icon"></span>
901 Package Components
902 </label>
903 <ul class="md-nav__list" data-md-scrollfix>
904
905
906
907
908
909 <li class="md-nav__item">
910 <a href="../../../package/package-xml/" class="md-nav__link">
911 package.xml
912 </a>
913 </li>
914
915
916
917
918
919
920
921
922 <li class="md-nav__item md-nav__item--nested">
923
924
925 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_2" type="checkbox" id="__nav_5_2" >
926
927 <label class="md-nav__link" for="__nav_5_2">
928 PIPs
929 <span class="md-nav__icon md-icon"></span>
930 </label>
931 <nav class="md-nav" aria-label="PIPs" data-md-level="2">
932 <label class="md-nav__title" for="__nav_5_2">
933 <span class="md-nav__icon md-icon"></span>
934 PIPs
935 </label>
936 <ul class="md-nav__list" data-md-scrollfix>
937
938
939
940
941
942 <li class="md-nav__item">
943 <a href="../../../package/pip/" class="md-nav__link">
944 Overview
945 </a>
946 </li>
947
948
949
950
951
952
953
954 <li class="md-nav__item">
955 <a href="../../../package/pip/acl-option/" class="md-nav__link">
956 aclOption
957 </a>
958 </li>
959
960
961
962
963
964
965
966 <li class="md-nav__item">
967 <a href="../../../package/pip/acp-menu/" class="md-nav__link">
968 acpMenu
969 </a>
970 </li>
971
972
973
974
975
976
977
978 <li class="md-nav__item">
979 <a href="../../../package/pip/acp-search-provider/" class="md-nav__link">
980 acpSearchProvider
981 </a>
982 </li>
983
984
985
986
987
988
989
990 <li class="md-nav__item">
991 <a href="../../../package/pip/acp-template/" class="md-nav__link">
992 acpTemplate
993 </a>
994 </li>
995
996
997
998
999
1000
1001
1002 <li class="md-nav__item">
1003 <a href="../../../package/pip/bbcode/" class="md-nav__link">
1004 bbcode
1005 </a>
1006 </li>
1007
1008
1009
1010
1011
1012
1013
1014 <li class="md-nav__item">
1015 <a href="../../../package/pip/box/" class="md-nav__link">
1016 box
1017 </a>
1018 </li>
1019
1020
1021
1022
1023
1024
1025
1026 <li class="md-nav__item">
1027 <a href="../../../package/pip/clipboard-action/" class="md-nav__link">
1028 clipboardAction
1029 </a>
1030 </li>
1031
1032
1033
1034
1035
1036
1037
1038 <li class="md-nav__item">
1039 <a href="../../../package/pip/core-object/" class="md-nav__link">
1040 coreObject
1041 </a>
1042 </li>
1043
1044
1045
1046
1047
1048
1049
1050 <li class="md-nav__item">
1051 <a href="../../../package/pip/cronjob/" class="md-nav__link">
1052 cronjob
1053 </a>
1054 </li>
1055
1056
1057
1058
1059
1060
1061
1062 <li class="md-nav__item">
1063 <a href="../../../package/pip/event-listener/" class="md-nav__link">
1064 eventListener
1065 </a>
1066 </li>
1067
1068
1069
1070
1071
1072
1073
1074 <li class="md-nav__item">
1075 <a href="../../../package/pip/file/" class="md-nav__link">
1076 file
1077 </a>
1078 </li>
1079
1080
1081
1082
1083
1084
1085
1086 <li class="md-nav__item">
1087 <a href="../../../package/pip/language/" class="md-nav__link">
1088 language
1089 </a>
1090 </li>
1091
1092
1093
1094
1095
1096
1097
1098 <li class="md-nav__item">
1099 <a href="../../../package/pip/media-provider/" class="md-nav__link">
1100 mediaProvider
1101 </a>
1102 </li>
1103
1104
1105
1106
1107
1108
1109
1110 <li class="md-nav__item">
1111 <a href="../../../package/pip/menu/" class="md-nav__link">
1112 menu
1113 </a>
1114 </li>
1115
1116
1117
1118
1119
1120
1121
1122 <li class="md-nav__item">
1123 <a href="../../../package/pip/menu-item/" class="md-nav__link">
1124 menuItem
1125 </a>
1126 </li>
1127
1128
1129
1130
1131
1132
1133
1134 <li class="md-nav__item">
1135 <a href="../../../package/pip/object-type/" class="md-nav__link">
1136 objectType
1137 </a>
1138 </li>
1139
1140
1141
1142
1143
1144
1145
1146 <li class="md-nav__item">
1147 <a href="../../../package/pip/object-type-definition/" class="md-nav__link">
1148 objectTypeDefinition
1149 </a>
1150 </li>
1151
1152
1153
1154
1155
1156
1157
1158 <li class="md-nav__item">
1159 <a href="../../../package/pip/option/" class="md-nav__link">
1160 option
1161 </a>
1162 </li>
1163
1164
1165
1166
1167
1168
1169
1170 <li class="md-nav__item">
1171 <a href="../../../package/pip/page/" class="md-nav__link">
1172 page
1173 </a>
1174 </li>
1175
1176
1177
1178
1179
1180
1181
1182 <li class="md-nav__item">
1183 <a href="../../../package/pip/pip/" class="md-nav__link">
1184 pip
1185 </a>
1186 </li>
1187
1188
1189
1190
1191
1192
1193
1194 <li class="md-nav__item">
1195 <a href="../../../package/pip/script/" class="md-nav__link">
1196 script
1197 </a>
1198 </li>
1199
1200
1201
1202
1203
1204
1205
1206 <li class="md-nav__item">
1207 <a href="../../../package/pip/smiley/" class="md-nav__link">
1208 smiley
1209 </a>
1210 </li>
1211
1212
1213
1214
1215
1216
1217
1218 <li class="md-nav__item">
1219 <a href="../../../package/pip/sql/" class="md-nav__link">
1220 sql
1221 </a>
1222 </li>
1223
1224
1225
1226
1227
1228
1229
1230 <li class="md-nav__item">
1231 <a href="../../../package/pip/style/" class="md-nav__link">
1232 style
1233 </a>
1234 </li>
1235
1236
1237
1238
1239
1240
1241
1242 <li class="md-nav__item">
1243 <a href="../../../package/pip/template/" class="md-nav__link">
1244 template
1245 </a>
1246 </li>
1247
1248
1249
1250
1251
1252
1253
1254 <li class="md-nav__item">
1255 <a href="../../../package/pip/template-listener/" class="md-nav__link">
1256 templateListener
1257 </a>
1258 </li>
1259
1260
1261
1262
1263
1264
1265
1266 <li class="md-nav__item">
1267 <a href="../../../package/pip/user-group-option/" class="md-nav__link">
1268 userGroupOption
1269 </a>
1270 </li>
1271
1272
1273
1274
1275
1276
1277
1278 <li class="md-nav__item">
1279 <a href="../../../package/pip/user-menu/" class="md-nav__link">
1280 userMenu
1281 </a>
1282 </li>
1283
1284
1285
1286
1287
1288
1289
1290 <li class="md-nav__item">
1291 <a href="../../../package/pip/user-notification-event/" class="md-nav__link">
1292 userNotificationEvent
1293 </a>
1294 </li>
1295
1296
1297
1298
1299
1300
1301
1302 <li class="md-nav__item">
1303 <a href="../../../package/pip/user-option/" class="md-nav__link">
1304 userOption
1305 </a>
1306 </li>
1307
1308
1309
1310
1311
1312
1313
1314 <li class="md-nav__item">
1315 <a href="../../../package/pip/user-profile-menu/" class="md-nav__link">
1316 userProfileMenu
1317 </a>
1318 </li>
1319
1320
1321
1322 </ul>
1323 </nav>
1324 </li>
1325
1326
1327
1328
1329
1330
1331
1332 <li class="md-nav__item">
1333 <a href="../../../package/database-php-api/" class="md-nav__link">
1334 Database PHP API
1335 </a>
1336 </li>
1337
1338
1339
1340 </ul>
1341 </nav>
1342 </li>
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354 <li class="md-nav__item md-nav__item--nested">
1355
1356
1357 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6" type="checkbox" id="__nav_6" >
1358
1359 <label class="md-nav__link" for="__nav_6">
1360 Migration
1361 <span class="md-nav__icon md-icon"></span>
1362 </label>
1363 <nav class="md-nav" aria-label="Migration" data-md-level="1">
1364 <label class="md-nav__title" for="__nav_6">
1365 <span class="md-nav__icon md-icon"></span>
1366 Migration
1367 </label>
1368 <ul class="md-nav__list" data-md-scrollfix>
1369
1370
1371
1372
1373
1374
1375 <li class="md-nav__item md-nav__item--nested">
1376
1377
1378 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_1" type="checkbox" id="__nav_6_1" >
1379
1380 <label class="md-nav__link" for="__nav_6_1">
1381 Migrating from WSC 5.3
1382 <span class="md-nav__icon md-icon"></span>
1383 </label>
1384 <nav class="md-nav" aria-label="Migrating from WSC 5.3" data-md-level="2">
1385 <label class="md-nav__title" for="__nav_6_1">
1386 <span class="md-nav__icon md-icon"></span>
1387 Migrating from WSC 5.3
1388 </label>
1389 <ul class="md-nav__list" data-md-scrollfix>
1390
1391
1392
1393
1394
1395 <li class="md-nav__item">
1396 <a href="../../../migration/wsc53/php/" class="md-nav__link">
1397 PHP API
1398 </a>
1399 </li>
1400
1401
1402
1403
1404
1405
1406
1407 <li class="md-nav__item">
1408 <a href="../../../migration/wsc53/session/" class="md-nav__link">
1409 Session Handling and Authentication
1410 </a>
1411 </li>
1412
1413
1414
1415
1416
1417
1418
1419 <li class="md-nav__item">
1420 <a href="../../../migration/wsc53/javascript/" class="md-nav__link">
1421 JavaScript
1422 </a>
1423 </li>
1424
1425
1426
1427
1428
1429
1430
1431 <li class="md-nav__item">
1432 <a href="../../../migration/wsc53/templates/" class="md-nav__link">
1433 Templates
1434 </a>
1435 </li>
1436
1437
1438
1439
1440
1441
1442
1443 <li class="md-nav__item">
1444 <a href="../../../migration/wsc53/libraries/" class="md-nav__link">
1445 Third Party Libraries
1446 </a>
1447 </li>
1448
1449
1450
1451 </ul>
1452 </nav>
1453 </li>
1454
1455
1456
1457
1458
1459
1460
1461
1462 <li class="md-nav__item md-nav__item--nested">
1463
1464
1465 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_2" type="checkbox" id="__nav_6_2" >
1466
1467 <label class="md-nav__link" for="__nav_6_2">
1468 Migrating from WSC 5.2
1469 <span class="md-nav__icon md-icon"></span>
1470 </label>
1471 <nav class="md-nav" aria-label="Migrating from WSC 5.2" data-md-level="2">
1472 <label class="md-nav__title" for="__nav_6_2">
1473 <span class="md-nav__icon md-icon"></span>
1474 Migrating from WSC 5.2
1475 </label>
1476 <ul class="md-nav__list" data-md-scrollfix>
1477
1478
1479
1480
1481
1482 <li class="md-nav__item">
1483 <a href="../../../migration/wsc52/php/" class="md-nav__link">
1484 PHP API
1485 </a>
1486 </li>
1487
1488
1489
1490
1491
1492
1493
1494 <li class="md-nav__item">
1495 <a href="../../../migration/wsc52/templates/" class="md-nav__link">
1496 Templates and Languages
1497 </a>
1498 </li>
1499
1500
1501
1502
1503
1504
1505
1506 <li class="md-nav__item">
1507 <a href="../../../migration/wsc52/libraries/" class="md-nav__link">
1508 Third Party Libraries
1509 </a>
1510 </li>
1511
1512
1513
1514 </ul>
1515 </nav>
1516 </li>
1517
1518
1519
1520
1521
1522
1523
1524
1525 <li class="md-nav__item md-nav__item--nested">
1526
1527
1528 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_3" type="checkbox" id="__nav_6_3" >
1529
1530 <label class="md-nav__link" for="__nav_6_3">
1531 Migrating from WSC 3.1
1532 <span class="md-nav__icon md-icon"></span>
1533 </label>
1534 <nav class="md-nav" aria-label="Migrating from WSC 3.1" data-md-level="2">
1535 <label class="md-nav__title" for="__nav_6_3">
1536 <span class="md-nav__icon md-icon"></span>
1537 Migrating from WSC 3.1
1538 </label>
1539 <ul class="md-nav__list" data-md-scrollfix>
1540
1541
1542
1543
1544
1545 <li class="md-nav__item">
1546 <a href="../../../migration/wsc31/php/" class="md-nav__link">
1547 PHP API
1548 </a>
1549 </li>
1550
1551
1552
1553 </ul>
1554 </nav>
1555 </li>
1556
1557
1558
1559
1560
1561
1562
1563
1564 <li class="md-nav__item md-nav__item--nested">
1565
1566
1567 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_4" type="checkbox" id="__nav_6_4" >
1568
1569 <label class="md-nav__link" for="__nav_6_4">
1570 Migrating from WSC 3.0
1571 <span class="md-nav__icon md-icon"></span>
1572 </label>
1573 <nav class="md-nav" aria-label="Migrating from WSC 3.0" data-md-level="2">
1574 <label class="md-nav__title" for="__nav_6_4">
1575 <span class="md-nav__icon md-icon"></span>
1576 Migrating from WSC 3.0
1577 </label>
1578 <ul class="md-nav__list" data-md-scrollfix>
1579
1580
1581
1582
1583
1584 <li class="md-nav__item">
1585 <a href="../../../migration/wsc30/php/" class="md-nav__link">
1586 PHP API
1587 </a>
1588 </li>
1589
1590
1591
1592
1593
1594
1595
1596 <li class="md-nav__item">
1597 <a href="../../../migration/wsc30/javascript/" class="md-nav__link">
1598 JavaScript API
1599 </a>
1600 </li>
1601
1602
1603
1604
1605
1606
1607
1608 <li class="md-nav__item">
1609 <a href="../../../migration/wsc30/templates/" class="md-nav__link">
1610 Templates
1611 </a>
1612 </li>
1613
1614
1615
1616
1617
1618
1619
1620 <li class="md-nav__item">
1621 <a href="../../../migration/wsc30/css/" class="md-nav__link">
1622 CSS
1623 </a>
1624 </li>
1625
1626
1627
1628
1629
1630
1631
1632 <li class="md-nav__item">
1633 <a href="../../../migration/wsc30/package/" class="md-nav__link">
1634 Package Components
1635 </a>
1636 </li>
1637
1638
1639
1640 </ul>
1641 </nav>
1642 </li>
1643
1644
1645
1646
1647
1648
1649
1650
1651 <li class="md-nav__item md-nav__item--nested">
1652
1653
1654 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_5" type="checkbox" id="__nav_6_5" >
1655
1656 <label class="md-nav__link" for="__nav_6_5">
1657 Migrating from WCF 2.1
1658 <span class="md-nav__icon md-icon"></span>
1659 </label>
1660 <nav class="md-nav" aria-label="Migrating from WCF 2.1" data-md-level="2">
1661 <label class="md-nav__title" for="__nav_6_5">
1662 <span class="md-nav__icon md-icon"></span>
1663 Migrating from WCF 2.1
1664 </label>
1665 <ul class="md-nav__list" data-md-scrollfix>
1666
1667
1668
1669
1670
1671 <li class="md-nav__item">
1672 <a href="../../../migration/wcf21/php/" class="md-nav__link">
1673 PHP API
1674 </a>
1675 </li>
1676
1677
1678
1679
1680
1681
1682
1683 <li class="md-nav__item">
1684 <a href="../../../migration/wcf21/templates/" class="md-nav__link">
1685 Templates
1686 </a>
1687 </li>
1688
1689
1690
1691
1692
1693
1694
1695 <li class="md-nav__item">
1696 <a href="../../../migration/wcf21/css/" class="md-nav__link">
1697 CSS
1698 </a>
1699 </li>
1700
1701
1702
1703
1704
1705
1706
1707 <li class="md-nav__item">
1708 <a href="../../../migration/wcf21/package/" class="md-nav__link">
1709 Package Components
1710 </a>
1711 </li>
1712
1713
1714
1715 </ul>
1716 </nav>
1717 </li>
1718
1719
1720
1721 </ul>
1722 </nav>
1723 </li>
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735 <li class="md-nav__item md-nav__item--nested">
1736
1737
1738 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7" type="checkbox" id="__nav_7" >
1739
1740 <label class="md-nav__link" for="__nav_7">
1741 Tutorials
1742 <span class="md-nav__icon md-icon"></span>
1743 </label>
1744 <nav class="md-nav" aria-label="Tutorials" data-md-level="1">
1745 <label class="md-nav__title" for="__nav_7">
1746 <span class="md-nav__icon md-icon"></span>
1747 Tutorials
1748 </label>
1749 <ul class="md-nav__list" data-md-scrollfix>
1750
1751
1752
1753
1754
1755
1756 <li class="md-nav__item md-nav__item--nested">
1757
1758
1759 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7_1" type="checkbox" id="__nav_7_1" >
1760
1761 <label class="md-nav__link" for="__nav_7_1">
1762 Tutorial Series
1763 <span class="md-nav__icon md-icon"></span>
1764 </label>
1765 <nav class="md-nav" aria-label="Tutorial Series" data-md-level="2">
1766 <label class="md-nav__title" for="__nav_7_1">
1767 <span class="md-nav__icon md-icon"></span>
1768 Tutorial Series
1769 </label>
1770 <ul class="md-nav__list" data-md-scrollfix>
1771
1772
1773
1774
1775
1776 <li class="md-nav__item">
1777 <a href="../../../tutorial/series/overview/" class="md-nav__link">
1778 Overview
1779 </a>
1780 </li>
1781
1782
1783
1784
1785
1786
1787
1788 <li class="md-nav__item">
1789 <a href="../../../tutorial/series/part_1/" class="md-nav__link">
1790 Part 1
1791 </a>
1792 </li>
1793
1794
1795
1796
1797
1798
1799
1800 <li class="md-nav__item">
1801 <a href="../../../tutorial/series/part_2/" class="md-nav__link">
1802 Part 2
1803 </a>
1804 </li>
1805
1806
1807
1808
1809
1810
1811
1812 <li class="md-nav__item">
1813 <a href="../../../tutorial/series/part_3/" class="md-nav__link">
1814 Part 3
1815 </a>
1816 </li>
1817
1818
1819
1820 </ul>
1821 </nav>
1822 </li>
1823
1824
1825
1826 </ul>
1827 </nav>
1828 </li>
1829
1830
1831
1832 </ul>
1833 </nav>
1834 </div>
1835 </div>
1836 </div>
1837
1838
1839
1840 <div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
1841 <div class="md-sidebar__scrollwrap">
1842 <div class="md-sidebar__inner">
1843
1844 <nav class="md-nav md-nav--secondary" aria-label="Table of contents">
1845
1846
1847
1848
1849
1850 <label class="md-nav__title" for="__toc">
1851 <span class="md-nav__icon md-icon"></span>
1852 Table of contents
1853 </label>
1854 <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
1855
1856 <li class="md-nav__item">
1857 <a href="#understanding-caching" class="md-nav__link">
1858 Understanding Caching
1859 </a>
1860
1861 <nav class="md-nav" aria-label="Understanding Caching">
1862 <ul class="md-nav__list">
1863
1864 <li class="md-nav__item">
1865 <a href="#when-to-use-a-cache" class="md-nav__link">
1866 When to Use a Cache
1867 </a>
1868
1869 </li>
1870
1871 <li class="md-nav__item">
1872 <a href="#when-not-to-use-a-cache" class="md-nav__link">
1873 When not to Use a Cache
1874 </a>
1875
1876 </li>
1877
1878 </ul>
1879 </nav>
1880
1881 </li>
1882
1883 </ul>
1884
1885 </nav>
1886 </div>
1887 </div>
1888 </div>
1889
1890
1891 <div class="md-content" data-md-component="content">
1892 <article class="md-content__inner md-typeset">
1893
1894
1895 <a href="https://github.com/WoltLab/docs.woltlab.com/edit/5.4/docs/php/api/caches.md" title="Edit this page" class="md-content__button md-icon">
1896 <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>
1897 </a>
1898
1899
1900 <h1 id="caches">Caches<a class="headerlink" href="#caches" title="Permanent link">#</a></h1>
1901 <p>WoltLab Suite offers two distinct types of caches:</p>
1902 <ol>
1903 <li><a href="../caches_persistent-caches/">Persistent caches</a> created by cache builders whose data can be stored using different cache sources.</li>
1904 <li><a href="../caches_runtime-caches/">Runtime caches</a> store objects for the duration of a single request.</li>
1905 </ol>
1906 <h2 id="understanding-caching">Understanding Caching<a class="headerlink" href="#understanding-caching" title="Permanent link">#</a></h2>
1907 <p>Every so often, plugins make use of cache builders or runtime caches to store
1908 their data, even if there is absolutely no need for them to do so. Usually, this
1909 involves a strong opinion about the total number of SQL queries on a page,
1910 including but not limited to some magic treshold numbers, which should not be
1911 exceeded for "performance reasons".</p>
1912 <p>This misconception can easily lead into thinking that SQL queries should be
1913 avoided or at least written to a cache, so that it doesn't need to be executed
1914 so often. Unfortunately, this completely ignores the fact that both a single
1915 query can take down your app (e. g. full table scan on millions of rows), but
1916 10 queries using a primary key on a table with a few hundred rows will not slow
1917 down your page.</p>
1918 <p>There are some queries that should go into caches by design, but most of the
1919 cache builders weren't initially there, but instead have been added because
1920 they were required to reduce the load <em>significantly</em>. You need to understand
1921 that caches always come at a cost, even a runtime cache does! In particular,
1922 they will always consume memory that is not released over the duration of the
1923 request lifecycle and potentially even leak memory by holding references to
1924 objects and data structures that are no longer required.</p>
1925 <p>Caching should always be a solution for a problem.</p>
1926 <h3 id="when-to-use-a-cache">When to Use a Cache<a class="headerlink" href="#when-to-use-a-cache" title="Permanent link">#</a></h3>
1927 <p>It's difficult to provide a definite answer or checklist when to use a cache
1928 and why it is required at this point, because the answer is: It depends. The
1929 permission cache for user groups is a good example for a valid cache, where
1930 we can achieve significant performance improvement compared to processing this
1931 data on every request.</p>
1932 <p>Its caches are build for each permutation of user group memberships that are
1933 encountered for a page request. Building this data is an expensive process that
1934 involves both inheritance and specific rules in regards to when a value for a
1935 permission overrules another value. The added benefit of this cache is that one
1936 cache usually serves a large number of users with the same group memberships and
1937 by computing these permissions once, we can serve many different requests. Also,
1938 the permissions are rather static values that change very rarely and thus we can
1939 expect a very high cache lifetime before it gets rebuild.</p>
1940 <h3 id="when-not-to-use-a-cache">When not to Use a Cache<a class="headerlink" href="#when-not-to-use-a-cache" title="Permanent link">#</a></h3>
1941 <p>I remember, a few years ago, there was a plugin that displayed a user's character
1942 from an online video game. The character sheet not only included a list of basic
1943 statistics, but also displayed the items that this character was wearing and or
1944 holding at the time.</p>
1945 <p>The data for these items were downloaded in bulk from the game's vendor servers
1946 and stored in a persistent cache file that periodically gets renewed. There is
1947 nothing wrong with the idea of caching the data on your own server rather than
1948 requesting them everytime from the vendor's servers - not only because they
1949 imposed a limit on the number of requests per hour.</p>
1950 <p>Unfortunately, the character sheet had a sub-par performance and the users were
1951 upset by the significant loading times compared to literally every other page
1952 on the same server. The author of the plugin was working hard to resolve this
1953 issue and was evaluating all kind of methods to improve the page performance,
1954 including deep-diving into the realm of micro-optimizations to squeeze out every
1955 last bit of performance that is possible.</p>
1956 <p>The real problem was the cache file itself, it turns out that it was holding the
1957 data for several thousand items with a total file size of about 13 megabytes.
1958 It doesn't look that much at first glance, after all this isn't the '90s anymore,
1959 but unserializing a 13 megabyte array is really slow and looking up items in such
1960 a large array isn't exactly fast either.</p>
1961 <p>The solution was rather simple, the data that was fetched from the vendor's API
1962 was instead written into a separate database table. Next, the persistent cache
1963 was removed and the character sheet would now request the item data for that
1964 specific character straight from the database. Previously, the character sheet
1965 took several seconds to load and after the change it was done in a fraction of
1966 a second. Although quite extreme, this illustrates a situation where the cache
1967 file was introduced in the design process, without evaluating if the cache -
1968 at least how it was implemented - was really necessary.</p>
1969 <p>Caching should always be a solution for a problem. Not the other way around.</p>
1970
1971
1972
1973
1974 <hr>
1975 <div class="md-source-date">
1976 <small>
1977
1978 Last update: 2021-01-08
1979
1980 </small>
1981 </div>
1982
1983
1984
1985
1986
1987
1988
1989
1990 </article>
1991 </div>
1992 </div>
1993 </main>
1994
1995
1996 <footer class="md-footer">
1997
1998 <nav class="md-footer__inner md-grid" aria-label="Footer">
1999
2000 <a href="../../exceptions/" class="md-footer__link md-footer__link--prev" rel="prev">
2001 <div class="md-footer__button md-icon">
2002 <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>
2003 </div>
2004 <div class="md-footer__title">
2005 <div class="md-ellipsis">
2006 <span class="md-footer__direction">
2007 Previous
2008 </span>
2009 Exceptions
2010 </div>
2011 </div>
2012 </a>
2013
2014
2015 <a href="../comments/" class="md-footer__link md-footer__link--next" rel="next">
2016 <div class="md-footer__title">
2017 <div class="md-ellipsis">
2018 <span class="md-footer__direction">
2019 Next
2020 </span>
2021 Comments
2022 </div>
2023 </div>
2024 <div class="md-footer__button md-icon">
2025 <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>
2026 </div>
2027 </a>
2028
2029 </nav>
2030
2031 <div class="md-footer-meta md-typeset">
2032 <div class="md-footer-meta__inner md-grid">
2033 <div class="md-footer-copyright">
2034
2035 <div class="md-footer-copyright__highlight">
2036 Copyright © 2020 WoltLab GmbH
2037 </div>
2038
2039 Made with
2040 <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
2041 Material for MkDocs
2042 </a>
2043
2044 </div>
2045 <div class="md-footer-copyright">
2046 <a href="https://www.woltlab.com/legal-notice/">Legal Notice</a>
2047 <a href="https://www.woltlab.com/privacy-policy/">Privacy Policy</a>
2048 </div>
2049 </div>
2050 </div>
2051 </footer>
2052
2053 </div>
2054 <div class="md-dialog" data-md-component="dialog">
2055 <div class="md-dialog__inner md-typeset"></div>
2056 </div>
2057 <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.fb4a9340.min.js", "version": {"provider": "mike"}}</script>
2058
2059
2060 <script src="../../../assets/javascripts/bundle.5cf3e710.min.js"></script>
2061
2062
2063 </body>
2064 </html>