Advanced usage: example with Doctrine

That's not really an advanced topic, but the sample will be a bit hard to read (as it takes many files), so let's say it targets more experienced Symfony users.

In this demo, we're displaying a MyArray of MyElements, both persisted into the database. The MyArray entity only have an id and a name, and MyElement has id, MyArray's id and a value. This is quite the same as we seen in all demos, but persisted.

Array name:
Add an element...

Existing arrays:
Name Open Delete
gufc fucvuy Open Delete
name}) }} Open Delete
xv Open Delete
___ ☘ Cela fonctionne à Open Delete
___ ☘ Cela fonctionne Ã34н34н Open Delete
___ Array with Elements ... Click Open to test loading Open Delete
_____ Open Delete
____________________________1 test Open Delete
_________coucou Open Delete
_________coucou------------------ Open Delete
___%20%C3%83%C2%A2%C3%82%C2%98%C3%82%C2%98%20Cela%20fonctionne%20%C3%83 Open Delete
___%20%C3%83%C2%A2%C3%82%C2%98%C3%82%C2%98%20Cela%20fonctionne%20%C3%83%C2%A2%C3%82%C2%98%C3%82%C2%98 Open Delete
___%20%C3%A2%C2%98%C2%98%20Cela%20fonctionne%20%C3%A2 Open Delete
___%20%E2%98%98%20Cela%20fonctionne%20%E2%98%98 Open Delete
___array___ Open Delete
__bvnvbnvbnvbn Open Delete
---#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
---#i21ef661e2506d5d0e513dce166c17d49 Open Delete
---#i27992875ec4286a24e569b1e015b0473 Open Delete
---#i5784b3886628c4362594ffa43547edb4 Open Delete
---#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
---%23i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
!!!!sdsdsd Open Delete
? Open Delete
'rtrt Open Delete
" Open Delete
(SELECT (CASE WHEN (4287=3498) THEN 'kjh' ELSE (SELECT 3498 UNION SELECT 3037) END)) Open Delete
&&&&&&&&&&& Open Delete
#1 Open Delete
#69 Open Delete
#91 Open Delete
#AlgoSucks Open Delete
#timowashere Open Delete
%2372 Open Delete
%2372uuuuokokok Open Delete
%25237233333 Open Delete
%25237233333#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
%25237233333#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
%25237233333#i5784b3886628c4362594ffa43547edb4 Open Delete
%25237233333#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
%25237233333#ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
%252372uuuu#i21ef661e2506d5d0e513dce166c17d49 Open Delete
%252372uuuu#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
%252372uuuu#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
%2525237233333%23i27992875ec4286a24e569b1e015b0473 Open Delete
%2525237233333%23ie025efbbb0738ed01a63b326c174233e Open Delete
%25252372uuuu Open Delete
%25252372uuuu%23i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
%25253F%23i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
%25253F%23i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
%253F Open Delete
%253F#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
%253F#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
%253F#i21ef661e2506d5d0e513dce166c17d49 Open Delete
%253F#i27992875ec4286a24e569b1e015b0473 Open Delete
%253F#i5784b3886628c4362594ffa43547edb4 Open Delete
%25C3%2583%25C2%25B1lkjlkj Open Delete
%25C3%25B1sfkjaldsa Open Delete
%27 Open Delete
%28orph%C3%A9e%29 Open Delete
%28SELECT%20%28CASE%20WHEN%20%283158=3158%29%20THEN%20%27kjh%27%20ELSE%20%28SELECT%201437%20UNION%20SELECT%202166%29%20END%29%29 Open Delete
%28SELECT%20%28CASE%20WHEN%20%284626=9556%29%20THEN%20%27kjh%27%20ELSE%20%28SELECT%209556%20UNION%20SELECT%209237%29%20END%29%29 Open Delete
%3C%3Fphp%20echo%20%27%20i%20don%27t%20like%20it%20%27 Open Delete
%C3%83%C2%83%C3%82%C2%B1sfkjaldsa Open Delete
%C3%83%C2%B1sf Open Delete
%C3%A2%C2%98%C2%98%20Cela%20fonctionne%20%C3%A2%C2%98%C2%98 Open Delete
%C3%B1lkjlkj Open Delete
%C3%B1sfkjaldsa Open Delete
%D1%80%D0%BE%D0%BB%D1%80 Open Delete
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<LETTRE GREC>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> Open Delete
<script>alert('test')</script> Open Delete
<script>alert('test')</script>%n%n%n%n%n%n Open Delete
<script>alert('test')</script>%n%n%n%n%n%n<script>alert('test')</script>%n%n%n%n%n%n<script>alert('test')</script>%n%n%n%n%n%n<script>alert('test')</script>%n%n%n%n%n%n<script>alert('test')</script>%n%n%n%n%n%n<script>alert('test')</script>%n%n%n%n%n%n<sc Open Delete
00000 Open Delete
000tom Open Delete
001122334455 Open Delete
01233 Open Delete
1 Open Delete
10 Open Delete
11#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
11#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
11#ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
11#ie025efbbb0738ed01a63b326c174233e Open Delete
11%23i5784b3886628c4362594ffa43547edb4 Open Delete
1111 Open Delete
1111#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
1111#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
1111#i21ef661e2506d5d0e513dce166c17d49 Open Delete
1111#i27992875ec4286a24e569b1e015b0473 Open Delete
1111#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
1111111111111111111111111111111111#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
1111111111111111111111111111111111#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
1111111111111111111111111111111111#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
1111111111111111111111111111111111#ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
1111111111111111111111111111111111%23i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
1111111111111111111111111111111111%23ie025efbbb0738ed01a63b326c174233e Open Delete
1121 Open Delete
121113 Open Delete
12345 Open Delete
1525 Open Delete
1aa Open Delete
1Alpha Open Delete
2%27 Open Delete
222 Open Delete
2222%20example Open Delete
2222%252520example Open Delete
2344234 Open Delete
32jnni Open Delete
454 Open Delete
5 Open Delete
5454 Open Delete
63 Open Delete
78 Open Delete
8 Open Delete
86787 Open Delete
888 Open Delete
99 Open Delete
999 Open Delete
a Lorenz Open Delete
a%20Lorenz Open Delete
ñlkjlkj Open Delete
ñsf Open Delete
ñsfkjaldsa Open Delete
☘ Cela fonctionne ☘ Open Delete
A1 Open Delete
ñlkjlkj Open Delete
ñlkjlkj Open Delete
ñsfkjaldsa Open Delete
aaaaaa Open Delete
aaaaaaaaaaaaa Open Delete
aaaaaaaaaaaaaa Open Delete
aaaaaaaaaaaaaaaaaaaaaaaaaa Open Delete
AAAAAEER Open Delete
тест Open Delete
aaamine Open Delete
aaamine22222#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
aaamine22222#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
aaamine22222#ie025efbbb0738ed01a63b326c174233e Open Delete
aaamine22222%23i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
aaamine22222%23ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
aarzarzample Open Delete
adfadf Open Delete
adfadf'A=0 Open Delete
adfadf%27A=0 Open Delete
adsada Open Delete
aee Open Delete
AlgoSucks Open Delete
any Open Delete
Array Open Delete
array%20new Open Delete
arrayGilmry Open Delete
articulo Open Delete
asd Open Delete
asda Open Delete
asdasd#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
asdasd#i27992875ec4286a24e569b1e015b0473 Open Delete
asdasd#i5784b3886628c4362594ffa43547edb4 Open Delete
asdasd#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
asdasd#ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
asdasd#ie025efbbb0738ed01a63b326c174233e Open Delete
asdasd%23i5784b3886628c4362594ffa43547edb4 Open Delete
asdasdadasd Open Delete
asdasdadasd#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
asdasdadasd#i21ef661e2506d5d0e513dce166c17d49 Open Delete
asdasdadasd#i5784b3886628c4362594ffa43547edb4 Open Delete
asdasdadasd#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
asdasdadasd#ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
asdasdadasd#ie025efbbb0738ed01a63b326c174233e Open Delete
asdfasdfasd Open Delete
az Open Delete
balala Open Delete
bbbbbbbbbbb Open Delete
bc Delete
bcvbcvb Open Delete
bjfhj#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
bjfhj#i21ef661e2506d5d0e513dce166c17d49 Open Delete
bjfhj#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
bjfhj#ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
bjfhj#ie025efbbb0738ed01a63b326c174233e Open Delete
bjfhj%23i27992875ec4286a24e569b1e015b0473 Open Delete
blah Open Delete
blah#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
blah#i21ef661e2506d5d0e513dce166c17d49 Open Delete
blah%23i21ef661e2506d5d0e513dce166c17d49 Open Delete
blah%23i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
caca Open Delete
cccio Open Delete
cdcdc Open Delete
Cela fonctionne Open Delete
Cela fonctionne pas Open Delete
Cmucik Open Delete
cnes Open Delete
cool Open Delete
crap Open Delete
cups Open Delete
Cuves Open Delete
cvSDFSD Open Delete
cx%3Cwc Open Delete
D#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
D#i21ef661e2506d5d0e513dce166c17d49 Open Delete
D#i5784b3886628c4362594ffa43547edb4 Open Delete
D#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
D#ie025efbbb0738ed01a63b326c174233e Open Delete
D%23i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
dadd Open Delete
dasf Open Delete
dd Open Delete
ddd Open Delete
ddddd Open Delete
delete_empty Open Delete
Demo Open Delete
dfa#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
dfa#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
dfa#i5784b3886628c4362594ffa43547edb4 Open Delete
dfa#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
dfa#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
dfa#ie025efbbb0738ed01a63b326c174233e Open Delete
dfa%23ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
dfdfdf Open Delete
dfdt Open Delete
dfty Open Delete
dfzre Open Delete
dgh Open Delete
dsadsadd Open Delete
dsd Open Delete
dsdfgsdfgdf Open Delete
dsds Open Delete
dsvfdsfg%255D Open Delete
eaze Open Delete
ee Open Delete
ejemplo 2 Open Delete
ejemplo 2017 Open Delete
ejemplo 2017-11-23 Open Delete
ejemplo%202017 Open Delete
erwgfu%25C4%25B1gj8hl%25C4%25B1 Open Delete
erwgfu%C4%B1gj8hl%C4%B1 Open Delete
erwgfuıgj8hlı Open Delete
erwgfuıgj8hlı Open Delete
ewe Open Delete
example Open Delete
example Radu Open Delete
example+exam Open Delete
example123 Open Delete
example123#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
example123#i5784b3886628c4362594ffa43547edb4 Open Delete
example123#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
example123%23i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
example123%23ie025efbbb0738ed01a63b326c174233e Open Delete
example33333 Open Delete
exampleasdas Open Delete
exampleasfsafasf Open Delete
exampleasfsafasf#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
exampleasfsafasf#i5784b3886628c4362594ffa43547edb4 Open Delete
exampleasfsafasf#ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
exampleasfsafasf#ie025efbbb0738ed01a63b326c174233e Open Delete
exampleaz Open Delete
exampledsdsdd Open Delete
examplee Open Delete
examplemmm Open Delete
examplenhnhd Open Delete
exampleqqqq Open Delete
exampleqzd Open Delete
examplertyrtyrty Open Delete
examplesafsaf Open Delete
examplesafsafsfsf Open Delete
examplesdsd Open Delete
exampless Open Delete
examplevbnvnhv Open Delete
examplexzasca Open Delete
examqdqsple Open Delete
exdedededdedeeample Open Delete
Existing arr Open Delete
Existing%20arrays: Open Delete
exkiample Open Delete
fasdfasf Open Delete
fdasfdaF Open Delete
fdf#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
fdf#i21ef661e2506d5d0e513dce166c17d49 Open Delete
fdf#i5784b3886628c4362594ffa43547edb4 Open Delete
fdf#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
fdf#ie025efbbb0738ed01a63b326c174233e Open Delete
fdf%23i5784b3886628c4362594ffa43547edb4 Open Delete
fdf%23ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
fdg Open Delete
fdgfdgfdgfdgfd Open Delete
fe Open Delete
ff Open Delete
ff%20d Open Delete
fff Open Delete
ffsss Open Delete
fg Open Delete
fgdfg Open Delete
fgdfgfg Open Delete
fgfdg Open Delete
fghjkl Open Delete
fgjgh Open Delete
frfrf Open Delete
fsgv Open Delete
fuck Open Delete
fuck%20you Open Delete
fuck%2520you Open Delete
gdfg#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
gdfg%23ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
gg Open Delete
gg%27A=0 Open Delete
ghfhgfg Open Delete
ghgtytyt Open Delete
ghjk#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
ghjk#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
ghjk#i21ef661e2506d5d0e513dce166c17d49 Open Delete
ghjk#i5784b3886628c4362594ffa43547edb4 Open Delete
ghjk#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
ghjk#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
gjkl Open Delete
Group%252BC Open Delete
Group%2BC#i21ef661e2506d5d0e513dce166c17d49 Open Delete
Group%2BC#i5784b3886628c4362594ffa43547edb4 Open Delete
Group%2BC#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
Group%2BC#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
hello Open Delete
hellowrld Open Delete
HEYY :D Open Delete
HEYY%20:D Open Delete
HEYY%2520:D Open Delete
HEYY%2520:D#i27992875ec4286a24e569b1e015b0473 Open Delete
HEYY%2520:D#i5784b3886628c4362594ffa43547edb4 Open Delete
HEYY%2520:D#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
HEYY%252520:D%23ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
hgkjh Open Delete
hhh Open Delete
hikj Open Delete
hjh Open Delete
hjvhj Open Delete
hoho Open Delete
hrthrh Open Delete
htrhrh Open Delete
i Open Delete
ilesh Open Delete
itemList2 Open Delete
iuy Open Delete
iziokisio Open Delete
jbnn Open Delete
jghjghjgj Open Delete
jhkl Open Delete
jk Open Delete
jkbhkjh Open Delete
jkjk Open Delete
jose Open Delete
julio Open Delete
khj Open Delete
khj#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
khj#i21ef661e2506d5d0e513dce166c17d49 Open Delete
khj#i27992875ec4286a24e569b1e015b0473 Open Delete
khj#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
khj%23ie025efbbb0738ed01a63b326c174233e Open Delete
kj Open Delete
kjh Open Delete
kjh AND 1091=5857 Open Delete
kjh AND 2060=2060 Open Delete
kjh AND 4281=2310-- NRaM Open Delete
kjh AND 5825=4111 Open Delete
kjh AND 6275=3623-- Gjwd Open Delete
kjh AND 7954=(SELECT UPPER(XMLType(CHR(60)||CHR(58)||CHR(113)||CHR(122)||CHR(107)||CHR(120)||CHR(113)||(SELECT (CASE WHEN (7954=7954) THEN 1 ELSE 0 END) FROM DUAL)||CHR(113)||CHR(106)||CHR(107)||CHR(122)||CHR(113)||CHR(62))) FROM DUAL) Open Delete
kjh AND 9650=6116 Open Delete
kjh AND EXTRACTVALUE(7241,CONCAT(0x5c,0x717a6b7871,(SELECT (ELT(7241=7241,1))),0x716a6b7a71))-- fAHu Open Delete
kjh ORDER BY 1-- PNBN Open Delete
kjh' AND 5727=1498 AND 'nmqQ'='nmqQ Open Delete
kjh' AND 7954=(SELECT UPPER(XMLType(CHR(60)||CHR(58)||CHR(113)||CHR(122)||CHR(107)||CHR(120)||CHR(113)||(SELECT (CASE WHEN (7954=7954) THEN 1 ELSE 0 END) FRO Open Delete
kjh' AND 7954=(SELECT UPPER(XMLType(CHR(60)||CHR(58)||CHR(113)||CHR(122)||CHR(107)||CHR(120)||CHR(113)||(SELECT (CASE WHEN (7954=7954) THEN 1 ELSE 0 END) FROM DUAL)||CHR(113)||CHR(106)||CHR(107)||CHR(122)||CHR(113)||CHR(62))) FROM DUAL) AND 'HwZm'='HwZm Open Delete
kjh' AND 8611=(SELECT UPPER(XMLType(CHR(60)||CHR(58)||CHR(113)||CHR(106)||CHR(106)||CHR(118)||CHR(113)||(SELECT (CASE WHEN (8611=8611) THEN 1 ELSE 0 END) FROM DUAL)||CHR(113)||CHR(113)||CHR(122)||CHR(120)||CHR(113)||CHR(62))) FROM DUAL) AND 'QXBI'='QXBI Open Delete
kjh' AND 9667 IN (SELECT (CHAR(113)+CHAR(122)+CHAR(107)+CHAR(120)+CHAR(113)+(SELECT (CASE WHEN (9667=9667) THEN CHAR(49) ELSE CHAR(48) END))+CHAR(113)+CHAR(106)+CHAR(107)+CHAR(122)+CHAR(113))) AND 'mDsE'='mDsE Open Delete
kjh') AND 2060=2060 AND ('JwAk'='JwAk Open Delete
kjh') AND 3055=4968 AND ('igun'='igun Open Delete
kjh') AND 6285=CAST((CHR(113)||CHR(106)||CHR(106)||CHR(118)||CHR(113))||(SELECT (CASE WHEN (6285=6285) THEN 1 ELSE 0 END))::text||(CHR(113)||CHR(113)||CHR(122)||CHR(120)||CHR(113)) AS NUMERIC) AND ('bnAs'='bnAs Open Delete
kjh') AND 9667 IN (SELECT (CHAR(113)+CHAR(122)+CHAR(107)+CHAR(120)+CHAR(113)+(SELECT (CASE WHEN (9667=9667) THEN CHAR(49) ELSE CHAR(48) END))+CHAR(113)+CHAR(106)+CHAR(107)+CHAR(122)+CHAR(113))) AND ('ixOS'='ixOS Open Delete
kjh'vKJjiT<'">dxPGFb Open Delete
kjh"'(,),().( Open Delete
kjh) AND 3637=2334 AND (3292=3292 Open Delete
kjh) AND 7390 IN (SELECT (CHAR(113)+CHAR(106)+CHAR(106)+CHAR(118)+CHAR(113)+(SELECT (CASE WHEN (7390=7390) THEN CHAR(49) ELSE CHAR(48) END))+CHAR(113)+CHAR(113)+CHAR(122)+CHAR(120)+CHAR(113))) AND (2379=2379 Open Delete
kjh) AND EXTRACTVALUE(7241 Open Delete
kjh%20AND%20EXTRACTVALUE%287241,CONCAT%280x5c,0x717a6b7871,%28SELECT%20%28ELT%287241=7241,1%29%29%29,0x716a6b7a71%29%29 Open Delete
kjh%27%20AND%207954=%28SELECT%20UPPER%28XMLType%28CHR%2860%29%7C%7CCHR%2858%29%7C%7CCHR%28113%29%7C%7CCHR%28122%29%7C%7CCHR%28107%29%7C%7CCHR%28120%29%7C%7CCHR%28113%29%7C%7C%28SELECT%20%28CASE%20WHEN%20%287954=7954%29%20THEN%201%20ELSE%200%20END%29%20FRO Open Delete
kjh%27%20AND%208611=%28SELECT%20UPPER%28XMLType%28CHR%2860%29%7C%7CCHR%2858%29%7C%7CCHR%28113%29%7C%7CCHR%28106%29%7C%7CCHR%28106%29%7C%7CCHR%28118%29%7C%7CCHR%28113%29%7C%7C%28SELECT%20%28CASE%20WHEN%20%288611=8611%29%20THEN%201%20ELSE%200%20END%29%20FRO Open Delete
kjh%27%29%20AND%203055=4968%20AND%20%28%27igun%27=%27igun Open Delete
kjh%27%29%20AND%207390%20IN%20%28SELECT%20%28CHAR%28113%29+CHAR%28106%29+CHAR%28106%29+CHAR%28118%29+CHAR%28113%29+%28SELECT%20%28CASE%20WHEN%20%287390=7390%29%20THEN%20CHAR%2849%29%20ELSE%20CHAR%2848%29%20END%29%29+CHAR%28113%29+CHAR%28113%29+CHAR%28122% Open Delete
kjh%27%29%20AND%20EXTRACTVALUE%287241,CONCAT%280x5c,0x717a6b7871,%28SELECT%20%28ELT%287241=7241,1%29%29%29,0x716a6b7a71%29%29%20AND%20%28%27oZSA%27=%27oZSA Open Delete
kjh%27FIFazt%3C%27%22%3EkJJxrd Open Delete
kjh%29%20AND%209930=6330%20AND%20%289057=9057 Open Delete
kkik Open Delete
kkk#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
kkk#i21ef661e2506d5d0e513dce166c17d49 Open Delete
kkk#i27992875ec4286a24e569b1e015b0473 Open Delete
kkk#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
kkk#ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
kkk%23ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
kkk%23ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
klk Open Delete
kmkm Open Delete
kpok Open Delete
kpok%C3%82%C2%B4p Open Delete
kpok´p Open Delete
kpok´p Open Delete
l Open Delete
lel Open Delete
lj Open Delete
lkjlkj Open Delete
lkk Open Delete
ll Open Delete
lmklk Open Delete
lol Open Delete
Lorenz du Open Delete
Lorenz du stinker Open Delete
mardi Open Delete
mec Open Delete
mkmkmk Open Delete
moiGHOY - Resources/views/Advanced/doctrine-them Open Delete
mon%20exemple Open Delete
mon%20putain%20de%20tableau Open Delete
mon%20tableau Open Delete
Mumbojumbo Open Delete
my_array Open Delete
myarr Open Delete
mytest Open Delete
Names Open Delete
nbnv Open Delete
New_test_2017- Open Delete
New_test_2017-03_03 Open Delete
New%20Array Open Delete
new%20test Open Delete
New%2520Array Open Delete
ñlkjlkj Open Delete
nmn Open Delete
nmn#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
nmn#i21ef661e2506d5d0e513dce166c17d49 Open Delete
nmn#i27992875ec4286a24e569b1e015b0473 Open Delete
nmn%23ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
nnnnn Open Delete
ñsfkjaldsa Open Delete
Numeros de prueba Open Delete
o%25C4%25B1 Open Delete
o%C3%84%C2%B1 Open Delete
oı Open Delete
Ouiiiiiiiiiiii Open Delete
Ouiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii Open Delete
Ouiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii Open Delete
ouiou Open Delete
perebetes Open Delete
perses#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
perses#i5784b3886628c4362594ffa43547edb4 Open Delete
perses#ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
perses#ie025efbbb0738ed01a63b326c174233e Open Delete
perses%23i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
perses%23ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
perses%23ie025efbbb0738ed01a63b326c174233e Open Delete
po Open Delete
polo Open Delete
pp Open Delete
pppppii Open Delete
pppppii#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
pppppii#i21ef661e2506d5d0e513dce166c17d49 Open Delete
pppppii#i27992875ec4286a24e569b1e015b0473 Open Delete
pppppii%23ie025efbbb0738ed01a63b326c174233e Open Delete
pppppp Open Delete
prabu Open Delete
Premier element de test Open Delete
Product Open Delete
project 1 Open Delete
project%201 Open Delete
punto%202 Open Delete
qe Open Delete
qqq Open Delete
qsdfqsdf Open Delete
quantite --1 Open Delete
qwe Open Delete
qwerqwerqw Open Delete
qwert Open Delete
qwery Open Delete
rar Open Delete
rdfgdf Open Delete
rerererere Open Delete
resr Open Delete
rrrr#i21ef661e2506d5d0e513dce166c17d49 Open Delete
rrrr#ie025efbbb0738ed01a63b326c174233e Open Delete
rrrr%23i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
rrrr%23i5784b3886628c4362594ffa43547edb4 Open Delete
rtyr Open Delete
ryhre Open Delete
sa Open Delete
saASD Open Delete
sad.asdasd.sdsad Open Delete
sample Open Delete
samples Open Delete
sasa Open Delete
scyx Open Delete
sdfsdfsd Open Delete
sdg Open Delete
sdsd Open Delete
SED Open Delete
seeme Open Delete
seeme#i21ef661e2506d5d0e513dce166c17d49 Open Delete
seeme#i5784b3886628c4362594ffa43547edb4 Open Delete
seeme#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
seeme#ie025efbbb0738ed01a63b326c174233e Open Delete
seeme%23ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
seqtest Open Delete
sf Open Delete
sfdf Open Delete
sfsa Open Delete
some new array Open Delete
someNewArray Open Delete
someNewArray#i21ef661e2506d5d0e513dce166c17d49 Open Delete
someNewArray#i27992875ec4286a24e569b1e015b0473 Open Delete
someNewArray#i5784b3886628c4362594ffa43547edb4 Open Delete
someNewArray#i8c18088ea4d8dd4d6e5e986bceed35da Open Delete
someNewArray#ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
someNewArray#ie025efbbb0738ed01a63b326c174233e Open Delete
ssssssssssssss Open Delete
Starojitski Open Delete
STASI Open Delete
Stringkey Open Delete
suck%20my%20cock%20fgts Open Delete
t11 Open Delete
Ta mere la grosse choin Open Delete
Ta%20mere%20la%20grosse%20tchoin Open Delete
Ta%2520mere%2520la%2520grosse%2520choin#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
Ta%2520mere%2520la%2520grosse%2520choin#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
Ta%2520mere%2520la%2520grosse%2520choin#i27992875ec4286a24e569b1e015b0473 Open Delete
Ta%2520mere%2520la%2520grosse%2520choin#ibcac9f4c58199eeaa7ba5c7750b8434b Open Delete
Ta%2520mere%2520la%2520grosse%2520choin#ie025efbbb0738ed01a63b326c174233e Open Delete
tableau cellule unique Open Delete
tableau%20cellule%20unique Open Delete
Telous Open Delete
tesr Open Delete
tesss Open Delete
TEST Open Delete
test array Open Delete
test nours Open Delete
test--1 Open Delete
test%20array Open Delete
Test2 Open Delete
test22 Open Delete
TEST912 Open Delete
teste2 Open Delete
Tester Open Delete
testN17 Open Delete
testname Open Delete
testsetse Open Delete
testtest Open Delete
tet Open Delete
the test Open Delete
thhtrh Open Delete
this%20is%20an Open Delete
timo Open Delete
toti Open Delete
tre Open Delete
tryy5 Open Delete
tyrtyrtr Open Delete
tyrtyrtrhgfhgfhg Open Delete
tzzttz Open Delete
ui Open Delete
ukh Open Delete
uu Open Delete
Vai que da Open Delete
vcvcvcvcvv Open Delete
vdsvd Open Delete
vffv Open Delete
Volta Dilma Fora Temer Open Delete
Volta Dilma Fora% Open Delete
Volta%2 Open Delete
Volta%20Dilma%20Fo Open Delete
Volta%2520Dilma%2520Fora% Open Delete
Volta%2520Dilma%2520Fora%2520Temer Open Delete
Volta%2520Dilma%2520Fora%2520Temer#i1097c8b84b58a65ed6ec7b4f0da3ab67 Open Delete
Volta%2520Dilma%2520Fora%2520Temer#i1dcd1cbb0d8eeb1fd3a32dc2aa9c8013 Open Delete
Volta%2520Dilma%2520Fora%2520Temer#i2 Open Delete
Volta%2520Dilma%2520Fora%2520Temer#i21ef661e2506d5d0e513dce16 Open Delete
Volta%2520Dilma%2520Fora%2520Temer#ic3ee8978c60737ab5d058b5a3f6a1b09 Open Delete
Volta%252520Dilma%252520Fora%25 Open Delete
Volta+Dilma+Fo Open Delete
Volta+Dilma+Fora+Temer Open Delete
VRE Open Delete
vv Open Delete
werweexample Open Delete
why%20doctrine%20on%20delete%20not%20work%3F Open Delete
Woop wooop Open Delete
Woop% Open Delete
wxc%3Cwxc Open Delete
wxc<wxc Open Delete
xx Open Delete
xy Open Delete
xzcvxcv Open Delete
You Open Delete
yy Open Delete
yytutyutyu Open Delete
zdzd Open Delete
тест Open Delete
File: Base/BaseController.php
<?php

namespace Fuz\AppBundle\Base;

use Fuz\AppBundle\Entity\Value;
use Fuz\AppBundle\Form\ValueType;
use Fuz\QuickStartBundle\Base\BaseController as QuickStartBase;
use Symfony\Component\Form\Extension\Core\Type;
use Symfony\Component\HttpFoundation\Request;

class BaseController extends QuickStartBase
{
    protected function createContextSample(Request $request, $name = 'form', $values = ['a', 'b', 'c'])
    {
        $data = ['values' => $values];

        $form = $this
           ->get('form.factory')
           ->createNamedBuilder($name, Type\FormType::class, $data)
           ->add('values', Type\CollectionType::class, [
               'entry_type'    => Type\TextType::class,
               'label'         => 'Add, move, remove values and press Submit.',
               'entry_options' => [
                   'label' => 'Value',
               ],
               'allow_add'    => true,
               'allow_delete' => true,
               'prototype'    => true,
               'attr'         => [
                   'class' => "{$name}-collection",
               ],
           ])
           ->add('submit', Type\SubmitType::class)
           ->getForm()
        ;

        $form->handleRequest($request);
        if ($form->isValid()) {
            $data = $form->getData();
        }

        return [
            $name         => $form->createView(),
            "{$name}Data" => $data,
        ];
    }

    protected function createAdvancedContextSample(Request $request, $name = 'advancedForm')
    {
        $a = new Value('a');
        $b = new Value('b');
        $c = new Value('c');

        $data = ['values' => [$a, $b, $c]];

        $form = $this
           ->get('form.factory')
           ->createNamedBuilder($name, Type\FormType::class, $data)
           ->add('values', Type\CollectionType::class, [
               'entry_type'   => ValueType::class,
               'label'        => 'Add, move, remove values and press Submit.',
               'allow_add'    => true,
               'allow_delete' => true,
               'prototype'    => true,
               'required'     => false,
               'attr'         => [
                   'class' => "{$name}-collection",
               ],
           ])
           ->add('submit', Type\SubmitType::class)
           ->getForm()
        ;

        $form->handleRequest($request);
        if ($form->isValid()) {
            $data = $form->getData();
        }

        return [
            $name         => $form->createView(),
            "{$name}Data" => $data,
        ];
    }
}
File: Base/BaseController.php
File: Controller/AdvancedController.php
<?php

namespace Fuz\AppBundle\Controller;

use Fuz\AppBundle\Base\BaseController;
use Fuz\AppBundle\Entity\Address;
use Fuz\AppBundle\Entity\Addresses;
use Fuz\AppBundle\Entity\Fancy;
use Fuz\AppBundle\Entity\FancyCollection;
use Fuz\AppBundle\Entity\Value;
use Fuz\AppBundle\Form\AddressesType;
use Fuz\AppBundle\Form\FancyCollectionType;
use Fuz\AppBundle\Form\MyArrayType;
use Fuz\AppBundle\Form\ValueType;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
use Symfony\Component\Form\Extension\Core\Type;
use Symfony\Component\HttpFoundation\Request;

/**
 * @Route("/advanced")
 */
class AdvancedController extends BaseController
{
    /**
     * Advanced usage
     *
     * You can reference your form collection in the view, instead of
     * putting a selector in the form type.
     *
     * @Route("/mvcCompliance", name="mvcCompliance")
     * @Template()
     */
    public function mvcComplianceAction(Request $request)
    {
        $data = ['values' => ['a', 'b', 'c']];

        $form = $this
           ->createFormBuilder($data)
           ->add('values', Type\CollectionType::class, [
               'entry_type'    => Type\TextType::class,
               'label'         => 'Add, move, remove values and press Submit.',
               'entry_options' => [
                   'label' => 'Value',
               ],
               'allow_add'    => true,
               'allow_delete' => true,
               'prototype'    => true,
               'required'     => false,
//                   'attr' => array (
//                           'class' => 'my-selector', <--- Not MVC compliant!
//                   ),
           ])
           ->add('submit', Type\SubmitType::class)
           ->getForm()
        ;

        $form->handleRequest($request);
        if ($form->isValid()) {
            $data = $form->getData();
        }

        return [
            'form' => $form->createView(),
            'data' => $data,
        ];
    }

    /**
     * Advanced usage
     *
     * A custom form theme helps define button's layout and positions as and where you want.
     *
     * @Route("/customFormTheme", name="customFormTheme")
     * @Template()
     */
    public function customFormThemeAction(Request $request)
    {
        $data = ['values' => [new Value('a'), new Value('b'), new Value('c')]];

        $form = $this
           ->createFormBuilder($data)
           ->add('values', Type\CollectionType::class, [
               'entry_type'   => ValueType::class,
               'label'        => 'Add, move, remove values and press Submit.',
               'allow_add'    => true,
               'allow_delete' => true,
               'prototype'    => true,
               'required'     => false,
               'attr'         => [
                   'class' => 'collection',
               ],
           ])
           ->add('submit', Type\SubmitType::class)
           ->getForm()
        ;

        $form->handleRequest($request);
        if ($form->isValid()) {
            $data = $form->getData();
        }

        return [
            'form' => $form->createView(),
            'data' => $data,
        ];
    }

    /**
     * Advanced usage
     *
     * Same demo as above, but with the add button located at the bottom of
     * the form instead of close to each field.
     *
     * @Route("/customFormThemeAddBottom", name="customFormThemeAddBottom")
     * @Template()
     */
    public function customFormThemeAddBottomAction(Request $request)
    {
        return $this->customFormThemeAction($request);
    }

    /**
     * Advanced usage
     *
     * Collection of collections are useful on the most dynamic forms, and a good
     * way to test if the plugin is working as expected too.
     *
     * @Route("/collectionOfCollections", name="collectionOfCollections")
     * @Template()
     */
    public function collectionOfCollectionsAction(Request $request)
    {
        $data = [
            'collections' => [
                [new Value('a'), new Value('b'), new Value('c')],
                [new Value('d'), new Value('e'), new Value('f')],
                [new Value('g'), new Value('h'), new Value('i')],
            ],
        ];

        $form = $this
           ->get('form.factory')
           ->createNamedBuilder('form', Type\FormType::class, $data)
           ->add('collections', Type\CollectionType::class, [
               'entry_type'    => Type\CollectionType::class,
               'label'         => 'Add, move, remove collections',
               'entry_options' => [
                   'entry_type'    => ValueType::class,
                   'label'         => 'Add, move, remove values',
                   'entry_options' => [
                       'label' => 'Value',
                   ],
                   'allow_add'      => true,
                   'allow_delete'   => true,
                   'prototype'      => true,
                   'prototype_name' => '__children_name__',
                   'attr'           => [
                       'class' => 'child-collection',
                   ],
               ],
               'allow_add'      => true,
               'allow_delete'   => true,
               'prototype'      => true,
               'prototype_name' => '__parent_name__',
               'attr'           => [
                   'class' => 'parent-collection',
               ],
           ])
           ->add('submit', Type\SubmitType::class)
           ->getForm()
        ;

        $form->handleRequest($request);
        if ($form->isValid()) {
            $data = $form->getData();
        }

        return [
            'form' => $form->createView(),
            'data' => $data,
        ];
    }

    /**
     * Advanced usage
     *
     * Looks like there are weird behaviours with Doctrine:
     * https://github.com/ninsuo/symfony-collection/issues/7
     * Let's test that live!
     *
     * ... hmm, doesn't look bad anyway
     *
     * @Route(
     *      "/usageWithDoctrine/{name}",
     *      name = "usageWithDoctrine",
     *      defaults = {
     *          "name" = "example"
     *      }
     * )
     * @Template()
     */
    public function usageWithDoctrineAction(Request $request, $name)
    {
        $repo = $this->getDoctrine()->getRepository('FuzAppBundle:MyArray');

        $data = $repo->findOneByName($name);
        if (is_null($data)) {
            $data = $repo->create($name);
        }

        $form = $this->createForm(MyArrayType::class, $data);
        $form->handleRequest($request);

        $form->get('save')->isClicked() && $form->isValid() && $repo->save($data);

        return [
            'names' => $repo->getArrayNames(),
            'form'  => $form->createView(),
            'data'  => $data,
        ];
    }

    /**
     * Related to usageWithDoctrine demo
     *
     * @Route(
     *      "/usageWithDoctrineDelete/{name}",
     *      name = "usageWithDoctrineDelete"
     * )
     */
    public function usageWithDoctrineDeleteAction(Request $request, $name)
    {
        $repo = $this->getDoctrine()->getRepository('FuzAppBundle:MyArray');
        if (!is_null($data = $repo->findOneByName($name))) {
            $repo->delete($data);
        }

        return $this->forward('FuzAppBundle:Advanced:usageWithDoctrine', [
            'name' => 'example',
        ]);
    }

    /**
     * A form having a theme and containing several fields
     *
     * @Route(
     *      "/formHavingSeveralFields",
     *      name = "formHavingSeveralFields"
     * )
     * @Template()
     */
    public function formHavingSeveralFieldsAction(Request $request)
    {
        $address = new Address();
        $address->setName('Mickael Steller');
        $address->setCompany('fuz.org');
        $address->setStreet('41 rue de la Paix');
        $address->setPostalcode('75002');
        $address->setCity('Paris');
        $address->setCountry('France');

        $addresses = new Addresses();
        $addresses->getAddresses()->add($address);

        $form = $this->createForm(AddressesType::class, $addresses);
        if ($request->isMethod('POST')) {
            $form->handleRequest($request);
        }

        return [
            'form' => $form->createView(),
            'data' => $addresses,
        ];
    }

    /**
     * Another example of form theme
     *
     * @Route(
     *      "/fancyFormTheme",
     *      name = "fancyFormTheme"
     * )
     * @Template()
     */
    public function fancyFormThemeAction(Request $request)
    {
        $fancyCollection = new FancyCollection();

        for ($i = 0; $i < 3; $i++) {
            $fancy = new Fancy();
            $fancyCollection->getFancyCollection()->add($fancy);
        }

        $form = $this->createForm(FancyCollectionType::class, $fancyCollection);

        $form->handleRequest($request);
        if ($form->isValid()) {
            $data = $form->getData();
        }

        return [
            'form' => $form->createView(),
            'data' => $fancyCollection,
        ];
    }
}
File: Controller/AdvancedController.php
File: Entity/MyArray.php
<?php

namespace Fuz\AppBundle\Entity;

use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\ORM\Mapping as ORM;

/**
 * MyArray
 *
 * @ORM\Table(
 *      name="my_array",
 *      uniqueConstraints={@ORM\UniqueConstraint(name="name_idx", columns={"name"})}
 * )
 * @ORM\Entity(repositoryClass="Fuz\AppBundle\Repository\MyArrayRepository")
 */
class MyArray
{
    /**
     * @var int
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    /**
     * @var string
     *
     * @ORM\Column(name="name", type="string", length=255)
     */
    protected $name;

    /**
     * @var ArrayCollection
     *
     * @ORM\OneToMany(targetEntity="MyElement", mappedBy="array", cascade={"all"}, orphanRemoval=true)
     */
    protected $elements;

    public function __construct()
    {
        $this->elements = new ArrayCollection();
    }

    public function getId()
    {
        return $this->id;
    }

    public function getName()
    {
        return $this->name;
    }

    public function setName($name)
    {
        $this->name = $name;

        return $this;
    }

    public function getElements()
    {
        return $this->elements;
    }
}
File: Entity/MyArray.php
File: Entity/MyElement.php
<?php

namespace Fuz\AppBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
 * MyElement
 *
 * @ORM\Table(name="my_element"),
 * @ORM\Entity
 */
class MyElement
{
    /**
     * @var int
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    /**
     * @var MyArray
     *
     * @ORM\ManyToOne(targetEntity="MyArray", inversedBy="elements")
     * @ORM\JoinColumn(name="my_array_id", referencedColumnName="id")
     */
    protected $array;

    /**
     * @var string
     *
     * @ORM\Column(name="value", type="string", length=255)
     */
    protected $value;

    public function setId($id)
    {
        $this->id = $id;

        return $this;
    }

    public function getId()
    {
        return $this->id;
    }

    public function setArray(MyArray $array)
    {
        $this->array = $array;

        return $this;
    }

    public function getArray()
    {
        return $this->array;
    }

    public function setValue($value)
    {
        $this->value = $value;

        return $this;
    }

    public function getValue()
    {
        return $this->value;
    }
}
File: Entity/MyElement.php
File: Form/MyArrayType.php
<?php

namespace Fuz\AppBundle\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\Extension\Core\Type\CollectionType;
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;

class MyArrayType extends AbstractType
{
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder->add('name', TextType::class, [
                'label' => 'Array name:',
        ]);

        $builder->add('elements', CollectionType::class, [
            'label'        => 'Add an element...',
            'entry_type'   => MyElementType::class,
            'allow_add'    => true,
            'allow_delete' => true,
            'prototype'    => true,
            'required'     => false,
            'by_reference' => true,
            'delete_empty' => true,
            'attr'         => [
                'class' => 'doctrine-sample',
            ],
        ]);

        $builder->add('save', SubmitType::class, [
                'label' => 'Save this array',
        ]);
    }

    public function configureOptions(OptionsResolver $resolver)
    {
        $resolver->setDefaults([
            'data_class' => 'Fuz\AppBundle\Entity\MyArray',
        ]);
    }

    public function getBlockPrefix()
    {
        return 'my_array';
    }
}
File: Form/MyArrayType.php
File: Form/MyElementType.php
<?php

