3 namespace Friendica\Repository;
5 use Friendica\BaseModel;
6 use Friendica\BaseRepository;
7 use Friendica\Collection;
8 use Friendica\Database\Database;
11 use Friendica\Util\DateTimeFormat;
12 use Psr\Log\LoggerInterface;
14 class ProfileField extends BaseRepository
16 protected static $table_name = 'profile_field';
18 protected static $model_class = Model\ProfileField::class;
20 protected static $collection_class = Collection\ProfileFields::class;
22 /** @var PermissionSet */
23 private $permissionSet;
25 public function __construct(Database $dba, LoggerInterface $logger, PermissionSet $permissionSet)
27 parent::__construct($dba, $logger);
29 $this->permissionSet = $permissionSet;
34 * @return Model\ProfileField
36 protected function create(array $data)
38 return new Model\ProfileField($this->dba, $this->logger, $this->permissionSet, $data);
42 * @param array $condition
43 * @return Model\ProfileField
44 * @throws \Friendica\Network\HTTPException\NotFoundException
46 public function selectFirst(array $condition)
48 return parent::selectFirst($condition);
52 * @param array $condition
53 * @param array $params
54 * @return Collection\ProfileFields
57 public function select(array $condition = [], array $params = [])
59 return parent::select($condition, $params);
63 * @param array $condition
64 * @param array $params
65 * @param int|null $max_id
66 * @param int|null $since_id
68 * @return Collection\ProfileFields
71 public function selectByBoundaries(array $condition = [], array $params = [], int $max_id = null, int $since_id = null, int $limit = self::LIMIT)
73 return parent::selectByBoundaries($condition, $params, $max_id, $since_id, $limit);
77 * @param int $uid Field owner user Id
78 * @return Collection\ProfileFields
81 public function selectByUserId(int $uid)
85 ['order' => ['order']]
90 * Retrieve all custom profile field a given contact is able to access to, including public profile fields.
92 * @param int $cid Private contact id, must be owned by $uid
93 * @param int $uid Field owner user id
94 * @return Collection\ProfileFields
97 public function selectByContactId(int $cid, int $uid)
99 $permissionSets = $this->permissionSet->selectByContactId($cid, $uid);
101 $psids = $permissionSets->column('id');
103 // Includes public custom fields
106 return $this->select(
107 ['uid' => $uid, 'psid' => $psids],
108 ['order' => ['order']]
113 * @param array $fields
114 * @return Model\ProfileField|bool
117 public function insert(array $fields)
119 $fields['created'] = DateTimeFormat::utcNow();
120 $fields['edited'] = DateTimeFormat::utcNow();
122 return parent::insert($fields);
126 * @param Model\ProfileField $model
130 public function update(BaseModel $model)
132 $model->edited = DateTimeFormat::utcNow();
134 return parent::update($model);
138 * @param int $uid User Id
139 * @param Collection\ProfileFields $profileFields Collection of existing profile fields
140 * @param array $profileFieldInputs Array of profile field form inputs indexed by profile field id
141 * @param array $profileFieldOrder List of profile field id in order
142 * @return Collection\ProfileFields
145 public function updateCollectionFromForm(int $uid, Collection\ProfileFields $profileFields, array $profileFieldInputs, array $profileFieldOrder)
147 $aclFormatter = DI::aclFormatter();
149 // Returns an associative array of id => order values
150 $profileFieldOrder = array_flip($profileFieldOrder);
152 // Creation of the new field
153 if (!empty($profileFieldInputs['new']['label'])) {
154 $psid = $this->permissionSet->getIdFromACL(
156 $aclFormatter->toString($profileFieldInputs['new']['contact_allow'] ?? ''),
157 $aclFormatter->toString($profileFieldInputs['new']['group_allow'] ?? ''),
158 $aclFormatter->toString($profileFieldInputs['new']['contact_deny'] ?? ''),
159 $aclFormatter->toString($profileFieldInputs['new']['group_deny'] ?? '')
162 $newProfileField = $this->insert([
164 'label' => $profileFieldInputs['new']['label'],
165 'value' => $profileFieldInputs['new']['value'],
167 'order' => $profileFieldOrder['new'],
170 $profileFieldInputs[$newProfileField->id] = $profileFieldInputs['new'];
171 $profileFieldOrder[$newProfileField->id] = $profileFieldOrder['new'];
173 $profileFields[] = $newProfileField;
176 unset($profileFieldInputs['new']);
177 unset($profileFieldOrder['new']);
179 // Prunes profile field whose label has been emptied
180 $profileFields = $profileFields->filter(function (Model\ProfileField $profileField) use (&$profileFieldInputs, &$profileFieldOrder) {
181 $keepModel = !isset($profileFieldInputs[$profileField->id]) || !empty($profileFieldInputs[$profileField->id]['label']);
184 unset($profileFieldInputs[$profileField->id]);
185 unset($profileFieldOrder[$profileField->id]);
186 $this->delete($profileField);
192 // Regenerates the order values if items were deleted
193 $profileFieldOrder = array_flip(array_keys($profileFieldOrder));
195 // Update existing profile fields from form values
196 $profileFields = $profileFields->map(function (Model\ProfileField $profileField) use ($uid, $aclFormatter, &$profileFieldInputs, &$profileFieldOrder) {
197 if (isset($profileFieldInputs[$profileField->id]) && isset($profileFieldOrder[$profileField->id])) {
198 $psid = $this->permissionSet->getIdFromACL(
200 $aclFormatter->toString($profileFieldInputs[$profileField->id]['contact_allow'] ?? ''),
201 $aclFormatter->toString($profileFieldInputs[$profileField->id]['group_allow'] ?? ''),
202 $aclFormatter->toString($profileFieldInputs[$profileField->id]['contact_deny'] ?? ''),
203 $aclFormatter->toString($profileFieldInputs[$profileField->id]['group_deny'] ?? '')
206 $profileField->psid = $psid;
207 $profileField->label = $profileFieldInputs[$profileField->id]['label'];
208 $profileField->value = $profileFieldInputs[$profileField->id]['value'];
209 $profileField->order = $profileFieldOrder[$profileField->id];
211 unset($profileFieldInputs[$profileField->id]);
212 unset($profileFieldOrder[$profileField->id]);
215 return $profileField;
218 return $profileFields;