Files transferred over Shell protocol (FISH) is a network protocol that uses Secure Shell (SSH) or Remote Shell (RSH) to transfer files between computers and manage remote files.

The advantage of FISH is that all it requires on the server-side is an SSH or RSH implementation, Unix shell, and a set of standard Unix utilities (like ls, cat or dd—unlike other methods of remote access to files via a remote shell, scp for example, which requires scp on the server side). Optionally, there can be a special FISH server program (called start_fish_server) on the server, which executes FISH commands instead of Unix shell and thus speeds up operations.

The protocol was designed by Czech Linux Kernel Hacker, Pavel Machek, in 1998 for the Midnight Commander software tool.[1]

Protocol messages

edit

Client sends text requests of the following form:

#FISH_COMMAND arguments...
equivalent shell commands,
which may be multi-line

Fish commands are all defined, shell equivalents may vary. Fish commands always have priority: the server is expected to execute a fish command if it understands it. If it does not, however, it can try to execute a shell command. When there is no special server program, Unix shell ignores the fish command as a comment and executes the equivalent shell command(s).

Server replies are multi-line, but always end with

### xyz<optional text>

line. ### is a prefix to mark this line, xyz is the return code. Return codes are a superset to those used in FTP. The codes 000 and 001 are special, their meaning depends on presence of server output before the end line.

Session initiation

edit

The client initiates SSH or RSH connection with echo FISH:;/bin/sh as the command executed on remote machine. This should make it possible for the server to distinguish FISH connections from normal RSH or SSH.

The first two commands sent to the server are FISH and VER to negotiate FISH protocol, its version and extensions.

 #FISH
 echo; start_fish_server; echo '### 200'

 #VER 0.0.2 <feature1> <feature2> <...>
 echo '### 000'

The server may reply to VER command with a lines like

VER 0.0.0 <feature2> <...>
### 200

which indicates supported version of the FISH protocol and supported extensions.

Implementations

edit

See also

edit

References

edit
  1. ^ File: Fish.c - via Midnight Commander Official Repository
  2. ^ "Mc/Fish.c at master · MidnightCommander/Mc". GitHub.
  3. ^ "Feature: Consider porting FISH(FIle transfer over SHell filesystem) from Midnight Commander · Issue #1819 · elfmz/Far2l". GitHub.
  4. ^ "LFTP/SRC/Fish.cc at master · lavv17/LFTP". GitHub.
  5. ^ "Kio-extras/Fish/Fish.CPP at master · KDE/Kio-extras". GitHub.
  6. ^ related commit in Emacs
  7. ^ "Re: Tramp's fish method".
edit

📚 Artikel Terkait di Wikipedia

SSH File Transfer Protocol

File Transfer Protocol, also known as Secure File Transfer Protocol (SFTP), is a network protocol that provides file access, file transfer, and file management

Secure copy protocol

copy (rcp) Comparison of file transfer protocols Files transferred over shell protocol (FISH) FTP over SSH FTPS rsync Secure shell WinSCP "Linux and Unix

Comparison of file transfer protocols

Connect:Direct Files transferred over shell protocol (FISH) Pragmatic General Multicast Sendfile Waarp "Background_Intelligent Transfer Service". Microsoft

FTPS

cryptographic protocols. FTPS should not be confused with the SSH File Transfer Protocol (SFTP), a secure file transfer subsystem for the Secure Shell (SSH) protocol

Secure Shell

The Secure Shell Protocol (SSH Protocol) is a cryptographic network protocol for operating network services securely over an unsecured network. Its most

File Transfer Protocol

The File Transfer Protocol (FTP) is a standard communication protocol used for the transfer of computer files from a server to a client over a computer

GVfs

OBEX, MTP and others. GVfs does not seem to support the Files transferred over shell protocol (FISH). GVfs also contains modules for GIO that implement

SSHFS

ExpanDrive Files transferred over shell protocol (FISH) FileZilla, a free software utility for multiple platforms. FTPFS GVfs SSH file transfer protocol (SFTP)