1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
|
<?php
/**
* SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
* SPDX-FileCopyrightText: 2016 ownCloud, Inc.
* SPDX-License-Identifier: AGPL-3.0-only
*/
// use OCP namespace for all classes that are considered public.
// This means that they should be used by apps instead of the internal Nextcloud classes
namespace OCP;
use OC\Tags;
/**
* Class for easily tagging objects by their id
*
* A tag can be e.g. 'Family', 'Work', 'Chore', 'Special Occation' or
* anything else that is either parsed from a vobject or that the user chooses
* to add.
* Tag names are not case-sensitive, but will be saved with the case they
* are entered in. If a user already has a tag 'family' for a type, and
* tries to add a tag named 'Family' it will be silently ignored.
* @since 6.0.0
*/
interface ITags {
/**
* @since 19.0.0
*/
public const TAG_FAVORITE = '_$!<Favorite>!$_';
/**
* Check if any tags are saved for this type and user.
* @since 6.0.0
*/
public function isEmpty(): bool;
/**
* Returns an array mapping a given tag's properties to its values:
* ['id' => 0, 'name' = 'Tag', 'owner' = 'User', 'type' => 'tagtype']
*
* @param string $id The ID of the tag that is going to be mapped
* @return array|false
* @since 8.0.0
*/
public function getTag(string $id);
/**
* Get the tags for a specific user.
*
* This returns an array with id/name maps:
*
* ```php
* [
* ['id' => 0, 'name' = 'First tag'],
* ['id' => 1, 'name' = 'Second tag'],
* ]
* ```
*
* @return array<array-key, array{id: int, name: string}>
* @since 6.0.0
*/
public function getTags(): array;
/**
* Get a list of tags for the given item ids.
*
* This returns an array with object id / tag names:
*
* ```php
* [
* 1 => array('First tag', 'Second tag'),
* 2 => array('Second tag'),
* 3 => array('Second tag', 'Third tag'),
* ]
* ```
*
* @param list<int> $objIds item ids
* @return array<int, list<string>>|false with object id as key and an array
* of tag names as value or false if an error occurred
* @since 8.0.0
*/
public function getTagsForObjects(array $objIds);
/**
* Get a list of items tagged with $tag.
*
* Throws an exception if the tag could not be found.
*
* @param string|integer $tag Tag id or name.
* @return array|false An array of object ids or false on error.
* @since 6.0.0
*/
public function getIdsForTag($tag);
/**
* Checks whether a tag is already saved.
*
* @param string $name The name to check for.
* @since 6.0.0
*/
public function hasTag(string $name): bool;
/**
* Checks whether a tag is saved for the given user,
* disregarding the ones shared with them.
*
* @param string $name The tag name to check for.
* @param string $user The user whose tags are to be checked.
* @return bool
* @since 8.0.0
*/
public function userHasTag(string $name, string $user): bool;
/**
* Add a new tag.
*
* @param string $name A string with a name of the tag
* @return int|false the id of the added tag or false if it already exists.
* @since 6.0.0
*/
public function add(string $name);
/**
* Rename tag.
*
* @param string|integer $from The name or ID of the existing tag
* @param string $to The new name of the tag.
* @return bool
* @since 6.0.0
*/
public function rename($from, string $to): bool;
/**
* Add a list of new tags.
*
* @param string|string[] $names A string with a name or an array of strings containing
* the name(s) of the to add.
* @param bool $sync When true, save the tags
* @param int|null $id int Optional object id to add to this|these tag(s)
* @return bool Returns false on error.
* @since 6.0.0
*/
public function addMultiple($names, bool $sync = false, ?int $id = null): bool;
/**
* Delete tag/object relations from the db
*
* @param array $ids The ids of the objects
* @return boolean Returns false on error.
* @since 6.0.0
*/
public function purgeObjects(array $ids);
/**
* Get favorites for an object type
*
* @return array|false An array of object ids.
* @since 6.0.0
*/
public function getFavorites();
/**
* Add an object to favorites
*
* @param int $objid The id of the object
* @return boolean
* @since 6.0.0
*/
public function addToFavorites($objid);
/**
* Remove an object from favorites
*
* @param int $objid The id of the object
* @return boolean
* @since 6.0.0
*/
public function removeFromFavorites($objid);
/**
* Creates a tag/object relation.
*
* @param int $objid The id of the object
* @param string $tag The id or name of the tag
* @return boolean Returns false on database error.
* @since 6.0.0
*/
public function tagAs($objid, $tag);
/**
* Delete single tag/object relation from the db
*
* @param int $objid The id of the object
* @param string $tag The id or name of the tag
* @return boolean
* @since 6.0.0
*/
public function unTag($objid, $tag);
/**
* Delete tags from the database
*
* @param string[]|integer[] $names An array of tags (names or IDs) to delete
* @return bool Returns false on error
* @since 6.0.0
*/
public function delete($names);
}
|