Skip to content

Commit

Permalink
merged Vagabond changes with those on local mac
Browse files Browse the repository at this point in the history
  • Loading branch information
zanerock committed Jul 13, 2014
2 parents 7958267 + 50cc828 commit c1e6c9a
Show file tree
Hide file tree
Showing 15 changed files with 420 additions and 74 deletions.
4 changes: 4 additions & 0 deletions README.repo
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
This is a conveyor-workflow repository and is intended for use with conveyor-workflow
porcelain. For further information, please refer to:

http://dogfoodsoftware.com/documentation/conveyor-workflow
124 changes: 124 additions & 0 deletions bin/harden
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
#!/bin/bash
#/**
# * <div id="Overview" class="blurbSummary grid_12">
# * <div class="p">
# * Script to harden a Vagabond environment account. Specifically, the script
# * does two things:
# * <ol>
# * <li>Generates a unique environment key and distributes to all (Vagrant)
# * machine images in the environment.</li>
# * <li>Generates or accepts an environment password (used to sign into the
# * <code>user</code> account) and updates all machine images in the
# * environment.</li>
# * </ol>
# * </div>
# * </div><!-- .blurbSummary#Overview -->
# * <div id="Current-Limitations" class="blurbSummary grid_12">
# * <div class="subHeader"><span>Single Machine Environments</span></div>
# * <div class="p">
# * The current implementation is assumes single machine environments in which
# * the single machine configuration is an immediate child of the provided
# * environment path. Future versions will traverse all sub-directories,
# * applying correctness tests to each. The <code>-f|--force</code> option
# * will allow users to skip the checks and harden each machine that matches
# * and ignore anything that doesn't. Otherwise, any correctness failure will
# * cause the entire process to fail.
# * </div>
# * <div class="p">
# * It would be interesting to locate the checks in a separate file that could
# * be inculded by a runtime check as well. This would be in support of
# * expanding the standard tests to support runtime / production checks as
# * well / in parallel with code checks. We could support code checks for
# * development and initial install and runtime checks to help verify
# * integrity of the running system.
# * </div>
# * <div class="subHeader"><span>General Account Management</span></subHeader>
# * <div class="p">
# * Future versions will accept a <code>-a|--account-handle<code> flag
# * indicating the account to update in place of the default <code>user</code>
# * account.
# * </div>
# * <div class="subHeader"><span>Macine Subsets</span></subHeader>
# * <div class="p">
# * Future versions will accept multiple environment paths allowing the
# * process to operate on multiple environments or environment
# * subsets. Subsets simply specify a path within an environment rather than
# * the environment root.
# * </div>
# * <div class="subHeader"><span>Authorization Checks</span></subHeader>
# * <div class="p">
# * The current implementation performs no authorization checks. In general,
# * the bash scripts are trusted, and access to the script imlicitly grants
# * authorization. In order to support web services, however, we do want to
# * provide the ability to request an authorization check prior to executing
# * the command with the <code>--check-authorizations</code> option. The
# * implementation would process the normalized set of target machines against
# * the user's environment local account name as specified by the
# * <code>-a|--account-handle</code>. The <code>user</code> user account is
# * incompatible with this option and always exits with an authorization
# * failure, which is checked by the script. For all other accounts, we check
# * <code>authorizations/?subject=/users/&lt;environment&gt;/&lt;handle&gt;&amp;operation=/vagrants/manage-account&amp;target=/vagrants/&lt;machine
# * path&gt;</code> resource to determine authorization.
# * </div>
# * <div class="subHeader"><span>Web Service Considerations</span></subHeader>
# * <div class="p">
# * With the above in place, we believe we have a solid and secure foundation
# * for exposing these operations through a web service. The web service will
# * probably want to do it's own authorization checks. This small amount of
# * duplicate code is acceptable to support consistency in implementation. The
# * script would support updating the SSH key and user password.
# * </div>
# * </div><!-- .blurbSummary#Current-Limitations -->
# * <div id="Implementation" class="blurbSummary grid_12" data-perspective="implementation">
# * <div class="blurbTitle">Implementation</div>
# */

ENVIRONMENT_PATH="$1"
# For aesthetics, we want to set up ENVIRONMENT_PATH as an absolute
# directory. In bash, it's a bit of a trick, using the 'PWD' environment
# var. Notice that we're using '$0' rather than specifying the Conveyor
# development path. This is because Vagabond supports stand alone
# installation, and the project directory is not guaranteed to be deployed in
# a Conveyor context.
VAGABOND_BASE="`dirname $0`/../"
cd $VAGABOND_BASE
VAGABOND_BASE="$PWD"
ENVIRONMENT_BASE="$VAGABOND_BASE/data/environment"

if [ ! -d "$ENVIRONMENT_PATH" ]; then
echo "Environment not found in '$ENVIRONMENT_PATH'." 1>&2
exit 1
fi
if [ ! -f "$ENVIRONMENT_PATH/Vagrantfile" ]; then
echo "Environment incomplete, no 'Vagrantfile'." 1>&2
exit 1
fi
if [ ! -f "$ENVIRONMENT_PATH/machine.rb" ]; then
echo "Environment incomplete, no 'machine.rb'." 1>&2
exit 1
fi
# everything looks good
ACCOUNT_NAME=user

# First, set up working directory.
WORKING_DIR="$VAGABOND_BASE/data/harden/$ACCOUNT_NAME/"
if [ -d "$WORKING_DIR" ]; then
# TODO: Check no '.lock' file; exit if so.
# Clean out any lingering work directory.
rm -rf "$WORKING_DIR"
fi
touch "$WORKING_DIR/lock"
# TODO: Add exit handler to delete lock file.

