diff --git a/modules/box.module b/modules/box.module index a493b5a33f1..d4f35256715 100644 --- a/modules/box.module +++ b/modules/box.module @@ -12,8 +12,8 @@ function box_help() {
If you know how to script in PHP, PHP boxes are pretty easy to create. Don't worry if you're no PHP-wizard: simply use ASCII or HTML boxes instead.
You can use any piece of PHP code to make up the content of a PHP box: this implies that you can declare and use functions, consult the SQL database, access configuration settings and much more. A PHP box's code is stored in the database and the engine will dynamically embed the PHP code just-in-time for execution.
-There are however some factors to keep in mind when using and creating PHP boxes: PHP boxes can be extremly useful and flexible, yet they can be dangerous and insecure if not properly used. If you are not familiar with PHP, SQL or even with the site engine for that matter, avoid experimenting with PHP boxes because you can - and you probably will - corrupt your database or even render your site unusable! If you don't plan to do fancy stuff with boxes then you're probably better off with ASCII or HTML boxes.
-Remember that the code within each PHP box must be valid PHP code, including things like terminating statements with a semicolon so the parser won't die. Therefore, it is highly recommended to test your boxes seperatly using a simple test script on top of a test database before migrating to your production environment running your real database.
+There are however some factors to keep in mind when using and creating PHP boxes: PHP boxes can be extremely useful and flexible, yet they can be dangerous and insecure if not properly used. If you are not familiar with PHP, SQL or even with the site engine for that matter, avoid experimenting with PHP boxes because you can - and you probably will - corrupt your database or even render your site unusable! If you don't plan to do fancy stuff with boxes then you're probably better off with ASCII or HTML boxes.
+Remember that the code within each PHP box must be valid PHP code, including things like terminating statements with a semicolon so the parser won't die. Therefore, it is highly recommended to test your boxes separately using a simple test script on top of a test database before migrating to your production environment running your real database.
Note that you can use global variables such as configuration parameters within the scope of a PHP box. Also keep in mind that variables that have been given values in a PHP box will retain these values in the engine or module afterwards.
You can use the return
statement to return the actual content for your block as well.
A basic example:
diff --git a/modules/documentation.module b/modules/documentation.module index 82a97d00a0d..8d8e21ed954 100644 --- a/modules/documentation.module +++ b/modules/documentation.module @@ -15,7 +15,7 @@ function documentation() {Drupal is the English pronounciation for the dutch word 'druppel' which means 'drop'. Drupal is a fully-featured content management/discussion engine suitable to setup a news-driven community or portal site. Drupal aims to provide easy installation, excessive configuration and fine-grained maintainance capabilities. Due to its modular design, drupal is flexible and easy to adapt or extend.
+Drupal is the English pronunciation for the Dutch word 'druppel' which means 'drop'. Drupal is a fully-featured content management/discussion engine suitable to setup a news-driven community or portal site. Drupal aims to provide easy installation, excessive configuration and fine-grained maintenance capabilities. Due to its modular design, drupal is flexible and easy to adapt or extend.
Drupal is primarily written by Dries Buytaert (dries_at_drop.org) and built after Slash (http://slashcode.com/) and Scoop (http://scoop.kuro5hin.org/).
1. Download the distribution tarball and unzip it into the directory you want to serve web files from:
+1. Download the distribution tar-ball and unzip it into the directory you want to serve web files from:
$ tar -zxvf drupal-x.x.x.tar.gz
2. We assume that you have some working experience with Apache, MySQL and PHP. In order to set up your drupal site correctly, you'll first have to get Apache, MySQL and PHP working together. So if you still need to install Apache, MySQL or PHP, please install them now. Otherwise, head on to point 3. The installation of these required packages is beyond the scope of this document but what follows are some brief guidelines to get you started.
-Installing MySQL shouldn't be too much of a burden, when using a Linux distribution that can handle RPMs. All you have to do is grab the RMPs from the MySQL website. Please do note that you'll also need the MySQL client RPM, not only the MySQL server one. Once MySQL has been installed, download Apache and PHP, and unpack them in the same directory. To install Apache together with PHP and MySQL, follow the "quick install"-instructions in the INSTALL
-file located in your PHP directory. When configuring PHP do not forget to replace 'apache_1.3.x' with your version of Apache. This may sound silly but it got me twice.
Installing MySQL shouldn't be too much of a burden, when using a Linux distribution that can handle RPMs. All you have to do is grab the RPMs from the MySQL website. Please do note that you'll also need the MySQL client RPM, not only the MySQL server one. Once MySQL has been installed, download Apache and PHP, and unpack them in the same directory. To install Apache together with PHP and MySQL, follow the "quick install"-instructions in the INSTALL
-file located in your PHP directory. When configuring PHP do not forget to replace 'apache_1.3.x' with your version of Apache. This may sound silly but it got me twice.
After the compilation process you have to set the DocumentRoot
in Apache's httpd.conf
to the path of your drupal
-directory. Make sure your Apache is setup to allow .htaccess
files so drupal can override Apache options from within the drupal directories. Therefore, set AllowOverride
to "All" instead of "None". Somewhat down httpd.conf
they ask you to set Directory
to whatever you set DocumentRoot
to. The last thing to do is to add index.php
in IfModule mod_dir.c
behind DirectoryIndex
. Apache will then look for index.php
in the DocumentRoot
and will display it as its main page.
3. Create a MySQL database for your drupal site (if you haven't already):
$ mysqladmin create <database>@@ -56,7 +56,7 @@ function documentation() {
If you want to host multiple domains (or subdomains) on top of the same database (e.g. http://yourdomain.com/ and http://www.yourdomain.com/), simply use symbolic links to setup the required configuration files:
-$ ln -s includes/yourserver.com.conf includes/www.yourserver.com.conf+
$ ln -s includes/yourdomain.com.conf includes/www.yourdomain.com.conf
$ ls -l includes/*.conf -rw-rw-r-- 1 drupal drupal includes/yourdomain.com.conf @@ -94,10 +94,10 @@ function documentation() {Cron
-Cron (wich stands for chronograph) is a periodic command scheduler: it executes commands at intervals specified in seconds. It can be used to control the execution of daily, weekly and monthly jobs (or anything with a period of n seconds). Automating tasks is one of the best ways to keep a system running smoothly, and if most of your administration does not require your direct involvement, cron is an ideal solution.
+Cron (which stands for chronograph) is a periodic command scheduler: it executes commands at intervals specified in seconds. It can be used to control the execution of daily, weekly and monthly jobs (or anything with a period of n seconds). Automating tasks is one of the best ways to keep a system running smoothly, and if most of your administration does not require your direct involvement, cron is an ideal solution.
Note that cron does not guarantee that the commands will be executed at the specified interval. However, the engine will make sure that the commands are run at the specified intervals as closely as possible.
Whenever
-http://yourdomain.com/cron.php
is accessed, cron will run: it queries the database for the jobs cron controls, and their periods in seconds. If a certain task wasn't executed in the last n seconds, where n is the period of that job, it will be executed. It then records the date in the database so it can know when to run it again. When all the executed commands terminate, cron is done.Cron is handy to run daily, weekly and monthly tasks that take care of various "housekeeping chores" such as database maintainance, recalculating settings, periodic mailings, scheduled backups and so on.
+Cron is handy to run daily, weekly and monthly tasks that take care of various "housekeeping chores" such as database maintenance, recalculating settings, periodic mailings, scheduled backups and so on.
The recommended way to setup drupal's cron system is to setup a Unix/Linux
crontab
that frequently visitshttp://yourdomain.com/cron.php
: the more you visitcron.php
, the more accurate cron will be. If your hosting company does not allow you to setupcrontabs
, you can always ask someone else to setup acrontab
for you. After all, virtually any Unix/Linux machine with access to the internet can setup acrontab
to frequently visithttp://yourdomain.com/cron.php
for you.
For the
crontab
itself, use a browser likelynx
orwget
but make sure the process terminates: either use/usr/bin/lynx -source http://yourdomain.com/cron.php
or/usr/bin/wget -O /dev/null http://yourdomain.com/cron.php
. Take a look at the example scripts in thescripts
-directory and make sure to adjust them to your needs.A good
@@ -114,7 +114,7 @@ function documentation() {crontab
-line to run thecron
-script once every hour would be:Moderation, collaborative rating
We like to experiment with moderation, trust metrics and collaborative filtering. Why? To help individuals and communities address the challenges of information overload.
-As each new piece of information competes for attention, people quickly tend to become overwhelmed and seek assistance in identifying the most interesting, worthwhile, valuable or enteraining items. Not to mention the fact that reader-contributed content and other levels of interactivity tend to become chaotic, bloated and disreputable.
+As each new piece of information competes for attention, people quickly tend to become overwhelmed and seek assistance in identifying the most interesting, worthwhile, valuable or entertaining items. Not to mention the fact that reader-contributed content and other levels of interactivity tend to become chaotic, bloated and disreputable.
Therefor, we decided to develop a public system powered by a community that aims to bring quality content to everyone's attention and to filter out all junk: to sort the wheat from the chaff. The output should be something clean and homogenized featuring quality content, and should slide down the gullet far more easily.
Open submission queue
@@ -148,7 +148,7 @@ function documentation() {- admin
If a module requires a spot in the administrator section it should implement +module_admin
. The engine will automatically add a link to the administration menus and will callmodule_admin
when this link is followed. In order to make virtually any module maintainer's life easier, you don't have to worry about access rights or permissions for that matter. The engine will only allow priveleged users to call exportedadmin
functions.If a module requires a spot in the administrator section it should implement module_admin
. The engine will automatically add a link to the administration menus and will callmodule_admin
when this link is followed. In order to make virtually any module maintainer's life easier, you don't have to worry about access rights or permissions for that matter. The engine will only allow privileged users to call exportedadmin
functions.@@ -156,7 +156,7 @@ function documentation() { block
- cron
Modules that require to schedule some commands to be executed on regular intervals can implement the +cron
interface: the engine will then callmodule_cron
at the appropriate intervals defined by the administrator. This interface is particulary handy to implement timers or to automate certain tasks like for instance database maintainance, recalculation of settings or parameters, automatic mailings and so on.Modules that require to schedule some commands to be executed on regular intervals can implement the cron
interface: the engine will then callmodule_cron
at the appropriate intervals defined by the administrator. This interface is particularly handy to implement timers or to automate certain tasks like for instance database maintenance, recalculation of settings or parameters, automatic mailings and so on.@@ -179,7 +179,7 @@ function documentation() { help
Theme system
-Drupal's theme system is simple, elegant, flexible and powerful. You can accommodate rather major changes in overall appearance and significant structural changes. Moreover, you control all aspects of your drupal site in terms of colors, markup, layout and even the position of most blocks (or boxes). You can leave blocks out, move them from right to left, up and down until it fits your needs.
+Drupal's theme system is simple, elegant, flexible and powerful. You can accommodate rather major changes in overall appearance and significant structural changes. Moreover, you control all aspects of your drupal site in terms of colors, mark-up, layout and even the position of most blocks (or boxes). You can leave blocks out, move them from right to left, up and down until it fits your needs.
In order to accomplish this, drupal uses a theme class that has a handful of functions. The drupal engine dynamically loads the correct theme class, instantiates it and then calls this class' functions where appropriate.
Let's illustrate this with an easy example. Say, to generate the main page, the drupal engine would use something like:
@@ -198,14 +198,14 @@ function documentation() {User management
-Drupal's user management system is capable of handling registrations, confirmation emails, account updates, authentication, access rights and user-based permissions among various other things.
+Drupal's user management system is capable of handling registrations, confirmation e-mails, account updates, authentication, access rights and user-based permissions among various other things.
No participant can use his own name or handle to post comments until they sign up and submit their e-mail address. Those who do not may participate as anonymous users, but they will suffer numerous disadvantages, for example their posts beginning at a lower score.
-In contrast, those with a user account can use their own name or handle and are granted various priveleges: the most important are probably the ability to moderate new submissions, to rate comments and to fine-tune the site to their personal liking.
+In contrast, those with a user account can use their own name or handle and are granted various privileges: the most important are probably the ability to moderate new submissions, to rate comments and to fine-tune the site to their personal liking.
Registered users need to authenticate by supplying a username and password. The username and password are kept in your database, where the password is hashed so that no one can read nor use it. When a username and password needs to be checked the system goes down the list of registered users till it finds a matching username, and then hashes the password that was supplied and compares it to the listed value. If they match then that means the username and password supplied were correct.
Once a user authenticated a session is started and until that session is over they won't have to re-authenticate. To keep track of the individual sessions, drupal relies on PHP's session support. A visitor accessing your web site is assigned an unique ID, the so-called session ID, which is stored in a cookie. For security's sake, the cookie does not contain personal information but acts as a key to retrieve the information stored on your server's side. When a visitor accesses your site, drupal will check whether a specific session ID has been sent with the request. If this is the case, the prior saved environment is recreated.
Drupal allows you to control who is allowed to get authenticated and who is not. To accomplish this, you can ban certain hostnames, IPs, IP-ranges, e-mail address and usernames. Any user that matches any of the given ban criteria will not be able to authenticate or to register as a new user.
Authenticated users can themselves select entirely different appearances for the site, utilizing their own preferences for how the pages are structured, how navigation lists and other page components are presented and much more.
-An important feature of drupal is that any user can be granted administrator rights. The ability to share maintainance responsibility with volunteers from across the globe can be considered valuable for most community-based projects.
+An important feature of drupal is that any user can be granted administrator rights. The ability to share maintenance responsibility with volunteers from across the globe can be considered valuable for most community-based projects.
Chapter 4: drupal modules
@@ -222,7 +222,7 @@ function documentation() {Introduction
-CVS is a tool to manage software revisions and release control in a multi-developer, multi-directory, multi-group environment. It comes in very handy to maintain local modificiations.
+CVS is a tool to manage software revisions and release control in a multi-developer, multi-directory, multi-group environment. It comes in very handy to maintain local modifications.
Thus, CVS helps you if you are part of a group of people working on the same project. In large software development projects, it's usually necessary for more then one software developer to be modifying modules of the code at the same time. Without CVS, it is all too easy to overwrite each others' changes unless you are extremely careful.
In addition, CVS helps to keep track of all changes. Therefor, the CVS server has been setup to mail all CVS commits to all maintainers. Thus, it does not require any effort to inform the other people about the work you have done, and by reading the mails everyone is kept up to date.
@@ -240,7 +240,7 @@ function documentation() {This will create a directory called
drupal
containing the latest drupal source tree. For the other source code repositories on this system just substitute the correct package name.5. Whenever you want to merge in the latest code changes, use the following command from within the
drupal
directory:$ cvs ci file1 file2 file3-6. To add binary files like gifs you have to use:
+6. To add binary files like GIFs you have to use:
$ cvs add -kb file1 file2 file3If a binary file accidentically gets added without `-kb', one can use the cvs admin command to recover. For example:
$ cvs admin -kb file1 file2 file3@@ -261,7 +261,7 @@ function documentation() {
cvs commit file1 file2 file3Diff and patch
-Diff is the first command in the set. It has the simple purpose to create a file called a patch or a diff which contains the differences between two text files or two groups of text files. diff can write into different formats, although the unified difference format is preferred. The patches this command generates are much easier to distribute and allow maintainers to see quickly and easily what changed and to make a judgement.
+Diff is the first command in the set. It has the simple purpose to create a file called a patch or a diff which contains the differences between two text files or two groups of text files. diff can write into different formats, although the unified difference format is preferred. The patches this command generates are much easier to distribute and allow maintainers to see quickly and easily what changed and to make a judgment.
Patch is diff's complement and takes a patch file generated by diff and applies it against a file or a group of files.
The actual usage of diff and patch is not complicated.
At its simplest, a diff command for comparing two files would be:
@@ -278,7 +278,7 @@ function documentation() {For a person or company who wishes to submit a change, the process can sometimes be daunting if you're not familiar with "the system". This text is a collection of suggestions which can greatly increase the chances of your change being accepted.
1. Coding style:
If your code deviates too much from the "standard" coding style, it is more likely to be rejected without further review and without comment.2. "diff -u":
-
Use "diff -u" or "diff -urN" to create patches: when creating your patch, make sure to create it in "unified diff" format, as supplied by the '-u' argument to diff. Patches should be based in the root source directory, not in any lower subdirectory. Make sure to create patches against a "vanilla", or unmodified source tree.3. Describe your changes:
+
Describe the technical detail of the change(s) your patch includes and try to be as specific as possible. Note that we prefer technical reasoning above marketing: give us clear reasons why "this way" is good. Justify your changes and try to cary enough weigth. It is important to note the version to which this patch applies.3. Describe your changes:
Describe the technical detail of the change(s) your patch includes and try to be as specific as possible. Note that we prefer technical reasoning above marketing: give us clear reasons why "this way" is good. Justify your changes and try to carry enough weight. It is important to note the version to which this patch applies.4. Separate your changes:
Separate each logical change into its own patch. For example, if your changes include both bug fixes and performance enhancements, separate those changes into two or more patches. If your changes include an API update, and a new module which uses that new API, separate those into two patches.5. Mail or submit the patch:
diff --git a/modules/drupal.module b/modules/drupal.module index 95ccda5363e..3eb6d4455b8 100644 --- a/modules/drupal.module +++ b/modules/drupal.module @@ -9,7 +9,7 @@ function drupal_page() { $output .= "
Remember: no MIME, no HTML mail, no links, no compression, no attachments. Just plain text.Introduction
-Drupal is the English pronounciation for the dutch word 'druppel' which stands for 'drop'. Drupal is a full-featured content management/discussion engine suitable to setup a news-driven community or portal site. Drupal aims towards easy installation, excessive configuration and fine-grained maintainance capabilities. Due to its modular design drupal is flexibel and easy to adapt or extend.
+Drupal is the English pronunciation for the Dutch word 'druppel' which stands for 'drop'. Drupal is a full-featured content management/discussion engine suitable to setup a news-driven community or portal site. Drupal aims towards easy installation, excessive configuration and fine-grained maintenance capabilities. Due to its modular design drupal is flexible and easy to adapt or extend.
Drupal is primarily written by Dries Buytaert (dries_at_drop.org) and build after Slash (http://slashcode.com/) and Scoop (http://scoop.kuro5hin.org/) and source code is available under terms of GNU General Public License (GPL).
Download
drupal 1.00-rc1 (2000/01/01) diff --git a/modules/drupal/drupal.module b/modules/drupal/drupal.module index 95ccda5363e..3eb6d4455b8 100644 --- a/modules/drupal/drupal.module +++ b/modules/drupal/drupal.module @@ -9,7 +9,7 @@ function drupal_page() { $output .= "Introduction
-Drupal is the English pronounciation for the dutch word 'druppel' which stands for 'drop'. Drupal is a full-featured content management/discussion engine suitable to setup a news-driven community or portal site. Drupal aims towards easy installation, excessive configuration and fine-grained maintainance capabilities. Due to its modular design drupal is flexibel and easy to adapt or extend.
+Drupal is the English pronunciation for the Dutch word 'druppel' which stands for 'drop'. Drupal is a full-featured content management/discussion engine suitable to setup a news-driven community or portal site. Drupal aims towards easy installation, excessive configuration and fine-grained maintenance capabilities. Due to its modular design drupal is flexible and easy to adapt or extend.
Drupal is primarily written by Dries Buytaert (dries_at_drop.org) and build after Slash (http://slashcode.com/) and Scoop (http://scoop.kuro5hin.org/) and source code is available under terms of GNU General Public License (GPL).
Download
drupal 1.00-rc1 (2000/01/01)