File: copy-collection-items.rst

package info (click to toggle)
debusine 0.14.4
  • links: PTS, VCS
  • area: main
  • in suites: forky
  • size: 15,344 kB
  • sloc: python: 198,722; sh: 850; javascript: 335; makefile: 117
file content (49 lines) | stat: -rw-r--r-- 2,354 bytes parent folder | download | duplicates (4)
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
.. task:: CopyCollectionItems

CopyCollectionItems task
------------------------

This server task copies items into given target collections, which may or
may not be in the same workspace as the original items.  It returns an error
if:

* the user/workflow that created the task does not have permission to read
  the items or to write to the target collection
* any of the items is a collection
* ``unembargo`` is False, any of the items are in a private workspace, and
  the target collection is in a public workspace
* the collection manager fails to add the items (e.g. because they are
  incompatible with the collection)

The ``task_data`` for this task may contain the following keys:

* ``copies``: a list of dictionaries as follows:

  * ``source_items`` (:ref:`lookup-multiple`, required): a list of items to
    copy (as usual for lookups, these may be collection items or they may be
    artifacts looked up directly by ID)
  * ``target_collection`` (:ref:`lookup-single`, required): the collection
    to copy items into
  * ``unembargo`` (boolean, defaults to False): if True, allow copying from
    private to public workspaces
  * ``replace`` (boolean, defaults to False): if True, replace existing
    similar items
  * ``name_template`` (string, optional): template used to generate the name
    for the target collection item, using the ``str.format`` templating
    syntax (with variables inside curly braces)
  * ``variables`` (dictionary, optional): pass these variables when adding
    items to the target collection; if a given source item came from a
    collection, then this is merged into the per-item data from the
    corresponding source collection item, with the values given here taking
    priority in cases of conflict

For each of the entries in ``copies``, the task copies the source items to
the target collection's workspace; when copying artifacts, if the contained
files are already in one of that workspace's file stores, then it copies
references to them, and otherwise it copies the file contents.  For each
source item, it then adds a collection item to the target collection, using
``name_template`` and ``variables`` in the same way as in
:ref:`action-update-collection-with-artifacts`.

All the requested copies happen in a single database transaction; if one of
them fails then they are all rolled back.