18700: Merge branch 'main'
[arvados.git] / doc / api / methods / links.html.textile.liquid
1 ---
2 layout: default
3 navsection: api
4 navmenu: API Methods
5 title: "links"
6
7 ...
8 {% comment %}
9 Copyright (C) The Arvados Authors. All rights reserved.
10
11 SPDX-License-Identifier: CC-BY-SA-3.0
12 {% endcomment %}
13
14 API endpoint base: @https://{{ site.arvados_api_host }}/arvados/v1/links@
15
16 Object type: @o0j2j@
17
18 Example UUID: @zzzzz-o0j2j-0123456789abcde@
19
20 h2. Resource
21
22 Links are an extensible way to describe relationships between Arvados objects and metadata about individual objects.
23
24 Each link has, in addition to the "Common resource fields":{{site.baseurl}}/api/resources.html:
25
26 table(table table-bordered table-condensed).
27 |_. Attribute|_. Type|_. Description|
28 |head_uuid|string|The object being described or acted on.|
29 |tail_uuid|string|The origin or actor in the description or action (may be null).|
30 |link_class|string|Type of link|
31 |name|string|Primary value of the link.|
32 |properties|hash|Additional information, expressed as a key→value hash. Key: string. Value: string, number, array, or hash.  May be used in queries using "subproperty filters":{{site.baseurl}}/api/methods.html#subpropertyfilters|
33
34 h2. Link classes
35
36 Some classes are pre-defined by convention and have standard meanings attached to names.
37
38 h3. permission
39
40 See "permission links":{{site.baseurl}}/api/permission-model.html#links section of the permission model.
41
42 h3. star
43
44 A **star** link is a shortcut to a project that is displayed in the user interface (Workbench) as "favorites".  Users can mark their own favorites (implemented by creating or deleting **star** links).
45
46 An admin can also create **star** links owned by the "Public favorites" project.  These are favorites will be displayed to all users that have permission to read the project that has been favorited.
47
48 The schema for a star link is:
49
50 table(table table-bordered table-condensed).
51 |_. Field|_. Value|_. Description|
52 |owner_uuid|user or group uuid|Either the user that owns the favorite, or the "Public favorites" group.|
53 |tail_uuid|user or group uuid|Should be the same as owner_uuid|
54 |head_uuid|project uuid|The project being favorited|
55 |link_class|string of value "star"|Indicates this represents a link to a user favorite|
56
57 h4. Creating a public favorite
58
59 @owner_uuid@ is either an individual user, or the "Public favorites" group.  The @head_uuid@ is the project being favorited.
60
61 <pre>
62 $ linkuuid=$(arv --format=uuid link create --link '{
63     "link_class": "star",
64     "owner_uuid": "zzzzz-j7d0g-publicfavorites",
65     "tail_uuid": "zzzzz-j7d0g-publicfavorites",
66     "head_uuid":  "zzzzz-j7d0g-theprojectuuid"}')
67 </pre>
68
69 h4. Removing a favorite
70
71 <pre>
72 $ arv link delete --uuid zzzzz-o0j2j-thestarlinkuuid
73 </pre>
74
75 h4. Listing favorites
76
77 To list all 'star' links that will be displayed for a user:
78
79 <pre>
80 $ arv link list --filters '[
81   ["link_class", "=", "star"],
82   ["tail_uuid", "in", ["zzzzz-j7d0g-publicfavorites", "zzzzz-tpzed-currentuseruuid"]]]'
83 </pre>
84
85 h3. tag
86
87 A **tag** link describes an object using an unparsed plain text string.  Tags can be used to annotate objects that are not directly editable by the user, like collections and objects shared as read-only.
88
89 table(table table-bordered table-condensed).
90 |_. tail_type&rarr;head_type|_. name&rarr;head_uuid {properties}|
91 |&rarr;Collection           | _tag name_ &rarr; _collection uuid_|
92 |&rarr;Job                  | _tag name_ &rarr; _job uuid_|
93
94 h2. Methods
95
96 See "Common resource methods":{{site.baseurl}}/api/methods.html for more information about @create@, @delete@, @get@, @list@, and @update@.
97
98 Required arguments are displayed in %{background:#ccffcc}green%.
99
100 h3. create
101
102 Create a new Link.
103
104 Arguments:
105
106 table(table table-bordered table-condensed).
107 |_. Argument |_. Type |_. Description |_. Location |_. Example |
108 |link|object||query||
109
110 h3. delete
111
112 Delete an existing Link.
113
114 Arguments:
115
116 table(table table-bordered table-condensed).
117 |_. Argument |_. Type |_. Description |_. Location |_. Example |
118 {background:#ccffcc}.|uuid|string|The UUID of the Link in question.|path||
119
120 h3. get
121
122 Gets a Link's metadata by UUID.
123
124 Arguments:
125
126 table(table table-bordered table-condensed).
127 |_. Argument |_. Type |_. Description |_. Location |_. Example |
128 {background:#ccffcc}.|uuid|string|The UUID of the Link in question.|path||
129
130 h3. list
131
132 List links.
133
134 See "common resource list method.":{{site.baseurl}}/api/methods.html#index
135
136 h3. update
137
138 Update attributes of an existing Link.
139
140 Arguments:
141
142 table(table table-bordered table-condensed).
143 |_. Argument |_. Type |_. Description |_. Location |_. Example |
144 {background:#ccffcc}.|uuid|string|The UUID of the Link in question.|path||
145 |link|object||query||
146
147 h3. get_permissions
148
149 Get all permission links that point directly to given UUID (in the head_uuid field).  The requesting user must have @can_manage@ permission or be an admin.
150
151 Arguments:
152
153 table(table table-bordered table-condensed).
154 |_. Argument |_. Type |_. Description |_. Location |_. Example |
155 {background:#ccffcc}.|uuid|string|The UUID of the object.|path||