Programming Tips - How was Dave's Brain implemented?

Date: 2006nov6 Update: 2018nov10 Keywords: daves, davekb.com Q. How was Dave's Brain implemented? A. The articles are stored in folders that group them into categories. They are mostly plain text files. The application, written in PHP, pretties up the text files based on a few simple rules when displaying them. It's LAMP without the MySql which makes LAP, I guess. That's pretty much it. Simple is good. The searching is reasonably fast because there aren't that many files and because Linux probably has the files cached. There are an number of amazing things that come for free when you use a filesystem has a "database": - Each file must have a unique name - You can easily edit or spellcheck any file - Your program can easily read any file - They are listed in alphabetical order by default We employ OpenID for the login. We used the SimpleOpenID php class from http://www.fivestores.com OpenID has a number of nice features: - Maybe the user already has an OpenID (user friendly) - If the user doesn't have an OpenID we thing they are more likely to go to the trouble of getting an OpenID than a Dave's Brain login. - We don't need to keep a database of users - We don't need to make pages for users to register, recover their passwords, edit their profile, etc. - There are weekly cron jobs to rebuild the keywords and crawlers lists. Those are stored in php serialized format for quick retrieval. - Hourly, the folders are checked for updates and if necessary the list of recent article is rebuilt and stored in the same php serialized format. - To provide better spelling suggestions the words from articles are converted into an installation specific dictionary weekly. So if a user enters "phq" it might suggest "php".