1 | <?php |
||
33 | class PartialFormSubmission extends SubmittedForm |
||
34 | { |
||
35 | private static $table_name = 'PartialFormSubmission'; |
||
|
|||
36 | |||
37 | /** |
||
38 | * @var array |
||
39 | */ |
||
40 | private static $db = [ |
||
41 | 'IsSend' => 'Boolean(false)', |
||
42 | 'TokenSalt' => 'Varchar(16)', |
||
43 | 'Token' => 'Varchar(16)', |
||
44 | 'Password' => 'Varchar(64)', |
||
45 | ]; |
||
46 | |||
47 | /** |
||
48 | * @var array |
||
49 | */ |
||
50 | private static $has_one = [ |
||
51 | 'UserDefinedForm' => DataObject::class |
||
52 | ]; |
||
53 | |||
54 | /** |
||
55 | * @var array |
||
56 | */ |
||
57 | private static $has_many = [ |
||
58 | 'PartialFields' => PartialFieldSubmission::class |
||
59 | ]; |
||
60 | |||
61 | private static $cascade_deletes = [ |
||
62 | 'PartialFields' |
||
63 | ]; |
||
64 | |||
65 | /** |
||
66 | * @var array |
||
67 | */ |
||
68 | private static $summary_fields = [ |
||
69 | 'ID' => 'ID', |
||
70 | 'PartialLink' => 'Link', |
||
71 | 'Created' => 'Created', |
||
72 | 'LastEdited' => 'Last Edited', |
||
73 | ]; |
||
74 | |||
75 | private static $special_characters = [ |
||
76 | '!', |
||
77 | '@', |
||
78 | '#', |
||
79 | '$', |
||
80 | '%', |
||
81 | '^', |
||
82 | '&', |
||
83 | '*', |
||
84 | '(', |
||
85 | ')', |
||
86 | '_', |
||
87 | '-', |
||
88 | '=', |
||
89 | '+', |
||
90 | ';', |
||
91 | ':', |
||
92 | ',', |
||
93 | '.', |
||
94 | '?' |
||
95 | ]; |
||
96 | |||
97 | /** |
||
98 | * @return FieldList |
||
99 | * @throws \Exception |
||
100 | */ |
||
101 | public function getCMSFields() |
||
102 | { |
||
103 | /** @var FieldList $fields */ |
||
104 | $fields = parent::getCMSFields(); |
||
105 | $fields->removeByName( |
||
106 | [ |
||
107 | 'Values', |
||
108 | 'IsSend', |
||
109 | 'PartialFields', |
||
110 | 'TokenSalt', |
||
111 | 'Token', |
||
112 | 'UserDefinedFormID', |
||
113 | 'Submitter', |
||
114 | 'Password' |
||
115 | ] |
||
116 | ); |
||
117 | |||
118 | $partialFields = GridField::create( |
||
119 | 'PartialFields', |
||
120 | _t(static::class . '.PARTIALFIELDS', 'Partial fields'), |
||
121 | $this->PartialFields()->sort('Created', 'ASC') |
||
122 | ); |
||
123 | |||
124 | $exportColumns = [ |
||
125 | 'Title' => 'Title', |
||
126 | 'ExportValue' => 'Value' |
||
127 | ]; |
||
128 | |||
129 | $config = new GridFieldConfig(); |
||
130 | $config->addComponent(new GridFieldDataColumns()); |
||
131 | $config->addComponent(new GridFieldButtonRow('after')); |
||
132 | $config->addComponent(new GridFieldExportButton('buttons-after-left', $exportColumns)); |
||
133 | $config->addComponent(new GridFieldPrintButton('buttons-after-left')); |
||
134 | $partialFields->setConfig($config); |
||
135 | |||
136 | $fields->addFieldsToTab( |
||
137 | 'Root.Main', |
||
138 | [ |
||
139 | ReadonlyField::create('ReadonlyPartialLink', 'Partial Link', $this->getPartialLink()), |
||
140 | $partialFields |
||
141 | ] |
||
142 | ); |
||
143 | |||
144 | return $fields; |
||
145 | } |
||
146 | |||
147 | /** |
||
148 | * @return DataObject|UserDefinedForm |
||
149 | */ |
||
150 | public function getParent() |
||
151 | { |
||
152 | return $this->UserDefinedForm(); |
||
153 | } |
||
154 | |||
155 | /** |
||
156 | * Generate the partial tokens |
||
157 | * If the submission is password protected, generate a password. |
||
158 | * @throws \Exception |
||
159 | */ |
||
160 | public function onBeforeWrite() |
||
161 | { |
||
162 | parent::onBeforeWrite(); |
||
163 | $this->getPartialToken(); |
||
164 | $this->generatePassword(); |
||
165 | } |
||
166 | |||
167 | /** |
||
168 | * @param Member |
||
169 | * |
||
170 | * @return boolean|string |
||
171 | */ |
||
172 | public function canCreate($member = null, $context = []) |
||
173 | { |
||
174 | return false; |
||
175 | } |
||
176 | |||
177 | /** |
||
178 | * @param Member |
||
179 | * |
||
180 | * @return boolean|string |
||
181 | */ |
||
182 | public function canView($member = null) |
||
183 | { |
||
184 | if ($this->UserDefinedForm()) { |
||
185 | return $this->UserDefinedForm()->canView($member); |
||
186 | } |
||
187 | |||
188 | return parent::canView($member); |
||
189 | } |
||
190 | |||
191 | /** |
||
192 | * @param Member |
||
193 | * |
||
194 | * @return boolean|string |
||
195 | */ |
||
196 | public function canEdit($member = null) |
||
197 | { |
||
198 | if ($this->UserDefinedForm()) { |
||
199 | return $this->UserDefinedForm()->canEdit($member); |
||
200 | } |
||
201 | |||
202 | return parent::canEdit($member); |
||
203 | } |
||
204 | |||
205 | /** |
||
206 | * @param Member |
||
207 | * |
||
208 | * @return boolean|string |
||
209 | */ |
||
210 | public function canDelete($member = null) |
||
211 | { |
||
212 | if ($this->UserDefinedForm()) { |
||
213 | return $this->UserDefinedForm()->canDelete($member); |
||
214 | } |
||
215 | |||
216 | return parent::canDelete($member); |
||
217 | } |
||
218 | |||
219 | /** |
||
220 | * Get the share link of the form |
||
221 | * |
||
222 | * @return string |
||
223 | * @throws \Exception |
||
224 | */ |
||
225 | public function getPartialLink() |
||
226 | { |
||
227 | if (!$this->isInDB()) { |
||
228 | return '(none)'; |
||
229 | } |
||
230 | |||
231 | $token = $this->Token; |
||
232 | |||
233 | return Controller::join_links( |
||
234 | Director::absoluteBaseURL(), |
||
235 | 'partial', |
||
236 | $this->generateKey($token), |
||
237 | $token |
||
238 | ); |
||
239 | } |
||
240 | |||
241 | /** |
||
242 | * Get the unique token for the share link |
||
243 | * |
||
244 | * @return bool|string|null |
||
245 | * @throws \Exception |
||
246 | */ |
||
247 | protected function getPartialToken() |
||
248 | { |
||
249 | if (!$this->TokenSalt) { |
||
250 | $this->TokenSalt = $this->generateToken(); |
||
251 | $this->Token = $this->generateToken(); |
||
252 | } |
||
253 | |||
254 | return $this->Token; |
||
255 | } |
||
256 | |||
257 | /** |
||
258 | * Generate a new token |
||
259 | * |
||
260 | * @return bool|string |
||
261 | * @throws \Exception |
||
262 | */ |
||
263 | protected function generateToken() |
||
269 | |||
270 | /** |
||
271 | * Generate a key based on the share token salt |
||
272 | * |
||
273 | * @param string $token |
||
274 | * @return mixed |
||
275 | */ |
||
276 | public function generateKey($token) |
||
280 | |||
281 | /** |
||
282 | * @return void |
||
283 | */ |
||
284 | protected function generatePassword() |
||
285 | { |
||
286 | if (!$this->Password && |
||
287 | $this->getParent() && |
||
288 | $this->getParent()->PasswordProtected |
||
289 | ) { |
||
300 | } |
||
301 |