Why WikiGroups?
Explanations about WikiGroups given by Patrick R. Michaud on the [pmwiki-users] mailing-list
''Over time people have asked for something that could contrast WikiFarms and WikiGroups, especially the advantages and disadvantages of each, and I agree such documentation is needed.'' But thus far I haven't been able to come up with a concise description, so lacking that I'll just tell the story, motivations, and conceptualization behind each, and perhaps we can all refine it into something that works well on a page. Or maybe the stories will suffice.
For this message I'll talk primarily about WikiGroups, and save WikiFarms for another message (since they came later in development). And I'll just present things as a narrative -- a history -- since this is still the example I work from when thinking of how WikiGroups can work. Apologies in advance for the length of the narrative -- if I knew a good way to shorten it we'd have our description. :-)
In September 2001, when I wrote the first version of PmWiki (pmwiki-0.1), my desire was that the various groups I worked with at the University and elsewhere could use "wiki" concepts to maintain web sites that were otherwise unmaintained. In general, the overarching theme was that each of these web sites had its own designated webmaster, but that web maintenance was only a small part of each webmasters' overall duties. What's more, the webmaster typically served as a bottleneck, in that even if there were several people willing to update page content, they had to coordinate or submit the changes to the webmaster for them to take effect. So, updates happened rarely, if at all, and the sites quickly became out of date. ("Page rot" is the common term.)
Since I was the webmaster for several of the sites, anything that I could do to empower others to update the site without involving me would be a Good Thing. This is a central theme behind PmWiki development -- make it possible for other people to do the work that I would have to otherwise be doing. :-)
So, I created the first version of PmWiki, and started using it to build and maintain web sites for the various projects and groups I was involved in. These included a research group, the computer science club, the college, my academic department, each of the various courses I was teaching, as well as my own personal pages. Initially I started out by installing separate copies of PmWiki for each "group" that wanted a set of pages.
Pretty soon, other people, departments, instructors, and organizations saw how I was using wiki to maintain my site, and they all wanted wikis of their own. So, I'd either get them to build pages in one of the wikis I had already set up, or install yet another copy of the software somewhere that they could use.
With only one level of page names, having independent groups try to share the same namespace didn't always work well. There could only be one page named "MyResume", and so authors had to "plan ahead" as far as what to name their links and pages.
Also, there wasn't a good mechanism to be able to protect a set of pages from being edited -- one could protect individual pages, but that got really tedious if there were several dozen pages to be protected (and every new page had to have a password added to it).
So, since the single flat namespace wasn't working out well, pretty soon I was fielding more requests for independent wikis. This involved installing a new copy of the software, coordinating software updates, and trying to keep track of all of the RecentChanges pages to make sure things were going well.
Of course, this went directly against my goal of getting others to do the work. :-) Of course, I could've just started handing people copies of the software and telling them to maintain it, or making it possible for people to create their own fields in a wikifarm, but that would require that others know the same things an administrator would need to know, and many of the people who wanted to create wiki spaces didn't even have a Unix account.
What I *really* wanted was for >>authors<< to be able to create their own "wiki spaces" without them having to become wiki administrators or ask me to set things up for them. And I wanted groups of people to be able to create and reorganize pages on a moment's notice. Thus, the concept of WikiGroups was born -- as a way for people (non-admins) to create their own spaces for wiki content without having to seek out or become an administrator to do it.
One of the key ideas behind WikiGroups was that it would be possible to make each group "appear" to authors as though it was separated from other groups on the wiki. Thus, each WikiGroup can have its own set of passwords, header, footer, and skin. Each WikiGroup could have its own "HomePage", "RecentChanges", etc., and to someone who didn't know anything about "WikiGroups" it all appeared to be its own wiki. But for those who did know what was going on -- and it didn't take long for people to figure it out -- they could share a common set of documentation, help files, tips for using the wiki, etc., and they could also easily link to related pages belonging to other groups (e.g. the CSClub could link to pages in the CSDepartment or to course notes in the COSC1435 group.)
From my perspective as an administrator, this was a much better scenario than the original one. First, whenever someone wanted a place for wiki pages, I didn't have to install anything, I would tell them "just create a page in a new group". Even better was when they stopped asking me even that -- since there were plenty of other people around (besides me) who could tell them how to do it. Soon people started sharing with others the details of setting group passwords, creating new pages, making "skins" using GroupHeader and GroupFooter, etc. My involvement became more along the lines of improving the software, updating a few installations, and helping out with the occasional problem or feature request.
Another advantage of the WikiGroup structure was that I could monitor a whole bunch of groups at once through the AllRecentChanges page.
The things that have happened since then with WikiGroups are really just extensions of that original concept -- i.e., make it possible for authors to create specialized sections of content without necessarily having to involve an admin to do it.
To show how well it works in practice, the student wiki at Texas A&M University- Corpus Christi currently has 5,372 WikiGroups. Yes, that's *groups* -- there are currently over 180,000 *pages* on that wiki. The instructors in the First Year Program all walk the students through the basics of creating a personal WikiGroup, editing pages in the group, and linking to other pages, and then the students use that throughout the academic year for various assignments, information, and collaborative projects with other students. The wiki administrators (all part-time) never have to deal with creating the groups, other than to handle the occasional issues with forgotten passwords or upgrading software. (And several of the instructors in the program have been given the site admin password so they can resolve password or content problems without having to contact the wikiadmin.)
So, that's the history and original motivation of WikiGroups. It's primary feature is that it allows creating new sections of related content without having to involve an admin, but still allows an "overview" picture to be formed from all of the groups.
More about WikiGroups versus WikiFarms in a later message.
This page may have a more recent version on pmwiki.org: PmWiki:WikiGroupMotivation, and a talk page: PmWiki:WikiGroupMotivation-Talk.