namespace Fuz\AppBundle\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;

class MyElementType extends AbstractType
{
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder->add('value', TextType::class, [
            'required' => false,
        ]);
    }

    public function configureOptions(OptionsResolver $resolver)
    {
        $resolver->setDefaults([
            'data_class' => 'Fuz\AppBundle\Entity\MyElement',
        ]);
    }

    public function getBlockPrefix()
    {
        return 'my_element';
    }
}
File: Form/MyElementType.php
File: Repository/MyArrayRepository.php
<?php

namespace Fuz\AppBundle\Repository;

use Doctrine\DBAL\Exception\UniqueConstraintViolationException;
use Doctrine\ORM\EntityRepository;
use Fuz\AppBundle\Entity\MyArray;

/**
 * MyArrayRepository.
 */
class MyArrayRepository extends EntityRepository
{
    public function create($name)
    {
        $data = new MyArray();
        $data->setName($name);
        try {
            $this->_em->persist($data);
            $this->_em->flush();
        } catch (UniqueConstraintViolationException $e) {
            return null;
        }

        return $data;
    }

    public function save(MyArray $data)
    {
        foreach ($data->getElements() as $element) {
            $element->setArray($data);
        }
        try {
            $this->_em->persist($data);
            $this->_em->flush();
        } catch (UniqueConstraintViolationException $e) {
            return null;
        }

        return $data;
    }

