apt-offline

Section: USER COMMANDS (8)
Updated: May, 2017
Page Index
 

NAME

apt-offline - Offline APT Package manager  

SYNOPSIS

apt-offline [ARGUMENTS] [OPTIONS]

 

DESCRIPTION

apt-offline brings offline package management functionality to Debian based system. It can be used to download packages and its dependencies to be installed later on (or required to update) a disconnected machine. Packages can be downloaded from a different connected machine.

It can also fetch bug reports for the packages that are downloaded.

Unless the -h/-v or --help/--version options are given, one of the get, set or install commands must be provided.

 

set FILENAME [-h] [--install-packages PKG...PKG_N] [--install-src-packages PKG...PKG_N] --src-build-dep [--release release_name] [--update] [--upgrade] [--upgrade-type upgrade]

set generates a signature file with the data required to install on or update the disconnected machine.

FILENAME {apt-offline.sig} is the signature file generated on the machine. This file will contain all the information necessary for apt.

--install-packages [PKG...PKG_N]
Packages that need to be installed

--install-src-packages [PKG...PKG_N]
Source packages that need to be installed

--src-build-dep
Download Build Dependency packages for the source packages requested

--release release_name
Release target to install packages from

--apt-backend apt-get
APT backend to use. One of: apt, apt-get, python-apt

--generate-changelog
Generate changelog of the version to be downloaded

--update
Generate APT Database signature for an update. This is the equivalent of using apt-get update

--upgrade
Generate APT Database signature for package upgrade. This is the equivalent of using apt-get upgrade

--upgrade-type {upgrade_type}
Type of upgrade you would like to perform. Default is upgrade. Other valid types are dist-upgrade and dselect-upgrade

Note:
If neither of the --update or --upgrade option is explicitly mentioned, the set command will generate signature for both the --update and --upgrade options.

 

get FILENAME [-h] [--socket-timeout ] [-d / --download-dir] [-s / --cache-dir] [--no-checksum] [-t / --threads ] [--bundle] [--bug-reports] [--proxy-host] [--proxy-port]

get downloads APT data as per a signature file.

FILENAME {apt-offline.sig} is the signature file required for details about data to be downloaded. This file should have been generated by the above set command.

-d, --download-dir DIR_NAME
Download data to the specified DIR_NAME folder. If no folder name is specified, data is downloaded to a folder in the TEMPDIR path in the format apt-offline-download-$PID

-s, --cache-dir DIR_NAME
Look for data in the cache before downloading it from the internet. If you are on a Debian box, you would want to specify /var/cache/apt/archives here. If the data is not available in the cache, the downloaded data is also copied to the cache.

--no-checksum
Enabling this option will bypass the checksum verification of each downloaded file thus losing integrity of the package. Usage of this option is highly discouraged

-t, --threads NUM_OF_THREADS
Number of threads to spawn for downloads. Default is 1. Using too many threads can overload the servers, hence it is advisable to keep the number low

--bundle FILENAME
Create an archive file FILENAME. The file is archived in zip format

--bug-reports
Download bug reports for packages that are being downloaded. Currently only the Debian BTS is supported.

--proxy-host
Specify the Proxy Host to be used.

--proxy-port
Specify the Proxy port number to be used.

 

install FILE/FOLDER [-h] [--skip-bug-reports ] [--install-src-path PATH] [--allow-unauthenticated]

install installs APT data to the APT package database and updates it.

FILE {archive_bundle_file} Install data from the archive (bundle) file.

FOLDER {/folder/path} Install data from the folder path.

Either FILE or FOLDER argument can be provided to the install command.

--skip-bug-reports
Skip listing of downloaded bug reports, if any.

--skip-changelog
Skip display of changelog, if any.

--allow-unauthenticated
Don't verify GPG signatures for the data to be installed to APT. Usage of this option is highly discouraged.

--install-src-path PATH
Path to filesystem where we want the source packages to be installed to. Default will be a folder in your TEMPDIR.

 

GLOBAL OPTIONS

-h, --help
Show help message

--verbose
Run in verbose mode

--simulate
Developer only. Used for testing.

-v, --version
Display the version of the program

 

EXAMPLES

NOTE: argument/option handling
apt-offline relies on argparse for argument/option parsing. To explicitly instruct apt-offline about an argument, you can pass it with the -- delimiter.

Ex. apt-offline set --update --upgrade --install-packages wm2 -- foo.sig

By specifying the -- delimiter, we instruct apt-offline that foo.sig is an argument to the apt-offline command and not to the --install-packages option.

