Skip to content

ucsf-web-services/ucsf_utility_scripts

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

#UCSF Utility Scripts

The Utitlity Scripts are primarily useful if you are on Acquia Cloud hosting. Posting on Github so that other Acquia clients can use and collaborate on the scripts. These are provided as is with no support. That being said, we are happy to collaborate with other groups, particularly other Higher Ed and Non-profits.

###Iterator:

This is a server-side script that needs to be executed from within your /docroot directory.

Iterator Script runs through drupal sites and runs drush based on file added to "deploy folder". Can also be run via command line.

####Syntax

Drush command|target module

####Example file command:

updb|chosen
cc all|ucsf_images_gallery

The first would run a update on all sites with chosen module enabled.
The second would run status on all sites with the ucsf pharmacy image module.

####Installation

Add the iterator script to the /scripts directory underneath your repository root.

####Running Iterator Manually

Execute iterator from within your /docroot whilst providing it with the path to your commands script and the indicator of the environment you're operating in.

For example, if you want to execute the Drush commands defined in the ~/runthis.txt script on your production server, run this from within /docroot.

./../scripts/iterator file ~/runthis.txt prod

Alternatively, you may give iterator a single (piped) Drush command (see syntax described above) directly, instead of a file path. Use run as the second argument, followed by the Drush command in quotes.

E.g. this will clear all caches on sites in the test environment that have the Views module enabled.

./../scripts/iterator run "cc all|views" test

####Running Iterator Automatically

We use a tag naming convention and the Acquia Cloud API "post-code-deploy" hook to run iterator automatically in our test and production enviroments immediately after each tag deployment.

Based on the name of the release tag that gets pushed, the hook script will find the corresponding commands-script in the /deploy directory and call the Iterator script with it.

E.g. If we are pushing the release tag 2014-09-02 to production, the hook script will search for a script named 2014-09-02 in the /deploy directory on your server. I found, iterator will be called with with that script.

This is roughly equivalent to manually running

./../scripts/iterator file ./../deploy/2014-09-02 <env>

This means that the same Drush commands are applied during deployment in test and production as we push release tags forward.

That's a Good Thing!

###Module Madness:

Module Madness is a reporting script. It let's you know which site is running which module. Useful when managing 500+ sites!

####Dependencies

Piggy-backs on the Iterator script and requires the custom Drush commands defined in ucsf.drush.inc, so make sure that Drush can find them.

###Site Builder:

This script uses the Acquia API and git to quickly build empty site document roots based on an orginal site called mysite.ucsf.edu

###Sync files:

This script allow for more fine grained file updates between sites than the current Acquia workflow tool. Very useful when migrating a new site from Dev to Test and then Produciton.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages