From 667b086b59ee37d38579f5cea8ec6f61122390ae Mon Sep 17 00:00:00 2001
From: david-sarah <david-sarah@jacaranda.org>
Date: Mon, 8 Aug 2011 11:21:46 -0700
Subject: [PATCH] Documentation for drop-upload frontend. refs #1429

---
 docs/configuration.rst         |   6 ++
 docs/frontends/drop-upload.rst | 141 +++++++++++++++++++++++++++++++++
 2 files changed, 147 insertions(+)
 create mode 100644 docs/frontends/drop-upload.rst

diff --git a/docs/configuration.rst b/docs/configuration.rst
index 4f414f66..634d063f 100644
--- a/docs/configuration.rst
+++ b/docs/configuration.rst
@@ -359,6 +359,12 @@ FTP, SFTP
     for instructions on configuring these services, and the ``[ftpd]`` and
     ``[sftpd]`` sections of ``tahoe.cfg``.
 
+Drop-Upload
+
+    As of Tahoe-LAFS v1.9.0, a node running on Linux can be configured to
+    automatically upload files that are created or changed in a specified
+    local directory. See `<frontends/drop_upload.rst>`_ for details.
+
 
 
 Storage Server Configuration
diff --git a/docs/frontends/drop-upload.rst b/docs/frontends/drop-upload.rst
new file mode 100644
index 00000000..ed2d4167
--- /dev/null
+++ b/docs/frontends/drop-upload.rst
@@ -0,0 +1,141 @@
+===============================
+Tahoe-LAFS Drop-Upload Frontend
+===============================
+
+1.  `Introduction`_
+2.  `Configuration`_
+3.  `Known Issues and Limitations`_
+
+
+Introduction
+============
+
+The drop-upload frontend allows an upload to a Tahoe-LAFS grid to be triggered
+automatically whenever a file is created or changed in a specific local
+directory. This is a preview of a feature that we expect to support across
+several platforms, but it currently works only on Linux.
+
+The implementation was written as a prototype at the First International
+Tahoe-LAFS Summit in June 2011, and is not currently in as mature a state as
+the other frontends (web, CLI, FTP and SFTP). This means that you probably
+should not keep important data in the upload directory, and should not rely
+on all changes to files in the local directory to result in successful uploads.
+There might be incompatible changes to how the feature is configured in
+future versions. There is even the possibility that it may be abandoned, for
+example if unsolveable reliability issues are found.
+
+We are very interested in feedback on how well this feature works for you, and
+suggestions to improve its usability, functionality, and reliability.
+
+
+Configuration
+=============
+
+The drop-upload frontend runs as part of a gateway node. To set it up, you
+need to choose the local directory to monitor for file changes, and a mutable
+directory on the grid to which files will be uploaded.
+
+These settings are configured in the ``[drop_upload]`` section of the
+gateway's ``tahoe.cfg`` file.
+
+``[drop_upload]``
+
+``enabled = (boolean, optional)``
+
+    If this is ``True``, drop-upload will be enabled (provided that the
+    ``upload.uri`` and ``local.directory`` fields are also set). The default
+    value is ``False``.
+
+``upload.uri = (URI)``
+
+    This is the Tahoe URI of an existing mutable directory to be used as
+    the target of uploads. It must be the full URI of the directory
+    (starting with ``URI:DIR2:``), and cannot include an alias or path.
+
+``local.directory = (UTF-8 path)``
+
+    This specifies the local directory to be monitored for new or changed
+    files. If the path contains non-ASCII characters, it should be encoded
+    in UTF-8 regardless of the system's filesystem encoding. Relative paths
+    will be interpreted starting from the node's base directory.
+
+After setting the above fields and starting or restarting the gateway,
+you can confirm that the feature is working by copying a file into the
+local directory. Then, use the WUI or CLI to check that it has appeared
+in the upload directory with the same filename. A large file may take some
+time to appear, since it is only linked into the directory after the upload
+has completed.
+
+The 'Operational Statistics' page linked from the Welcome page shows
+counts of the number of files uploaded, the number of change events currently
+queued, and the number of failed uploads. The 'Recent Uploads and Downloads'
+page and the node log_ may be helpful to determine the cause of any failures.
+
+.. _log: ../logging.rst
+
+
+Known Issues and Limitations
+============================
+
+This frontend only works on Linux. There is an even-more-experimental
+implementation for Windows (`#1431`_), and a ticket to add support for
+Mac OS X and BSD-based systems (`#1432`_).
+
+Subdirectories of the local directory are not monitored. If a subdirectory
+is created, it will be ignored. (`#1433`_)
+
+If files are created or changed in the local directory just after the gateway
+has started, it might not have connected to a sufficient number of servers
+when the upload is attempted, causing the upload to fail. (`#1449`_)
+
+Files that were created or changed in the local directory while the gateway
+was not running, will not be uploaded. (`#1458`_)
+
+The only way to determine whether uploads have failed is to look at the
+'Operational Statistics' page linked from the Welcome page. This only shows
+a count of failures, not the names of files. Uploads are never retried.
+
+The drop-upload frontend performs its uploads sequentially (i.e. it waits
+until each upload is finished before starting the next), even when there
+would be enough memory and bandwidth to efficiently perform them in parallel.
+A drop-upload can occur in parallel with an upload by a different frontend,
+though. (`#1459`_)
+
+If there are a large number of near-simultaneous file creation or
+change events (greater than the number specified in the file
+``/proc/sys/fs/inotify/max_queued_events``), it is possible that some events
+could be missed. This is fairly unlikely under normal circumstances, because
+the default value of ``max_queued_events`` in most Linux distributions is
+16384, and events are removed from this queue immediately without waiting for
+the corresponding upload to complete. (`#1430`_)
+
+Some filesystems may not support the necessary change notifications.
+So, it is recommended for the local directory to be on a directly attached
+disk-based filesystem, not a network filesystem or one provided by a virtual
+machine.
+
+Attempts to read the mutable directory at about the same time as an uploaded
+file is being linked into it, might fail, even if they are done through the
+same gateway. (`#1105`_)
+
+Files are always uploaded as immutable. If there is an existing mutable file
+of the same name in the upload directory, it will be unlinked and replaced
+with an immutable file.
+
+If a file in the upload directory is changed (actually relinked to a new
+file), then the old file is still present on the grid, and any other caps
+to it will remain valid. See `docs/garbage-collection.rst
+<../garbage-collection.rst>`_ for how to reclaim the space used by files
+that are no longer needed.
+
+Unicode names are supported, but the local name of a file must be encoded
+correctly in order for it to be uploaded. The expected encoding is that
+printed by ``python -c "import sys; print sys.getfilesystemencoding()"``.
+
+.. _`#1105`: http://tahoe-lafs.org/trac/tahoe-lafs/ticket/1105
+.. _`#1430`: http://tahoe-lafs.org/trac/tahoe-lafs/ticket/1430
+.. _`#1431`: http://tahoe-lafs.org/trac/tahoe-lafs/ticket/1431
+.. _`#1432`: http://tahoe-lafs.org/trac/tahoe-lafs/ticket/1432
+.. _`#1449`: http://tahoe-lafs.org/trac/tahoe-lafs/ticket/1449
+.. _`#1458`: http://tahoe-lafs.org/trac/tahoe-lafs/ticket/1458
+.. _`#1459`: http://tahoe-lafs.org/trac/tahoe-lafs/ticket/1459
-- 
2.45.2