    public function getArrayNames()
    {
        $arrays = $this
            ->_em
            ->createQuery("
               SELECT arr.name
               FROM Fuz\AppBundle\Entity\MyArray arr
            ")
            ->execute();
        $names = [];
        foreach ($arrays as $array) {
            $names[] = $array['name'];
        }

        return $names;
    }

    public function delete(MyArray $data)
    {
        foreach ($data->getElements() as $element) {
            $this->_em->remove($element);
        }
        $this->_em->remove($data);
        $this->_em->flush();
    }
}
File: Repository/MyArrayRepository.php
File: Resources/views/Advanced/doctrine-theme.html.twig

{% block my_element_label %}{% endblock %}
{% block my_element_errors %}{% endblock %}

{% block my_element_widget %}

    <div class="row">
        <div class="col-md-7">
            {{ form_widget(form.value) }}
        </div>
        <div class="col-md-2">
            <a href="#" class="collection-up btn btn-default">Up</a>
            <a href="#" class="collection-down btn btn-default">Down</a>
        </div>
        <div class="col-md-2">
            <a href="#" class="collection-remove btn btn-default">Remove</a>
            <a href="#" class="collection-add btn btn-default">Add</a>
        </div>
        <div class="col-md-1">
            <a href="#" class="collection-duplicate btn btn-default">Duplicate</a>
        </div>
    </div>

{% endblock %}
File: Resources/views/Advanced/doctrine-theme.html.twig
File: Resources/views/Advanced/usageWithDoctrine.html.twig
{% extends 'FuzAppBundle::layout.html.twig' %}

{% block extra_js %}
    <script src="{{ asset('js/jquery.collection.js') }}"></script>
{% endblock %}

{% block title %}Advanced usage: example with Doctrine{% endblock %}

{% block body %}

