File: xx

package info (click to toggle)
fex 20160919-2
  • links: PTS, VCS
  • area: non-free
  • in suites: bookworm, bullseye, forky, sid, trixie
  • size: 1,944 kB
  • sloc: perl: 17,699; sh: 346; makefile: 67
file content (99 lines) | stat: -rw-r--r-- 2,871 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
With xx you have a network wide shell based clip board for files and
STDIN/STDOUT: easy data exchange between different accounts on different
hosts.

  usage: send file(s):          xx file...
     or: send STDIN:            xx -
     or: send pipe:             ... | xx
     or: get file(s) or STDIN:  xx
     or: get file(s) quickly:   xx --


Pipe example:

  framstag@tandem:~: uname -a | xx
  /home/framstag/.fex/tmp/STDFEX : 0 kB in 1 s (0 kB/s)


  framstag@fex:~: xx
  transfered: 0 MB (100%)
  Linux tandem 2.6.24-28-server #1 SMP Wed Aug 18 22:01:20 UTC 2010 i686 GNU/Linux


File transfer example:

  framstag@tandem:~: xx /boot/
  making tar transfer file /home/framstag/.fex/tmp/STDFEX :
  /boot/
  /boot/initrd.img-2.6.24-27-generic
  /boot/vmlinuz-2.6.24-28-generic
  (...)
  /boot/System.map-2.6.24-27-generic
  /home/framstag/.fex/tmp/STDFEX : 34 MB in 2 s (17605 kB/s)


  framstag@fex:/tmp: xx
  transfered: 34 MB (100%)
  Files in transfer-container:

  drwxr-xr-x root/root         0 2010-10-20 07:37 boot/
  -rw-r--r-- root/root   7905085 2010-05-25 15:38 boot/initrd.img-2.6.24-27-generic
  -rw-r--r-- root/root   1927544 2010-10-16 20:38 boot/vmlinuz-2.6.24-28-generic
  (...)
  -rw-r--r-- root/root    906803 2010-03-24 14:33 boot/System.map-2.6.24-27-generic

  Extract these files?


One problem are shared system accounts like root where different persons
use them: xx (like fexsend and fexget) uses $HOME/.fex/id which contains
personal data.

But you can put the ID authorization in the environment variable FEXID.

fexsend on your local account gives you a string for "cut and paste", example:

  framstag@moep:~: fexsend -I
  export FEXID='fex.rus.uni-stuttgart.de:8080 framstag jmBhf9ht'
  history -d $(history 1);history -d $(history 1)

You then copy these two lines with your mouse into the root account:

  root@tandem:~# export FEXID'=fex.rus.uni-stuttgart.de:8080 framstag jmBhf9ht'
  root@tandem:~# history -d $(history 1);history -d $(history 1)

(The second line deletes these two lines from the bash history)

Now you can use xx (or fexsend and fexget) as normal. Example:

  root@tandem:~# grep sshd /var/log/daemon | xx
  transfered: 265 kB in 1 s (265 kB/s)

  framstag@moep:~: xx | wc -l
  434279


After logging out from root@tandem the F*EX authorization data has gone.


Internal details:

The intermediate transfer file container is $HOME/.fex/tmp/STDFEX

When transfering files tar/gzip format is used, whereas STDIN (pipe) will
be transfered uncompressed. Tip: If you want to transfer files uncompress,
then use: tar cvf - your files... | xx

With default usage only one "storage slot" is available: STDFEX
But you can use as many "storage slots" as you want by using "xx :TAG"
Examples:

  uname -a | xx

  grep sshd /var/log/daemon | xx :log

  xx :log | grep obertux

  xx :config /boot /etc /root

  xx :config --