packages icon



 KIT(1)                                                               KIT(1)
                              Version 2.0 PL28



 NAME
      kit, mailkit, unkit - the ultimate mailing tools

 SYNOPSIS
      kit [ -EFHMBVXefhpx ] [ -S size ] [ -a address ] [ -k key ] [ -d dir ]
      [ -m address ] [ -n basename ] [ -l file ] [ -s name ] directories |
      files

      mailkit [ -EFVcefhp ] [ -l file ] [ -n partname ] title [ address(es) ]

      unkit [ -bhlprsSV ] [-d dir ] [ -k key ] [ files ]

 DESCRIPTION
      Kit is the ultimate mailing tool. It enables you to mail data without
      any consideration of possible escape sequences or control characters.
      Given a file name or a directory, it builds a single file using tar(1)
      and compress(1). Then this file is hex-encoded (option -H) or ASCII-
      encoded with btoa(1) (option -B, which is used by default) before
      being shell-archived.  Kit produces files that match "Kit*" regular
      expression.  This default base name can be changed thanks to the -n
      option.  With the -m option, it is possible to give one mail address,
      and kit will invoke mailkit to send the archive. There may be as many
      -m options as needed (to send the same archive to more than a single
      person).  If there are a lot of recipients, you may want to store them
      in a file and use the -l option to tell kit where the recipient file
      is located.

      The -E, -F, -e, -f and -p options are passed on to mailkit, so if no
      -m option is used, they will be ignored. When sending files with -m,
      the subject of the message holds the name of the first file given in
      the command line (supposed to be the name of the kit). It is possible
      to overwrite this default by using the -s option.

      If you want to send sensible data, it is possible to encrypt them
      using a public-domain implementation of Data Encryption Standard
      (DES).  The -x option will use the Cipher Block Chaining mode
      (default), while -X requests the Electronic Code Book mode. If you do
      not specify the encryption key with -k, des(1) will prompt you for
      one. If you use the -k option, -x is assumed.

      It may happen that there are no write permissions in the directory
      where the root directory to be kitted lies. The -d option enables you
      to specify another directory, where all the temporary files will be
      stored. If you use something like /tmp, you must be careful to use -n
      to change the base name used (in case someone else is doing the same
      thing, otherwise files may get mangled). To prevent common mistakes,
      kit will stop and give an error message if the argument of -d is not a
      directory, if the directory is not writable by the user, or if a kit
      file is present in the temporary directory (same base name).





                                    - 1 -        Formatted:  January 2, 2025






 KIT(1)                                                               KIT(1)
                              Version 2.0 PL28



      When you send a kit to someone who may not have kit, the -M option may
      be used to include a minikit script, which is a minimal set of
      commands to unkit an unencrypted ASCII-encoded kit. The overhead is
      small (around 4K) and some instructions are provided in the header of
      every kit part. The minikit is usually called minikit, but should you
      already have a file with that name in your distribution, it will be
      renamed MINIKIT. If by chance (!) you named one of your files MINIKIT,
      then a unique name of the form mkitXXXXX will be generated (XXXXX
      stands for the PID of the kit process).

      By using the -a option, you ask the remote unkit program to send an
      automatic acknowledgment to the specified e-mail address upon
      successful archive extraction. However, this feature is only supported
      if the remote end has at least the 2.0 PL15 release. You will receive
      a short message with a junk precedence, telling you who extracted the
      archive and when.

      The default part size generated by kit is currently 50000 bytes.
      However, this can be changed throughout the -S option, which expects a
      part size as argument. It can be given in bytes (e.g. -S 40000 to set
      the maximum part size to 40000 bytes) or in kbytes by appending a k at
      the end (i.e. -S 60k would produce parts with size ranging up to 61440
      bytes).

      Mailkit takes "Kit*" files and sends them to a list of addresses.  The
      -n option can be used to change that base name, if necessary.  Each
      message sent corresponds to one part and has its `Subject:' field set
      to the number of this part with the title given, and you also have the
      total number of parts, so that missing parts can easily be located.

      The options -E and -e from mailkit enable you to give the recipient
      some instructions. They both call an editor. At the top of the file
      edited, there is a little message, which will (of course) be stripped
      from the text you enter, so do not remove it or your own message will
      be cut instead. With -E, the message will be sent in an extra part
      (#0), while with -e it will be included in each part. Empty messages
      will be ignored.

      Options -F and -f are very similar, but take their input from stdin
      (standard input) instead of calling an editor.  Option -p asks mailkit
      for preserving mailed files. They are removed by default.

      When mailkit is given a -l option, it takes the file name as a file
      whith recipients addresses in it and adds the optional addresses that
      may be given on the command line. Addresses in the recipient file are
      separated with spaces, commas or new lines. Shell-style comments
      starting with a pound sign (#) are allowed. More than one -l can be
      used to get addresses from multiple files (duplicates will not be
      removed by mailkit but should be taken care of by the underlying
      transport mechanism).




                                    - 2 -        Formatted:  January 2, 2025






 KIT(1)                                                               KIT(1)
                              Version 2.0 PL28



      If mailkit is invoked by kit via -m options, it will be given the -c
      flag to clean up parts when they are successfully sent, unless -p was
      also provided. However, when invoking mailkit directly from a shell,
      the default action is to not remove the parts when they have been sent
      (that is to say, -p is the default action unless you add the -c option
      yourself). If for some reason one part could not be sent and mailkit
      was directed to remove parts when sent, then the file is not removed
      immediately. If the input and output are connected to a terminal,
      mailkit will ask you at the end whether you wish to keep the unsent
      parts, on an individual basis. Otherwise, (e.g. standard output
      redirected to a file), the unsent parts will be removed without
      asking.

      Another useful feature when invoking mailkit manually is the ability
      to send only a subset of all the kit parts by using the -r option and
      supplying a range list of parts to be sent. A range list is a set of
      ranges comma separated. A range is a part number by itself or a set of
      two numbers separated with a minus sign, indicating the lowest and the
      largest bound, hence specifying an interval. If the lowest bound is
      missing, 1 is assumed. If the largest bound is missing, the total
      number of parts is substituted. Thus, a range of 1- means all the
      parts, while 1,4-7,10 would send parts 1, 4 trough 7 and 10. Finally,
      -5,8- would send parts 1 through 5 and 8 up to the end. If you
      introduce spaces in your range list specification, do not forget to
      quote the whole list for the shell...

      Unkit is used to restore the original files. The argument is a list of
      archive files (or mail files, as unshar(1), which is called by unkit,
      can deal with mail headers).  Input files are not removed unless
      option -r is given. By default, option -p is used to preserve the
      input file(s).  If no file name is given to unkit, the standard input
      is processed.  This is useful to process messages directly from a mail
      user agent.

      You may save more than one kit part into a file and give that file as
      an argument to unkit, which will then identify and extract the embeded
      parts to process them. The program lists on the standard error the
      files as they are processed and tells you how many kit parts it found
      within each file.

      Sometimes, tar does not work well accross NFS and will fail restoring
      ownership on files, even with the -o option. If you chose to install
      badtar at configuration time, you may use -b to instruct unkit using
      badtar as a filter before running tar. This is the default action on
      some systems (the -h option will tell you what was determined at
      configuration time).

      If you want to know what unkit will create without actually doing it,
      use the -l option. With this option, -r is ignored. You may also use
      unkit in place of unshar: it will stop after having unpacked the shell
      archives if it does not detect any kit file.



                                    - 3 -        Formatted:  January 2, 2025






 KIT(1)                                                               KIT(1)
                              Version 2.0 PL28



      When unpacking crypted archives, the -k option may be used to specify
      the key to be used by DES. If you do not supply it, DES will prompt
      you on the terminal.

      By default, unkit will perform security checks on the shell archives
      (if perl is available) to detect alien code. It will skip those parts
      containing suspicious code which should not be part of the archive.
      You may explicitely skip those checks by using the -s option, which
      should be used only when unkit input can be reliably trusted.
      Unfortunately, the script used to make those checks is written in
      perl, so nothing will happen if perl is not in your PATH. The -S
      option will make kit abort with an error if it is unable to perform
      security checks due to the absence of perl.

      For all of these commands, option -V prints the version number with
      the current patch level and exits, while -h gives a little help
      message with the syntax and the meaning of the options.

 OPTIONS
      This section summarizes the different options. All the options may be
      specified separately (e.g. -a -b foo -c) or grouped together, along
      with optional arguments (e.g. -ac -bfoo). Option parsing stops when --
      is encountered.

      Kit has the following options:

      -B             Use btoa encoding (default), as opposed to hexadecimal
                     encoding.

      -E             Edit instructions which will be sent as part #0.

      -F             Get instructions to be sent as part #0 from standard
                     input.

      -H             Use hexadecimal encoding, as opposed to the default
                     btoa. This is an obsolete feature, kept for
                     compatibility with kit 1.0.

      -M             Include minikit in the distribution, in order to allow
                     unkiting by the recipient, should kit be missing at the
                     remote site. Note that minikit will only be able to
                     unkit plain btoa-encoded packages (i.e. encryption is
                     not supported, although automatic acknowledgment is).

      -V             Print version number and patchlevel.

      -S size        Set each part size in bytes or kbytes (by appending a
                     single k after the size figure). The actual size of
                     each part may be slightly bigger than the maximum
                     stated (a few hundred bytes at most).




                                    - 4 -        Formatted:  January 2, 2025






 KIT(1)                                                               KIT(1)
                              Version 2.0 PL28



      -X             Encryption with DES Electronic Code Block algorithm.
                     You will be prompted for a key, unless you specify one
                     on the command line via the -k option.

      -a address     Ask the unkiting process to send an acknowldgment to
                     the specified e-mail address upon successful
                     extraction.

      -d dir         Put temporary files in the specified directory. This is
                     useful if you do not have writing permission in the
                     current directory. If you specify a common directory
                     like /tmp, be sure to use the -n option or your kit
                     might be clobbered if somebody else is doing the same
                     thing.

      -e             Edit instructions to be sent at the top of each part.

      -f             Get instructions to be sent at the top of each part
                     from standard input.

      -h             Print usage and option summary.

      -k key         Set the key to be used for encryption. The -x option
                     will be assumed, unless -X is explicitely given to
                     override the default.

      -m address     Invoke mailkit to send all the parts at the given
                     address. Several -m may be specifed to send the package
                     to more than one recipient. The kit parts will be
                     removed at the end, unless -p is given. When sending
                     large files to multiple recipients, it is wise to use
                     this option in case one part gets lost.

      -l file        Send the kit parts to the recipients held in the file
                     (one recipient per line).

      -n basename    Set the basename of the generated parts. The default is
                     Kit. You should use this option when a kit is already
                     present in the current directory, or when you use
                     something like -d /tmp.

      -p             Preserve file sent. This option is meaningful only when
                     -m or -l is given.

      -s name        Set the kit name, which will be copied as-is into the
                     Subject of messages sent by mailkit (provided -m or -l
                     is specified), and also in the automatic
                     acknowledgment. By default, the name of the first
                     directory or file specified on the command line will be
                     used.




                                    - 5 -        Formatted:  January 2, 2025






 KIT(1)                                                               KIT(1)
                              Version 2.0 PL28



      -x             Use DES Cipher Block Chaining encryption algorithm.
                     You will be prompted for a key, unless you specify one
                     on the command line via the -k option.

      Mailkit recognizes the following options:

      -E             Edit instructions which will be sent as part #0.

      -F             Get instructions to be sent as part #0 from standard
                     input.

      -V             Print version number and patchlevel.

      -c             Clean up after each part sent: all the parts
                     successfully sent will be removed from the disk.

      -e             Edit instructions to be sent at the top of each part.

      -f             Get instructions to be sent at the top of each part
                     from standard input.

      -h             Print usage and option summary.

      -l file        Get the recipient list from a file (one recipient per
                     line).

      -n basename    Set the basename of the generated parts. The default is
                     Kit. You should use this option when more than one kit
                     is present in the current directory, or when you used
                     the kit's -n option to change the default basename.

      -p             Preserve files sent. This is the default, unless -c is
                     specified.

      -r range       Specify which parts are to be sent. For instance, -r
                     1,4-7 would send part #1 and then parts #4 through #7.

      Unkit uses the following options:

      -S             Complain loudly and abort if perl is not found, since
                     that would make it impossible to check each kit part
                     for possible alien code before running them through the
                     shell.

      -V             Print version number and patchlevel.

      -b             Force usage of badtar.

      -d dir         Go to dir before starting extraction.





                                    - 6 -        Formatted:  January 2, 2025






 KIT(1)                                                               KIT(1)
                              Version 2.0 PL28



      -h             Print usage and option summary.

      -k key         Set the key to be used for data decryption. Unkit is
                     able to determine automatically whether decryption is
                     needed or not and will prompt you for the key unless
                     this option is used.

      -l             Lists the files contained in the kit package without
                     extracting them.

      -r             Remove input files if unshar succeeds.

      -s             Force skipping of security checks, which are conducted
                     only if perl is available in your PATH.

 FILES
      {zag,zcb,zec}.hex.*
                     temporary files used by kit and unkit for datas which
                     are hex-encoded.
      {zag,zcb,zec}.ba.*
                     temporary files used by kit and unkit for datas which
                     are ASCII-encoded.
      Kit*           files generated by kit
      zag*           non encrypted temporary files.
      zcb*           data encrypted using CBC mode.
      zec*           data encrypted using ECB mode.
      zzz.minikit    file holding the name of the extras files added by kit.
      zzz.ack        contains the address where acknowledgment should be
                     sent.
      zzz.subject    contains the name of kit archive for acknowledgment
                     purposes.
      /opt/kit/lib/minikit
                     the script which may be used to unkit a distribution
                     when the kit package is not available.
      /opt/kit/lib/makeshar
                     the script which emulates cshar's makekit program.
      /opt/kit/lib/rshar
                     a simple shell archive maker.
      /opt/kit/lib/secure
                     security checks (detection of alien code) in kit
                     archives.

 ENVIRONMENT
      The following environment variables are paid attention to by mailkit.
      If they are not set, a default determined at configuration time will
      be used:

      EDITOR         the name of the editor to call when -E option and
                     friends are used.





                                    - 7 -        Formatted:  January 2, 2025






 KIT(1)                                                               KIT(1)
                              Version 2.0 PL28



      MAILER         the name of the program to invoke to send mail. This
                     program must be ready to take a list of addresses as
                     argument and the whole message (with some headers
                     already computed) from standard input.

 NOTES
      Kit may now be used as a standalone package, i.e. without the help of
      the cshar distribution.  This was not true before version 2.0 PL10.
      Two simple shell scripts now emulate cshar's behaviour. Those scripts
      are held in the private library directory because they are not
      intended to be used directly by any user.

      In order to use kit, hexdecode, hexencode, atob and btoa must be
      installed and compress must be available.  If any of these is missing,
      this mailing kit is useless.

      Unkit has its own unshar built-in, but it will not be used if unshar
      is installed, because it is really simple-minded and not smart at all
      in case of errors. However, this is useful if you do not have cshar,
      but still want to use unkit.

 EXAMPLES
      To mail ram@educ.emse.fr a directory called XLOCK and all what it may
      hold, do:

           kit XLOCK
           mailkit XLOCK ram@educ.emse.fr

      Kit will produce files Kit*, and mailkit will send them.  Or, to do it
      all in one:

           kit -m ram@educ.emse.fr XLOCK

      Assuming the XLOCK package has 5 kit parts, you could send only parts
      3 and 5 by using:

           mailkit -r 3,5 XLOCK ram@eiffel.com

      If you have no write permissions in the current directory, you can
      specify an alternate directory for temporary files:

           kit -m ram@eiffel.com -d /tmp -n mykit XLOCK

      To unkit, save the mail messages in files called, e.g. xlock.01 (for
      part 01), xlock.02 (for part 02) and so on.  Then do:

           unkit xlock*

      Even if it succeeds, files xlock* will not be removed.





                                    - 8 -        Formatted:  January 2, 2025






 KIT(1)                                                               KIT(1)
                              Version 2.0 PL28



 BUGS
      Try "kit .": it is harmless (well, I hope !), and you will quickly
      understand the problem. The solution is to use the -d option.

      If you use the -r option in unkit and one or more kit parts are
      missing, all the files will be lost.  So use it with care...

      Some systems cannot extract tar archives with overwriting of ownership
      informations (usually this is done with tar option -o).

      The -M option is unknown to versions of kit prior to 2.0 PL9, which
      means the remote unkit program will not be able to clean-up the extras
      files. Similarly, the automatic acknowledgment feature was added at
      2.0 PL15. Fortunately, kit programs newer than 2.0 PL9 will know how
      to deal with the extras files, although the acknowledgment feature
      itself will only be handled by 2.0 PL15 and later versions.

 SEE ALSO
      atob(1), btoa(1), unshar(1), makekit(1).

 AUTHOR
      Raphael Manfredi <ram@acri.fr>.

      Kit was first developed at the Ecole des Mines, Saint-Etienne, France.
      Many improvements were added at Interactive Software Engineering Inc.,
      Santa-Barbara CA, USA.




























                                    - 9 -        Formatted:  January 2, 2025