1 | <?php |
||
19 | >>>>>>> Safe files to partial submissions |
||
20 | use SilverStripe\UserForms\Model\EditableFormField; |
||
21 | use SilverStripe\View\Requirements; |
||
22 | |||
23 | /** |
||
24 | * Class PartialUserFormController |
||
25 | * @package Firesphere\PartialUserforms\Controllers |
||
26 | */ |
||
27 | class PartialUserFormController extends ContentController |
||
28 | { |
||
29 | /** |
||
30 | * Session key name |
||
31 | */ |
||
32 | const SESSION_KEY = 'PartialSubmissionID'; |
||
33 | |||
34 | /** |
||
35 | * @var array |
||
36 | */ |
||
37 | private static $url_handlers = [ |
||
38 | 'save' => 'savePartialSubmission', |
||
39 | '$Key/$Token' => 'partial', |
||
40 | ]; |
||
41 | |||
42 | /** |
||
43 | * @var array |
||
44 | */ |
||
45 | private static $allowed_actions = [ |
||
46 | 'savePartialSubmission', |
||
47 | 'partial', |
||
48 | ]; |
||
49 | |||
50 | /** |
||
51 | * @param HTTPRequest $request |
||
52 | * @return int|mixed|void |
||
53 | * @throws ValidationException |
||
54 | * @throws \SilverStripe\Control\HTTPResponse_Exception |
||
55 | */ |
||
56 | public function savePartialSubmission(HTTPRequest $request) |
||
57 | { |
||
58 | if (!$request->isPOST()) { |
||
59 | return $this->httpError(404); |
||
60 | } |
||
61 | |||
62 | $postVars = $request->postVars(); |
||
63 | $editableField = null; |
||
64 | |||
65 | // We don't want SecurityID and/or the process Action stored as a thing |
||
66 | unset($postVars['SecurityID'], $postVars['action_process']); |
||
67 | $submissionID = $request->getSession()->get(self::SESSION_KEY); |
||
68 | |||
69 | /** @var PartialFormSubmission $partialSubmission */ |
||
70 | $partialSubmission = PartialFormSubmission::get()->byID($submissionID); |
||
71 | |||
72 | if (!$submissionID || !$partialSubmission) { |
||
73 | $partialSubmission = PartialFormSubmission::create(); |
||
74 | $submissionID = $partialSubmission->write(); |
||
75 | } |
||
76 | $request->getSession()->set(self::SESSION_KEY, $submissionID); |
||
77 | foreach ($postVars as $field => $value) { |
||
78 | /** @var EditableFormField $editableField */ |
||
79 | $editableField = $this->createOrUpdateSubmission([ |
||
80 | 'Name' => $field, |
||
81 | 'Value' => $value, |
||
82 | 'SubmittedFormID' => $submissionID |
||
83 | ]); |
||
84 | } |
||
85 | |||
86 | if ($editableField instanceof EditableFormField && !$partialSubmission->UserDefinedFormID) { |
||
87 | $partialSubmission->update([ |
||
88 | 'UserDefinedFormID' => $editableField->Parent()->ID, |
||
89 | 'ParentID' => $editableField->Parent()->ID, |
||
90 | 'ParentClass' => $editableField->Parent()->ClassName, |
||
91 | 'UserDefinedFormClass' => $editableField->Parent()->ClassName |
||
92 | ]); |
||
93 | $partialSubmission->write(); |
||
94 | } |
||
95 | |||
96 | return $submissionID; |
||
97 | } |
||
98 | |||
99 | /** |
||
100 | * @param $formData |
||
101 | * @return DataObject|EditableFormField |
||
102 | * @throws ValidationException |
||
103 | */ |
||
104 | protected function createOrUpdateSubmission($formData) |
||
105 | { |
||
106 | $filter = [ |
||
107 | 'Name' => $formData['Name'], |
||
108 | 'SubmittedFormID' => $formData['SubmittedFormID'], |
||
109 | ]; |
||
110 | |||
111 | // Set the title |
||
112 | /** @var EditableFormField $editableField */ |
||
113 | $editableField = EditableFormField::get()->filter(['Name' => $formData['Name']])->first(); |
||
114 | if ($editableField instanceof EditableFormField\EditableFileField) { |
||
115 | $this->savePartialFile($formData, $filter, $editableField); |
||
116 | } elseif ($editableField instanceof EditableFormField) { |
||
117 | $this->savePartialField($formData, $filter, $editableField); |
||
118 | } |
||
119 | |||
120 | // Return the ParentID to link the PartialSubmission to it's proper thingy |
||
121 | return $editableField; |
||
122 | } |
||
123 | |||
124 | /** |
||
125 | * @param $formData |
||
126 | * @param array $filter |
||
127 | * @param EditableFormField\EditableFileField $editableField |
||
128 | * @throws ValidationException |
||
129 | * @throws \Exception |
||
130 | */ |
||
131 | protected function savePartialFile($formData, array $filter, EditableFormField\EditableFileField $editableField) |
||
132 | { |
||
133 | $partialFileSubmission = PartialFileFieldSubmission::get()->filter($filter)->first(); |
||
134 | $partialData = []; |
||
135 | // Don't overwrite existing uploads |
||
136 | if (!$partialFileSubmission) { |
||
137 | if ($editableField) { |
||
138 | $partialData['Title'] = $editableField->Title; |
||
139 | $partialData['ParentClass'] = $editableField->Parent()->ClassName; |
||
140 | } |
||
141 | } |
||
142 | if (is_array($formData['Value']) && !$partialFileSubmission->UploadedFileID) { |
||
143 | $file = $this->uploadFile($partialData, $editableField); |
||
144 | $formData['UploadedFileID'] = $file->ID ?? 0; |
||
145 | $partialFileSubmission = PartialFileFieldSubmission::create($partialData); |
||
146 | } |
||
147 | $partialFileSubmission->write(); |
||
148 | } |
||
149 | |||
150 | /** |
||
151 | * @param $formData |
||
152 | * @param array $filter |
||
153 | * @param EditableFormField $editableField |
||
154 | * @throws ValidationException |
||
155 | */ |
||
156 | protected function savePartialField($formData, array $filter, EditableFormField $editableField) |
||
157 | { |
||
158 | $exists = PartialFieldSubmission::get()->filter($filter)->first(); |
||
159 | if (is_array($formData['Value'])) { |
||
160 | $formData['Value'] = implode(', ', $formData['Value']); |
||
161 | } |
||
162 | if ($editableField) { |
||
163 | $formData['Title'] = $editableField->Title; |
||
164 | $formData['ParentClass'] = $editableField->Parent()->ClassName; |
||
165 | } |
||
166 | if (!$exists) { |
||
167 | $exists = PartialFieldSubmission::create($formData); |
||
168 | } else { |
||
169 | $exists->update($formData); |
||
170 | } |
||
248 |