From eebde41cd201eb496f6525de366c296c76a80c2a Mon Sep 17 00:00:00 2001 From: Giovanni Pizzi Date: Mon, 25 May 2020 19:12:59 +0200 Subject: [PATCH] Docs: Adding How-to delete data (#4110) Adding How-to delete data. Co-authored-by: Carl Simon Adorf --- docs/source/howto/data.rst | 46 ++++++++++++++++++++++++++++++++++++-- 1 file changed, 44 insertions(+), 2 deletions(-) diff --git a/docs/source/howto/data.rst b/docs/source/howto/data.rst index 8551df521c..49afdf80b2 100644 --- a/docs/source/howto/data.rst +++ b/docs/source/howto/data.rst @@ -276,7 +276,50 @@ Sharing data Deleting data ============= -`#3999`_ +By default, every time you run or submit a new calculation, AiiDA will create for you new nodes in the database, and will never replace or delete data. +There are cases, however, when it might be useful to delete nodes that are not useful anymore, for instance test runs or incorrect/wrong data and calculations. +For this case, AiiDA provides the ``verdi node delete`` command to remove the nodes from the provenance graph. + +.. caution:: + Once the data is deleted, there is no way to recover it (unless you made a backup). + +Critically, note that even if you ask to delete only one node, ``verdi node delete`` will typically delete a number of additional linked nodes, in order to preserve a consistent state of the provenance graph. +For instance, if you delete an input of a calculation, AiiDA will delete also the calculation itself (as otherwise you would be effectively changing the inputs to that calculation in the provenance graph). +The full set of consistency rules are explained in detail :ref:`here `. + +Therefore: always check the output of ``verdi node delete`` to make sure that it is not deleting more than you expect. +You can also use the ``--dry-run`` flag of ``verdi node delete`` to see what the command would do without performing any actual operation. + +In addition, there are a number of additional rules that are not mandatory to ensure consistency, but can be toggled by the user. +For instance, you can set ``--create-forward`` if, when deleting a calculation, you want to delete also the data it produced (using instead ``--no-create-forward`` will delete the calculation only, keeping the output data: note that this effectively strips out the provenance information of the output data). +The full list of these flags is available from the help command ``verdi node delete -h``. + +Deleting computers +------------------ +To delete a computer, you can use ``verdi computer delete``. +This command is mostly useful if, right after creating a computer, you realise that there was an error and you want to remove it. +In particular, note that ``verdi computer delete`` will prevent execution if the computer has been already used by at least one node. In this case, you will need to use ``verdi node delete`` to delete first the corresponding nodes. + +Deleting mutable data +--------------------- +A subset of data in AiiDA is mutable also after storing a node, and is used as a convenience for the user to tag/group/comment on data. +This data can be safely deleted at any time. +This includes, notably: + +* *Node extras*: These can be deleted using :py:meth:`~aiida.orm.nodes.node.Node.delete_extra` and :py:meth:`~aiida.orm.nodes.node.Node.delete_extra_many`. +* *Node comments*: These can be removed using :py:meth:`~aiida.orm.nodes.node.Node.remove_comment`. +* *Groups*: These can be deleted using :py:meth:`Group.objects.delete() `. + This command will only delete the group, not the nodes contained in the group. + +Completely deleting an AiiDA profile +------------------------------------ +If you don't want to selectively delete some nodes, but instead want to delete a whole AiiDA profile altogether, use the ``verdi profile delete`` command. +This command will delete both the file repository and the database. + +.. danger:: + + It is not possible to restore a deleted profile unless it was previously backed up! + Serving your data to others =========================== @@ -363,4 +406,3 @@ Notice that we haven't specified any port in the URLs since Apache listens conve .. _#3996: https://github.com/aiidateam/aiida-core/issues/3996 .. _#3997: https://github.com/aiidateam/aiida-core/issues/3997 .. _#3998: https://github.com/aiidateam/aiida-core/issues/3998 -.. _#3999: https://github.com/aiidateam/aiida-core/issues/3999