    <h2>{{ block('title') }}</h2>

    <p>
        That's not really an <i>advanced</i> topic, but the sample will be a bit hard to read (as it takes many files),
        so let's say it targets more experienced Symfony users.
    </p>

    <p>
        In this demo, we're displaying a MyArray of MyElements, both persisted into the database. The MyArray entity
        only have an id and a name, and MyElement has id, MyArray's id and a value. This is quite the same as we seen
        in all demos, but persisted.
    </p>

    <div class="text-center">
        <input type="button" id="new" class="btn btn-default" value="Create new array"/>
    </div>

    {%
        form_theme form
            'jquery.collection.html.twig'
            'FuzAppBundle:Advanced:doctrine-theme.html.twig'
    %}
    {{ form(form) }}

    <hr/>

    {% if names|length %}
        Existing arrays:
        <table class="table">
            <thead>
                <th>Name</th>
                <th>Open</th>
                <th>Delete</th>
            </thead>
            <tbody>
                {% for name in names %}
                    <tr>
                        <td>{{ name }}</td>
                        <td>
                            {% if data.name != name %}<a href="{{ path('usageWithDoctrine', {'name': name}) }}">Open</a>{% endif %}
                        </td>
                        <td><a href="{{ path('usageWithDoctrineDelete', {'name': name}) }}">Delete</a></td>
                    </tr>
                {% endfor %}
            </tbody>
        </table>
    {% endif %}

    {{
        tabs([
            'Base/BaseController.php',
            'Controller/AdvancedController.php',
            'Resources/views/Advanced/usageWithDoctrine.html.twig',
            'Resources/views/Advanced/doctrine-theme.html.twig',
            'Entity/MyArray.php',
            'Form/MyArrayType.php',
            'Entity/MyElement.php',
            'Form/MyElementType.php',
            'Repository/MyArrayRepository.php',
        ])
    }}

{% endblock %}

{% block script %}

    <script type="text/javascript">

        // only useful for the "new" button...
        $('#new').on('click', function() {
           var name = prompt("Which name would you like to use?");
           if (name) {
               var uri = '{{ path('usageWithDoctrine', {'name': 'a'}) }}';
               document.location = uri.substr(0, uri.length - 1) + encodeURIComponent(name);
           }
        });

        $('.doctrine-sample').collection();

    </script>

{% endblock %}
File: Resources/views/Advanced/usageWithDoctrine.html.twig