Subject: SOC project proposal: easy updates
To: NetBSD tech-install mailing list <tech-install@netbsd.org>
From: Julian Coleman <jdc@coris.org.uk>
List: tech-install
Date: 03/15/2007 03:42:27
Hi,

How does this sound as an SoC project proposal?

Thanks,

J

  - - 8< - - - - - - - - - - - - - Cut here - - - - - - - - - - - - - >8 - -

  Easy updates for NetBSD systems

  Project summary:
    Estimated difficulty: Medium
    Person/group of contact: Julian Coleman <jdc AT netbsd.org>
    Person/group of contact: tech-misc mailing list
    Person/group of contact: tech-install mailing list

  Add the ability to easily update NetBSD systems with security patches and
  OS updates.

  This project involves work in two major areas.  The first area is the
  NetBSD build process, where the framework for updates needs be added
  into the build process.  The second area is the client side, where the
  mechanisms for discovering and installing updates need to be written.

  There is unfinished work where all the installed files in the NetBSD
  system are tagged with a system package (syspkg) name.  This work needs
  to be finished, so that all installed system files are recorded in a
  similar fashion to the way that pkgsrc files are recorded.  This will
  be an additional part of the NetBSD build process.

  For system updates, for example the change from 3.0 to 3.0.1 or 3.1, not
  all the installed system files are updated.  The NetBSD build process
  should be extended to compare the results of the "base" system build
  (e.g. 3.0) and the results of the "update" system build (e.g. 3.0.1).
  This comparison will generate a collection of system packages that need
  to be installed in order to update the system to the newer version.
  Security patches, which usually affect a small number of system packages
  could be handled in the same way.  For ease of installation and
  administration, each update should be a superset of the previous ones.

  On the client side, a tool needs to be written to handle system package
  updates.  This could be an extension to the existing `sysinst` program.
  The tool needs to compare the list of currently installed system packages
  with the list of newer system packages available for download.  For
  example, the program could determine that the the base system is 3.0 and
  discover that there are updates available to 3.0.1, 3.0.2 and 3.1, as well
  as security patches for 3.0.2 and 3.1.  The way in which this information
  is generated for the client tool needs to be determined, as it needs to an
  integral part of the build process, above.

  The client tool needs to be able to safely backup the existing system
  packages and install the new versions.  When the user is happy with the
  new packages, the previous versions can be removed.

  Project deliverables:
    build system: "database" of installed system packages, with versions
    build system: ability to compare two NetBSD builds to determine which
      system packages are changed
    build system: creation of downloadable system package "update list" for
      updated packages
    client tool: query and compare installed system package list and update
      list(s) from server(s)
    client tool: backup obsoleted system packages, download and install
      updated system packages

  Background investigations:
    NetBSD build process
    NetBSD syspkg infrastructure
    pkgsrc databse of installed files and packages
    Other OS update mechanisms (e.g. FreeBSD)

  Knowledge required:
    C programming
    Makefile programming
    Shell script programming

  - - 8< - - - - - - - - - - - - - Cut here - - - - - - - - - - - - - >8 - -

-- 
  My other computer also runs NetBSD    /        Sailing at Newbiggin
        http://www.netbsd.org/        /   http://www.newbigginsailingclub.org/