3 <html lang=
"en" class=
"no-js">
7 <meta name=
"viewport" content=
"width=device-width,initial-scale=1">
11 <link rel=
"canonical" href=
"https://docs.woltlab.com/6.0/migration/wcf21/php/">
14 <link rel=
"prev" href=
"../../wsc30/package/">
17 <link rel=
"next" href=
"../templates/">
19 <link rel=
"icon" href=
"../../../assets/default.favicon.ico">
20 <meta name=
"generator" content=
"mkdocs-1.5.1, mkdocs-material-9.1.21">
24 <title>PHP API - WoltLab Suite Documentation
</title>
28 <link rel=
"stylesheet" href=
"../../../assets/stylesheets/main.eebd395e.min.css">
31 <link rel=
"stylesheet" href=
"../../../assets/stylesheets/palette.ecc896b0.min.css">
41 <link rel=
"stylesheet" href=
"../../../stylesheets/extra.css">
43 <script>__md_scope=new URL(
"../../..",location),__md_hash=e=
>[...e].reduce((e,_)=
>(e<
<5)-e+_.charCodeAt(
0),
0),__md_get=(e,_=localStorage,t=__md_scope)=
>JSON.parse(_.getItem(t.pathname+
"."+e)),__md_set=(e,_,t=localStorage,a=__md_scope)=
>{try{t.setItem(a.pathname+
"."+e,JSON.stringify(_))}catch(e){}}
</script>
58 <body dir=
"ltr" data-md-color-scheme=
"default" data-md-color-primary=
"teal" data-md-color-accent=
"indigo">
62 <input class=
"md-toggle" data-md-toggle=
"drawer" type=
"checkbox" id=
"__drawer" autocomplete=
"off">
63 <input class=
"md-toggle" data-md-toggle=
"search" type=
"checkbox" id=
"__search" autocomplete=
"off">
64 <label class=
"md-overlay" for=
"__drawer"></label>
65 <div data-md-component=
"skip">
68 <a href=
"#wcf-21x-php" class=
"md-skip">
73 <div data-md-component=
"announce">
75 <aside class=
"md-banner">
76 <div class=
"md-banner__inner md-grid md-typeset">
79 <a href=
"https://www.woltlab.com">Back to
<strong>woltlab.com
</strong></a>
87 <div data-md-color-scheme=
"default" data-md-component=
"outdated" hidden
>
96 <header class=
"md-header md-header--shadow" data-md-component=
"header">
97 <nav class=
"md-header__inner md-grid" aria-label=
"Header">
98 <a href=
"../../.." title=
"WoltLab Suite Documentation" class=
"md-header__button md-logo" aria-label=
"WoltLab Suite Documentation" data-md-component=
"logo">
100 <img src=
"../../../assets/logo.png" alt=
"logo">
103 <label class=
"md-header__button md-icon" for=
"__drawer">
104 <svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 24 24"><path d=
"M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2Z"/></svg>
106 <div class=
"md-header__title" data-md-component=
"header-title">
107 <div class=
"md-header__ellipsis">
108 <div class=
"md-header__topic">
109 <span class=
"md-ellipsis">
110 WoltLab Suite Documentation
113 <div class=
"md-header__topic" data-md-component=
"header-topic">
114 <span class=
"md-ellipsis">
127 <label class=
"md-header__button md-icon" for=
"__search">
128 <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>
130 <div class=
"md-search" data-md-component=
"search" role=
"dialog">
131 <label class=
"md-search__overlay" for=
"__search"></label>
132 <div class=
"md-search__inner" role=
"search">
133 <form class=
"md-search__form" name=
"search">
134 <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" required
>
135 <label class=
"md-search__icon md-icon" for=
"__search">
136 <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>
137 <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>
139 <nav class=
"md-search__options" aria-label=
"Search">
141 <button type=
"reset" class=
"md-search__icon md-icon" title=
"Clear" aria-label=
"Clear" tabindex=
"-1">
142 <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>
147 <div class=
"md-search__output">
148 <div class=
"md-search__scrollwrap" data-md-scrollfix
>
149 <div class=
"md-search-result" data-md-component=
"search-result">
150 <div class=
"md-search-result__meta">
153 <ol class=
"md-search-result__list" role=
"presentation"></ol>
161 <div class=
"md-header__source">
162 <a href=
"https://github.com/WoltLab/docs.woltlab.com/" title=
"Go to repository" class=
"md-source" data-md-component=
"source">
163 <div class=
"md-source__icon md-icon">
165 <svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 448 512"><!--! Font Awesome Free 6.4.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2023 Fonticons, Inc.--><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>
167 <div class=
"md-source__repository">
177 <div class=
"md-container" data-md-component=
"container">
184 <main class=
"md-main" data-md-component=
"main">
185 <div class=
"md-main__inner md-grid">
189 <div class=
"md-sidebar md-sidebar--primary" data-md-component=
"sidebar" data-md-type=
"navigation" >
190 <div class=
"md-sidebar__scrollwrap">
191 <div class=
"md-sidebar__inner">
195 <nav class=
"md-nav md-nav--primary" aria-label=
"Navigation" data-md-level=
"0">
196 <label class=
"md-nav__title" for=
"__drawer">
197 <a href=
"../../.." title=
"WoltLab Suite Documentation" class=
"md-nav__button md-logo" aria-label=
"WoltLab Suite Documentation" data-md-component=
"logo">
199 <img src=
"../../../assets/logo.png" alt=
"logo">
202 WoltLab Suite Documentation
205 <div class=
"md-nav__source">
206 <a href=
"https://github.com/WoltLab/docs.woltlab.com/" title=
"Go to repository" class=
"md-source" data-md-component=
"source">
207 <div class=
"md-source__icon md-icon">
209 <svg xmlns=
"http://www.w3.org/2000/svg" viewBox=
"0 0 448 512"><!--! Font Awesome Free 6.4.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2023 Fonticons, Inc.--><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>
211 <div class=
"md-source__repository">
217 <ul class=
"md-nav__list" data-md-scrollfix
>
226 <li class=
"md-nav__item">
227 <a href=
"../../../getting-started/" class=
"md-nav__link">
242 <li class=
"md-nav__item md-nav__item--nested">
247 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_2" >
251 <label class=
"md-nav__link" for=
"__nav_2" id=
"__nav_2_label" tabindex=
"0">
253 <span class=
"md-nav__icon md-icon"></span>
256 <nav class=
"md-nav" data-md-level=
"1" aria-labelledby=
"__nav_2_label" aria-expanded=
"false">
257 <label class=
"md-nav__title" for=
"__nav_2">
258 <span class=
"md-nav__icon md-icon"></span>
261 <ul class=
"md-nav__list" data-md-scrollfix
>
268 <li class=
"md-nav__item">
269 <a href=
"../../../php/pages/" class=
"md-nav__link">
282 <li class=
"md-nav__item">
283 <a href=
"../../../php/database-objects/" class=
"md-nav__link">
296 <li class=
"md-nav__item">
297 <a href=
"../../../php/database-access/" class=
"md-nav__link">
310 <li class=
"md-nav__item">
311 <a href=
"../../../php/exceptions/" class=
"md-nav__link">
325 <li class=
"md-nav__item md-nav__item--nested">
330 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_2_5" >
334 <label class=
"md-nav__link" for=
"__nav_2_5" id=
"__nav_2_5_label" tabindex=
"0">
336 <span class=
"md-nav__icon md-icon"></span>
339 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_2_5_label" aria-expanded=
"false">
340 <label class=
"md-nav__title" for=
"__nav_2_5">
341 <span class=
"md-nav__icon md-icon"></span>
344 <ul class=
"md-nav__list" data-md-scrollfix
>
352 <li class=
"md-nav__item md-nav__item--nested">
357 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_2_5_1" >
361 <label class=
"md-nav__link" for=
"__nav_2_5_1" id=
"__nav_2_5_1_label" tabindex=
"0">
363 <span class=
"md-nav__icon md-icon"></span>
366 <nav class=
"md-nav" data-md-level=
"3" aria-labelledby=
"__nav_2_5_1_label" aria-expanded=
"false">
367 <label class=
"md-nav__title" for=
"__nav_2_5_1">
368 <span class=
"md-nav__icon md-icon"></span>
371 <ul class=
"md-nav__list" data-md-scrollfix
>
378 <li class=
"md-nav__item">
379 <a href=
"../../../php/api/caches/" class=
"md-nav__link">
392 <li class=
"md-nav__item">
393 <a href=
"../../../php/api/caches_persistent-caches/" class=
"md-nav__link">
406 <li class=
"md-nav__item">
407 <a href=
"../../../php/api/caches_runtime-caches/" class=
"md-nav__link">
427 <li class=
"md-nav__item">
428 <a href=
"../../../php/api/comments/" class=
"md-nav__link">
441 <li class=
"md-nav__item">
442 <a href=
"../../../php/api/cronjobs/" class=
"md-nav__link">
455 <li class=
"md-nav__item">
456 <a href=
"../../../php/api/events/" class=
"md-nav__link">
470 <li class=
"md-nav__item md-nav__item--nested">
475 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_2_5_5" >
479 <label class=
"md-nav__link" for=
"__nav_2_5_5" id=
"__nav_2_5_5_label" tabindex=
"0">
481 <span class=
"md-nav__icon md-icon"></span>
484 <nav class=
"md-nav" data-md-level=
"3" aria-labelledby=
"__nav_2_5_5_label" aria-expanded=
"false">
485 <label class=
"md-nav__title" for=
"__nav_2_5_5">
486 <span class=
"md-nav__icon md-icon"></span>
489 <ul class=
"md-nav__list" data-md-scrollfix
>
496 <li class=
"md-nav__item">
497 <a href=
"../../../php/api/form_builder/overview/" class=
"md-nav__link">
510 <li class=
"md-nav__item">
511 <a href=
"../../../php/api/form_builder/structure/" class=
"md-nav__link">
524 <li class=
"md-nav__item">
525 <a href=
"../../../php/api/form_builder/form_fields/" class=
"md-nav__link">
538 <li class=
"md-nav__item">
539 <a href=
"../../../php/api/form_builder/validation_data/" class=
"md-nav__link">
552 <li class=
"md-nav__item">
553 <a href=
"../../../php/api/form_builder/dependencies/" class=
"md-nav__link">
573 <li class=
"md-nav__item">
574 <a href=
"../../../php/api/package_installation_plugins/" class=
"md-nav__link">
575 Package Installation Plugins
587 <li class=
"md-nav__item">
588 <a href=
"../../../php/api/user_activity_points/" class=
"md-nav__link">
601 <li class=
"md-nav__item">
602 <a href=
"../../../php/api/user_notifications/" class=
"md-nav__link">
615 <li class=
"md-nav__item">
616 <a href=
"../../../php/api/sitemaps/" class=
"md-nav__link">
636 <li class=
"md-nav__item">
637 <a href=
"../../../php/code-style/" class=
"md-nav__link">
650 <li class=
"md-nav__item">
651 <a href=
"../../../php/apps/" class=
"md-nav__link">
664 <li class=
"md-nav__item">
665 <a href=
"../../../php/gdpr/" class=
"md-nav__link">
687 <li class=
"md-nav__item md-nav__item--nested">
692 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_3" >
696 <label class=
"md-nav__link" for=
"__nav_3" id=
"__nav_3_label" tabindex=
"0">
697 Languages, Templates & CSS
698 <span class=
"md-nav__icon md-icon"></span>
701 <nav class=
"md-nav" data-md-level=
"1" aria-labelledby=
"__nav_3_label" aria-expanded=
"false">
702 <label class=
"md-nav__title" for=
"__nav_3">
703 <span class=
"md-nav__icon md-icon"></span>
704 Languages, Templates & CSS
706 <ul class=
"md-nav__list" data-md-scrollfix
>
713 <li class=
"md-nav__item">
714 <a href=
"../../../view/languages/" class=
"md-nav__link">
727 <li class=
"md-nav__item">
728 <a href=
"../../../view/templates/" class=
"md-nav__link">
741 <li class=
"md-nav__item">
742 <a href=
"../../../view/template-modifiers/" class=
"md-nav__link">
755 <li class=
"md-nav__item">
756 <a href=
"../../../view/template-plugins/" class=
"md-nav__link">
769 <li class=
"md-nav__item">
770 <a href=
"../../../view/css/" class=
"md-nav__link">
792 <li class=
"md-nav__item md-nav__item--nested">
797 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_4" >
801 <label class=
"md-nav__link" for=
"__nav_4" id=
"__nav_4_label" tabindex=
"0">
802 TypeScript and JavaScript API
803 <span class=
"md-nav__icon md-icon"></span>
806 <nav class=
"md-nav" data-md-level=
"1" aria-labelledby=
"__nav_4_label" aria-expanded=
"false">
807 <label class=
"md-nav__title" for=
"__nav_4">
808 <span class=
"md-nav__icon md-icon"></span>
809 TypeScript and JavaScript API
811 <ul class=
"md-nav__list" data-md-scrollfix
>
818 <li class=
"md-nav__item">
819 <a href=
"../../../javascript/general-usage/" class=
"md-nav__link">
832 <li class=
"md-nav__item">
833 <a href=
"../../../javascript/typescript/" class=
"md-nav__link">
847 <li class=
"md-nav__item md-nav__item--nested">
852 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_4_3" >
856 <label class=
"md-nav__link" for=
"__nav_4_3" id=
"__nav_4_3_label" tabindex=
"0">
858 <span class=
"md-nav__icon md-icon"></span>
861 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_4_3_label" aria-expanded=
"false">
862 <label class=
"md-nav__title" for=
"__nav_4_3">
863 <span class=
"md-nav__icon md-icon"></span>
866 <ul class=
"md-nav__list" data-md-scrollfix
>
873 <li class=
"md-nav__item">
874 <a href=
"../../../javascript/components_ckeditor5/" class=
"md-nav__link">
887 <li class=
"md-nav__item">
888 <a href=
"../../../javascript/components_confirmation/" class=
"md-nav__link">
901 <li class=
"md-nav__item">
902 <a href=
"../../../javascript/components_dialog/" class=
"md-nav__link">
915 <li class=
"md-nav__item">
916 <a href=
"../../../javascript/components_google_maps/" class=
"md-nav__link">
929 <li class=
"md-nav__item">
930 <a href=
"../../../javascript/components_pagination/" class=
"md-nav__link">
951 <li class=
"md-nav__item md-nav__item--nested">
956 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_4_4" >
960 <label class=
"md-nav__link" for=
"__nav_4_4" id=
"__nav_4_4_label" tabindex=
"0">
962 <span class=
"md-nav__icon md-icon"></span>
965 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_4_4_label" aria-expanded=
"false">
966 <label class=
"md-nav__title" for=
"__nav_4_4">
967 <span class=
"md-nav__icon md-icon"></span>
970 <ul class=
"md-nav__list" data-md-scrollfix
>
977 <li class=
"md-nav__item">
978 <a href=
"../../../javascript/new-api_writing-a-module/" class=
"md-nav__link">
991 <li class=
"md-nav__item">
992 <a href=
"../../../javascript/new-api_core/" class=
"md-nav__link">
1005 <li class=
"md-nav__item">
1006 <a href=
"../../../javascript/new-api_dom/" class=
"md-nav__link">
1019 <li class=
"md-nav__item">
1020 <a href=
"../../../javascript/new-api_events/" class=
"md-nav__link">
1033 <li class=
"md-nav__item">
1034 <a href=
"../../../javascript/new-api_ajax/" class=
"md-nav__link">
1047 <li class=
"md-nav__item">
1048 <a href=
"../../../javascript/new-api_dialogs/" class=
"md-nav__link">
1061 <li class=
"md-nav__item">
1062 <a href=
"../../../javascript/new-api_browser/" class=
"md-nav__link">
1063 Browser and Screen Sizes
1075 <li class=
"md-nav__item">
1076 <a href=
"../../../javascript/new-api_ui/" class=
"md-nav__link">
1096 <li class=
"md-nav__item">
1097 <a href=
"../../../javascript/legacy-api/" class=
"md-nav__link">
1110 <li class=
"md-nav__item">
1111 <a href=
"../../../javascript/code-snippets/" class=
"md-nav__link">
1133 <li class=
"md-nav__item md-nav__item--nested">
1138 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_5" >
1142 <label class=
"md-nav__link" for=
"__nav_5" id=
"__nav_5_label" tabindex=
"0">
1144 <span class=
"md-nav__icon md-icon"></span>
1147 <nav class=
"md-nav" data-md-level=
"1" aria-labelledby=
"__nav_5_label" aria-expanded=
"false">
1148 <label class=
"md-nav__title" for=
"__nav_5">
1149 <span class=
"md-nav__icon md-icon"></span>
1152 <ul class=
"md-nav__list" data-md-scrollfix
>
1159 <li class=
"md-nav__item">
1160 <a href=
"../../../package/package-xml/" class=
"md-nav__link">
1174 <li class=
"md-nav__item md-nav__item--nested">
1179 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_5_2" >
1183 <label class=
"md-nav__link" for=
"__nav_5_2" id=
"__nav_5_2_label" tabindex=
"0">
1185 <span class=
"md-nav__icon md-icon"></span>
1188 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_5_2_label" aria-expanded=
"false">
1189 <label class=
"md-nav__title" for=
"__nav_5_2">
1190 <span class=
"md-nav__icon md-icon"></span>
1193 <ul class=
"md-nav__list" data-md-scrollfix
>
1200 <li class=
"md-nav__item">
1201 <a href=
"../../../package/pip/" class=
"md-nav__link">
1214 <li class=
"md-nav__item">
1215 <a href=
"../../../package/pip/acl-option/" class=
"md-nav__link">
1228 <li class=
"md-nav__item">
1229 <a href=
"../../../package/pip/acp-menu/" class=
"md-nav__link">
1242 <li class=
"md-nav__item">
1243 <a href=
"../../../package/pip/acp-search-provider/" class=
"md-nav__link">
1256 <li class=
"md-nav__item">
1257 <a href=
"../../../package/pip/acp-template/" class=
"md-nav__link">
1270 <li class=
"md-nav__item">
1271 <a href=
"../../../package/pip/acp-template-delete/" class=
"md-nav__link">
1284 <li class=
"md-nav__item">
1285 <a href=
"../../../package/pip/bbcode/" class=
"md-nav__link">
1298 <li class=
"md-nav__item">
1299 <a href=
"../../../package/pip/box/" class=
"md-nav__link">
1312 <li class=
"md-nav__item">
1313 <a href=
"../../../package/pip/clipboard-action/" class=
"md-nav__link">
1326 <li class=
"md-nav__item">
1327 <a href=
"../../../package/pip/core-object/" class=
"md-nav__link">
1340 <li class=
"md-nav__item">
1341 <a href=
"../../../package/pip/cronjob/" class=
"md-nav__link">
1354 <li class=
"md-nav__item">
1355 <a href=
"../../../package/pip/database/" class=
"md-nav__link">
1368 <li class=
"md-nav__item">
1369 <a href=
"../../../package/pip/event-listener/" class=
"md-nav__link">
1382 <li class=
"md-nav__item">
1383 <a href=
"../../../package/pip/file/" class=
"md-nav__link">
1396 <li class=
"md-nav__item">
1397 <a href=
"../../../package/pip/file-delete/" class=
"md-nav__link">
1410 <li class=
"md-nav__item">
1411 <a href=
"../../../package/pip/language/" class=
"md-nav__link">
1424 <li class=
"md-nav__item">
1425 <a href=
"../../../package/pip/media-provider/" class=
"md-nav__link">
1438 <li class=
"md-nav__item">
1439 <a href=
"../../../package/pip/menu/" class=
"md-nav__link">
1452 <li class=
"md-nav__item">
1453 <a href=
"../../../package/pip/menu-item/" class=
"md-nav__link">
1466 <li class=
"md-nav__item">
1467 <a href=
"../../../package/pip/object-type/" class=
"md-nav__link">
1480 <li class=
"md-nav__item">
1481 <a href=
"../../../package/pip/object-type-definition/" class=
"md-nav__link">
1482 objectTypeDefinition
1494 <li class=
"md-nav__item">
1495 <a href=
"../../../package/pip/option/" class=
"md-nav__link">
1508 <li class=
"md-nav__item">
1509 <a href=
"../../../package/pip/page/" class=
"md-nav__link">
1522 <li class=
"md-nav__item">
1523 <a href=
"../../../package/pip/pip/" class=
"md-nav__link">
1536 <li class=
"md-nav__item">
1537 <a href=
"../../../package/pip/script/" class=
"md-nav__link">
1550 <li class=
"md-nav__item">
1551 <a href=
"../../../package/pip/smiley/" class=
"md-nav__link">
1564 <li class=
"md-nav__item">
1565 <a href=
"../../../package/pip/sql/" class=
"md-nav__link">
1578 <li class=
"md-nav__item">
1579 <a href=
"../../../package/pip/style/" class=
"md-nav__link">
1592 <li class=
"md-nav__item">
1593 <a href=
"../../../package/pip/template/" class=
"md-nav__link">
1606 <li class=
"md-nav__item">
1607 <a href=
"../../../package/pip/template-delete/" class=
"md-nav__link">
1620 <li class=
"md-nav__item">
1621 <a href=
"../../../package/pip/template-listener/" class=
"md-nav__link">
1634 <li class=
"md-nav__item">
1635 <a href=
"../../../package/pip/user-group-option/" class=
"md-nav__link">
1648 <li class=
"md-nav__item">
1649 <a href=
"../../../package/pip/user-menu/" class=
"md-nav__link">
1662 <li class=
"md-nav__item">
1663 <a href=
"../../../package/pip/user-notification-event/" class=
"md-nav__link">
1664 userNotificationEvent
1676 <li class=
"md-nav__item">
1677 <a href=
"../../../package/pip/user-option/" class=
"md-nav__link">
1690 <li class=
"md-nav__item">
1691 <a href=
"../../../package/pip/user-profile-menu/" class=
"md-nav__link">
1711 <li class=
"md-nav__item">
1712 <a href=
"../../../package/database-php-api/" class=
"md-nav__link">
1736 <li class=
"md-nav__item md-nav__item--active md-nav__item--nested">
1741 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6" checked
>
1745 <label class=
"md-nav__link" for=
"__nav_6" id=
"__nav_6_label" tabindex=
"0">
1747 <span class=
"md-nav__icon md-icon"></span>
1750 <nav class=
"md-nav" data-md-level=
"1" aria-labelledby=
"__nav_6_label" aria-expanded=
"true">
1751 <label class=
"md-nav__title" for=
"__nav_6">
1752 <span class=
"md-nav__icon md-icon"></span>
1755 <ul class=
"md-nav__list" data-md-scrollfix
>
1763 <li class=
"md-nav__item md-nav__item--nested">
1768 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_1" >
1772 <label class=
"md-nav__link" for=
"__nav_6_1" id=
"__nav_6_1_label" tabindex=
"0">
1773 From WoltLab Suite
5.5
1774 <span class=
"md-nav__icon md-icon"></span>
1777 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_1_label" aria-expanded=
"false">
1778 <label class=
"md-nav__title" for=
"__nav_6_1">
1779 <span class=
"md-nav__icon md-icon"></span>
1780 From WoltLab Suite
5.5
1782 <ul class=
"md-nav__list" data-md-scrollfix
>
1789 <li class=
"md-nav__item">
1790 <a href=
"../../wsc55/php/" class=
"md-nav__link">
1803 <li class=
"md-nav__item">
1804 <a href=
"../../wsc55/javascript/" class=
"md-nav__link">
1805 TypeScript and JavaScript
1817 <li class=
"md-nav__item">
1818 <a href=
"../../wsc55/templates/" class=
"md-nav__link">
1831 <li class=
"md-nav__item">
1832 <a href=
"../../wsc55/icons/" class=
"md-nav__link">
1845 <li class=
"md-nav__item">
1846 <a href=
"../../wsc55/dialogs/" class=
"md-nav__link">
1859 <li class=
"md-nav__item">
1860 <a href=
"../../wsc55/libraries/" class=
"md-nav__link">
1861 Third Party Libraries
1873 <li class=
"md-nav__item">
1874 <a href=
"../../wsc55/deprecations_removals/" class=
"md-nav__link">
1875 Deprecations and Removals
1895 <li class=
"md-nav__item md-nav__item--nested">
1900 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_2" >
1904 <label class=
"md-nav__link" for=
"__nav_6_2" id=
"__nav_6_2_label" tabindex=
"0">
1905 From WoltLab Suite
5.4
1906 <span class=
"md-nav__icon md-icon"></span>
1909 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_2_label" aria-expanded=
"false">
1910 <label class=
"md-nav__title" for=
"__nav_6_2">
1911 <span class=
"md-nav__icon md-icon"></span>
1912 From WoltLab Suite
5.4
1914 <ul class=
"md-nav__list" data-md-scrollfix
>
1921 <li class=
"md-nav__item">
1922 <a href=
"../../wsc54/php/" class=
"md-nav__link">
1935 <li class=
"md-nav__item">
1936 <a href=
"../../wsc54/javascript/" class=
"md-nav__link">
1937 TypeScript and JavaScript
1949 <li class=
"md-nav__item">
1950 <a href=
"../../wsc54/templates/" class=
"md-nav__link">
1963 <li class=
"md-nav__item">
1964 <a href=
"../../wsc54/libraries/" class=
"md-nav__link">
1965 Third Party Libraries
1977 <li class=
"md-nav__item">
1978 <a href=
"../../wsc54/deprecations_removals/" class=
"md-nav__link">
1979 Deprecations and Removals
1999 <li class=
"md-nav__item md-nav__item--nested">
2004 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_3" >
2008 <label class=
"md-nav__link" for=
"__nav_6_3" id=
"__nav_6_3_label" tabindex=
"0">
2009 From WoltLab Suite
5.3
2010 <span class=
"md-nav__icon md-icon"></span>
2013 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_3_label" aria-expanded=
"false">
2014 <label class=
"md-nav__title" for=
"__nav_6_3">
2015 <span class=
"md-nav__icon md-icon"></span>
2016 From WoltLab Suite
5.3
2018 <ul class=
"md-nav__list" data-md-scrollfix
>
2025 <li class=
"md-nav__item">
2026 <a href=
"../../wsc53/php/" class=
"md-nav__link">
2039 <li class=
"md-nav__item">
2040 <a href=
"../../wsc53/session/" class=
"md-nav__link">
2041 Session Handling and Authentication
2053 <li class=
"md-nav__item">
2054 <a href=
"../../wsc53/javascript/" class=
"md-nav__link">
2055 TypeScript and JavaScript
2067 <li class=
"md-nav__item">
2068 <a href=
"../../wsc53/templates/" class=
"md-nav__link">
2081 <li class=
"md-nav__item">
2082 <a href=
"../../wsc53/libraries/" class=
"md-nav__link">
2083 Third Party Libraries
2103 <li class=
"md-nav__item md-nav__item--nested">
2108 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_4" >
2112 <label class=
"md-nav__link" for=
"__nav_6_4" id=
"__nav_6_4_label" tabindex=
"0">
2113 From WoltLab Suite
5.2
2114 <span class=
"md-nav__icon md-icon"></span>
2117 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_4_label" aria-expanded=
"false">
2118 <label class=
"md-nav__title" for=
"__nav_6_4">
2119 <span class=
"md-nav__icon md-icon"></span>
2120 From WoltLab Suite
5.2
2122 <ul class=
"md-nav__list" data-md-scrollfix
>
2129 <li class=
"md-nav__item">
2130 <a href=
"../../wsc52/php/" class=
"md-nav__link">
2143 <li class=
"md-nav__item">
2144 <a href=
"../../wsc52/templates/" class=
"md-nav__link">
2145 Templates and Languages
2157 <li class=
"md-nav__item">
2158 <a href=
"../../wsc52/libraries/" class=
"md-nav__link">
2159 Third Party Libraries
2179 <li class=
"md-nav__item md-nav__item--nested">
2184 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_5" >
2188 <label class=
"md-nav__link" for=
"__nav_6_5" id=
"__nav_6_5_label" tabindex=
"0">
2189 From WoltLab Suite
3.1
2190 <span class=
"md-nav__icon md-icon"></span>
2193 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_5_label" aria-expanded=
"false">
2194 <label class=
"md-nav__title" for=
"__nav_6_5">
2195 <span class=
"md-nav__icon md-icon"></span>
2196 From WoltLab Suite
3.1
2198 <ul class=
"md-nav__list" data-md-scrollfix
>
2205 <li class=
"md-nav__item">
2206 <a href=
"../../wsc31/php/" class=
"md-nav__link">
2227 <li class=
"md-nav__item md-nav__item--nested">
2232 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_6" >
2236 <label class=
"md-nav__link" for=
"__nav_6_6" id=
"__nav_6_6_label" tabindex=
"0">
2237 From WoltLab Suite
3.0
2238 <span class=
"md-nav__icon md-icon"></span>
2241 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_6_label" aria-expanded=
"false">
2242 <label class=
"md-nav__title" for=
"__nav_6_6">
2243 <span class=
"md-nav__icon md-icon"></span>
2244 From WoltLab Suite
3.0
2246 <ul class=
"md-nav__list" data-md-scrollfix
>
2253 <li class=
"md-nav__item">
2254 <a href=
"../../wsc30/php/" class=
"md-nav__link">
2267 <li class=
"md-nav__item">
2268 <a href=
"../../wsc30/javascript/" class=
"md-nav__link">
2281 <li class=
"md-nav__item">
2282 <a href=
"../../wsc30/templates/" class=
"md-nav__link">
2295 <li class=
"md-nav__item">
2296 <a href=
"../../wsc30/css/" class=
"md-nav__link">
2309 <li class=
"md-nav__item">
2310 <a href=
"../../wsc30/package/" class=
"md-nav__link">
2333 <li class=
"md-nav__item md-nav__item--active md-nav__item--nested">
2338 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_6_7" checked
>
2342 <label class=
"md-nav__link" for=
"__nav_6_7" id=
"__nav_6_7_label" tabindex=
"0">
2344 <span class=
"md-nav__icon md-icon"></span>
2347 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_6_7_label" aria-expanded=
"true">
2348 <label class=
"md-nav__title" for=
"__nav_6_7">
2349 <span class=
"md-nav__icon md-icon"></span>
2352 <ul class=
"md-nav__list" data-md-scrollfix
>
2361 <li class=
"md-nav__item md-nav__item--active">
2363 <input class=
"md-nav__toggle md-toggle" type=
"checkbox" id=
"__toc">
2369 <label class=
"md-nav__link md-nav__link--active" for=
"__toc">
2371 <span class=
"md-nav__icon md-icon"></span>
2374 <a href=
"./" class=
"md-nav__link md-nav__link--active">
2380 <nav class=
"md-nav md-nav--secondary" aria-label=
"Table of contents">
2387 <label class=
"md-nav__title" for=
"__toc">
2388 <span class=
"md-nav__icon md-icon"></span>
2391 <ul class=
"md-nav__list" data-md-component=
"toc" data-md-scrollfix
>
2393 <li class=
"md-nav__item">
2394 <a href=
"#message-processing" class=
"md-nav__link">
2398 <nav class=
"md-nav" aria-label=
"Message Processing">
2399 <ul class=
"md-nav__list">
2401 <li class=
"md-nav__item">
2402 <a href=
"#input-processing-for-storage" class=
"md-nav__link">
2403 Input Processing for Storage
2408 <li class=
"md-nav__item">
2409 <a href=
"#embedded-objects" class=
"md-nav__link">
2415 <li class=
"md-nav__item">
2416 <a href=
"#rendering-the-message" class=
"md-nav__link">
2417 Rendering the Message
2420 <nav class=
"md-nav" aria-label=
"Rendering the Message">
2421 <ul class=
"md-nav__list">
2423 <li class=
"md-nav__item">
2424 <a href=
"#simplified-output" class=
"md-nav__link">
2430 <li class=
"md-nav__item">
2431 <a href=
"#plaintext-output" class=
"md-nav__link">
2442 <li class=
"md-nav__item">
2443 <a href=
"#rebuilding-data" class=
"md-nav__link">
2447 <nav class=
"md-nav" aria-label=
"Rebuilding Data">
2448 <ul class=
"md-nav__list">
2450 <li class=
"md-nav__item">
2451 <a href=
"#converting-from-bbcode" class=
"md-nav__link">
2452 Converting from BBCode
2457 <li class=
"md-nav__item">
2458 <a href=
"#extracting-embedded-objects" class=
"md-nav__link">
2459 Extracting Embedded Objects
2474 <li class=
"md-nav__item">
2475 <a href=
"#breadcrumbs-page-location" class=
"md-nav__link">
2476 Breadcrumbs / Page Location
2481 <li class=
"md-nav__item">
2482 <a href=
"#pages-and-forms" class=
"md-nav__link">
2488 <li class=
"md-nav__item">
2489 <a href=
"#search" class=
"md-nav__link">
2493 <nav class=
"md-nav" aria-label=
"Search">
2494 <ul class=
"md-nav__list">
2496 <li class=
"md-nav__item">
2497 <a href=
"#isearchableobjecttype" class=
"md-nav__link">
2498 ISearchableObjectType
2503 <li class=
"md-nav__item">
2504 <a href=
"#searchindexmanager" class=
"md-nav__link">
2529 <li class=
"md-nav__item">
2530 <a href=
"../templates/" class=
"md-nav__link">
2543 <li class=
"md-nav__item">
2544 <a href=
"../css/" class=
"md-nav__link">
2557 <li class=
"md-nav__item">
2558 <a href=
"../package/" class=
"md-nav__link">
2587 <li class=
"md-nav__item md-nav__item--nested">
2592 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_7" >
2596 <label class=
"md-nav__link" for=
"__nav_7" id=
"__nav_7_label" tabindex=
"0">
2598 <span class=
"md-nav__icon md-icon"></span>
2601 <nav class=
"md-nav" data-md-level=
"1" aria-labelledby=
"__nav_7_label" aria-expanded=
"false">
2602 <label class=
"md-nav__title" for=
"__nav_7">
2603 <span class=
"md-nav__icon md-icon"></span>
2606 <ul class=
"md-nav__list" data-md-scrollfix
>
2614 <li class=
"md-nav__item md-nav__item--nested">
2619 <input class=
"md-nav__toggle md-toggle " type=
"checkbox" id=
"__nav_7_1" >
2623 <label class=
"md-nav__link" for=
"__nav_7_1" id=
"__nav_7_1_label" tabindex=
"0">
2625 <span class=
"md-nav__icon md-icon"></span>
2628 <nav class=
"md-nav" data-md-level=
"2" aria-labelledby=
"__nav_7_1_label" aria-expanded=
"false">
2629 <label class=
"md-nav__title" for=
"__nav_7_1">
2630 <span class=
"md-nav__icon md-icon"></span>
2633 <ul class=
"md-nav__list" data-md-scrollfix
>
2640 <li class=
"md-nav__item">
2641 <a href=
"../../../tutorial/series/overview/" class=
"md-nav__link">
2654 <li class=
"md-nav__item">
2655 <a href=
"../../../tutorial/series/part_1/" class=
"md-nav__link">
2668 <li class=
"md-nav__item">
2669 <a href=
"../../../tutorial/series/part_2/" class=
"md-nav__link">
2682 <li class=
"md-nav__item">
2683 <a href=
"../../../tutorial/series/part_3/" class=
"md-nav__link">
2696 <li class=
"md-nav__item">
2697 <a href=
"../../../tutorial/series/part_4/" class=
"md-nav__link">
2710 <li class=
"md-nav__item">
2711 <a href=
"../../../tutorial/series/part_5/" class=
"md-nav__link">
2724 <li class=
"md-nav__item">
2725 <a href=
"../../../tutorial/series/part_6/" class=
"md-nav__link">
2754 <div class=
"md-sidebar md-sidebar--secondary" data-md-component=
"sidebar" data-md-type=
"toc" >
2755 <div class=
"md-sidebar__scrollwrap">
2756 <div class=
"md-sidebar__inner">
2759 <nav class=
"md-nav md-nav--secondary" aria-label=
"Table of contents">
2766 <label class=
"md-nav__title" for=
"__toc">
2767 <span class=
"md-nav__icon md-icon"></span>
2770 <ul class=
"md-nav__list" data-md-component=
"toc" data-md-scrollfix
>
2772 <li class=
"md-nav__item">
2773 <a href=
"#message-processing" class=
"md-nav__link">
2777 <nav class=
"md-nav" aria-label=
"Message Processing">
2778 <ul class=
"md-nav__list">
2780 <li class=
"md-nav__item">
2781 <a href=
"#input-processing-for-storage" class=
"md-nav__link">
2782 Input Processing for Storage
2787 <li class=
"md-nav__item">
2788 <a href=
"#embedded-objects" class=
"md-nav__link">
2794 <li class=
"md-nav__item">
2795 <a href=
"#rendering-the-message" class=
"md-nav__link">
2796 Rendering the Message
2799 <nav class=
"md-nav" aria-label=
"Rendering the Message">
2800 <ul class=
"md-nav__list">
2802 <li class=
"md-nav__item">
2803 <a href=
"#simplified-output" class=
"md-nav__link">
2809 <li class=
"md-nav__item">
2810 <a href=
"#plaintext-output" class=
"md-nav__link">
2821 <li class=
"md-nav__item">
2822 <a href=
"#rebuilding-data" class=
"md-nav__link">
2826 <nav class=
"md-nav" aria-label=
"Rebuilding Data">
2827 <ul class=
"md-nav__list">
2829 <li class=
"md-nav__item">
2830 <a href=
"#converting-from-bbcode" class=
"md-nav__link">
2831 Converting from BBCode
2836 <li class=
"md-nav__item">
2837 <a href=
"#extracting-embedded-objects" class=
"md-nav__link">
2838 Extracting Embedded Objects
2853 <li class=
"md-nav__item">
2854 <a href=
"#breadcrumbs-page-location" class=
"md-nav__link">
2855 Breadcrumbs / Page Location
2860 <li class=
"md-nav__item">
2861 <a href=
"#pages-and-forms" class=
"md-nav__link">
2867 <li class=
"md-nav__item">
2868 <a href=
"#search" class=
"md-nav__link">
2872 <nav class=
"md-nav" aria-label=
"Search">
2873 <ul class=
"md-nav__list">
2875 <li class=
"md-nav__item">
2876 <a href=
"#isearchableobjecttype" class=
"md-nav__link">
2877 ISearchableObjectType
2882 <li class=
"md-nav__item">
2883 <a href=
"#searchindexmanager" class=
"md-nav__link">
2903 <div class=
"md-content" data-md-component=
"content">
2904 <article class=
"md-content__inner md-typeset">
2912 <h1 id=
"wcf-21x-php">WCF
2.1.x - PHP
<a class=
"headerlink" href=
"#wcf-21x-php" title=
"Permanent link">#
</a></h1>
2913 <h2 id=
"message-processing">Message Processing
<a class=
"headerlink" href=
"#message-processing" title=
"Permanent link">#
</a></h2>
2914 <p>WoltLab Suite
3.0 finally made the transition from raw bbcode to bbcode-flavored HTML, with many new features related to message processing being added. This change impacts both message validation and storing, requiring slightly different APIs to get the job done.
</p>
2915 <h3 id=
"input-processing-for-storage">Input Processing for Storage
<a class=
"headerlink" href=
"#input-processing-for-storage" title=
"Permanent link">#
</a></h3>
2916 <p>The returned HTML is an intermediate representation with a maximum of meta data embedded into it, designed to be stored in the database. Some bbcodes are replaced during this process, for example
<code>[b]…[/b]
</code> becomes
<code><strong
>…
</strong
></code>, while others are converted into a metacode tag for later processing.
</p>
2917 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal">1</span>
2918 <span class=
"normal">2</span>
2919 <span class=
"normal">3</span>
2920 <span class=
"normal">4</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"o"><?
</span><span class=
"nx">php
</span>
2921 <span class=
"nv">$processor
</span> <span class=
"o">=
</span> <span class=
"k">new
</span> <span class=
"nx">\wcf\system\html\input\HtmlInputProcessor
</span><span class=
"p">();
</span>
2922 <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">process
</span><span class=
"p">(
</span><span class=
"nv">$message
</span><span class=
"p">,
</span> <span class=
"nv">$messageObjectType
</span><span class=
"p">,
</span> <span class=
"nv">$messageObjectID
</span><span class=
"p">);
</span>
2923 <span class=
"nv">$html
</span> <span class=
"o">=
</span> <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">getHtml
</span><span class=
"p">();
</span>
2924 </code></pre></div></td></tr></table></div>
2925 <p>The
<code>$messageObjectID
</code> can be zero if the element did not exist before, but it should be non-zero when saving an edited message.
</p>
2926 <h3 id=
"embedded-objects">Embedded Objects
<a class=
"headerlink" href=
"#embedded-objects" title=
"Permanent link">#
</a></h3>
2927 <p>Embedded objects need to be registered after saving the message, but once again you can use the processor instance to do the job.
</p>
2928 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal"> 1</span>
2929 <span class=
"normal"> 2</span>
2930 <span class=
"normal"> 3</span>
2931 <span class=
"normal"> 4</span>
2932 <span class=
"normal"> 5</span>
2933 <span class=
"normal"> 6</span>
2934 <span class=
"normal"> 7</span>
2935 <span class=
"normal"> 8</span>
2936 <span class=
"normal"> 9</span>
2937 <span class=
"normal">10</span>
2938 <span class=
"normal">11</span>
2939 <span class=
"normal">12</span>
2940 <span class=
"normal">13</span>
2941 <span class=
"normal">14</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"o"><?
</span><span class=
"nx">php
</span>
2942 <span class=
"nv">$processor
</span> <span class=
"o">=
</span> <span class=
"k">new
</span> <span class=
"nx">\wcf\system\html\input\HtmlInputProcessor
</span><span class=
"p">();
</span>
2943 <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">process
</span><span class=
"p">(
</span><span class=
"nv">$message
</span><span class=
"p">,
</span> <span class=
"nv">$messageObjectType
</span><span class=
"p">,
</span> <span class=
"nv">$messageObjectID
</span><span class=
"p">);
</span>
2944 <span class=
"nv">$html
</span> <span class=
"o">=
</span> <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">getHtml
</span><span class=
"p">();
</span>
2946 <span class=
"c1">// at this point the message is saved to database and the created object
</span>
2947 <span class=
"c1">// `$example` is a `DatabaseObject` with the id column `$exampleID`
</span>
2949 <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">setObjectID
</span><span class=
"p">(
</span><span class=
"nv">$example
</span><span class=
"o">-
></span><span class=
"na">exampleID
</span><span class=
"p">);
</span>
2950 <span class=
"k">if
</span> <span class=
"p">(
</span><span class=
"nx">\wcf\system\message\embedded\object\MessageEmbeddedObjectManager
</span><span class=
"o">::
</span><span class=
"na">getInstance
</span><span class=
"p">()
</span><span class=
"o">-
></span><span class=
"na">registerObjects
</span><span class=
"p">(
</span><span class=
"nv">$processor
</span><span class=
"p">))
</span> <span class=
"p">{
</span>
2951 <span class=
"c1">// there is at least one embedded object, this is also the point at which you
</span>
2952 <span class=
"c1">// would set `hasEmbeddedObjects` to true (if implemented by your type)
</span>
2953 <span class=
"p">(
</span><span class=
"k">new
</span> <span class=
"nx">\wcf\data\example\ExampleEditor
</span><span class=
"p">(
</span><span class=
"nv">$example
</span><span class=
"p">))
</span><span class=
"o">-
></span><span class=
"na">update
</span><span class=
"p">([
</span><span class=
"s1">'hasEmbeddedObjects
'</span> <span class=
"o">=
></span> <span class=
"mi">1</span><span class=
"p">]);
</span>
2954 <span class=
"p">}
</span>
2955 </code></pre></div></td></tr></table></div>
2956 <h3 id=
"rendering-the-message">Rendering the Message
<a class=
"headerlink" href=
"#rendering-the-message" title=
"Permanent link">#
</a></h3>
2957 <p>The output processor will parse the intermediate HTML and finalize the output for display. This step is highly dynamic and allows for bbcode evaluation and contextual output based on the viewer's permissions.
</p>
2958 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal">1</span>
2959 <span class=
"normal">2</span>
2960 <span class=
"normal">3</span>
2961 <span class=
"normal">4</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"o"><?
</span><span class=
"nx">php
</span>
2962 <span class=
"nv">$processor
</span> <span class=
"o">=
</span> <span class=
"k">new
</span> <span class=
"nx">\wcf\system\html\output\HtmlOutputProcessor
</span><span class=
"p">();
</span>
2963 <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">process
</span><span class=
"p">(
</span><span class=
"nv">$html
</span><span class=
"p">,
</span> <span class=
"nv">$messageObjectType
</span><span class=
"p">,
</span> <span class=
"nv">$messageObjectID
</span><span class=
"p">);
</span>
2964 <span class=
"nv">$renderedHtml
</span> <span class=
"o">=
</span> <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">getHtml
</span><span class=
"p">();
</span>
2965 </code></pre></div></td></tr></table></div>
2966 <h4 id=
"simplified-output">Simplified Output
<a class=
"headerlink" href=
"#simplified-output" title=
"Permanent link">#
</a></h4>
2967 <p>At some point there can be the need of a simplified output HTML that includes only basic HTML formatting and reduces more sophisticated bbcodes into a simpler representation.
</p>
2968 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal">1</span>
2969 <span class=
"normal">2</span>
2970 <span class=
"normal">3</span>
2971 <span class=
"normal">4</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"o"><?
</span><span class=
"nx">php
</span>
2972 <span class=
"nv">$processor
</span> <span class=
"o">=
</span> <span class=
"k">new
</span> <span class=
"nx">\wcf\system\html\output\HtmlOutputProcessor
</span><span class=
"p">();
</span>
2973 <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">setOutputType
</span><span class=
"p">(
</span><span class=
"s1">'text/simplified-html
'</span><span class=
"p">);
</span>
2974 <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">process
</span><span class=
"p">(
</span><span class=
"nx">…
</span><span class=
"p">);
</span>
2975 </code></pre></div></td></tr></table></div>
2976 <h4 id=
"plaintext-output">Plaintext Output
<a class=
"headerlink" href=
"#plaintext-output" title=
"Permanent link">#
</a></h4>
2977 <p>The
<code>text/plain
</code> output type will strip down the simplified HTML into pure text, suitable for text-only output such as the plaintext representation of an email.
</p>
2978 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal">1</span>
2979 <span class=
"normal">2</span>
2980 <span class=
"normal">3</span>
2981 <span class=
"normal">4</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"o"><?
</span><span class=
"nx">php
</span>
2982 <span class=
"nv">$processor
</span> <span class=
"o">=
</span> <span class=
"k">new
</span> <span class=
"nx">\wcf\system\html\output\HtmlOutputProcessor
</span><span class=
"p">();
</span>
2983 <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">setOutputType
</span><span class=
"p">(
</span><span class=
"s1">'text/plain
'</span><span class=
"p">);
</span>
2984 <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">process
</span><span class=
"p">(
</span><span class=
"nx">…
</span><span class=
"p">);
</span>
2985 </code></pre></div></td></tr></table></div>
2986 <h3 id=
"rebuilding-data">Rebuilding Data
<a class=
"headerlink" href=
"#rebuilding-data" title=
"Permanent link">#
</a></h3>
2987 <h4 id=
"converting-from-bbcode">Converting from BBCode
<a class=
"headerlink" href=
"#converting-from-bbcode" title=
"Permanent link">#
</a></h4>
2988 <div class=
"admonition warning">
2989 <p class=
"admonition-title">Enabling message conversion for HTML messages is undefined and yields unexpected results.
</p>
2991 <p>Legacy message that still use raw bbcodes must be converted to be properly parsed by the html processors. This process is enabled by setting the fourth parameter of
<code>process()
</code> to
<code>true
</code>.
</p>
2992 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal">1</span>
2993 <span class=
"normal">2</span>
2994 <span class=
"normal">3</span>
2995 <span class=
"normal">4</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"o"><?
</span><span class=
"nx">php
</span>
2996 <span class=
"nv">$processor
</span> <span class=
"o">=
</span> <span class=
"k">new
</span> <span class=
"nx">\wcf\system\html\input\HtmlInputProcessor
</span><span class=
"p">();
</span>
2997 <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">process
</span><span class=
"p">(
</span><span class=
"nv">$html
</span><span class=
"p">,
</span> <span class=
"nv">$messageObjectType
</span><span class=
"p">,
</span> <span class=
"nv">$messageObjectID
</span><span class=
"p">,
</span> <span class=
"k">true
</span><span class=
"p">);
</span>
2998 <span class=
"nv">$renderedHtml
</span> <span class=
"o">=
</span> <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">getHtml
</span><span class=
"p">();
</span>
2999 </code></pre></div></td></tr></table></div>
3000 <h4 id=
"extracting-embedded-objects">Extracting Embedded Objects
<a class=
"headerlink" href=
"#extracting-embedded-objects" title=
"Permanent link">#
</a></h4>
3001 <p>The
<code>process()
</code> method of the input processor is quite expensive, as it runs through the full message validation including the invocation of HTMLPurifier. This is perfectly fine when dealing with single messages, but when you're handling messages in bulk to extract their embedded objects, you're better of with
<code>processEmbeddedContent()
</code>. This method deconstructs the message, but skips all validation and expects the input to be perfectly valid, that is the output of a previous run of
<code>process()
</code> saved to storage.
</p>
3002 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal">1</span>
3003 <span class=
"normal">2</span>
3004 <span class=
"normal">3</span>
3005 <span class=
"normal">4</span>
3006 <span class=
"normal">5</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"o"><?
</span><span class=
"nx">php
</span>
3007 <span class=
"nv">$processor
</span> <span class=
"o">=
</span> <span class=
"k">new
</span> <span class=
"nx">\wcf\system\html\input\HtmlInputProcessor
</span><span class=
"p">();
</span>
3008 <span class=
"nv">$processor
</span><span class=
"o">-
></span><span class=
"na">processEmbeddedContent
</span><span class=
"p">(
</span><span class=
"nv">$html
</span><span class=
"p">,
</span> <span class=
"nv">$messageObjectType
</span><span class=
"p">,
</span> <span class=
"nv">$messageObjectID
</span><span class=
"p">);
</span>
3010 <span class=
"c1">// invoke `MessageEmbeddedObjectManager::registerObjects` here
</span>
3011 </code></pre></div></td></tr></table></div>
3012 <h2 id=
"breadcrumbs-page-location">Breadcrumbs / Page Location
<a class=
"headerlink" href=
"#breadcrumbs-page-location" title=
"Permanent link">#
</a></h2>
3013 <div class=
"admonition warning">
3014 <p class=
"admonition-title">Breadcrumbs used to be added left to right, but parent locations are added from the bottom to the top, starting with the first ancestor and going upwards. In most cases you simply need to reverse the order.
</p>
3016 <p>Breadcrumbs used to be a lose collection of arbitrary links, but are now represented by actual page objects and the control has shifted over to the
<code>PageLocationManager
</code>.
</p>
3017 <div class=
"highlight"><table class=
"highlighttable"><tr><td class=
"linenos"><div class=
"linenodiv"><pre><span></span><span class=
"normal">1</span>
3018 <span class=
"normal">2</span>
3019 <span class=
"normal">3</span>
3020 <span class=
"normal">4</span>
3021 <span class=
"normal">5</span>
3022 <span class=
"normal">6</span></pre></div></td><td class=
"code"><div><pre><span></span><code><span class=
"o"><?
</span><span class=
"nx">php
</span>
3023 <span class=
"c1">// before
</span>
3024 <span class=
"nx">\wcf\system\WCF
</span><span class=
"o">::
</span><span class=
"na">getBreadcrumbs
</span><span class=
"p">()
</span><span class=
"o">-
></span><span class=
"na">add
</span><span class=
"p">(
</span><span class=
"k">new
</span> <span class=
"nx">\wcf\system\breadcrumb\Breadcrumb
</span><span class=
"p">(
</span><span class=
"s1">'title
'</span><span class=
"p">,
</span> <span class=
"s1">'link
'</span><span class=
"p">));
</span>
3026 <span class=
"c1">// after
</span>
3027 <span class=
"nx">\wcf\system\page\PageLocationManager
</span><span class=
"o">::
</span><span class=
"na">getInstance
</span><span class=
"p">()
</span><span class=
"o">-
></span><span class=
"na">addParentLocation
</span><span class=
"p">(
</span><span class=
"nv">$pageIdentifier
</span><span class=
"p">,
</span> <span class=
"nv">$pageObjectID
</span><span class=
"p">,
</span> <span class=
"nv">$object
</span><span class=
"p">);
</span>
3028 </code></pre></div></td></tr></table></div>
3029 <h2 id=
"pages-and-forms">Pages and Forms
<a class=
"headerlink" href=
"#pages-and-forms" title=
"Permanent link">#
</a></h2>
3030 <p>The property
<code>$activeMenuItem
</code> has been deprecated for the front end and is no longer evaluated at runtime. Recognition of the active item is entirely based around the invoked controller class name and its definition in the page table. You need to properly
<a href=
"../../../package/pip/page/">register your pages
</a> for this feature to work.
</p>
3031 <h2 id=
"search">Search
<a class=
"headerlink" href=
"#search" title=
"Permanent link">#
</a></h2>
3032 <h3 id=
"isearchableobjecttype">ISearchableObjectType
<a class=
"headerlink" href=
"#isearchableobjecttype" title=
"Permanent link">#
</a></h3>
3033 <p>Added the
<code>setLocation()
</code> method that is used to set the current page location based on the search result.
</p>
3034 <h3 id=
"searchindexmanager">SearchIndexManager
<a class=
"headerlink" href=
"#searchindexmanager" title=
"Permanent link">#
</a></h3>
3035 <p>The methods
<code>SearchIndexManager::add()
</code> and
<code>SearchIndexManager::update()
</code> have been deprecated and forward their call to the new method
<code>SearchIndexManager::set()
</code>.
</p>
3038 <div class=
"md-source-file">
3060 <footer class=
"md-footer">
3062 <div class=
"md-footer-meta md-typeset">
3063 <div class=
"md-footer-meta__inner md-grid">
3064 <div class=
"md-copyright">
3066 <div class=
"md-copyright__highlight">
3067 Copyright ©
2020 WoltLab GmbH
3072 <a href=
"https://squidfunk.github.io/mkdocs-material/" target=
"_blank" rel=
"noopener">
3078 <div class=
"md-copyright">
3079 <a href=
"https://www.woltlab.com/legal-notice/">Legal Notice
</a>
3080 <a href=
"https://www.woltlab.com/privacy-policy/">Privacy Policy
</a>
3088 <div class=
"md-dialog" data-md-component=
"dialog">
3089 <div class=
"md-dialog__inner md-typeset"></div>
3092 <script id=
"__config" type=
"application/json">{
"base":
"../../..",
"features": [
"navigation.tracking"],
"search":
"../../../assets/javascripts/workers/search.74e28a9f.min.js",
"translations": {
"clipboard.copied":
"Copied to clipboard",
"clipboard.copy":
"Copy to clipboard",
"search.result.more.one":
"1 more on this page",
"search.result.more.other":
"# more on this page",
"search.result.none":
"No matching documents",
"search.result.one":
"1 matching document",
"search.result.other":
"# matching documents",
"search.result.placeholder":
"Type to start searching",
"search.result.term.missing":
"Missing",
"select.version":
"Select version"},
"version": {
"provider":
"mike"}}
</script>
3095 <script src=
"../../../assets/javascripts/bundle.220ee61c.min.js"></script>