Date: Tue, 18 Dec 2007 19:41:50 -0800 From: Garrett Cooper <youshi10@u.washington.edu> To: current@freebsd.org Subject: Fwd: YAFI or Yet Another FreeBSD Installer Message-ID: <766AE492-7772-4D22-AD68-36FA34612636@u.washington.edu> References: <239A880E-674A-4A45-A742-3A45E12700CF@u.washington.edu>
next in thread | previous in thread | raw e-mail | index | archive | help
> From: Garrett Cooper <youshi10@u.washington.edu> > Date: December 18, 2007 4:55:41 PM PST > To: mtm@FreeBSD.Org > Subject: Re: YAFI or Yet Another FreeBSD Installer > > On Dec 18, 2007, at 3:24 PM, Mike Makonnen wrote: > >> Hi folks, >> >> I've been working on an installer for FreeBSD for the past month, >> and I've finally come along far enough that I have something usable >> that people can play with and provide feedback. >> >> Our sysinstall(8) is actually pretty darn nice. No really. Think >> about >> it. Forget for a moment that it doesn't have a spiffy GUI and look at >> some of the things it does right: >> 1. It doesn't have any 3rd party dependency (it builds out of >> the src >> tree). >> 2. You're not limited by the physical media the installer is on. >> You can install from CD, FTP, HTTP, NFS, UFS, FAT, etc. >> 3. If you want to build your own release you can use a >> configuration >> file for unattended setup. >> 4. libdisk(3) >> >> On the other hand it suffers from one major flaw (which is the root >> cause of its other problems): the presentation and logic is so >> tightly >> coupled together that it's damn hard to make non-trivial changes >> without >> breaking it. So, it hasn't been able to move with the times or change >> significantly over the years because it would essentially have >> meant a >> complete rewrite. >> >> The DragonFly folks went ahead and did a complete re-write, but while >> their implementation addressed sysinstall's major problem, they >> didn't >> keep (or re-implement) its good points. Worse, from our stand-point, >> the BSD Installer (www.bsdinstaller.org) only works from a live-cd >> and depends on messy command lines and string-parsing to install the >> system. Recently, I believe they've gone even further and re- >> implemented >> the back-end using the Lua scripting language (making it even more >> unusable for us). Having said that; however, there is one thing that >> I really like about it: they've managed to completely divorce the >> presentation layer from the installer logic. All the logic for >> installing the system is contained in the back-end application, and >> all the front-end does is essentially just display forms and return >> the user's choices to the back-end. What I like even better is that >> the front-end and the back-end don't even have to be on the same >> machine, which opens up a whole new area of installation options. >> >> So essentially, what I'm doing is taking all the parts I like about >> sysinstall(8), putting it on the framework provided by the BSD >> Installer >> folks, and adding a couple of ideas of my own. Here's what I envision >> the end-product to look like: >> 1. One back-end (in C), multiple front-ends (curses, web >> browser, X) >> 2. Supports multiple installation media >> 3. XML based application configuration >> - no hard coded options/distributions/packages in source >> files >> - no flat file (key=value) configuration files >> 4. Supports Internationalization >> 5. Clean and modular backend so that the installer can grow right >> along FreeBSD itself (i.e. - ZFS support, etc) >> >> What I have so far is alpha quality. It will install a basic FreeBSD >> system that you can boot into, but that's about it. It works on >> i386/amd64, uses libdisk(3) for slicing and dicing disks, and looks >> for the install cd on the first IDE CD-Rom. It installs the complete >> base system (all distributions), and doesn't know about packages yet. >> >> You can find the tarball at: http://people.freebsd.org/~mtm/ >> fin.tar.bz2 >> The tarball contains the modified BSD Installer source code, a script >> to copy the code into the right places in the source tree, and a diff >> against src/ to integrate it into the build system and make a release >> CD. >> The script I use to build a release is here: >> http://people.freebsd.org/~mtm/scripts/makerelease >> >> I'm very much interested in your comments and suggestions. >> >> Cheers. >> -- >> Mike Makonnen | GPG-KEY: http://people.freebsd.org/~mtm/ >> mtm.asc >> mmakonnen @ gmail.com | AC7B 5672 2D11 F4D0 EBF8 5279 5359 2B82 >> 7CD4 1F55 >> mtm @ FreeBSD.Org | FreeBSD - http://www.freebsd.org > > That's awesome! I assume that certain GUI~ish features can now be > invoked via the command line like the disklabel editor? That would > be the ultimate next step if it's not already in the works :).. > > Thanks Mike! > -Garrett Forgot to include current@. -Garrett
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?766AE492-7772-4D22-AD68-36FA34612636>