Otherwise, you could also use it positionally next to the set command

Ex. apt-offline set foo.sig --update --upgrade --install-packages wm2

apt-offline set FILENAME
This command will generate a signature file FILENAME for APT Package Database. To generate only the signature for updates, use the --update option. To generate only the signature for package upgrades, use the --upgrade option. Default behavior when no options are specified is to generate a signature for both the operations.

apt-offline get FILENAME
This command will fetch the data required for APT Package Database as per the signature file FILENAME generated by apt-offline get. To download bug reports also use the --bug-reports option. Currently supported bug tracker is Debian BTS only. By default, if neither of -d or --bundle options are specified, apt-offline downloads data into a folder inside the TEMPDIR environment folder in the format apt-offline-downloads-PID, where PID is the PID of the running apt-offline process. Example on a linux machine would be something like: /tmp/apt-offline-downloads-23242/

apt-offline install FILE|FOLDER
This command will sync the data downloaded by apt-offline get to the APT Package Database and update it. Depending on where the data was downloaded to or packed into, either the absolute FOLDER path or the archive FILE path can be specified.

NOTE1: On a freshly installed box, that was installed without the network, the package database is null. In that case, you first need to run apt-offline with just the --update option to ensure you have a meaningful package database

Example: apt-offline set set.uris --update

NOTE2: On a fresh setup installed through CD/DVD, the default APT setting lists only the install media URLs. In such case, you need to add the default APT network repositories to the list. For example, for a fresh (DVD) installed Debian box, add the relevant repository to

/etc/apt/sources.list.d/apt-offline.list or /etc/apt/sources.list

deb http://httpredir.debian.org/debian stable main contrib

(For Debian Stable)

deb http://httpredir.debian.org/debian unstable main contrib

(For Debian Unstable/Sid)

deb http://httpredir.debian.org/debian stretch main contrib

(For Debian Stretch)

deb http://security.debian.org stable/updates main contrib

(Security Updates for Debian Stable)

deb http://security.debian.org testing/updates main contrib

(Security Updates for Debian Testing)

Sequence 1: The following set of commands, when run in sequence, will update a disconnected machine.

apt-offline set update.sig --update

(Generate the required data needed to update the APT database. Should be run on the disconnected machine)

apt-offline get update.sig --bundle update.zip

(Download the required data needed to update the APT database. Should be run on a machine with internet connectivity)

apt-offline install update.zip

(Installs the data needed to update the APT database. Should be run on the disconnected machine)

Sequence 2: With successful completion of Sequence 1, the APT database on the disconnected machine will be up-to-date. Now, the following set of commands, when run in sequence, will upgrade a disconnected machine.

apt-offline set upgrade.sig --upgrade

(Genereate the required data needed to upgrade the upgradable packages. Should be run on the disconnected machine)

apt-offline get upgrade.sig --bundle upgrade.zip

(Download the required data needed to upgrade the upgradable packages. Should be run on a machine with internet connectivity)

apt-offline install upgrade.zip

(Installs the data needed to upgrade the upgradable packages. Should be run on the disconnected machine)

After successful completion of
Sequence 1 and Sequence 2 in order, further running apt-get upgrade will result in 0 bytes of additional download.

 

AUTHOR

apt-offline is written by Ritesh Raj Sarraf (rrs@researchut.com)

If you wish to report a bug in apt-offline, please see http://apt-offline.alioth.debian.org or http://github.com/rickysarraf/apt-offline or else, send an email to me at rrs@researchut.com

 

SEE ALSO

apt-get(8), apt-cache(8), dpkg(8), aptitude(8),

 

DEDICATION

This software is dedicated to the memory of my father Santosh Kumar Sarraf. We miss you a lot.


 

Index

NAME
SYNOPSIS
DESCRIPTION
set FILENAME [-h] [--install-packages PKG...PKG_N] [--install-src-packages PKG...PKG_N] --src-build-dep [--release release_name] [--update] [--upgrade] [--upgrade-type upgrade]
get FILENAME [-h] [--socket-timeout ] [-d / --download-dir] [-s / --cache-dir] [--no-checksum] [-t / --threads ] [--bundle] [--bug-reports] [--proxy-host] [--proxy-port]
install FILE/FOLDER [-h] [--skip-bug-reports ] [--install-src-path PATH] [--allow-unauthenticated]
GLOBAL OPTIONS
EXAMPLES
AUTHOR
SEE ALSO
DEDICATION