Skip to content

Commit

Permalink
tfpt: polish user guides
Browse files Browse the repository at this point in the history
  • Loading branch information
IngelaAndin committed May 31, 2024
1 parent 9a6d8e8 commit a830c79
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 43 deletions.
16 changes: 1 addition & 15 deletions lib/tftp/doc/guides/getting_started.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,27 +17,13 @@ limitations under the License.
%CopyrightEnd%
-->
# Getting Started
# Examples

## General Information

The [start/1](`tftp:start/1`) function starts a daemon process listening for UDP
packets on a port. When it receives a request for read or write, it spawns a
temporary server process handling the transfer.

On the client side, function [read_file/3](`tftp:read_file/3`) and
[write_file/3](`tftp:write_file/3`) spawn a temporary client process
establishing contact with a TFTP daemon and perform the file transfer.

`tftp` uses a callback module to handle the file transfer. Two such callback
modules are provided, `tftp_binary` and `tftp_file`. See
[read_file/3](`tftp:read_file/3`) and [write_file/3](`tftp:write_file/3`) for
details. You can also implement your own callback modules, see
[CALLBACK FUNCTIONS](`m:tftp#tftp_callback`). A callback module provided by the
user is registered using option `callback`, see [DATA TYPES](`m:tftp#options`).

## Using the TFTP client and server

This is a simple example of starting the TFTP server and reading the content of
a sample file using the TFTP client.

Expand Down
51 changes: 24 additions & 27 deletions lib/tftp/doc/guides/introduction.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,30 +17,27 @@ limitations under the License.
%CopyrightEnd%
-->
# Introduction

## Purpose

The Trivial File Transfer Protocol or TFTP is a very simple protocol used to
transfer files.

It has been implemented on top of the User Datagram protocol (UDP) so it may be
used to move files between machines on different networks implementing UDP. It
is designed to be small and easy to implement. Therefore, it lacks most of the
features of a regular FTP. The only thing it can do is read and write files (or
mail) from/to a remote server. It cannot list directories, and currently has no
provisions for user authentication.

The `tftp` application implements the following IETF standards:

- RFC 1350, The TFTP Protocol (revision 2)
- RFC 2347, TFTP Option Extension
- RFC 2348, TFTP Blocksize Option
- RFC 2349, TFTP Timeout Interval and Transfer Size Options

The only feature that not is implemented is the `netascii` transfer mode.

## Prerequisites

It is assumed that the reader is familiar with the Erlang programming language,
concepts of OTP, and has a basic understanding of the TFTP protocol.
# Overwiew

TFTP is a very simple protocol used to transfer files over Transport
datagram protcol UDP. It is from this that its name comes, Trivial
File Transfer Protocol or TFTP.

On the client side, function [read_file/3](`tftp:read_file/3`) and
[write_file/3](`tftp:write_file/3`) spawn a temporary client process
establishing contact with a TFTP daemon and perform the file transfer.

`tftp` uses a callback module to handle the file transfer. Two such callback
modules are provided, `tftp_binary` and `tftp_file`. See
[read_file/3](`tftp:read_file/3`) and [write_file/3](`tftp:write_file/3`) for
details. You can also implement your own callback modules, see
[callbacks](`m:tftp#callbacks`).

# Security Considerations

As stated in RFC be aware that TFTP includes no login or access
control mechanisms, care must be taken in the rights granted to a TFTP
server process so as not to violate the security of the server hosts
file system. TFTP is often installed with controls such that only
files that have public read access are available via TFTP and writing
files via TFTP is disallowed.
2 changes: 1 addition & 1 deletion lib/tftp/src/tftp.erl
Original file line number Diff line number Diff line change
Expand Up @@ -206,7 +206,7 @@ All options most of them common to the client and server.
`write_file/3`.
The callback module must implement the `tftp` behavior, see
[CALLBACK FUNCTIONS](`m:tftp#tftp_callback`).
[callbacks](`m:tftp#callbacks`).
- **`{logger, module()}`**
Expand Down

0 comments on commit a830c79

Please sign in to comment.