# Generate key.
# TODO: Look into using the -G/-T modality tests.
ssh-keygen -f "$WORKING_DIR/id_rsa" -t rsa -b 2048

# Distribute key.
# TODO: would be nice to do a 'secure delete' just to be safe
# update password

rm "$WORKING_DIR/lock"
#/**
# * </div><!-- .blurbSummary#Implemntation -->
# */
26 changes: 23 additions & 3 deletions bin/vagabond
Original file line number Diff line number Diff line change
Expand Up @@ -93,17 +93,37 @@
# * <div class="subHeader"><span><code>vagabond-environments</code></span></div>
# * <div class="p">
# * Whereas a <code>vagabond-templates</code> item describes a
# * meta-environment, a <code>code-environment</code> item relates to
# * meta-environment, a <code>vagabond-environment</code> item relates to
# * a runnable environment. Environments exist as <a
# * href="/documentation/kibbles/lexicon/Runtime-Data</a>runtime
# * data</a>. Any given machine template (corresponding to a
# * <code>Vagabondfile</code>) from a <code>vagabond-templates</code>
# * item may be used to initiate zero or more machine instances in a
# * given <code>vagabond-environment</code> item.
# * </div>

# * <div class="subHeader"><span><code>vagabond-boxes</code></span></div>

# * <div class="p">
# * A <code>vagabond-box</code> is a running virtual machine instance.
# * </div>
# * </div>
# * <div class="subHeader"><span><code>vagabond-images</code></span></div>
# * <div class="p">
# * A <code>vagabond-image</code> is a base box image used to create a runtime
# * <code>vagabond-box</code>
# * </div>
# * </div>
# * <div class="subHeader"><span><code>vagabond-snapshot</code></span></div>
# * <div class="p">
# * A <code>vagabond-image</code> is a disk-snapshot of an enviornment
# * runtime; a live backup.
# * </div>
# * </div>
# * </div><!-- .blurbSummary#Resource-Specification -->
# */

# Within environmonts, you can have any number of sub-environments. So, the
# environment cookbook might pull in a 'apache cloud' environment to provide
# self-scaling HTTP front end processing. Each vagabond-box is a minimal
# vagabond-envioronment

vagabond snapshot PUT auto-id source=/vagabond-environment/jmfa-fraudmanager
34 changes: 0 additions & 34 deletions kdata/templates/conveyor-workstation/Vagrantfile

This file was deleted.

1 change: 0 additions & 1 deletion runnable

This file was deleted.

33 changes: 0 additions & 33 deletions src/lib/vagabond-lib.rb

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -111,8 +111,8 @@
about the versions not matching. In practice, the guest additions are
compatible enough and everything should work fine. We do intend to
automate the update of guest additions in the
future.<span class="note">There was a <a href="
http://blog.csanchez.org/2012/05/03/automatically-download-and-install-virtualbox-guest-additions-in-vagrant/">plugin</a>
future.<span class="note">There was
a <a href="http://blog.csanchez.org/2012/05/03/automatically-download-and-install-virtualbox-guest-additions-in-vagrant/">plugin</a>
for Vagrant v1, and in theory the process should be relatively easy to
automate with a shell script. It's on the TODO list.</span>
</div>
Expand Down
File renamed without changes.
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<div class="grid_12 blurbSummary">
<div class="p">
Vagabond uses <a href="www.vagrantup.com">Vagrant</a>
and <a href="www.virtualbox.org">Virtual Box</a>.
and <a href="http://www.virtualbox.org">Virtual Box</a>.
</div>
</div>
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
<div id="Reference-Documentation" class="blurbSummary grid_12">
<div class="blurbTitle">Reference Documentation</div>
<div class="p">
<ul>
<li><a href="http://www.3ware.com/support/userdocs/9000-series-cliguide-3-07.pdf">CLI
Guide</a></li>
</ul>
</div>
</div><!-- #Reference-Docs.blurbSummary -->
<div id="Weekly-Manual-Check" class="blurbSummary grid_12">
<div class="blurbTitle">Weekly Manual Check</div>
<div class="p">
<ol>
<li>Log into Vagabond Host via SSH.</li>
<li>From the bash prompt, execute: <code>sudo ./raid.9.5.3/cli/tw_cli</code></li>
<li>From the RAID CLI prompt, execute: <code>show</code>. Note the value
in the 'Ctl' column for each controller.</li>
<li>Form the RAID CLI prompt, execute: <code>show /&lt;controller
ID&gt;</code>. Verify that the 'Status' of each 'Unit', 'VPort' and
'bbu' is 'OK'.</li>
<li>Cound the number of 'ports' == hard drives.
<li>From the RAID CLI prompt, execute: <code>quit</code>.</li>
<li>From the bash prompt, execute: <code>smartctl -A -data -d 3ware,0
/dev/twa0</code>. If SSD, you will see a 'Media_Wearout_Indicator' or
'SSDLife'. '100' is best, '0' is worst. Mark drive for replacement
at... 25?.</li>
<li>Repeat command with '3ware,1', '3ware,2', etc. for each drive. Check
all SSD. For non-SSD... I'm not really sure. Need to update this
section. An 'input/output' error means there's no drive connected to
that port (or the drive is totally toast).
</div>
</div><!-- #Weekly-Manual-Check.blurbSummary -->
Loading

0 comments on commit c1e6c9a

Please sign in to comment.