Peter, Thank you for request for ideas and desires regarding the next improvement to the debian package management system.
1. Scripts provided by the package writer should only have access to files and directories specifically approved by the installer. 2. Most packages do not need to alter existing system directories or files, and should be installed and tested by an unprivelaged user (specified by the installer) in a directory chosen by the installer, and under which package scripts can create and modify files. 3. After testing, the installer should use ln -s, ln, or cp (as chosen by the installer) to integrate the package executables and files into the system. Ray Ingles and I, have spent some time discussing improvements to dpkg/dselect to permit users to take advantage of its dependency tracking without the security vulnerability entailed in always running it as root. The following is a first draft of a processing model (similar to the ISO network model) that hopes to provide the following: 1. Host selectable security - the installer chooses what level of trust (unprivelaged, privelaged, root) to grant to the package scripts. 2. Host testing - before the package is seen by other users, the installer can test the package 3. Portability - package writer can assume a single (or small number) of directories in which to create, modify, compile, configure, files and executables, independent of the platform or host ---- cut here ---- * Project: debian File: RFC: dpkg target model Author: Raymond A. Ingles Dr. Robert J. Meier, Jr. History: 97-04-03 -rjm- file creation * Goals ** ease of use The package provider and the installation process should automate as much of the installation and removal as feasible for ease of use. All operations should have defaults to support ease of use. ** security As far as possible, malicious or buggy package installation should not endanger existing installations. All default operations should be defined by the install procedure so as not to endanger existing installations. All package-suggested operation parameters must be individually approvable by the human installer. Successful or unsuccessful installation is completely reversible. ** flexibility As far as possible, package installation should be configurable by the host to meet individual user needs and concerns. As far as possible, package installation should be configurable by the host to meet individual package needs and concerns. All install operation parameters should be selectable by the installer. All install operation parameters should be suggestible by the package. ** repeatability As far as possible, package installation should produce the same behavior on different hosts (e.g. the package provider and the user). By default, installation will be done under a single host-selected directory with an image equivalent on the user host to that to the package provider host. * For design purposes, installation is divided into the following phases. ** (Template) Each phase needs to answer the provide answers to each of the following questions. The answers must express the minimum/default/maximum supplied by/required from the package/host. *** System privileges *** Host information *** Package information *** Intended results *** Prior assumptions *** Actions *** Validation *** Customization ** Download *** System privileges Minimum supplied by host: write a host-specified file as $DOWNLOADER. Default supplied by host: write a host-specified file as $DOWNLOADER. Maximum supplied by host: write host-specified files as $DOWNLOADER *** Host information Minimum supplied by host: $PACKAGEROOT Default supplied by host: $PACKAGEROOT Maximum supplied by package: filenames *** Package information Minimum supplied by package: number and description of required files and directories. Default supplied by package: number and description of required files (1) and directories (1) *** Intended results Minimum supplied by host: transfer the package to local file system Default supplied by host: transfer the package to local file system Maximum supplied by host: transfer the package to local file system Minimum supplied by package: from package file Default supplied by package: ftp, cd-read, floppy-read Maximum supplied by package: from net, cd, floppies, tape, etc. *** Prior assumptions Minimum supplied by package: the complete package is transferrable as a single file Default supplied by package: the complete package is a compressed tar file *** Actions Minimum supplied by host: Create a specified file in (a directory chosen by host) writable by $DOWNLOADER. Default supplied by host: Create the $PACKAGEROOT directory under $INSTALLER ownership. Default supplied by host: Create a specified file in $PACKAGEROOT writable by $DOWNLOADER. Maximum supplied by host: Create other directories under $INSTALLER ownership. Maximum supplied by host: Create specified files in specific directories writable by $DOWNLOADER. *** Validation Minimum supplied by host: none Default supplied by host: file length verification Minimum required by package: none Default supplied by package: none *** Customization Minimum supplied by host: none Default supplied by host: none Maximum supplied by host: none Minimum supplied by package: none Default supplied by package: none Maximum supplied by package: none ** Extraction *** System privileges Minimum supplied by host: create files and directories under $PACKAGEROOT as $INSTALLER. Default supplied by host: create files and directories under $PACKAGEROOT as $INSTALLER. Maximum supplied by host: create files and directories under host-specified directories $INSTALLER. Default required by package: create files and directories under $PACKAGEROOT as $INSTALLER. *** Host information Minimum supplied by host: $PACKAGEROOT Default supplied by host: $PACKAGEROOT Maximum supplied by package: filenames and directories relative to host-specified roots *** Package information Minimum supplied by package: extraction method (tar -zxvf) Minimum supplied by package: licensing restrictions (tar -zxvf) Default supplied by package: number of required directories (1) and human description of extra directories Default supplied by package: extraction method (tar -zxvf) Default supplied by package: minimum hardware/firmware requirements Default supplied by package: licensing restrictions (tar -zxvf) *** Intended results Minimum supplied by host: duplicate image of the package providers local file system under single host-chosen root directory Default supplied by host: duplicate image of the package providers local file system under single host-chosen root directory Maximum supplied by host: duplicate image of the package providers local file system under single host-chosen root directory *** Prior assumptions Minimum supplied by package: buildable from local file system under a few host-chosen root directories Maximum supplied by package: buildable from local file system under single host-chosen root directory Default supplied by package: buildable from local file system under single host-chosen root directory *** Actions Minimum supplied by host: Decompress and expand a specified file as $EXTRACTOR under $PACKAGEROOT. Default supplied by host: Decompress and expand a specified file as $EXTRACTOR under $PACKAGEROOT. Maximum supplied by host: Decompress and expand specified files as $EXTRACTOR under host-chosen directories. *** Validation Minimum supplied by host: none Default supplied by host: file size and list verification Minimum supplied by package: none Maximum supplied by package: file size and manifest *** Customization Minimum supplied by host: none Default supplied by host: none Maximum supplied by host: prompt for operator approval with description deny script authority, pause installation (default), examine script execute script as $INSTALLER Minimum supplied by package: none Default supplied by package: none Maximum supplied by package: script and description ** Setup This will normally be a no-op, since by default, the extracted file system image is sufficient. *** System privileges Minimum supplied by host: create files and directories under $PACKAGEROOT as $INSTALLER. Default supplied by host: create files, links, nodes, directories, etc. under $PACKAGEROOT as $INSTALLER. Maximum supplied by host: create files, links, nodes, directories, etc. under $PACKAGEROOT as $INSTALLER. Default required by package: create files, links, nodes, directories, etc. under $PACKAGEROOT as $INSTALLER. *** Host information Minimum supplied by host: $PACKAGEROOT Default supplied by host: $PACKAGEROOT Default supplied by package: none *** Package information Minimum supplied by package: none Default supplied by package: none Maximum supplied by package: script to execute as $INSTALLER. *** Intended results Minimum supplied by host: duplicate build environment designed by package provider Default supplied by host: duplicate build environment designed by package provider Maximum supplied by host: duplicate build environment designed by package provider *** Prior assumptions Minimum supplied by package: duplicated environment limitted by the installation procedure is sufficient to build the package Default supplied by package: duplicated environment limitted by the installation procedure is sufficient to build the package *** Actions Minimum supplied by host: none Default supplied by host: none Maximum supplied by host: execute script as $INSTALLER *** Validation Minimum supplied by host: none Default supplied by host: file size and list verification Minimum supplied by package: none Maximum supplied by package: file size and manifest *** Customization Minimum supplied by host: none Default supplied by host: none Maximum supplied by host: prompt for operator approval with description deny script authority, pause installation (default), examine script execute script Minimum supplied by package: none Default supplied by package: none Maximum supplied by package: perl script and description ** Configuration *** System privileges Minimum supplied by host: execute scripts relative to $PACKAGEROOT as $INSTALLER. Default supplied by host: execute scripts relative to $PACKAGEROOT as $INSTALLER. Maximum supplied by host: execute scripts relative to host-specified directories as $INSTALLER. Default required by package: execute scripts relative to $PACKAGEROOT as $INSTALLER. *** Host information Minimum supplied by host: $PACKAGEROOT Default supplied by host: sh, perl, bash Default supplied by package: none *** Package information Minimum supplied by package: none Default supplied by package: make config Maximum supplied by package: script to execute as $INSTALLER. *** Intended results Minimum supplied by package: generate default Makefiles Default supplied by package: probe machine for common configuration variations Default supplied by package: generate human readable configuration file Maximum supplied by package: interactively query human for all configuration variations *** Prior assumptions Maximum required by package: build environment is duplicated correctly Default required by package: build environment is duplicated correctly *** Actions Minimum supplied by host: execute script as $INSTALLER Default supplied by host: execute script as $INSTALLER Maximum supplied by host: execute script as $INSTALLER *** Validation Minimum supplied by host: none Default supplied by host: none Minimum supplied by package: none Default supplied by package: none *** Customization Minimum supplied by host: none Default supplied by host: none Maximum supplied by host: prompt for operator approval with description deny script authority, pause installation (default), examine script execute script Minimum supplied by package: none Default supplied by package: none Maximum supplied by package: script and description ** Customization This will normally be a no-op, since by default, configuration should be sufficient. *** System privileges Minimum supplied by host: create files and directories under $PACKAGEROOT as $INSTALLER. Default supplied by host: create files, links, nodes, directories, etc. under $PACKAGEROOT as $INSTALLER. Maximum supplied by host: create files, links, nodes, directories, etc. under $PACKAGEROOT as $INSTALLER. Default required by package: none *** Host information Minimum supplied by host: $PACKAGEROOT Default supplied by host: $PACKAGEROOT Default supplied by package: none *** Package information Minimum supplied by package: none Default supplied by package: none Maximum supplied by package: human readable procedure *** Intended results Minimum supplied by host: none Default supplied by host: none *** Prior assumptions Minimum supplied by package: duplicated environment ready for automatic build Default supplied by package: duplicated environment ready for automatic build *** Actions Minimum supplied by host: none Default supplied by host: none Maximum supplied by host: execute script as $INSTALLER *** Validation Minimum supplied by host: none Default supplied by host: none Minimum supplied by package: none Maximum supplied by package: none *** Customization Minimum supplied by host: none Default supplied by host: none Maximum supplied by host: prompt for operator approval with description deny script authority, pause installation (default), examine script execute script Minimum supplied by package: none Default supplied by package: none Maximum supplied by package: perl script and description ** Build This will normally be a totally automatic after proper configuration. *** System privileges Minimum supplied by host: execute scripts under $PACKAGEROOT as $INSTALLER. Default supplied by host: execute scripts under $PACKAGEROOT as $INSTALLER. Maximum supplied by host: execute scripts under $PACKAGEROOT as $INSTALLER. Default required by package: execute scripts under $PACKAGEROOT as $INSTALLER. *** Host information Minimum supplied by host: $PACKAGEROOT Default supplied by host: $PACKAGEROOT Default supplied by package: none *** Package information Minimum supplied by package: Makefile(s) Default supplied by package: Makefile(s) Maximum supplied by package: executable scripts *** Intended results Minimum supplied by host: testable installation of package Default supplied by host: usable installation of package *** Prior assumptions Minimum supplied by package: duplicated environment ready for automatic build Default supplied by package: duplicated environment ready for automatic build *** Actions Minimum supplied by host: make under $PACKAGEROOT as $INSTALLER. Default supplied by host: make under $PACKAGEROOT as $INSTALLER. Maximum supplied by host: make under $PACKAGEROOT as $INSTALLER. *** Validation Minimum supplied by host: none Default supplied by host: make under $PACKAGEROOT as $INSTALLER. Minimum supplied by package: none Default supplied by package: Makefiles Maximum supplied by package: complete regression suite *** Customization Minimum supplied by host: none Default supplied by host: none Maximum supplied by host: prompt for operator approval with description deny script authority, pause installation (default), examine script execute script Minimum supplied by package: none Default supplied by package: none Maximum supplied by package: perl script and description ** Soak This will normally be a totally non-automatic check by the human installer before integration. The human installer will usually change username and group to an unprivileged user otherwise typical of the expected user community. Temporary environment variables (e.g. $PATH) will point the test user to $PACKAGEROOT/... *** System privileges Minimum supplied by host: execute scripts under $PACKAGEROOT as $INSTALLER. Default supplied by host: execute scripts under $PACKAGEROOT as $INSTALLER. Maximum supplied by host: execute scripts under $PACKAGEROOT as $INSTALLER. Maximum supplied by package: none *** Host information Minimum supplied by host: $PACKAGEROOT Default supplied by host: $PACKAGEROOT Maximum supplied by package: none *** Package information Maximum supplied by package: none *** Intended results Minimum supplied by host: confidence that the package is non-destructive Default supplied by host: confidence that the package is non-destructive Default supplied by host: confidence that the package is fit for use *** Prior assumptions Minimum supplied by host: package is completely built Default supplied by host: package is completely built *** Actions Minimum supplied by host: pause installation procedure Default supplied by host: pause installation procedure Maximum supplied by host: pause installation procedure *** Validation Minimum supplied by host: none Default supplied by host: none Maximum supplied by package: none *** Customization Maximum supplied by host: none Minimum supplied by package: none Default supplied by package: none Maximum supplied by package: human readable description ** Integration This will normally be totally automatic according to local configuration files. *** System Privileges Minimum supplied by host: execute scripts under $PACKAGEROOT as $TOOLMANAGER Default supplied by host: execute scripts under $PACKAGEROOT as $TOOLMANAGER Maximum supplied by host: tools are not writable by group bin or other. (lest they be vulnerable during installation by tool.bin) Maximum required by package: none *** Host information Minimum supplied by host: $PACKAGEROOT Default supplied by host: $PACKAGEROOT Default supplied by package: none *** Package information Maximum supplied by package: none *** Intended results Minimum supplied by host: package ready for use Default supplied by host: package ready for use *** Prior assumptions Minimum supplied by package: package tested and found satisfactory Default supplied by package: package tested and found satisfactory *** Actions Minimum supplied by host: recursively walk $PACKAGEROOT/[bin doc lib etc] and create matching directory under $TOOLROOT Minimum supplied by host: create symbolic links from files under $PACKAGEROOT/[bin doc lib etc] to matching files under $TOOLROOT Default supplied by host: recursively walk $PACKAGEROOT/$STDDIRS and create matching directory under $TOOLROOT Default supplied by host: create symbolic links from files under $PACKAGEROOT/$STDDIRS to matching files under $TOOLROOT Maximum supplied by package: none *** Validation Minimum supplied by host: none Default supplied by host: none Maximum supplied by package: none *** Customization Minimum supplied by host: none Default supplied by host: none Maximum supplied by package: human readable description ** Cleanup This will normally be totally automatic according to local configuration files. *** System Privileges Minimum supplied by host: write directories under $PACKAGEROOT as $INSTALLER Default supplied by host: write directories under $PACKAGEROOT as $INSTALLER Maximum required by package: write directories under $PACKAGEROOT as $INSTALLER *** Host information Minimum supplied by host: $PACKAGEROOT Default supplied by host: $PACKAGEROOT Default supplied by package: none *** Package information Maximum supplied by package: list of files, nodes, directories, ... under $PACKAGEROOT to remove *** Intended results Minimum supplied by host: reclaim disk space no longer necessary for package use Default supplied by host: reclaim disk space no longer necessary for package use *** Prior assumptions Minimum supplied by package: package integrated and found satisfactory Default supplied by package: package integrated and found satisfactory *** Actions Minimum supplied by host: remove named files, nodes, directories, ... under $PACKAGEROOT Default supplied by host: remove named files, nodes, directories, ... under $PACKAGEROOT Maximum supplied by host: remove named files, nodes, directories, ... under $PACKAGEROOT Maximum supplied by package: none *** Validation Minimum supplied by host: none Default supplied by host: check for .o's, .olds, ... directories other than those linked during integration Maximum supplied by package: none *** Customization Minimum supplied by host: none Default supplied by host: none Maximum supplied by package: human readable description ** Removal This should remove everything safely even if installation fails. *** System Privileges Default supplied by host: write $PACKAGEROOT and the other install-specified directories as $TOOLMANAGER *** Host information Minimum supplied by host: $PACKAGEROOT Default supplied by host: $PACKAGEROOT Default supplied by package: none *** Package information Maximum supplied by package: none *** Intended results Minimum supplied by host: reclaim disk space used by the package Default supplied by host: cleanly reverse installation *** Prior assumptions Default supplied by host: everything was installed under $PACKAGEROOT or specified directories Default supplied by host: everything else was linked/copied by the installer *** Actions Default supplied by host: remove $PACKAGEROOT and the other install-specified directories Default supplied by host: remove symlinks into $PACKAGEROOT and the other install-specified directories Maximum supplied by package: none *** Validation Minimum supplied by host: verify absence of $PACKAGEROOT and install-specified directories Default supplied by host: verify absence of symlinks into $PACKAGEROOT and install-specified directories Maximum supplied by package: none *** Customization Minimum supplied by host: none Default supplied by host: none Maximum supplied by package: human readable description * For design purposes, installation information is divided into the following groups. ** Host information ***defaults PACKAGEDIR = /usr/package PACKAGEROOT = $PACKAGEDIR/<package> STDDIRS = bin lib doc etc TOOLROOT = /usr/local TOOLMANAGER = bin.bin DOWNLOADER = $TOOLMANAGER EXTRACTOR = $TOOLMANAGER INSTALLER = tool.bin INTEGRATOR = $TOOLMANAGER ***primary installation directory (PACKAGEROOT) default: $PACKAGEROOT ***primary usage directory default: $TOOLROOT ** Package information *** number of independent directory roots required default: 1 ** Installer information *** owner of primary installation directory root default: $TOOLMANAGER *** owner of primary installation directory default $INSTALLER ---- cut here ---- Reporting, -- Robert Meier FANUC Robotics North America, Inc. Internet: [EMAIL PROTECTED] Voice: 1-810-377-7469 Fax: 1-810-377-7363