Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xyproto/teaftp
:tea: Simple, read-only TFTP server
https://github.com/xyproto/teaftp
server tftp
Last synced: 12 days ago
JSON representation
:tea: Simple, read-only TFTP server
- Host: GitHub
- URL: https://github.com/xyproto/teaftp
- Owner: xyproto
- License: bsd-3-clause
- Created: 2018-10-14T11:59:05.000Z (over 6 years ago)
- Default Branch: main
- Last Pushed: 2024-04-25T11:38:59.000Z (9 months ago)
- Last Synced: 2025-01-08T14:01:52.962Z (15 days ago)
- Topics: server, tftp
- Language: Go
- Homepage:
- Size: 4.53 MB
- Stars: 16
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# TeaFTP
[![Build](https://github.com/xyproto/teaftp/actions/workflows/build.yml/badge.svg)](https://github.com/xyproto/teaftp/actions/workflows/build.yml) [![Go Report Card](https://goreportcard.com/badge/github.com/xyproto/teaftp)](https://goreportcard.com/report/github.com/xyproto/teaftp) [![License](https://img.shields.io/badge/license-BSD-green.svg?style=flat)](https://raw.githubusercontent.com/xyproto/teaftp/main/LICENSE)
Simple, read-only TFTP server.
### Features and Limitations
* Suitable for dealing with hardware devices that read files over TFTP at boot (PXE).
* Security is provided by providing a list of whitelisted prefixes, suffixes and/or running the server from within a Docker container.
* If not whitelisted filename prefixes or suffixes are provided, the server may share ANY file on the system, but not write to anything.
* Consider using the provided Docker container as a method to serve only a select group of files.
* Alternatively, utilize the list of allowed prefixes or suffixes for added security.
* Every access is logged to stdout.### Requirements
Go 1.17 or later
### Installation with Go 1.17 or Later
go install github.com/xyproto/teaftp@latest
### Running
#### Directly
Navigate to the directory where you intend to share files:
With sudo:
sudo ./teaftp
On Linux, you can `teaftp` it to `/usr/bin` and grant additional capabilities using `setcap`:
sudo install -Dm755 teaftp /usr/bin/teaftp
sudo setcap cap_net_bind_service=+ep /usr/bin/teaftpStarting the server:
teaftp
#### Docker
To build the Docker container and copy the contents of the `static` directory to `/srv/tftp` inside the container:
docker build . -t teaftp
To run TeaFTP with Docker:
docker run --network=host -t teaftp
To run TeaFTP with Docker and serve on port 9000 instead of port 69:
docker run -ePORT=9000 --network=host -t teaftp
#### Allowed Suffixes
You can pass allowed filename suffixes as arguments to TeaFTP. When no arguments are given, there's no restriction on the file suffixes.
Example:
sudo ./teaftp ".txt"
This configuration will only serve filenames that end with `.txt`.
### Dependencies
* [pin/tftp](https://github.com/pin/tftp)
* [sirupsen/logrus](https://github.com/sirupsen/logrus)
* [urfave/cli](https://github.com/urfave/cli)### General information
* Version: 1.3.1
* License: BSD-3
* Author: Alexander F. Rødseth <[email protected]>