/uglymongrel-wp-content

A fork of jquery-wp-content for the uglymongrel.com sites

Primary LanguagePHP

jQuery.com jquery-wp-content

jquery-wp-content is a custom replacement for the wp-content directory which contains the plugins, themes and site configuration to run the jQuery multi-site WordPress network.

Prerequisites

This install guide assumes you already have certain prerequisites already configured within your environment.

  • Apache
  • Mysql
  • PHP

Installation

  1. Configure your local webserver with a virtual host that covers the relevant jQuery domains, such as *.jquery.com and *.jqueryui.com, all pointing to the same root. For example, in Apache:

    <VirtualHost *:80>
    	ServerName local.jquery.com
    	ServerAlias *.jquery.com *.jqueryui.com *.jquery.org *.qunitjs.com *.sizzlejs.com *.jquerymobile.com
    	DocumentRoot "/srv/www/jquery"
    	php_value memory_limit 256M
    	<Directory /srv/www/jquery>
    		Options All
    		AllowOverride All
    		Order allow,deny
    		Allow from all
    	</Directory>
    </VirtualHost>
    

    Make sure that virtual hosts are enabled as well:

    NameVirtualHost *:80
    

    Both blocks of code should be pasted into extra/httpd-vhosts.conf. Be sure to check httpd.conf to verify there is a line that includes httpd-vhosts.conf. It may already exist, but be commented out.

    Check httpd.conf to ensure that the PHP module is enabled as well.

    You do not need to configure your /etc/hosts file for local.* because jquery.com's DNS handles this for you. However, if you plan to work offline, you can use the following rules:

    127.0.0.1 local.jquery.com local.api.jquery.com local.blog.jquery.com local.books.jquery.com local.codeorigin.jquery.com local.learn.jquery.com local.plugins.jquery.com
    127.0.0.1 local.jqueryui.com local.api.jqueryui.com local.blog.jqueryui.com
    127.0.0.1 local.jquerymobile.com local.api.jquerymobile.com local.blog.jquerymobile.com
    127.0.0.1 local.jquery.org local.brand.jquery.org local.contribute.jquery.org local.events.jquery.org local.irc.jquery.org local.meetings.jquery.org
    127.0.0.1 local.qunitjs.com local.api.qunitjs.com
    127.0.0.1 local.sizzlejs.com
    
  2. Place the WordPress core files at the document root you chose. For example, if you used /srv/www/jquery, you should unzip or clone WordPress directly into that directory, not a directory below it. Do not install WordPress. You can do this any number of ways:

  3. Clone jquery-wp-content inside of the directory where you put WordPress, so you have a file tree that looks like this:

    ├── jquery
    │   ├── gw-resources
    │   ├── index.php
    │   ├── jquery-wp-content
    │   ├── license.txt
    │   ├── readme.html
    │   ├── wp-activate.php
    │   ├── wp-admin
    │   ├── wp-blog-header.php
    │   ├── wp-comments-post.php
    │   ├── wp-config-sample.php
    │   ├── wp-content
    │   ├── ...
    │   └── xmlrpc.php
    
  4. Create a MySQL database and user. You can choose any name you want for both. Follow the WordPress instructions for a step by step guide.

  5. Copy jquery-wp-content/wp-config-sample.php and move it up one directory, to wp-config.php. Fill in your database credentials.

  6. Create an .htaccess file with the following content into that same document root:

    RewriteEngine On
    RewriteBase /
    RewriteRule ^index\.php$ - [L]
    
    RewriteRule ^resources/?$ index.php [L]
    RewriteRule ^resources/(.+) gw-resources/%{HTTP_HOST}/$1 [L]
    
    # Add a trailing slash to the wp-admin of a subsite.
    RewriteRule ^([_0-9a-zA-Z\.-]+/)?wp-admin$ $1wp-admin/ [R=301,L]
    
    RewriteCond %{REQUEST_FILENAME} -f [OR]
    RewriteCond %{REQUEST_FILENAME} -d
    RewriteRule ^ - [L]
    
    # Handle wp-admin, wp-includes, and root PHP files for subsites.
    RewriteRule  ^[_0-9a-zA-Z\.-]+/((wp-admin|wp-includes).*) $1 [L]
    RewriteRule  ^[_0-9a-zA-Z\.-]+/(.*\.php)$ $1 [L]
    
    RewriteRule . index.php [L]
    
  7. Make sure that you have assigned your WordPress files and directories the correct permissions. For example, if your WordPress files are in the directory wordpress, and you are running Apache under Mac OS X with the _www user:

    sudo chown -R _www wordpress
    sudo chmod -R g+w wordpress
    
  8. Restart your web server so the changes above are in use.

  9. Go to http://local.jquery.com and walk through the standard WordPress installation. jquery-wp-content includes a special install script that will initialize the entire network.

  10. Be sure to have node >= 0.8 installed on your system. Some sites, such as download.jqueryui.com, require that version or greater.

Auto-Updates

Changes pushed to master will be pulled onto the stage domain.

Copyright

Copyright 2014 jQuery Foundation and other contributors. All rights reserved.

The jquery-wp-content repository contains themes for rendering all jQuery Foundation web sites.

What is licensed

The contents of the web sites that run on top of jquery-wp-content are all available under the terms of the MIT license ( http://jquery.org/license ).

Special exception: Code samples are given away for you to freely use, for any purpose. For code samples in API sites and Learn articles (unlike the source code of jQuery projects) you don't even have to say where you got the code from. Just use it.

The PHP files in the jquery-wp-content repository are a derivative work of WordPress, and available under the terms of the GPL license ( http://codex.wordpress.org/License ).

What is not licensed

The design, layout, and look-and-feel of the jquery-wp-content repository, including all CSS, images, and icons, are copyright jQuery Foundation, Inc. and are not licensed for use. Designs and CSS from jquery-wp-content may not be used on any site, personal or commerical, without prior written consent from the jQuery Foundation. jquery-wp-content contains CSS, images, and icons that are copyrighted by other individuals; those items are licensed under their original terms.

The only permitted (and encouraged) exception to "use" is the case of cloning/forking this repository in order to create a local development environment to facilitate making contributions to jQuery Foundation websites.