termscp/README.md

196 lines
7.8 KiB
Markdown
Raw Normal View History

2021-05-05 22:13:57 +02:00
# termscp
2020-11-07 17:48:41 +01:00
2021-05-01 17:58:00 +02:00
<p align="center">
<img src="/assets/images/termscp.svg" width="256" height="256" />
</p>
2021-05-22 16:03:07 +02:00
<p align="center">~ A feature rich terminal file transfer ~</p>
<p align="center">
2021-05-22 16:04:42 +02:00
<a href="https://veeso.github.io/termscp/" target="_blank">Website</a>
2021-05-22 16:03:07 +02:00
·
2021-05-22 16:04:42 +02:00
<a href="https://veeso.github.io/termscp/#get-started" target="_blank">Installation</a>
2021-05-22 16:03:07 +02:00
·
2021-05-22 16:04:42 +02:00
<a href="https://veeso.github.io/termscp/#user-manual" target="_blank">User manual</a>
2021-05-22 16:03:07 +02:00
</p>
2021-05-23 15:56:18 +02:00
<p align="center">Developed by <a href="https://veeso.github.io/">@veeso</a></p>
2021-06-21 18:22:19 +02:00
<p align="center">Current version: 0.6.0 FIXME: (21/06/2021)</p>
2020-11-07 17:48:41 +01:00
2021-06-11 15:28:14 +02:00
[![License: MIT](https://img.shields.io/badge/License-MIT-teal.svg)](https://opensource.org/licenses/MIT) [![Stars](https://img.shields.io/github/stars/veeso/termscp.svg)](https://github.com/veeso/termscp) [![Downloads](https://img.shields.io/crates/d/termscp.svg)](https://crates.io/crates/termscp) [![Crates.io](https://img.shields.io/badge/crates.io-v0.5.1-orange.svg)](https://crates.io/crates/termscp) [![Docs](https://docs.rs/termscp/badge.svg)](https://docs.rs/termscp)
2021-05-23 15:56:18 +02:00
2021-06-20 11:29:12 +02:00
[![Linux](https://github.com/veeso/termscp/workflows/Linux/badge.svg)](https://github.com/veeso/termscp/actions) [![MacOs](https://github.com/veeso/termscp/workflows/MacOS/badge.svg)](https://github.com/veeso/termscp/actions) [![Windows](https://github.com/veeso/termscp/workflows/Windows/badge.svg)](https://github.com/veeso/termscp/actions) [![FreeBSD](https://github.com/veeso/termscp/workflows/FreeBSD/badge.svg)](https://github.com/veeso/termscp/actions) [![Coverage Status](https://coveralls.io/repos/github/veeso/termscp/badge.svg)](https://coveralls.io/github/veeso/termscp)
2021-05-23 15:56:18 +02:00
2020-11-07 17:48:41 +01:00
---
2021-05-05 22:13:57 +02:00
## About termscp 🖥
2020-11-07 17:48:41 +01:00
2021-04-23 22:03:12 +02:00
Termscp is a feature rich terminal file transfer and explorer, with support for SCP/SFTP/FTP. So basically is a terminal utility with an TUI to connect to a remote server to retrieve and upload files and to interact with the local file system. It is **Linux**, **MacOS**, **BSD** and **Windows** compatible and supports SFTP, SCP, FTP and FTPS.
2020-11-07 17:48:41 +01:00
2020-12-06 22:40:08 +01:00
![Explorer](assets/images/explorer.gif)
2020-12-06 22:36:18 +01:00
---
2020-12-06 12:52:47 +01:00
## Features 🎁
2020-11-07 17:48:41 +01:00
2021-05-21 12:59:42 +02:00
- 📁 Different communication protocols support
2020-11-07 17:48:41 +01:00
- SFTP
- SCP
2020-12-01 14:38:03 +01:00
- FTP and FTPS
2021-05-21 12:59:42 +02:00
- 🖥 Explore and operate on the remote and on the local machine file system with a handy UI
2021-03-08 14:38:03 +01:00
- Create, remove, rename, search, view and edit files
2021-05-21 12:59:42 +02:00
- ⭐ Connect to your favourite hosts through built-in bookmarks and recent connections
- 📝 View and edit text files with your favourite text editor
- 💁 SFTP/SCP authentication through SSH keys and username/password
- 🐧 Compatible with Windows, Linux, BSD and MacOS
- ✏ Customizable
- Themes
- Custom file explorer format
- Customizable text editor
- Customizable file sorting
2021-05-21 12:59:42 +02:00
- 🔐 Save your password in your operating system key vault
- 🦀 Rust-powered
- 🤝 Easy to extend with new file transfers protocols
- 👀 Developed keeping an eye on performance
- 🦄 Frequent awesome updates
2020-12-06 12:32:53 +01:00
---
2020-11-07 17:48:41 +01:00
2021-05-22 16:03:07 +02:00
## Get started 🚀
2020-11-07 17:48:41 +01:00
2021-05-05 22:13:57 +02:00
If you're considering to install termscp I want to thank you 💜 ! I hope you will enjoy termscp!
2020-11-07 17:48:41 +01:00
If you want to contribute to this project, don't forget to check out our contribute guide. [Read More](CONTRIBUTING.md)
2021-06-20 17:59:27 +02:00
If you are a Linux, a FreeBSD or a MacOS user this simple shell script will install termscp on your system with a single command:
2021-05-23 14:47:55 +02:00
```sh
2021-05-23 15:42:51 +02:00
curl --proto '=https' --tlsv1.2 -sSf "https://raw.githubusercontent.com/veeso/termscp/main/install.sh" | sh
2021-05-23 14:47:55 +02:00
```
while if you're a Windows user, you can install termscp with [Chocolatey](https://chocolatey.org/).
For more information or other platforms, please visit [veeso.github.io](https://veeso.github.io/termscp/#get-started) to view all installation methods.
2020-12-06 22:36:18 +01:00
2021-06-20 16:55:17 +02:00
### Requirements ❗
- **Linux/BSD** users:
- libssh
- libdbus-1
2021-06-11 13:01:28 +02:00
### Soft Requirements ✔️
These requirements are not forcely required to run termscp, but to enjoy all of its features
2021-06-20 16:55:17 +02:00
- **Linux/BSD** users:
2021-06-11 13:01:28 +02:00
- To **open** files via `V` (at least one of these)
- *xdg-open*
- *gio*
- *gnome-open*
- *kde-open*
2021-06-20 16:55:17 +02:00
- A keyring manager: read more in the [User manual](docs/man.md#linux-keyring)
2021-06-11 13:01:28 +02:00
- **WSL** users
- To **open** files via `V` (at least one of these)
- [wslu](https://github.com/wslutilities/wslu)
2020-12-06 22:36:18 +01:00
---
2021-05-22 16:03:07 +02:00
## Buy me a coffee ☕
2020-12-06 22:36:18 +01:00
2021-05-22 16:03:07 +02:00
If you like termscp and you'd love to see the project to grow, please consider a little donation 🥳
2021-05-22 16:03:07 +02:00
[![Buy-me-a-coffee](https://img.buymeacoffee.com/button-api/?text=Buy%20me%20a%20coffee&emoji=&slug=veeso&button_colour=404040&font_colour=ffffff&font_family=Comic&outline_colour=ffffff&coffee_colour=FFDD00)](https://www.buymeacoffee.com/veeso)
2020-12-06 22:36:18 +01:00
2020-12-06 12:32:53 +01:00
---
2020-11-07 17:48:41 +01:00
2020-12-06 12:32:53 +01:00
## Documentation 📚
2020-11-07 17:48:41 +01:00
The developer documentation can be found on Rust Docs at <https://docs.rs/termscp>
---
2020-12-06 12:32:53 +01:00
## Known issues 🧻
2020-11-07 17:48:41 +01:00
2021-05-21 12:59:42 +02:00
- `NoSuchFileOrDirectory` on connect (WSL1): I know about this issue and it's a glitch of WSL I guess. Don't worry about it, just move the termscp executable into another PATH location, such as `/usr/bin`, or install it through the appropriate package format (e.g. deb).
2020-11-07 17:48:41 +01:00
---
2020-12-06 12:32:53 +01:00
## Upcoming Features 🧪
2020-11-07 17:48:41 +01:00
2021-06-01 17:10:25 +02:00
Major termscp releases will now be seasonal, so expect 4 major updates during the year.
Planned for *🏄 Summer update 🌴*:
- **Keyring-rs on Linux 🔐**: Check for updates in [this issue](https://github.com/veeso/termscp/issues/2)
- **SMB Support 🎉**: This will require a long time to be implemented, since I'm currently working on a Rust native SMB library, since I don't want to add new C-bindings. ~~Fear the 🦚~~
- **Open files with any application ☄️**: possibility to open files of any kind and with any application directly inside termscp. This will be achieved through this awesome crate [open-rs](https://github.com/Byron/open-rs).
To be planned:
2021-03-26 22:19:24 +01:00
2021-05-21 12:08:53 +02:00
- **Themes provider 🎨**: I'm still thinking about how I will implement this, but basically the idea is to have a configuration file where it will be possible to define the color schema for the entire application. I haven't planned this release yet
- **Configuration profile for bookmarks 📚**: I would like to, but I still have to analyze it.
- **AWS S3 support 🪣**: There is already a library for AWS S3, but this is really on bottom of my implementation list at the moment, due to interest and I don't really have a system where to test it.
2021-03-26 22:19:24 +01:00
2021-05-21 12:08:53 +02:00
Along to new features, termscp developments is now focused on UI and performance improvements, so if you have any suggestion, feel free to open an issue.
2020-12-21 12:02:45 +01:00
2020-11-07 17:48:41 +01:00
---
## Contributing and issues 🤝🏻
2020-11-07 17:48:41 +01:00
Contributions, bug reports, new features and questions are welcome! 😉
If you have any question or concern, or you want to suggest a new feature, or you want just want to improve termscp, feel free to open an issue or a PR.
2020-11-07 17:48:41 +01:00
Please follow [our contributing guidelines](CONTRIBUTING.md)
---
2020-11-07 17:48:41 +01:00
2020-12-06 12:32:53 +01:00
## Changelog ⏳
2020-11-07 17:48:41 +01:00
2021-05-05 22:13:57 +02:00
View termscp's changelog [HERE](CHANGELOG.md)
2020-12-06 22:36:18 +01:00
---
2021-05-22 16:03:07 +02:00
## Powered by 💪
2020-12-06 22:36:18 +01:00
2021-05-05 22:13:57 +02:00
termscp is powered by these aweseome projects:
2020-12-06 22:36:18 +01:00
- [bytesize](https://github.com/hyunsik/bytesize)
- [crossterm](https://github.com/crossterm-rs/crossterm)
2020-12-20 15:22:52 +01:00
- [edit](https://github.com/milkey-mouse/edit)
2021-01-16 17:13:41 +01:00
- [keyring-rs](https://github.com/hwchen/keyring-rs)
2021-06-11 13:01:28 +02:00
- [open-rs](https://github.com/Byron/open-rs)
2020-12-06 22:36:18 +01:00
- [rpassword](https://github.com/conradkleinespel/rpassword)
2021-01-09 20:35:55 +01:00
- [rust-ftp](https://github.com/mattnenterprise/rust-ftp)
2020-12-06 22:36:18 +01:00
- [ssh2-rs](https://github.com/alexcrichton/ssh2-rs)
- [textwrap](https://github.com/mgeisler/textwrap)
- [tui-rs](https://github.com/fdehau/tui-rs)
2021-04-24 11:38:28 +02:00
- [tui-realm](https://github.com/veeso/tui-realm)
2020-12-06 22:36:18 +01:00
- [whoami](https://github.com/libcala/whoami)
2021-05-21 12:59:42 +02:00
- [wildmatch](https://github.com/becheran/wildmatch)
2020-12-06 22:36:18 +01:00
---
## Gallery 🎬
2020-12-16 21:09:59 +01:00
> Termscp Home
2020-12-06 22:40:08 +01:00
![Auth](assets/images/auth.gif)
2020-11-07 17:48:41 +01:00
2020-12-16 21:09:59 +01:00
> Bookmarks
![Bookmarks](assets/images/bookmarks.gif)
2021-01-09 15:28:20 +01:00
> Setup
![Setup](assets/images/config.gif)
2020-12-20 15:22:52 +01:00
> Text editor
![TextEditor](assets/images/text-editor.gif)
2020-11-07 17:48:41 +01:00
---
2020-12-06 12:32:53 +01:00
## License 📃
2020-11-07 17:48:41 +01:00
2021-05-01 10:38:13 +02:00
termscp is licensed under the MIT license.
2020-11-07 17:48:41 +01:00
You can read the entire license [HERE](LICENSE)