summaryrefslogtreecommitdiff
path: root/chef-server
diff options
context:
space:
mode:
authorDaniel DeLeo <dan@opscode.com>2010-04-26 00:51:16 -0700
committerDaniel DeLeo <dan@opscode.com>2010-05-07 11:09:23 -0700
commit3512842b24ad923849968681c82b11f8351c1c41 (patch)
treeffc0b212a4439180f26cb1dc58db9e5bc4dc7e31 /chef-server
parentc70f05c3f97d25478662893cd0227ef4ffc813c9 (diff)
downloadchef-3512842b24ad923849968681c82b11f8351c1c41.tar.gz
[CHEF-1072] rm chef-server tree
Diffstat (limited to 'chef-server')
-rw-r--r--chef-server/LICENSE201
-rw-r--r--chef-server/README.rdoc135
-rw-r--r--chef-server/Rakefile44
-rw-r--r--chef-server/app/controllers/application.rb2
-rw-r--r--chef-server/app/helpers/global_helpers.rb5
-rw-r--r--chef-server/app/views/exceptions/not_acceptable.html.erb63
-rw-r--r--chef-server/app/views/exceptions/not_found.html.erb47
-rw-r--r--chef-server/app/views/layout/application.html.erb12
-rwxr-xr-xchef-server/bin/chef-server80
-rwxr-xr-xchef-server/bin/chef-server-webui75
-rw-r--r--chef-server/config/dependencies-webui.rb27
-rw-r--r--chef-server/config/dependencies.rb24
-rw-r--r--chef-server/config/environments/development.rb13
-rw-r--r--chef-server/config/environments/production.rb10
-rw-r--r--chef-server/config/environments/rake.rb10
-rw-r--r--chef-server/config/environments/staging.rb10
-rw-r--r--chef-server/config/environments/test.rb13
-rw-r--r--chef-server/config/init-webui.rb34
-rw-r--r--chef-server/config/init.rb30
-rw-r--r--chef-server/config/rack.rb21
-rw-r--r--chef-server/config/router.rb39
-rw-r--r--chef-server/lib/tasks/install.rake7
-rw-r--r--chef-server/lib/tasks/package.rake34
-rw-r--r--chef-server/lib/tasks/uninstall.rake7
-rw-r--r--chef-server/lib/views/exceptions/bad_request.html.haml2
-rw-r--r--chef-server/public/.htaccess17
-rw-r--r--chef-server/public/favicon.icobin1078 -> 0 bytes
-rw-r--r--chef-server/public/images/merb.jpgbin5815 -> 0 bytes
-rw-r--r--chef-server/public/javascripts/application.js1
-rw-r--r--chef-server/public/javascripts/jquery.js19
-rwxr-xr-xchef-server/public/merb.fcgi22
-rw-r--r--chef-server/public/robots.txt5
-rw-r--r--chef-server/public/stylesheets/master.css119
-rw-r--r--chef-server/spec/spec.opts0
-rw-r--r--chef-server/spec/spec_helper.rb25
-rw-r--r--chef-server/tasks/doc.thor149
-rw-r--r--chef-server/tasks/merb.thor/app_script.rb31
-rw-r--r--chef-server/tasks/merb.thor/common.rb68
-rw-r--r--chef-server/tasks/merb.thor/gem_ext.rb125
-rw-r--r--chef-server/tasks/merb.thor/main.thor150
-rw-r--r--chef-server/tasks/merb.thor/ops.rb93
-rw-r--r--chef-server/tasks/merb.thor/utils.rb40
42 files changed, 0 insertions, 1809 deletions
diff --git a/chef-server/LICENSE b/chef-server/LICENSE
deleted file mode 100644
index 11069edd79..0000000000
--- a/chef-server/LICENSE
+++ /dev/null
@@ -1,201 +0,0 @@
- Apache License
- Version 2.0, January 2004
- http://www.apache.org/licenses/
-
-TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
-
-1. Definitions.
-
- "License" shall mean the terms and conditions for use, reproduction,
- and distribution as defined by Sections 1 through 9 of this document.
-
- "Licensor" shall mean the copyright owner or entity authorized by
- the copyright owner that is granting the License.
-
- "Legal Entity" shall mean the union of the acting entity and all
- other entities that control, are controlled by, or are under common
- control with that entity. For the purposes of this definition,
- "control" means (i) the power, direct or indirect, to cause the
- direction or management of such entity, whether by contract or
- otherwise, or (ii) ownership of fifty percent (50%) or more of the
- outstanding shares, or (iii) beneficial ownership of such entity.
-
- "You" (or "Your") shall mean an individual or Legal Entity
- exercising permissions granted by this License.
-
- "Source" form shall mean the preferred form for making modifications,
- including but not limited to software source code, documentation
- source, and configuration files.
-
- "Object" form shall mean any form resulting from mechanical
- transformation or translation of a Source form, including but
- not limited to compiled object code, generated documentation,
- and conversions to other media types.
-
- "Work" shall mean the work of authorship, whether in Source or
- Object form, made available under the License, as indicated by a
- copyright notice that is included in or attached to the work
- (an example is provided in the Appendix below).
-
- "Derivative Works" shall mean any work, whether in Source or Object
- form, that is based on (or derived from) the Work and for which the
- editorial revisions, annotations, elaborations, or other modifications
- represent, as a whole, an original work of authorship. For the purposes
- of this License, Derivative Works shall not include works that remain
- separable from, or merely link (or bind by name) to the interfaces of,
- the Work and Derivative Works thereof.
-
- "Contribution" shall mean any work of authorship, including
- the original version of the Work and any modifications or additions
- to that Work or Derivative Works thereof, that is intentionally
- submitted to Licensor for inclusion in the Work by the copyright owner
- or by an individual or Legal Entity authorized to submit on behalf of
- the copyright owner. For the purposes of this definition, "submitted"
- means any form of electronic, verbal, or written communication sent
- to the Licensor or its representatives, including but not limited to
- communication on electronic mailing lists, source code control systems,
- and issue tracking systems that are managed by, or on behalf of, the
- Licensor for the purpose of discussing and improving the Work, but
- excluding communication that is conspicuously marked or otherwise
- designated in writing by the copyright owner as "Not a Contribution."
-
- "Contributor" shall mean Licensor and any individual or Legal Entity
- on behalf of whom a Contribution has been received by Licensor and
- subsequently incorporated within the Work.
-
-2. Grant of Copyright License. Subject to the terms and conditions of
- this License, each Contributor hereby grants to You a perpetual,
- worldwide, non-exclusive, no-charge, royalty-free, irrevocable
- copyright license to reproduce, prepare Derivative Works of,
- publicly display, publicly perform, sublicense, and distribute the
- Work and such Derivative Works in Source or Object form.
-
-3. Grant of Patent License. Subject to the terms and conditions of
- this License, each Contributor hereby grants to You a perpetual,
- worldwide, non-exclusive, no-charge, royalty-free, irrevocable
- (except as stated in this section) patent license to make, have made,
- use, offer to sell, sell, import, and otherwise transfer the Work,
- where such license applies only to those patent claims licensable
- by such Contributor that are necessarily infringed by their
- Contribution(s) alone or by combination of their Contribution(s)
- with the Work to which such Contribution(s) was submitted. If You
- institute patent litigation against any entity (including a
- cross-claim or counterclaim in a lawsuit) alleging that the Work
- or a Contribution incorporated within the Work constitutes direct
- or contributory patent infringement, then any patent licenses
- granted to You under this License for that Work shall terminate
- as of the date such litigation is filed.
-
-4. Redistribution. You may reproduce and distribute copies of the
- Work or Derivative Works thereof in any medium, with or without
- modifications, and in Source or Object form, provided that You
- meet the following conditions:
-
- (a) You must give any other recipients of the Work or
- Derivative Works a copy of this License; and
-
- (b) You must cause any modified files to carry prominent notices
- stating that You changed the files; and
-
- (c) You must retain, in the Source form of any Derivative Works
- that You distribute, all copyright, patent, trademark, and
- attribution notices from the Source form of the Work,
- excluding those notices that do not pertain to any part of
- the Derivative Works; and
-
- (d) If the Work includes a "NOTICE" text file as part of its
- distribution, then any Derivative Works that You distribute must
- include a readable copy of the attribution notices contained
- within such NOTICE file, excluding those notices that do not
- pertain to any part of the Derivative Works, in at least one
- of the following places: within a NOTICE text file distributed
- as part of the Derivative Works; within the Source form or
- documentation, if provided along with the Derivative Works; or,
- within a display generated by the Derivative Works, if and
- wherever such third-party notices normally appear. The contents
- of the NOTICE file are for informational purposes only and
- do not modify the License. You may add Your own attribution
- notices within Derivative Works that You distribute, alongside
- or as an addendum to the NOTICE text from the Work, provided
- that such additional attribution notices cannot be construed
- as modifying the License.
-
- You may add Your own copyright statement to Your modifications and
- may provide additional or different license terms and conditions
- for use, reproduction, or distribution of Your modifications, or
- for any such Derivative Works as a whole, provided Your use,
- reproduction, and distribution of the Work otherwise complies with
- the conditions stated in this License.
-
-5. Submission of Contributions. Unless You explicitly state otherwise,
- any Contribution intentionally submitted for inclusion in the Work
- by You to the Licensor shall be under the terms and conditions of
- this License, without any additional terms or conditions.
- Notwithstanding the above, nothing herein shall supersede or modify
- the terms of any separate license agreement you may have executed
- with Licensor regarding such Contributions.
-
-6. Trademarks. This License does not grant permission to use the trade
- names, trademarks, service marks, or product names of the Licensor,
- except as required for reasonable and customary use in describing the
- origin of the Work and reproducing the content of the NOTICE file.
-
-7. Disclaimer of Warranty. Unless required by applicable law or
- agreed to in writing, Licensor provides the Work (and each
- Contributor provides its Contributions) on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- implied, including, without limitation, any warranties or conditions
- of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
- PARTICULAR PURPOSE. You are solely responsible for determining the
- appropriateness of using or redistributing the Work and assume any
- risks associated with Your exercise of permissions under this License.
-
-8. Limitation of Liability. In no event and under no legal theory,
- whether in tort (including negligence), contract, or otherwise,
- unless required by applicable law (such as deliberate and grossly
- negligent acts) or agreed to in writing, shall any Contributor be
- liable to You for damages, including any direct, indirect, special,
- incidental, or consequential damages of any character arising as a
- result of this License or out of the use or inability to use the
- Work (including but not limited to damages for loss of goodwill,
- work stoppage, computer failure or malfunction, or any and all
- other commercial damages or losses), even if such Contributor
- has been advised of the possibility of such damages.
-
-9. Accepting Warranty or Additional Liability. While redistributing
- the Work or Derivative Works thereof, You may choose to offer,
- and charge a fee for, acceptance of support, warranty, indemnity,
- or other liability obligations and/or rights consistent with this
- License. However, in accepting such obligations, You may act only
- on Your own behalf and on Your sole responsibility, not on behalf
- of any other Contributor, and only if You agree to indemnify,
- defend, and hold each Contributor harmless for any liability
- incurred by, or claims asserted against, such Contributor by reason
- of your accepting any such warranty or additional liability.
-
-END OF TERMS AND CONDITIONS
-
-APPENDIX: How to apply the Apache License to your work.
-
- To apply the Apache License to your work, attach the following
- boilerplate notice, with the fields enclosed by brackets "[]"
- replaced with your own identifying information. (Don't include
- the brackets!) The text should be enclosed in the appropriate
- comment syntax for the file format. We also recommend that a
- file or class name and description of purpose be included on the
- same "printed page" as the copyright notice for easier
- identification within third-party archives.
-
-Copyright [yyyy] [name of copyright owner]
-
-Licensed under the Apache License, Version 2.0 (the "License");
-you may not use this file except in compliance with the License.
-You may obtain a copy of the License at
-
- http://www.apache.org/licenses/LICENSE-2.0
-
-Unless required by applicable law or agreed to in writing, software
-distributed under the License is distributed on an "AS IS" BASIS,
-WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-See the License for the specific language governing permissions and
-limitations under the License.
diff --git a/chef-server/README.rdoc b/chef-server/README.rdoc
deleted file mode 100644
index 2c2eaa706b..0000000000
--- a/chef-server/README.rdoc
+++ /dev/null
@@ -1,135 +0,0 @@
-= Chef
-
-= DESCRIPTION:
-
-Chef is a configuration management tool designed to bring automation to your entire infrastructure.
-
-The Chef Wiki is the definitive source of user documentation.
-
-* http://wiki.opscode.com/display/chef/Home
-
-This README focuses on developers who want to modify Chef source code. For users who just want to run the latest and greatest Chef development version in their environment, see:
-
-* http://wiki.opscode.com/display/chef/Installing+Chef+from+HEAD
-
-= DEVELOPMENT:
-
-Before working on the code, if you plan to contribute your changes, you need to read the Opscode Contributing document.
-
-* http://wiki.opscode.com/display/opscode/Contributing
-
-You will also need to set up the repository with the appropriate branches. We document the process on the Chef Wiki.
-
-* http://wiki.opscode.com/display/opscode/Working+with+Git
-
-Once your repository is set up, you can start working on the code. We do use BDD/TDD with RSpec and Cucumber, so you'll need to get a development environment running.
-
-= ENVIRONMENT:
-
-In order to have a development environment where changes to the Chef code can be tested, we'll need to install a few things after setting up the Git repository.
-
-== Requirements:
-
-Install these via your platform's preferred method; for example apt, yum, ports, emerge, etc.
-
-* Git
-* CouchDB
-* libxml2 development package (for webrat)
-* libxslt develoment package (for webrat)
-
-Install the following RubyGems.
-
-* ohai
-* rake
-* rspec
-* cucumber
-* webrat
-* merb-core
-* roman-merb_cucumber
-
-Ohai is also by Opscode and available on GitHub, http://github.com/opscode/ohai/tree/master.
-
-roman-merb_cucumber is available from GitHub:
-
- gem install --source http://gems.github.com/ roman-merb_cucumber
-
-== Starting the Environment:
-
-Once everything is installed, run the dev:features rake task. Since the features do integration testing, root access is required.
-
- sudo rake dev:features
-
-The dev:features task:
-
-* Installs chef, chef-server, chef-server-slice gems. It will fail if required gems above are missing.
-* Starts chef-server on ports 4000 and 4001.
-* Starts chef-indexer.
-* Starts CouchDB on port 5984.
-* Starts the stompserver on port 61613.
-
-You'll know its running when you see:
-
- ~ Activating slice 'ChefServerSlice' ...
- merb : worker (port 4000) ~ Starting Mongrel at port 4000
- merb : worker (port 4000) ~ Successfully bound to port 4000
- merb : worker (port 4001) ~ Starting Mongrel at port 4001
- merb : worker (port 4001) ~ Successfully bound to port 4001
-
-You'll want to leave this terminal running the dev environment.
-
-== Web Interface:
-
-With the dev environment running, you can now access the web interface via http://localhost:4000/. Supply an OpenID to log in.
-
-== Spec testing:
-
-We use RSpec for unit/spec tests.
-
- rake spec
-
-This doesn't actually use the development environment, because it does the testing on all the Chef internals. For integration/usage testing, we use Cucumber features.
-
-== Integration testing:
-
-We test integration with Cucumber. The available feature tests are rake tasks:
-
- rake features # Run Features with Cucumber
- rake features:api # Run Features with Cucumber
- rake features:client # Run Features with Cucumber
- rake features:provider:package:macports # Run Features with Cucumber
- rake features:provider:remote_file # Run Features with Cucumber
- rake features:search # Run Features with Cucumber
-
-= LINKS:
-
-Source:
-
-* http://github.com/opscode/chef/tree/master
-
-Tickets/Issues:
-
-* http://tickets.opscode.com/
-
-Documentation:
-
-* http://wiki.opscode.com/display/chef/Home/
-
-= LICENSE:
-
-Chef - A configuration management system
-
-Author:: Adam Jacob (<adam@opscode.com>)
-Copyright:: Copyright (c) 2008, 2009 Opscode, Inc.
-License:: Apache License, Version 2.0
-
-Licensed under the Apache License, Version 2.0 (the "License");
-you may not use this file except in compliance with the License.
-You may obtain a copy of the License at
-
- http://www.apache.org/licenses/LICENSE-2.0
-
-Unless required by applicable law or agreed to in writing, software
-distributed under the License is distributed on an "AS IS" BASIS,
-WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-See the License for the specific language governing permissions and
-limitations under the License.
diff --git a/chef-server/Rakefile b/chef-server/Rakefile
deleted file mode 100644
index b1f6e68d68..0000000000
--- a/chef-server/Rakefile
+++ /dev/null
@@ -1,44 +0,0 @@
-
-require 'rubygems'
-require 'rake/rdoctask'
-
-require 'merb-core'
-require 'merb-core/tasks/merb'
-require 'spec'
-require 'spec/rake/spectask'
-
-# Load chef and chef-server slice from source rather than gem, if present
-[ 'chef', 'chef-server-slice' ].each do |lib|
- library = File.join(File.dirname(__FILE__), "..", lib, "lib", "#{lib}.rb")
- require library if File.exists?(library)
-end
-
-require 'chef' unless defined?(Chef)
-
-include FileUtils
-
-GEM = "chef-server"
-CHEF_SERVER_VERSION = "0.8.12"
-AUTHOR = "Opscode"
-EMAIL = "chef@opscode.com"
-HOMEPAGE = "http://wiki.opscode.com/display/chef"
-SUMMARY = "A systems integration framework, built to bring the benefits of configuration management to your entire infrastructure."
-
-tasks_path = File.join(File.dirname(__FILE__), "lib", "tasks")
-rake_files = Dir["#{tasks_path}/*.rake"]
-rake_files.each{|rake_file| load rake_file }
-
-desc "Start runner environment"
-task :merb_env do
- Merb.start_environment(:environment => init_env, :adapter => 'runner')
-end
-
-require 'spec/rake/spectask'
-require 'merb-core/test/tasks/spectasks'
-desc 'Default: run spec examples'
-task :default => 'spec'
-
-##############################################################################
-# ADD YOUR CUSTOM TASKS IN /lib/tasks
-# NAME YOUR RAKE FILES file_name.rake
-##############################################################################
diff --git a/chef-server/app/controllers/application.rb b/chef-server/app/controllers/application.rb
deleted file mode 100644
index 5ce39a0102..0000000000
--- a/chef-server/app/controllers/application.rb
+++ /dev/null
@@ -1,2 +0,0 @@
-class Application < Merb::Controller
-end \ No newline at end of file
diff --git a/chef-server/app/helpers/global_helpers.rb b/chef-server/app/helpers/global_helpers.rb
deleted file mode 100644
index 9c9e5aa197..0000000000
--- a/chef-server/app/helpers/global_helpers.rb
+++ /dev/null
@@ -1,5 +0,0 @@
-module Merb
- module GlobalHelpers
- # helpers defined here available to all views.
- end
-end
diff --git a/chef-server/app/views/exceptions/not_acceptable.html.erb b/chef-server/app/views/exceptions/not_acceptable.html.erb
deleted file mode 100644
index a7b7752ab2..0000000000
--- a/chef-server/app/views/exceptions/not_acceptable.html.erb
+++ /dev/null
@@ -1,63 +0,0 @@
-<div id="container">
- <div id="header-container">
- <img src="/images/merb.jpg" />
- <!-- <h1>Mongrel + Erb</h1> -->
- <h2>pocket rocket web framework</h2>
- <hr />
- </div>
-
- <div id="left-container">
- <h3>Exception:</h3>
- <p><%= request.exceptions.first.message %></p>
- </div>
-
- <div id="main-container">
- <h3>Why am I seeing this page?</h3>
- <p>Merb couldn't find an appropriate content_type to return,
- based on what you said was available via provides() and
- what the client requested.</p>
-
- <h3>How to add a mime-type</h3>
- <pre><code>
- Merb.add_mime_type :pdf, :to_pdf, %w[application/pdf], &quot;Content-Encoding&quot; =&gt; &quot;gzip&quot;
- </code></pre>
- <h3>What this means is:</h3>
- <ul>
- <li>Add a mime-type for :pdf</li>
- <li>Register the method for converting objects to PDF as <code>#to_pdf</code>.</li>
- <li>Register the incoming mime-type "Accept" header as <code>application/pdf</code>.</li>
- <li>Specify a new header for PDF types so it will set <code>Content-Encoding</code> to gzip.</li>
- </ul>
-
- <h3>You can then do:</h3>
- <pre><code>
- class Foo &lt; Application
- provides :pdf
- end
- </code></pre>
-
- <h3>Where can I find help?</h3>
- <p>If you have any questions or if you can't figure something out, please take a
- look at our <a href="http://merbivore.com/"> project page</a>,
- feel free to come chat at irc.freenode.net, channel #merb,
- or post to <a href="http://groups.google.com/group/merb">merb mailing list</a>
- on Google Groups.</p>
-
- <h3>What if I've found a bug?</h3>
- <p>If you want to file a bug or make your own contribution to Merb,
- feel free to register and create a ticket at our
- <a href="http://merb.lighthouseapp.com/">project development page</a>
- on Lighthouse.</p>
-
- <h3>How do I edit this page?</h3>
- <p>You can change what people see when this happens by editing <tt>app/views/exceptions/not_acceptable.html.erb</tt>.</p>
-
- </div>
-
- <div id="footer-container">
- <hr />
- <div class="left"></div>
- <div class="right">&copy; 2008 the merb dev team</div>
- <p>&nbsp;</p>
- </div>
-</div>
diff --git a/chef-server/app/views/exceptions/not_found.html.erb b/chef-server/app/views/exceptions/not_found.html.erb
deleted file mode 100644
index 42b41a89dc..0000000000
--- a/chef-server/app/views/exceptions/not_found.html.erb
+++ /dev/null
@@ -1,47 +0,0 @@
-<div id="container">
- <div id="header-container">
- <img src="/images/merb.jpg" />
- <!-- <h1>Mongrel + Erb</h1> -->
- <h2>pocket rocket web framework</h2>
- <hr />
- </div>
-
- <div id="left-container">
- <h3>Exception:</h3>
- <p><%= request.exceptions.first.message %></p>
- </div>
-
- <div id="main-container">
- <h3>Welcome to Merb!</h3>
- <p>Merb is a light-weight MVC framework written in Ruby. We hope you enjoy it.</p>
-
- <h3>Where can I find help?</h3>
- <p>If you have any questions or if you can't figure something out, please take a
- look at our <a href="http://merbivore.com/"> project page</a>,
- feel free to come chat at irc.freenode.net, channel #merb,
- or post to <a href="http://groups.google.com/group/merb">merb mailing list</a>
- on Google Groups.</p>
-
- <h3>What if I've found a bug?</h3>
- <p>If you want to file a bug or make your own contribution to Merb,
- feel free to register and create a ticket at our
- <a href="http://merb.lighthouseapp.com/">project development page</a>
- on Lighthouse.</p>
-
- <h3>How do I edit this page?</h3>
- <p>You're seeing this page because you need to edit the following files:
- <ul>
- <li>config/router.rb <strong><em>(recommended)</em></strong></li>
- <li>app/views/exceptions/not_found.html.erb <strong><em>(recommended)</em></strong></li>
- <li>app/views/layout/application.html.erb <strong><em>(change this layout)</em></strong></li>
- </ul>
- </p>
- </div>
-
- <div id="footer-container">
- <hr />
- <div class="left"></div>
- <div class="right">&copy; 2008 the merb dev team</div>
- <p>&nbsp;</p>
- </div>
-</div>
diff --git a/chef-server/app/views/layout/application.html.erb b/chef-server/app/views/layout/application.html.erb
deleted file mode 100644
index 4637ef2ded..0000000000
--- a/chef-server/app/views/layout/application.html.erb
+++ /dev/null
@@ -1,12 +0,0 @@
-<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
-<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-us" lang="en-us">
- <head>
- <title>Fresh Merb App</title>
- <meta http-equiv="content-type" content="text/html; charset=utf-8" />
- <link rel="stylesheet" href="/stylesheets/master.css" type="text/css" media="screen" charset="utf-8" />
- </head>
- <body>
- <%#= message[:notice] %>
- <%= catch_content :for_layout %>
- </body>
-</html> \ No newline at end of file
diff --git a/chef-server/bin/chef-server b/chef-server/bin/chef-server
deleted file mode 100755
index b9a5e724dd..0000000000
--- a/chef-server/bin/chef-server
+++ /dev/null
@@ -1,80 +0,0 @@
-#!/usr/bin/env ruby
-#
-# ./chef-server - Serving up piping hot infrastructure!
-#
-# Author:: Adam Jacob (<adam@opscode.com>)
-# Copyright:: Copyright (c) 2008 Opscode, Inc.
-# License:: Apache License, Version 2.0
-#
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-# Based on the 'merb' command, by Ezra
-
-# Add chef and chef-server-slice lib dirs to the load path
-# Load chef and chef-server slice from source rather than gem, if present
-
-puts "please use the chef-server command in the chef-server-api gem"
-exit 1
-
-require "rubygems"
-require "merb-core"
-
-CHEF_SERVER_VERSION = "0.8.12"
-
-[ 'chef', 'chef-server-api' ].each do |lib|
- $:.unshift(File.expand_path(File.join(File.dirname(__FILE__), "..", "..", "lib")))
- library = File.expand_path(File.join(File.dirname(__FILE__), "..", "..", lib, "lib", "#{lib}.rb"))
- require library if File.exists?(library)
-end
-
-# Ensure the chef gem we load is the same version as the chef server
-unless defined?(Chef)
- gem "chef", "=" + CHEF_SERVER_VERSION
- require 'chef'
-end
-
-Dir.chdir File.join(File.dirname(__FILE__),"..")
-__DIR__ = Dir.getwd
-
-if ARGV[0] && ARGV[0] =~ /^[^-]/
- ARGV.push "-H"
-end
-unless %w[-a --adapter -i --irb-console -r --script-runner].any? { |o| ARGV.index(o) }
- ARGV.push *%w[-a thin]
-end
-ARGV.push *[ "-I", File.join(__DIR__, "config", "init.rb") ]
-ARGV.push *[ "-m", __DIR__]
-
-# attempt to find the user and group that this process will become. Fixes CHEF-1015
-if (index = ARGV.index("-u"))
- Chef::Config[:signing_ca_user] = ARGV[index+1]
-end
-if (index = ARGV.index("-G"))
- Chef::Config[:signing_ca_group] = ARGV[index+1]
-end
-
-if index = ARGV.index("-C")
- config = ARGV[index+1]
- ARGV.delete("-C")
- ARGV.delete(config)
- Chef::Config.from_file(File.expand_path(config))
-else
- Chef::Config.from_file(
- File.join("/etc", "chef", "server.rb")
- )
-end
-
-Chef::Log.init(Chef::Config[:log_location])
-Chef::Log.level = Chef::Config[:log_level]
-
-Merb.start
diff --git a/chef-server/bin/chef-server-webui b/chef-server/bin/chef-server-webui
deleted file mode 100755
index 51681a8658..0000000000
--- a/chef-server/bin/chef-server-webui
+++ /dev/null
@@ -1,75 +0,0 @@
-#!/usr/bin/env ruby
-#
-# ./chef-server - Serving up piping hot infrastructure!
-#
-# Author:: Adam Jacob (<adam@opscode.com>)
-# Copyright:: Copyright (c) 2008 Opscode, Inc.
-# License:: Apache License, Version 2.0
-#
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-# Based on the 'merb' command, by Ezra
-
-# Add chef and chef-server-slice lib dirs to the load path
-# Load chef and chef-server slice from source rather than gem, if present
-
-puts "please use the chef-server-webui command in the chef-server-webui gem"
-exit 1
-
-require "rubygems"
-require "merb-core"
-
-[ 'chef', 'chef-server-webui' ].each do |lib|
- $:.unshift(File.expand_path(File.join(File.dirname(__FILE__), "..", "..", "lib")))
- library = File.expand_path(File.join(File.dirname(__FILE__), "..", "..", lib, "lib", "#{lib}.rb"))
- require library if File.exists?(library)
-end
-
-CHEF_SERVER_VERSION = "0.8.12"
-
-# Ensure the chef gem we load is the same version as the chef server
-unless defined?(Chef)
- gem "chef", "=" + CHEF_SERVER_VERSION
- require 'chef'
-end
-
-Dir.chdir File.join(File.dirname(__FILE__),"..")
-__DIR__ = Dir.getwd
-
-if ARGV[0] && ARGV[0] =~ /^[^-]/
- ARGV.push "-H"
-end
-unless %w[-a --adapter -i --irb-console -r --script-runner].any? { |o| ARGV.index(o) }
- ARGV.push *%w[-a thin]
-end
-unless %w[-p --port].any? { |o| ARGV.index(o) }
- ARGV.push *%w[-p 4040]
-end
-ARGV.push *[ "-I", File.join(__DIR__, "config", "init-webui.rb") ]
-ARGV.push *[ "-m", __DIR__]
-
-if index = ARGV.index("-C")
- config = ARGV[index+1]
- ARGV.delete("-C")
- ARGV.delete(config)
- Chef::Config.from_file(File.expand_path(config))
-else
- Chef::Config.from_file(
- File.join("/etc", "chef", "server.rb")
- )
-end
-
-Chef::Log.init(Chef::Config[:log_location])
-Chef::Log.level = Chef::Config[:log_level]
-
-Merb.start
diff --git a/chef-server/config/dependencies-webui.rb b/chef-server/config/dependencies-webui.rb
deleted file mode 100644
index 392e1dbf86..0000000000
--- a/chef-server/config/dependencies-webui.rb
+++ /dev/null
@@ -1,27 +0,0 @@
-# dependencies are generated using a strict version, don't forget to edit the dependency versions when upgrading.
-merb_gems_version = "> 1.0"
-
-%w{chef chef-server-webui}.each do |dep|
- $:.unshift(File.expand_path(File.join(File.dirname(__FILE__), "..", "..", dep, "lib")))
-end
-
-dependency "chef", :immediate=>true unless defined?(Chef)
-
-begin
- require 'chef'
- require 'chef-server-webui'
-rescue LoadError
-end
-
-# For more information about each component, please read http://wiki.merbivore.com/faqs/merb_components
-dependency "merb-core", merb_gems_version
-dependency "merb-slices", merb_gems_version
-dependency "merb-haml", merb_gems_version
-dependency "merb-assets", merb_gems_version
-dependency "merb-helpers", merb_gems_version
-if defined?(CHEF_SERVER_VERSION)
- dependency "chef-server-webui", CHEF_SERVER_VERSION unless defined?(ChefServerWebui)
-else
- dependency "chef-server-webui" unless defined?(ChefServerWebui)
-end
-
diff --git a/chef-server/config/dependencies.rb b/chef-server/config/dependencies.rb
deleted file mode 100644
index cd22b55db2..0000000000
--- a/chef-server/config/dependencies.rb
+++ /dev/null
@@ -1,24 +0,0 @@
-# dependencies are generated using a strict version, don't forget to edit the dependency versions when upgrading.
-merb_gems_version = "> 1.0"
-
-%w{chef chef-server-api chef-solr}.each do |dep|
- $:.unshift(File.join(File.dirname(__FILE__), "..", "..", dep, "lib"))
-end
-
-begin
- require 'chef'
- require 'chef-server-api'
-rescue
-end
-
-# For more information about each component, please read http://wiki.merbivore.com/faqs/merb_components
-dependency "merb-core", merb_gems_version
-dependency "merb-assets", merb_gems_version
-dependency "merb-helpers", merb_gems_version
-dependency "merb-slices", merb_gems_version
-if defined?(CHEF_SERVER_VERSION)
- dependency "chef-server-api", CHEF_SERVER_VERSION unless defined?(ChefServerApi)
-else
- dependency "chef-server-api" unless defined?(ChefServerApi)
-end
-
diff --git a/chef-server/config/environments/development.rb b/chef-server/config/environments/development.rb
deleted file mode 100644
index a3f091520b..0000000000
--- a/chef-server/config/environments/development.rb
+++ /dev/null
@@ -1,13 +0,0 @@
-Merb.logger.info("Loaded DEVELOPMENT Environment...")
-Merb::Config.use { |c|
- c[:exception_details] = true
- c[:reload_templates] = true
- c[:reload_classes] = true
- c[:reload_time] = 0.5
- c[:log_auto_flush ] = true
- c[:log_level] = :debug
- c[:log_stream] = Chef::Config[:log_location]
- c[:log_file] = nil
- # Or redirect logging into a file:
- # c[:log_file] = Merb.root / "log" / "development.log"
-}
diff --git a/chef-server/config/environments/production.rb b/chef-server/config/environments/production.rb
deleted file mode 100644
index 73c3d55a0d..0000000000
--- a/chef-server/config/environments/production.rb
+++ /dev/null
@@ -1,10 +0,0 @@
-Merb.logger.info("Loaded PRODUCTION Environment...")
-Merb::Config.use { |c|
- c[:exception_details] = false
- c[:reload_classes] = false
- c[:log_auto_flush] = true
- c[:log_level] = Chef::Config[:log_level]
- c[:log_stream] = Chef::Config[:log_location]
- # or redirect logger using IO handle
- # c[:log_stream] = STDOUT
-}
diff --git a/chef-server/config/environments/rake.rb b/chef-server/config/environments/rake.rb
deleted file mode 100644
index 6417884453..0000000000
--- a/chef-server/config/environments/rake.rb
+++ /dev/null
@@ -1,10 +0,0 @@
-Merb.logger.info("Loaded RAKE Environment...")
-Merb::Config.use { |c|
- c[:exception_details] = true
- c[:reload_classes] = false
- c[:log_auto_flush ] = true
- c[:log_stream] = Chef::Config[:log_location]
- c[:log_file] = nil
- # Or redirect logging into a file:
- # c[:log_file] = Merb.root / "log" / "development.log"
-}
diff --git a/chef-server/config/environments/staging.rb b/chef-server/config/environments/staging.rb
deleted file mode 100644
index 0ac303dd44..0000000000
--- a/chef-server/config/environments/staging.rb
+++ /dev/null
@@ -1,10 +0,0 @@
-Merb.logger.info("Loaded STAGING Environment...")
-Merb::Config.use { |c|
- c[:exception_details] = false
- c[:reload_classes] = false
- c[:log_level] = :error
- c[:log_stream] = Chef::Config[:log_location]
- c[:log_file] = nil
- # or redirect logger using IO handle
- # c[:log_stream] = STDOUT
-}
diff --git a/chef-server/config/environments/test.rb b/chef-server/config/environments/test.rb
deleted file mode 100644
index e180453873..0000000000
--- a/chef-server/config/environments/test.rb
+++ /dev/null
@@ -1,13 +0,0 @@
-Merb.logger.info("Loaded TEST Environment...")
-Merb::Config.use { |c|
- c[:testing] = true
- c[:exception_details] = true
- c[:log_auto_flush ] = true
-
- # log less in testing environment
- c[:log_level] = :error
- c[:log_stream] = Chef::Config[:log_location]
- c[:log_file] = nil
- #c[:log_file] = Merb.root / "log" / "test.log"
- # or redirect logger using IO handle
-}
diff --git a/chef-server/config/init-webui.rb b/chef-server/config/init-webui.rb
deleted file mode 100644
index 0de477a4e4..0000000000
--- a/chef-server/config/init-webui.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-# Go to http://wiki.merbivore.com/pages/init-rb
-
-require 'config/dependencies-webui.rb'
-unless defined?(Chef)
- gem "chef", "=" + CHEF_SERVER_VERSION if CHEF_SERVER_VERSION
- require 'chef'
-end
-
-File.umask Chef::Config[:umask]
-
-use_test :rspec
-use_template_engine :haml
-
-Merb::Config.use do |c|
- c[:use_mutex] = false
- c[:fork_for_class_load] = false
- c[:session_id_key] = '_chef_server_session_id'
- c[:session_secret_key] = Chef::Config.manage_secret_key
- c[:session_store] = 'cookie'
- c[:log_level] = Chef::Config[:log_level]
- if Chef::Config[:log_location].kind_of?(String)
- c[:log_file] = Chef::Config[:log_location]
- end
-end
-
-Merb::BootLoader.before_app_loads do
- # This will get executed after dependencies have been loaded but before your app's classes have loaded.
-end
-
-Merb::BootLoader.after_app_loads do
- # This will get executed after your app's classes have been loaded.
- OpenID::Util.logger = Merb.logger
-end
-
diff --git a/chef-server/config/init.rb b/chef-server/config/init.rb
deleted file mode 100644
index 6ed09b4eea..0000000000
--- a/chef-server/config/init.rb
+++ /dev/null
@@ -1,30 +0,0 @@
-# Go to http://wiki.merbivore.com/pages/init-rb
-
-require 'config/dependencies.rb'
-unless defined?(Chef)
- gem "chef", "=" + CHEF_SERVER_VERSION if CHEF_SERVER_VERSION
- require 'chef'
-end
-
-File.umask Chef::Config[:umask]
-
-use_test :rspec
-use_template_engine :haml
-
-Merb::Config.use do |c|
- c[:use_mutex] = false
- c[:fork_for_class_load] = false
- c[:log_level] = Chef::Config[:log_level]
- if Chef::Config[:log_location].kind_of?(String)
- c[:log_file] = Chef::Config[:log_location]
- end
-end
-
-Merb::BootLoader.before_app_loads do
- # This will get executed after dependencies have been loaded but before your app's classes have loaded.
-end
-
-Merb::BootLoader.after_app_loads do
- # This will get executed after your app's classes have been loaded. OpenID::Util.logger = Merb.logger
-end
-
diff --git a/chef-server/config/rack.rb b/chef-server/config/rack.rb
deleted file mode 100644
index 4ed0f70b55..0000000000
--- a/chef-server/config/rack.rb
+++ /dev/null
@@ -1,21 +0,0 @@
-$: << File.join(File.dirname(__FILE__))
-
-# use PathPrefix Middleware if :path_prefix is set in Merb::Config
-if prefix = ::Merb::Config[:path_prefix]
- use Merb::Rack::PathPrefix, prefix
-end
-
-# comment this out if you are running merb behind a load balancer
-# that serves static files
-use Merb::Rack::Static, Merb.dir_for(:public)
-
-Merb::Slices.config.each do |slice_module, config|
- slice_module = Object.full_const_get(slice_module.to_s.camel_case) if slice_module.class.in?(String, Symbol)
- slice_module.send("public_components").each do |component|
- slice_static_dir = slice_module.send("dir_for", :public)
- use Merb::Rack::Static, slice_static_dir
- end
-end
-
-# this is our main merb application
-run Merb::Rack::Application.new
diff --git a/chef-server/config/router.rb b/chef-server/config/router.rb
deleted file mode 100644
index f352c42f61..0000000000
--- a/chef-server/config/router.rb
+++ /dev/null
@@ -1,39 +0,0 @@
-# Merb::Router is the request routing mapper for the merb framework.
-#
-# You can route a specific URL to a controller / action pair:
-#
-# match("/contact").
-# to(:controller => "info", :action => "contact")
-#
-# You can define placeholder parts of the url with the :symbol notation. These
-# placeholders will be available in the params hash of your controllers. For example:
-#
-# match("/books/:book_id/:action").
-# to(:controller => "books")
-#
-# Or, use placeholders in the "to" results for more complicated routing, e.g.:
-#
-# match("/admin/:module/:controller/:action/:id").
-# to(:controller => ":module/:controller")
-#
-# You can specify conditions on the placeholder by passing a hash as the second
-# argument of "match"
-#
-# match("/registration/:course_name", :course_name => /^[a-z]{3,5}-\d{5}$/).
-# to(:controller => "registration")
-#
-# You can also use regular expressions, deferred routes, and many other options.
-# See merb/specs/merb/router.rb for a fairly complete usage sample.
-
-Merb.logger.info("Compiling routes...")
-Merb::Router.prepare do
- # RESTful routes
- # resources :posts
-
- # Adds the required routes for merb-auth using the password slice
- # slice(:merb_auth_slice_password, :name_prefix => nil, :path_prefix => "")
-
- slice(:chef_server_api, :path_prefix => "") if defined?(ChefServerApi)
- slice(:chef_server_webui, :path_prefix => "") if defined?(ChefServerWebui)
-
-end
diff --git a/chef-server/lib/tasks/install.rake b/chef-server/lib/tasks/install.rake
deleted file mode 100644
index 7e8078792f..0000000000
--- a/chef-server/lib/tasks/install.rake
+++ /dev/null
@@ -1,7 +0,0 @@
-require 'rubygems'
-require 'rake/gempackagetask'
-
-task :install => :package do
- sh %{gem install pkg/#{GEM}-#{CHEF_SERVER_VERSION} --no-rdoc --no-ri}
-end
-
diff --git a/chef-server/lib/tasks/package.rake b/chef-server/lib/tasks/package.rake
deleted file mode 100644
index 6560481640..0000000000
--- a/chef-server/lib/tasks/package.rake
+++ /dev/null
@@ -1,34 +0,0 @@
-require 'rubygems'
-require 'rake/gempackagetask'
-
-spec = Gem::Specification.new do |s|
- s.name = GEM
- s.version = CHEF_SERVER_VERSION
- s.platform = Gem::Platform::RUBY
- s.has_rdoc = true
- s.extra_rdoc_files = ["README.rdoc", "LICENSE" ]
- s.summary = SUMMARY
- s.description = s.summary
- s.author = AUTHOR
- s.email = EMAIL
- s.homepage = HOMEPAGE
- s.add_dependency "merb-core", "~> 1.0.0"
- s.add_dependency "merb-haml", "~> 1.0.0"
- s.add_dependency "merb-assets", "~> 1.0.0"
- s.add_dependency "merb-helpers", "~> 1.0.0"
- s.add_dependency "json", "<= 1.4.2"
-
- %w{ thin haml
- ruby-openid coderay}.each { |gem| s.add_dependency gem }
-
- s.bindir = "bin"
- s.executables = %w( chef-server chef-server-webui )
- s.files = %w(LICENSE README.rdoc config.ru config-webui.ru) + Dir.glob("{app,bin,config,lib,public}/**/*")
-end
-
-Rake::GemPackageTask.new(spec) do |pkg|
- pkg.gem_spec = spec
-end
-
-
-
diff --git a/chef-server/lib/tasks/uninstall.rake b/chef-server/lib/tasks/uninstall.rake
deleted file mode 100644
index dd475e22f0..0000000000
--- a/chef-server/lib/tasks/uninstall.rake
+++ /dev/null
@@ -1,7 +0,0 @@
-require 'rubygems'
-require 'rake/gempackagetask'
-
-task :uninstall do
- sh %{gem uninstall #{GEM} -x -v #{CHEF_SERVER_VERSION}}
-end
-
diff --git a/chef-server/lib/views/exceptions/bad_request.html.haml b/chef-server/lib/views/exceptions/bad_request.html.haml
deleted file mode 100644
index c70c26a658..0000000000
--- a/chef-server/lib/views/exceptions/bad_request.html.haml
+++ /dev/null
@@ -1,2 +0,0 @@
-- request.exceptions.each do |exception|
- = exception.message \ No newline at end of file
diff --git a/chef-server/public/.htaccess b/chef-server/public/.htaccess
deleted file mode 100644
index 455e706f96..0000000000
--- a/chef-server/public/.htaccess
+++ /dev/null
@@ -1,17 +0,0 @@
-# Sets the default handler for FastCGI scripts
-AddHandler fastcgi-script .fcgi
-
-# If Apache2 is used together with mod_fcgid,
-# uncomment the line below and comment in the line
-# above to set the correct script handler
-#AddHandler fcgid-script .fcgi
-
-RewriteEngine On
-
-RewriteRule ^$ index.html [QSA]
-RewriteRule ^([^.]+)$ $1.html [QSA]
-RewriteCond %{REQUEST_FILENAME} !-f
-RewriteRule ^(.*)$ merb.fcgi [QSA,L]
-
-
-ErrorDocument 500 "<h2>Application Error</h2>Merb could not be reached"
diff --git a/chef-server/public/favicon.ico b/chef-server/public/favicon.ico
deleted file mode 100644
index c908d63b92..0000000000
--- a/chef-server/public/favicon.ico
+++ /dev/null
Binary files differ
diff --git a/chef-server/public/images/merb.jpg b/chef-server/public/images/merb.jpg
deleted file mode 100644
index a19dcf4048..0000000000
--- a/chef-server/public/images/merb.jpg
+++ /dev/null
Binary files differ
diff --git a/chef-server/public/javascripts/application.js b/chef-server/public/javascripts/application.js
deleted file mode 100644
index 246a8be4c1..0000000000
--- a/chef-server/public/javascripts/application.js
+++ /dev/null
@@ -1 +0,0 @@
-// Common JavaScript code across your application goes here. \ No newline at end of file
diff --git a/chef-server/public/javascripts/jquery.js b/chef-server/public/javascripts/jquery.js
deleted file mode 100644
index 396646c842..0000000000
--- a/chef-server/public/javascripts/jquery.js
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * jQuery JavaScript Library v1.3
- * http://jquery.com/
- *
- * Copyright (c) 2009 John Resig
- * Dual licensed under the MIT and GPL licenses.
- * http://docs.jquery.com/License
- *
- * Date: 2009-01-13 12:50:31 -0500 (Tue, 13 Jan 2009)
- * Revision: 6104
- */
-(function(){var l=this,g,x=l.jQuery,o=l.$,n=l.jQuery=l.$=function(D,E){return new n.fn.init(D,E)},C=/^[^<]*(<(.|\s)+>)[^>]*$|^#([\w-]+)$/,f=/^.[^:#\[\.,]*$/;n.fn=n.prototype={init:function(D,G){D=D||document;if(D.nodeType){this[0]=D;this.length=1;this.context=D;return this}if(typeof D==="string"){var F=C.exec(D);if(F&&(F[1]||!G)){if(F[1]){D=n.clean([F[1]],G)}else{var H=document.getElementById(F[3]);if(H){if(H.id!=F[3]){return n().find(D)}var E=n(H);E.context=document;E.selector=D;return E}D=[]}}else{return n(G).find(D)}}else{if(n.isFunction(D)){return n(document).ready(D)}}if(D.selector&&D.context){this.selector=D.selector;this.context=D.context}return this.setArray(n.makeArray(D))},selector:"",jquery:"1.3",size:function(){return this.length},get:function(D){return D===g?n.makeArray(this):this[D]},pushStack:function(E,G,D){var F=n(E);F.prevObject=this;F.context=this.context;if(G==="find"){F.selector=this.selector+(this.selector?" ":"")+D}else{if(G){F.selector=this.selector+"."+G+"("+D+")"}}return F},setArray:function(D){this.length=0;Array.prototype.push.apply(this,D);return this},each:function(E,D){return n.each(this,E,D)},index:function(D){return n.inArray(D&&D.jquery?D[0]:D,this)},attr:function(E,G,F){var D=E;if(typeof E==="string"){if(G===g){return this[0]&&n[F||"attr"](this[0],E)}else{D={};D[E]=G}}return this.each(function(H){for(E in D){n.attr(F?this.style:this,E,n.prop(this,D[E],F,H,E))}})},css:function(D,E){if((D=="width"||D=="height")&&parseFloat(E)<0){E=g}return this.attr(D,E,"curCSS")},text:function(E){if(typeof E!=="object"&&E!=null){return this.empty().append((this[0]&&this[0].ownerDocument||document).createTextNode(E))}var D="";n.each(E||this,function(){n.each(this.childNodes,function(){if(this.nodeType!=8){D+=this.nodeType!=1?this.nodeValue:n.fn.text([this])}})});return D},wrapAll:function(D){if(this[0]){var E=n(D,this[0].ownerDocument).clone();if(this[0].parentNode){E.insertBefore(this[0])}E.map(function(){var F=this;while(F.firstChild){F=F.firstChild}return F}).append(this)}return this},wrapInner:function(D){return this.each(function(){n(this).contents().wrapAll(D)})},wrap:function(D){return this.each(function(){n(this).wrapAll(D)})},append:function(){return this.domManip(arguments,true,function(D){if(this.nodeType==1){this.appendChild(D)}})},prepend:function(){return this.domManip(arguments,true,function(D){if(this.nodeType==1){this.insertBefore(D,this.firstChild)}})},before:function(){return this.domManip(arguments,false,function(D){this.parentNode.insertBefore(D,this)})},after:function(){return this.domManip(arguments,false,function(D){this.parentNode.insertBefore(D,this.nextSibling)})},end:function(){return this.prevObject||n([])},push:[].push,find:function(D){if(this.length===1&&!/,/.test(D)){var F=this.pushStack([],"find",D);F.length=0;n.find(D,this[0],F);return F}else{var E=n.map(this,function(G){return n.find(D,G)});return this.pushStack(/[^+>] [^+>]/.test(D)?n.unique(E):E,"find",D)}},clone:function(E){var D=this.map(function(){if(!n.support.noCloneEvent&&!n.isXMLDoc(this)){var H=this.cloneNode(true),G=document.createElement("div");G.appendChild(H);return n.clean([G.innerHTML])[0]}else{return this.cloneNode(true)}});var F=D.find("*").andSelf().each(function(){if(this[h]!==g){this[h]=null}});if(E===true){this.find("*").andSelf().each(function(H){if(this.nodeType==3){return}var G=n.data(this,"events");for(var J in G){for(var I in G[J]){n.event.add(F[H],J,G[J][I],G[J][I].data)}}})}return D},filter:function(D){return this.pushStack(n.isFunction(D)&&n.grep(this,function(F,E){return D.call(F,E)})||n.multiFilter(D,n.grep(this,function(E){return E.nodeType===1})),"filter",D)},closest:function(D){var E=n.expr.match.POS.test(D)?n(D):null;return this.map(function(){var F=this;while(F&&F.ownerDocument){if(E?E.index(F)>-1:n(F).is(D)){return F}F=F.parentNode}})},not:function(D){if(typeof D==="string"){if(f.test(D)){return this.pushStack(n.multiFilter(D,this,true),"not",D)}else{D=n.multiFilter(D,this)}}var E=D.length&&D[D.length-1]!==g&&!D.nodeType;return this.filter(function(){return E?n.inArray(this,D)<0:this!=D})},add:function(D){return this.pushStack(n.unique(n.merge(this.get(),typeof D==="string"?n(D):n.makeArray(D))))},is:function(D){return !!D&&n.multiFilter(D,this).length>0},hasClass:function(D){return !!D&&this.is("."+D)},val:function(J){if(J===g){var D=this[0];if(D){if(n.nodeName(D,"option")){return(D.attributes.value||{}).specified?D.value:D.text}if(n.nodeName(D,"select")){var H=D.selectedIndex,K=[],L=D.options,G=D.type=="select-one";if(H<0){return null}for(var E=G?H:0,I=G?H+1:L.length;E<I;E++){var F=L[E];if(F.selected){J=n(F).val();if(G){return J}K.push(J)}}return K}return(D.value||"").replace(/\r/g,"")}return g}if(typeof J==="number"){J+=""}return this.each(function(){if(this.nodeType!=1){return}if(n.isArray(J)&&/radio|checkbox/.test(this.type)){this.checked=(n.inArray(this.value,J)>=0||n.inArray(this.name,J)>=0)}else{if(n.nodeName(this,"select")){var M=n.makeArray(J);n("option",this).each(function(){this.selected=(n.inArray(this.value,M)>=0||n.inArray(this.text,M)>=0)});if(!M.length){this.selectedIndex=-1}}else{this.value=J}}})},html:function(D){return D===g?(this[0]?this[0].innerHTML:null):this.empty().append(D)},replaceWith:function(D){return this.after(D).remove()},eq:function(D){return this.slice(D,+D+1)},slice:function(){return this.pushStack(Array.prototype.slice.apply(this,arguments),"slice",Array.prototype.slice.call(arguments).join(","))},map:function(D){return this.pushStack(n.map(this,function(F,E){return D.call(F,E,F)}))},andSelf:function(){return this.add(this.prevObject)},domManip:function(J,M,L){if(this[0]){var I=(this[0].ownerDocument||this[0]).createDocumentFragment(),F=n.clean(J,(this[0].ownerDocument||this[0]),I),H=I.firstChild,D=this.length>1?I.cloneNode(true):I;if(H){for(var G=0,E=this.length;G<E;G++){L.call(K(this[G],H),G>0?D.cloneNode(true):I)}}if(F){n.each(F,y)}}return this;function K(N,O){return M&&n.nodeName(N,"table")&&n.nodeName(O,"tr")?(N.getElementsByTagName("tbody")[0]||N.appendChild(N.ownerDocument.createElement("tbody"))):N}}};n.fn.init.prototype=n.fn;function y(D,E){if(E.src){n.ajax({url:E.src,async:false,dataType:"script"})}else{n.globalEval(E.text||E.textContent||E.innerHTML||"")}if(E.parentNode){E.parentNode.removeChild(E)}}function e(){return +new Date}n.extend=n.fn.extend=function(){var I=arguments[0]||{},G=1,H=arguments.length,D=false,F;if(typeof I==="boolean"){D=I;I=arguments[1]||{};G=2}if(typeof I!=="object"&&!n.isFunction(I)){I={}}if(H==G){I=this;--G}for(;G<H;G++){if((F=arguments[G])!=null){for(var E in F){var J=I[E],K=F[E];if(I===K){continue}if(D&&K&&typeof K==="object"&&!K.nodeType){I[E]=n.extend(D,J||(K.length!=null?[]:{}),K)}else{if(K!==g){I[E]=K}}}}}return I};var b=/z-?index|font-?weight|opacity|zoom|line-?height/i,p=document.defaultView||{},r=Object.prototype.toString;n.extend({noConflict:function(D){l.$=o;if(D){l.jQuery=x}return n},isFunction:function(D){return r.call(D)==="[object Function]"},isArray:function(D){return r.call(D)==="[object Array]"},isXMLDoc:function(D){return D.documentElement&&!D.body||D.tagName&&D.ownerDocument&&!D.ownerDocument.body},globalEval:function(F){F=n.trim(F);if(F){var E=document.getElementsByTagName("head")[0]||document.documentElement,D=document.createElement("script");D.type="text/javascript";if(n.support.scriptEval){D.appendChild(document.createTextNode(F))}else{D.text=F}E.insertBefore(D,E.firstChild);E.removeChild(D)}},nodeName:function(E,D){return E.nodeName&&E.nodeName.toUpperCase()==D.toUpperCase()},each:function(F,J,E){var D,G=0,H=F.length;if(E){if(H===g){for(D in F){if(J.apply(F[D],E)===false){break}}}else{for(;G<H;){if(J.apply(F[G++],E)===false){break}}}}else{if(H===g){for(D in F){if(J.call(F[D],D,F[D])===false){break}}}else{for(var I=F[0];G<H&&J.call(I,G,I)!==false;I=F[++G]){}}}return F},prop:function(G,H,F,E,D){if(n.isFunction(H)){H=H.call(G,E)}return typeof H==="number"&&F=="curCSS"&&!b.test(D)?H+"px":H},className:{add:function(D,E){n.each((E||"").split(/\s+/),function(F,G){if(D.nodeType==1&&!n.className.has(D.className,G)){D.className+=(D.className?" ":"")+G}})},remove:function(D,E){if(D.nodeType==1){D.className=E!==g?n.grep(D.className.split(/\s+/),function(F){return !n.className.has(E,F)}).join(" "):""}},has:function(E,D){return n.inArray(D,(E.className||E).toString().split(/\s+/))>-1}},swap:function(G,F,H){var D={};for(var E in F){D[E]=G.style[E];G.style[E]=F[E]}H.call(G);for(var E in F){G.style[E]=D[E]}},css:function(F,D,H){if(D=="width"||D=="height"){var J,E={position:"absolute",visibility:"hidden",display:"block"},I=D=="width"?["Left","Right"]:["Top","Bottom"];function G(){J=D=="width"?F.offsetWidth:F.offsetHeight;var L=0,K=0;n.each(I,function(){L+=parseFloat(n.curCSS(F,"padding"+this,true))||0;K+=parseFloat(n.curCSS(F,"border"+this+"Width",true))||0});J-=Math.round(L+K)}if(n(F).is(":visible")){G()}else{n.swap(F,E,G)}return Math.max(0,J)}return n.curCSS(F,D,H)},curCSS:function(H,E,F){var K,D=H.style;if(E=="opacity"&&!n.support.opacity){K=n.attr(D,"opacity");return K==""?"1":K}if(E.match(/float/i)){E=v}if(!F&&D&&D[E]){K=D[E]}else{if(p.getComputedStyle){if(E.match(/float/i)){E="float"}E=E.replace(/([A-Z])/g,"-$1").toLowerCase();var L=p.getComputedStyle(H,null);if(L){K=L.getPropertyValue(E)}if(E=="opacity"&&K==""){K="1"}}else{if(H.currentStyle){var I=E.replace(/\-(\w)/g,function(M,N){return N.toUpperCase()});K=H.currentStyle[E]||H.currentStyle[I];if(!/^\d+(px)?$/i.test(K)&&/^\d/.test(K)){var G=D.left,J=H.runtimeStyle.left;H.runtimeStyle.left=H.currentStyle.left;D.left=K||0;K=D.pixelLeft+"px";D.left=G;H.runtimeStyle.left=J}}}}return K},clean:function(E,J,H){J=J||document;if(typeof J.createElement==="undefined"){J=J.ownerDocument||J[0]&&J[0].ownerDocument||document}if(!H&&E.length===1&&typeof E[0]==="string"){var G=/^<(\w+)\s*\/?>$/.exec(E[0]);if(G){return[J.createElement(G[1])]}}var F=[],D=[],K=J.createElement("div");n.each(E,function(O,Q){if(typeof Q==="number"){Q+=""}if(!Q){return}if(typeof Q==="string"){Q=Q.replace(/(<(\w+)[^>]*?)\/>/g,function(S,T,R){return R.match(/^(abbr|br|col|img|input|link|meta|param|hr|area|embed)$/i)?S:T+"></"+R+">"});var N=n.trim(Q).toLowerCase();var P=!N.indexOf("<opt")&&[1,"<select multiple='multiple'>","</select>"]||!N.indexOf("<leg")&&[1,"<fieldset>","</fieldset>"]||N.match(/^<(thead|tbody|tfoot|colg|cap)/)&&[1,"<table>","</table>"]||!N.indexOf("<tr")&&[2,"<table><tbody>","</tbody></table>"]||(!N.indexOf("<td")||!N.indexOf("<th"))&&[3,"<table><tbody><tr>","</tr></tbody></table>"]||!N.indexOf("<col")&&[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"]||!n.support.htmlSerialize&&[1,"div<div>","</div>"]||[0,"",""];K.innerHTML=P[1]+Q+P[2];while(P[0]--){K=K.lastChild}if(!n.support.tbody){var M=!N.indexOf("<table")&&N.indexOf("<tbody")<0?K.firstChild&&K.firstChild.childNodes:P[1]=="<table>"&&N.indexOf("<tbody")<0?K.childNodes:[];for(var L=M.length-1;L>=0;--L){if(n.nodeName(M[L],"tbody")&&!M[L].childNodes.length){M[L].parentNode.removeChild(M[L])}}}if(!n.support.leadingWhitespace&&/^\s/.test(Q)){K.insertBefore(J.createTextNode(Q.match(/^\s*/)[0]),K.firstChild)}Q=n.makeArray(K.childNodes)}if(Q.nodeType){F.push(Q)}else{F=n.merge(F,Q)}});if(H){for(var I=0;F[I];I++){if(n.nodeName(F[I],"script")&&(!F[I].type||F[I].type.toLowerCase()==="text/javascript")){D.push(F[I].parentNode?F[I].parentNode.removeChild(F[I]):F[I])}else{if(F[I].nodeType===1){F.splice.apply(F,[I+1,0].concat(n.makeArray(F[I].getElementsByTagName("script"))))}H.appendChild(F[I])}}return D}return F},attr:function(I,F,J){if(!I||I.nodeType==3||I.nodeType==8){return g}var G=!n.isXMLDoc(I),K=J!==g;F=G&&n.props[F]||F;if(I.tagName){var E=/href|src|style/.test(F);if(F=="selected"&&I.parentNode){I.parentNode.selectedIndex}if(F in I&&G&&!E){if(K){if(F=="type"&&n.nodeName(I,"input")&&I.parentNode){throw"type property can't be changed"}I[F]=J}if(n.nodeName(I,"form")&&I.getAttributeNode(F)){return I.getAttributeNode(F).nodeValue}if(F=="tabIndex"){var H=I.getAttributeNode("tabIndex");return H&&H.specified?H.value:I.nodeName.match(/^(a|area|button|input|object|select|textarea)$/i)?0:g}return I[F]}if(!n.support.style&&G&&F=="style"){return n.attr(I.style,"cssText",J)}if(K){I.setAttribute(F,""+J)}var D=!n.support.hrefNormalized&&G&&E?I.getAttribute(F,2):I.getAttribute(F);return D===null?g:D}if(!n.support.opacity&&F=="opacity"){if(K){I.zoom=1;I.filter=(I.filter||"").replace(/alpha\([^)]*\)/,"")+(parseInt(J)+""=="NaN"?"":"alpha(opacity="+J*100+")")}return I.filter&&I.filter.indexOf("opacity=")>=0?(parseFloat(I.filter.match(/opacity=([^)]*)/)[1])/100)+"":""}F=F.replace(/-([a-z])/ig,function(L,M){return M.toUpperCase()});if(K){I[F]=J}return I[F]},trim:function(D){return(D||"").replace(/^\s+|\s+$/g,"")},makeArray:function(F){var D=[];if(F!=null){var E=F.length;if(E==null||typeof F==="string"||n.isFunction(F)||F.setInterval){D[0]=F}else{while(E){D[--E]=F[E]}}}return D},inArray:function(F,G){for(var D=0,E=G.length;D<E;D++){if(G[D]===F){return D}}return -1},merge:function(G,D){var E=0,F,H=G.length;if(!n.support.getAll){while((F=D[E++])!=null){if(F.nodeType!=8){G[H++]=F}}}else{while((F=D[E++])!=null){G[H++]=F}}return G},unique:function(J){var E=[],D={};try{for(var F=0,G=J.length;F<G;F++){var I=n.data(J[F]);if(!D[I]){D[I]=true;E.push(J[F])}}}catch(H){E=J}return E},grep:function(E,I,D){var F=[];for(var G=0,H=E.length;G<H;G++){if(!D!=!I(E[G],G)){F.push(E[G])}}return F},map:function(D,I){var E=[];for(var F=0,G=D.length;F<G;F++){var H=I(D[F],F);if(H!=null){E[E.length]=H}}return E.concat.apply([],E)}});var B=navigator.userAgent.toLowerCase();n.browser={version:(B.match(/.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/)||[0,"0"])[1],safari:/webkit/.test(B),opera:/opera/.test(B),msie:/msie/.test(B)&&!/opera/.test(B),mozilla:/mozilla/.test(B)&&!/(compatible|webkit)/.test(B)};n.each({parent:function(D){return D.parentNode},parents:function(D){return n.dir(D,"parentNode")},next:function(D){return n.nth(D,2,"nextSibling")},prev:function(D){return n.nth(D,2,"previousSibling")},nextAll:function(D){return n.dir(D,"nextSibling")},prevAll:function(D){return n.dir(D,"previousSibling")},siblings:function(D){return n.sibling(D.parentNode.firstChild,D)},children:function(D){return n.sibling(D.firstChild)},contents:function(D){return n.nodeName(D,"iframe")?D.contentDocument||D.contentWindow.document:n.makeArray(D.childNodes)}},function(D,E){n.fn[D]=function(F){var G=n.map(this,E);if(F&&typeof F=="string"){G=n.multiFilter(F,G)}return this.pushStack(n.unique(G),D,F)}});n.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(D,E){n.fn[D]=function(){var F=arguments;return this.each(function(){for(var G=0,H=F.length;G<H;G++){n(F[G])[E](this)}})}});n.each({removeAttr:function(D){n.attr(this,D,"");if(this.nodeType==1){this.removeAttribute(D)}},addClass:function(D){n.className.add(this,D)},removeClass:function(D){n.className.remove(this,D)},toggleClass:function(E,D){if(typeof D!=="boolean"){D=!n.className.has(this,E)}n.className[D?"add":"remove"](this,E)},remove:function(D){if(!D||n.filter(D,[this]).length){n("*",this).add([this]).each(function(){n.event.remove(this);n.removeData(this)});if(this.parentNode){this.parentNode.removeChild(this)}}},empty:function(){n(">*",this).remove();while(this.firstChild){this.removeChild(this.firstChild)}}},function(D,E){n.fn[D]=function(){return this.each(E,arguments)}});function j(D,E){return D[0]&&parseInt(n.curCSS(D[0],E,true),10)||0}var h="jQuery"+e(),u=0,z={};n.extend({cache:{},data:function(E,D,F){E=E==l?z:E;var G=E[h];if(!G){G=E[h]=++u}if(D&&!n.cache[G]){n.cache[G]={}}if(F!==g){n.cache[G][D]=F}return D?n.cache[G][D]:G},removeData:function(E,D){E=E==l?z:E;var G=E[h];if(D){if(n.cache[G]){delete n.cache[G][D];D="";for(D in n.cache[G]){break}if(!D){n.removeData(E)}}}else{try{delete E[h]}catch(F){if(E.removeAttribute){E.removeAttribute(h)}}delete n.cache[G]}},queue:function(E,D,G){if(E){D=(D||"fx")+"queue";var F=n.data(E,D);if(!F||n.isArray(G)){F=n.data(E,D,n.makeArray(G))}else{if(G){F.push(G)}}}return F},dequeue:function(G,F){var D=n.queue(G,F),E=D.shift();if(!F||F==="fx"){E=D[0]}if(E!==g){E.call(G)}}});n.fn.extend({data:function(D,F){var G=D.split(".");G[1]=G[1]?"."+G[1]:"";if(F===g){var E=this.triggerHandler("getData"+G[1]+"!",[G[0]]);if(E===g&&this.length){E=n.data(this[0],D)}return E===g&&G[1]?this.data(G[0]):E}else{return this.trigger("setData"+G[1]+"!",[G[0],F]).each(function(){n.data(this,D,F)})}},removeData:function(D){return this.each(function(){n.removeData(this,D)})},queue:function(D,E){if(typeof D!=="string"){E=D;D="fx"}if(E===g){return n.queue(this[0],D)}return this.each(function(){var F=n.queue(this,D,E);if(D=="fx"&&F.length==1){F[0].call(this)}})},dequeue:function(D){return this.each(function(){n.dequeue(this,D)})}});
-/*
- * Sizzle CSS Selector Engine - v0.9.1
- * Copyright 2009, The Dojo Foundation
- * Released under the MIT, BSD, and GPL Licenses.
- * More information: http://sizzlejs.com/
- */
-(function(){var N=/((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|[^[\]]+)+\]|\\.|[^ >+~,(\[]+)+|[>+~])(\s*,\s*)?/g,I=0,F=Object.prototype.toString;var E=function(ae,S,aa,V){aa=aa||[];S=S||document;if(S.nodeType!==1&&S.nodeType!==9){return[]}if(!ae||typeof ae!=="string"){return aa}var ab=[],ac,Y,ah,ag,Z,R,Q=true;N.lastIndex=0;while((ac=N.exec(ae))!==null){ab.push(ac[1]);if(ac[2]){R=RegExp.rightContext;break}}if(ab.length>1&&G.match.POS.exec(ae)){if(ab.length===2&&G.relative[ab[0]]){var U="",X;while((X=G.match.POS.exec(ae))){U+=X[0];ae=ae.replace(G.match.POS,"")}Y=E.filter(U,E(/\s$/.test(ae)?ae+"*":ae,S))}else{Y=G.relative[ab[0]]?[S]:E(ab.shift(),S);while(ab.length){var P=[];ae=ab.shift();if(G.relative[ae]){ae+=ab.shift()}for(var af=0,ad=Y.length;af<ad;af++){E(ae,Y[af],P)}Y=P}}}else{var ai=V?{expr:ab.pop(),set:D(V)}:E.find(ab.pop(),ab.length===1&&S.parentNode?S.parentNode:S);Y=E.filter(ai.expr,ai.set);if(ab.length>0){ah=D(Y)}else{Q=false}while(ab.length){var T=ab.pop(),W=T;if(!G.relative[T]){T=""}else{W=ab.pop()}if(W==null){W=S}G.relative[T](ah,W,M(S))}}if(!ah){ah=Y}if(!ah){throw"Syntax error, unrecognized expression: "+(T||ae)}if(F.call(ah)==="[object Array]"){if(!Q){aa.push.apply(aa,ah)}else{if(S.nodeType===1){for(var af=0;ah[af]!=null;af++){if(ah[af]&&(ah[af]===true||ah[af].nodeType===1&&H(S,ah[af]))){aa.push(Y[af])}}}else{for(var af=0;ah[af]!=null;af++){if(ah[af]&&ah[af].nodeType===1){aa.push(Y[af])}}}}}else{D(ah,aa)}if(R){E(R,S,aa,V)}return aa};E.matches=function(P,Q){return E(P,null,null,Q)};E.find=function(V,S){var W,Q;if(!V){return[]}for(var R=0,P=G.order.length;R<P;R++){var T=G.order[R],Q;if((Q=G.match[T].exec(V))){var U=RegExp.leftContext;if(U.substr(U.length-1)!=="\\"){Q[1]=(Q[1]||"").replace(/\\/g,"");W=G.find[T](Q,S);if(W!=null){V=V.replace(G.match[T],"");break}}}}if(!W){W=S.getElementsByTagName("*")}return{set:W,expr:V}};E.filter=function(S,ac,ad,T){var Q=S,Y=[],ah=ac,V,ab;while(S&&ac.length){for(var U in G.filter){if((V=G.match[U].exec(S))!=null){var Z=G.filter[U],R=null,X=0,aa,ag;ab=false;if(ah==Y){Y=[]}if(G.preFilter[U]){V=G.preFilter[U](V,ah,ad,Y,T);if(!V){ab=aa=true}else{if(V===true){continue}else{if(V[0]===true){R=[];var W=null,af;for(var ae=0;(af=ah[ae])!==g;ae++){if(af&&W!==af){R.push(af);W=af}}}}}}if(V){for(var ae=0;(ag=ah[ae])!==g;ae++){if(ag){if(R&&ag!=R[X]){X++}aa=Z(ag,V,X,R);var P=T^!!aa;if(ad&&aa!=null){if(P){ab=true}else{ah[ae]=false}}else{if(P){Y.push(ag);ab=true}}}}}if(aa!==g){if(!ad){ah=Y}S=S.replace(G.match[U],"");if(!ab){return[]}break}}}S=S.replace(/\s*,\s*/,"");if(S==Q){if(ab==null){throw"Syntax error, unrecognized expression: "+S}else{break}}Q=S}return ah};var G=E.selectors={order:["ID","NAME","TAG"],match:{ID:/#((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,CLASS:/\.((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,NAME:/\[name=['"]*((?:[\w\u00c0-\uFFFF_-]|\\.)+)['"]*\]/,ATTR:/\[\s*((?:[\w\u00c0-\uFFFF_-]|\\.)+)\s*(?:(\S?=)\s*(['"]*)(.*?)\3|)\s*\]/,TAG:/^((?:[\w\u00c0-\uFFFF\*_-]|\\.)+)/,CHILD:/:(only|nth|last|first)-child(?:\((even|odd|[\dn+-]*)\))?/,POS:/:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^-]|$)/,PSEUDO:/:((?:[\w\u00c0-\uFFFF_-]|\\.)+)(?:\((['"]*)((?:\([^\)]+\)|[^\2\(\)]*)+)\2\))?/},attrMap:{"class":"className","for":"htmlFor"},attrHandle:{href:function(P){return P.getAttribute("href")}},relative:{"+":function(T,Q){for(var R=0,P=T.length;R<P;R++){var S=T[R];if(S){var U=S.previousSibling;while(U&&U.nodeType!==1){U=U.previousSibling}T[R]=typeof Q==="string"?U||false:U===Q}}if(typeof Q==="string"){E.filter(Q,T,true)}},">":function(U,Q,V){if(typeof Q==="string"&&!/\W/.test(Q)){Q=V?Q:Q.toUpperCase();for(var R=0,P=U.length;R<P;R++){var T=U[R];if(T){var S=T.parentNode;U[R]=S.nodeName===Q?S:false}}}else{for(var R=0,P=U.length;R<P;R++){var T=U[R];if(T){U[R]=typeof Q==="string"?T.parentNode:T.parentNode===Q}}if(typeof Q==="string"){E.filter(Q,U,true)}}},"":function(S,Q,U){var R="done"+(I++),P=O;if(!Q.match(/\W/)){var T=Q=U?Q:Q.toUpperCase();P=L}P("parentNode",Q,R,S,T,U)},"~":function(S,Q,U){var R="done"+(I++),P=O;if(typeof Q==="string"&&!Q.match(/\W/)){var T=Q=U?Q:Q.toUpperCase();P=L}P("previousSibling",Q,R,S,T,U)}},find:{ID:function(Q,R){if(R.getElementById){var P=R.getElementById(Q[1]);return P?[P]:[]}},NAME:function(P,Q){return Q.getElementsByName?Q.getElementsByName(P[1]):null},TAG:function(P,Q){return Q.getElementsByTagName(P[1])}},preFilter:{CLASS:function(S,Q,R,P,U){S=" "+S[1].replace(/\\/g,"")+" ";for(var T=0;Q[T];T++){if(U^(" "+Q[T].className+" ").indexOf(S)>=0){if(!R){P.push(Q[T])}}else{if(R){Q[T]=false}}}return false},ID:function(P){return P[1].replace(/\\/g,"")},TAG:function(Q,P){for(var R=0;!P[R];R++){}return M(P[R])?Q[1]:Q[1].toUpperCase()},CHILD:function(P){if(P[1]=="nth"){var Q=/(-?)(\d*)n((?:\+|-)?\d*)/.exec(P[2]=="even"&&"2n"||P[2]=="odd"&&"2n+1"||!/\D/.test(P[2])&&"0n+"+P[2]||P[2]);P[2]=(Q[1]+(Q[2]||1))-0;P[3]=Q[3]-0}P[0]="done"+(I++);return P},ATTR:function(Q){var P=Q[1];if(G.attrMap[P]){Q[1]=G.attrMap[P]}if(Q[2]==="~="){Q[4]=" "+Q[4]+" "}return Q},PSEUDO:function(T,Q,R,P,U){if(T[1]==="not"){if(T[3].match(N).length>1){T[3]=E(T[3],null,null,Q)}else{var S=E.filter(T[3],Q,R,true^U);if(!R){P.push.apply(P,S)}return false}}else{if(G.match.POS.test(T[0])){return true}}return T},POS:function(P){P.unshift(true);return P}},filters:{enabled:function(P){return P.disabled===false&&P.type!=="hidden"},disabled:function(P){return P.disabled===true},checked:function(P){return P.checked===true},selected:function(P){P.parentNode.selectedIndex;return P.selected===true},parent:function(P){return !!P.firstChild},empty:function(P){return !P.firstChild},has:function(R,Q,P){return !!E(P[3],R).length},header:function(P){return/h\d/i.test(P.nodeName)},text:function(P){return"text"===P.type},radio:function(P){return"radio"===P.type},checkbox:function(P){return"checkbox"===P.type},file:function(P){return"file"===P.type},password:function(P){return"password"===P.type},submit:function(P){return"submit"===P.type},image:function(P){return"image"===P.type},reset:function(P){return"reset"===P.type},button:function(P){return"button"===P.type||P.nodeName.toUpperCase()==="BUTTON"},input:function(P){return/input|select|textarea|button/i.test(P.nodeName)}},setFilters:{first:function(Q,P){return P===0},last:function(R,Q,P,S){return Q===S.length-1},even:function(Q,P){return P%2===0},odd:function(Q,P){return P%2===1},lt:function(R,Q,P){return Q<P[3]-0},gt:function(R,Q,P){return Q>P[3]-0},nth:function(R,Q,P){return P[3]-0==Q},eq:function(R,Q,P){return P[3]-0==Q}},filter:{CHILD:function(P,S){var V=S[1],W=P.parentNode;var U="child"+W.childNodes.length;if(W&&(!W[U]||!P.nodeIndex)){var T=1;for(var Q=W.firstChild;Q;Q=Q.nextSibling){if(Q.nodeType==1){Q.nodeIndex=T++}}W[U]=T-1}if(V=="first"){return P.nodeIndex==1}else{if(V=="last"){return P.nodeIndex==W[U]}else{if(V=="only"){return W[U]==1}else{if(V=="nth"){var Y=false,R=S[2],X=S[3];if(R==1&&X==0){return true}if(R==0){if(P.nodeIndex==X){Y=true}}else{if((P.nodeIndex-X)%R==0&&(P.nodeIndex-X)/R>=0){Y=true}}return Y}}}}},PSEUDO:function(V,R,S,W){var Q=R[1],T=G.filters[Q];if(T){return T(V,S,R,W)}else{if(Q==="contains"){return(V.textContent||V.innerText||"").indexOf(R[3])>=0}else{if(Q==="not"){var U=R[3];for(var S=0,P=U.length;S<P;S++){if(U[S]===V){return false}}return true}}}},ID:function(Q,P){return Q.nodeType===1&&Q.getAttribute("id")===P},TAG:function(Q,P){return(P==="*"&&Q.nodeType===1)||Q.nodeName===P},CLASS:function(Q,P){return P.test(Q.className)},ATTR:function(T,R){var P=G.attrHandle[R[1]]?G.attrHandle[R[1]](T):T[R[1]]||T.getAttribute(R[1]),U=P+"",S=R[2],Q=R[4];return P==null?false:S==="="?U===Q:S==="*="?U.indexOf(Q)>=0:S==="~="?(" "+U+" ").indexOf(Q)>=0:!R[4]?P:S==="!="?U!=Q:S==="^="?U.indexOf(Q)===0:S==="$="?U.substr(U.length-Q.length)===Q:S==="|="?U===Q||U.substr(0,Q.length+1)===Q+"-":false},POS:function(T,Q,R,U){var P=Q[2],S=G.setFilters[P];if(S){return S(T,R,Q,U)}}}};for(var K in G.match){G.match[K]=RegExp(G.match[K].source+/(?![^\[]*\])(?![^\(]*\))/.source)}var D=function(Q,P){Q=Array.prototype.slice.call(Q);if(P){P.push.apply(P,Q);return P}return Q};try{Array.prototype.slice.call(document.documentElement.childNodes)}catch(J){D=function(T,S){var Q=S||[];if(F.call(T)==="[object Array]"){Array.prototype.push.apply(Q,T)}else{if(typeof T.length==="number"){for(var R=0,P=T.length;R<P;R++){Q.push(T[R])}}else{for(var R=0;T[R];R++){Q.push(T[R])}}}return Q}}(function(){var Q=document.createElement("form"),R="script"+(new Date).getTime();Q.innerHTML="<input name='"+R+"'/>";var P=document.documentElement;P.insertBefore(Q,P.firstChild);if(!!document.getElementById(R)){G.find.ID=function(T,U){if(U.getElementById){var S=U.getElementById(T[1]);return S?S.id===T[1]||S.getAttributeNode&&S.getAttributeNode("id").nodeValue===T[1]?[S]:g:[]}};G.filter.ID=function(U,S){var T=U.getAttributeNode&&U.getAttributeNode("id");return U.nodeType===1&&T&&T.nodeValue===S}}P.removeChild(Q)})();(function(){var P=document.createElement("div");P.appendChild(document.createComment(""));if(P.getElementsByTagName("*").length>0){G.find.TAG=function(Q,U){var T=U.getElementsByTagName(Q[1]);if(Q[1]==="*"){var S=[];for(var R=0;T[R];R++){if(T[R].nodeType===1){S.push(T[R])}}T=S}return T}}P.innerHTML="<a href='#'></a>";if(P.firstChild.getAttribute("href")!=="#"){G.attrHandle.href=function(Q){return Q.getAttribute("href",2)}}})();if(document.querySelectorAll){(function(){var P=E;E=function(T,S,Q,R){S=S||document;if(!R&&S.nodeType===9){try{return D(S.querySelectorAll(T),Q)}catch(U){}}return P(T,S,Q,R)};E.find=P.find;E.filter=P.filter;E.selectors=P.selectors;E.matches=P.matches})()}if(document.documentElement.getElementsByClassName){G.order.splice(1,0,"CLASS");G.find.CLASS=function(P,Q){return Q.getElementsByClassName(P[1])}}function L(Q,W,V,Z,X,Y){for(var T=0,R=Z.length;T<R;T++){var P=Z[T];if(P){P=P[Q];var U=false;while(P&&P.nodeType){var S=P[V];if(S){U=Z[S];break}if(P.nodeType===1&&!Y){P[V]=T}if(P.nodeName===W){U=P;break}P=P[Q]}Z[T]=U}}}function O(Q,V,U,Y,W,X){for(var S=0,R=Y.length;S<R;S++){var P=Y[S];if(P){P=P[Q];var T=false;while(P&&P.nodeType){if(P[U]){T=Y[P[U]];break}if(P.nodeType===1){if(!X){P[U]=S}if(typeof V!=="string"){if(P===V){T=true;break}}else{if(E.filter(V,[P]).length>0){T=P;break}}}P=P[Q]}Y[S]=T}}}var H=document.compareDocumentPosition?function(Q,P){return Q.compareDocumentPosition(P)&16}:function(Q,P){return Q!==P&&(Q.contains?Q.contains(P):true)};var M=function(P){return P.documentElement&&!P.body||P.tagName&&P.ownerDocument&&!P.ownerDocument.body};n.find=E;n.filter=E.filter;n.expr=E.selectors;n.expr[":"]=n.expr.filters;E.selectors.filters.hidden=function(P){return"hidden"===P.type||n.css(P,"display")==="none"||n.css(P,"visibility")==="hidden"};E.selectors.filters.visible=function(P){return"hidden"!==P.type&&n.css(P,"display")!=="none"&&n.css(P,"visibility")!=="hidden"};E.selectors.filters.animated=function(P){return n.grep(n.timers,function(Q){return P===Q.elem}).length};n.multiFilter=function(R,P,Q){if(Q){R=":not("+R+")"}return E.matches(R,P)};n.dir=function(R,Q){var P=[],S=R[Q];while(S&&S!=document){if(S.nodeType==1){P.push(S)}S=S[Q]}return P};n.nth=function(T,P,R,S){P=P||1;var Q=0;for(;T;T=T[R]){if(T.nodeType==1&&++Q==P){break}}return T};n.sibling=function(R,Q){var P=[];for(;R;R=R.nextSibling){if(R.nodeType==1&&R!=Q){P.push(R)}}return P};return;l.Sizzle=E})();n.event={add:function(H,E,G,J){if(H.nodeType==3||H.nodeType==8){return}if(H.setInterval&&H!=l){H=l}if(!G.guid){G.guid=this.guid++}if(J!==g){var F=G;G=this.proxy(F);G.data=J}var D=n.data(H,"events")||n.data(H,"events",{}),I=n.data(H,"handle")||n.data(H,"handle",function(){return typeof n!=="undefined"&&!n.event.triggered?n.event.handle.apply(arguments.callee.elem,arguments):g});I.elem=H;n.each(E.split(/\s+/),function(L,M){var N=M.split(".");M=N.shift();G.type=N.slice().sort().join(".");var K=D[M];if(n.event.specialAll[M]){n.event.specialAll[M].setup.call(H,J,N)}if(!K){K=D[M]={};if(!n.event.special[M]||n.event.special[M].setup.call(H,J,N)===false){if(H.addEventListener){H.addEventListener(M,I,false)}else{if(H.attachEvent){H.attachEvent("on"+M,I)}}}}K[G.guid]=G;n.event.global[M]=true});H=null},guid:1,global:{},remove:function(J,G,I){if(J.nodeType==3||J.nodeType==8){return}var F=n.data(J,"events"),E,D;if(F){if(G===g||(typeof G==="string"&&G.charAt(0)==".")){for(var H in F){this.remove(J,H+(G||""))}}else{if(G.type){I=G.handler;G=G.type}n.each(G.split(/\s+/),function(L,N){var P=N.split(".");N=P.shift();var M=RegExp("(^|\\.)"+P.slice().sort().join(".*\\.")+"(\\.|$)");if(F[N]){if(I){delete F[N][I.guid]}else{for(var O in F[N]){if(M.test(F[N][O].type)){delete F[N][O]}}}if(n.event.specialAll[N]){n.event.specialAll[N].teardown.call(J,P)}for(E in F[N]){break}if(!E){if(!n.event.special[N]||n.event.special[N].teardown.call(J,P)===false){if(J.removeEventListener){J.removeEventListener(N,n.data(J,"handle"),false)}else{if(J.detachEvent){J.detachEvent("on"+N,n.data(J,"handle"))}}}E=null;delete F[N]}}})}for(E in F){break}if(!E){var K=n.data(J,"handle");if(K){K.elem=null}n.removeData(J,"events");n.removeData(J,"handle")}}},trigger:function(H,J,G,D){var F=H.type||H;if(!D){H=typeof H==="object"?H[h]?H:n.extend(n.Event(F),H):n.Event(F);if(F.indexOf("!")>=0){H.type=F=F.slice(0,-1);H.exclusive=true}if(!G){H.stopPropagation();if(this.global[F]){n.each(n.cache,function(){if(this.events&&this.events[F]){n.event.trigger(H,J,this.handle.elem)}})}}if(!G||G.nodeType==3||G.nodeType==8){return g}H.result=g;H.target=G;J=n.makeArray(J);J.unshift(H)}H.currentTarget=G;var I=n.data(G,"handle");if(I){I.apply(G,J)}if((!G[F]||(n.nodeName(G,"a")&&F=="click"))&&G["on"+F]&&G["on"+F].apply(G,J)===false){H.result=false}if(!D&&G[F]&&!H.isDefaultPrevented()&&!(n.nodeName(G,"a")&&F=="click")){this.triggered=true;try{G[F]()}catch(K){}}this.triggered=false;if(!H.isPropagationStopped()){var E=G.parentNode||G.ownerDocument;if(E){n.event.trigger(H,J,E,true)}}},handle:function(J){var I,D;J=arguments[0]=n.event.fix(J||l.event);var K=J.type.split(".");J.type=K.shift();I=!K.length&&!J.exclusive;var H=RegExp("(^|\\.)"+K.slice().sort().join(".*\\.")+"(\\.|$)");D=(n.data(this,"events")||{})[J.type];for(var F in D){var G=D[F];if(I||H.test(G.type)){J.handler=G;J.data=G.data;var E=G.apply(this,arguments);if(E!==g){J.result=E;if(E===false){J.preventDefault();J.stopPropagation()}}if(J.isImmediatePropagationStopped()){break}}}},props:"altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode metaKey newValue originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),fix:function(G){if(G[h]){return G}var E=G;G=n.Event(E);for(var F=this.props.length,I;F;){I=this.props[--F];G[I]=E[I]}if(!G.target){G.target=G.srcElement||document}if(G.target.nodeType==3){G.target=G.target.parentNode}if(!G.relatedTarget&&G.fromElement){G.relatedTarget=G.fromElement==G.target?G.toElement:G.fromElement}if(G.pageX==null&&G.clientX!=null){var H=document.documentElement,D=document.body;G.pageX=G.clientX+(H&&H.scrollLeft||D&&D.scrollLeft||0)-(H.clientLeft||0);G.pageY=G.clientY+(H&&H.scrollTop||D&&D.scrollTop||0)-(H.clientTop||0)}if(!G.which&&((G.charCode||G.charCode===0)?G.charCode:G.keyCode)){G.which=G.charCode||G.keyCode}if(!G.metaKey&&G.ctrlKey){G.metaKey=G.ctrlKey}if(!G.which&&G.button){G.which=(G.button&1?1:(G.button&2?3:(G.button&4?2:0)))}return G},proxy:function(E,D){D=D||function(){return E.apply(this,arguments)};D.guid=E.guid=E.guid||D.guid||this.guid++;return D},special:{ready:{setup:A,teardown:function(){}}},specialAll:{live:{setup:function(D,E){n.event.add(this,E[0],c)},teardown:function(F){if(F.length){var D=0,E=RegExp("(^|\\.)"+F[0]+"(\\.|$)");n.each((n.data(this,"events").live||{}),function(){if(E.test(this.type)){D++}});if(D<1){n.event.remove(this,F[0],c)}}}}}};n.Event=function(D){if(!this.preventDefault){return new n.Event(D)}if(D&&D.type){this.originalEvent=D;this.type=D.type;this.timeStamp=D.timeStamp}else{this.type=D}if(!this.timeStamp){this.timeStamp=e()}this[h]=true};function k(){return false}function t(){return true}n.Event.prototype={preventDefault:function(){this.isDefaultPrevented=t;var D=this.originalEvent;if(!D){return}if(D.preventDefault){D.preventDefault()}D.returnValue=false},stopPropagation:function(){this.isPropagationStopped=t;var D=this.originalEvent;if(!D){return}if(D.stopPropagation){D.stopPropagation()}D.cancelBubble=true},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=t;this.stopPropagation()},isDefaultPrevented:k,isPropagationStopped:k,isImmediatePropagationStopped:k};var a=function(E){var D=E.relatedTarget;while(D&&D!=this){try{D=D.parentNode}catch(F){D=this}}if(D!=this){E.type=E.data;n.event.handle.apply(this,arguments)}};n.each({mouseover:"mouseenter",mouseout:"mouseleave"},function(E,D){n.event.special[D]={setup:function(){n.event.add(this,E,a,D)},teardown:function(){n.event.remove(this,E,a)}}});n.fn.extend({bind:function(E,F,D){return E=="unload"?this.one(E,F,D):this.each(function(){n.event.add(this,E,D||F,D&&F)})},one:function(F,G,E){var D=n.event.proxy(E||G,function(H){n(this).unbind(H,D);return(E||G).apply(this,arguments)});return this.each(function(){n.event.add(this,F,D,E&&G)})},unbind:function(E,D){return this.each(function(){n.event.remove(this,E,D)})},trigger:function(D,E){return this.each(function(){n.event.trigger(D,E,this)})},triggerHandler:function(D,F){if(this[0]){var E=n.Event(D);E.preventDefault();E.stopPropagation();n.event.trigger(E,F,this[0]);return E.result}},toggle:function(F){var D=arguments,E=1;while(E<D.length){n.event.proxy(F,D[E++])}return this.click(n.event.proxy(F,function(G){this.lastToggle=(this.lastToggle||0)%E;G.preventDefault();return D[this.lastToggle++].apply(this,arguments)||false}))},hover:function(D,E){return this.mouseenter(D).mouseleave(E)},ready:function(D){A();if(n.isReady){D.call(document,n)}else{n.readyList.push(D)}return this},live:function(F,E){var D=n.event.proxy(E);D.guid+=this.selector+F;n(document).bind(i(F,this.selector),this.selector,D);return this},die:function(E,D){n(document).unbind(i(E,this.selector),D?{guid:D.guid+this.selector+E}:null);return this}});function c(G){var D=RegExp("(^|\\.)"+G.type+"(\\.|$)"),F=true,E=[];n.each(n.data(this,"events").live||[],function(H,I){if(D.test(I.type)){var J=n(G.target).closest(I.data)[0];if(J){E.push({elem:J,fn:I})}}});n.each(E,function(){if(!G.isImmediatePropagationStopped()&&this.fn.call(this.elem,G,this.fn.data)===false){F=false}});return F}function i(E,D){return["live",E,D.replace(/\./g,"`").replace(/ /g,"|")].join(".")}n.extend({isReady:false,readyList:[],ready:function(){if(!n.isReady){n.isReady=true;if(n.readyList){n.each(n.readyList,function(){this.call(document,n)});n.readyList=null}n(document).triggerHandler("ready")}}});var w=false;function A(){if(w){return}w=true;if(document.addEventListener){document.addEventListener("DOMContentLoaded",function(){document.removeEventListener("DOMContentLoaded",arguments.callee,false);n.ready()},false)}else{if(document.attachEvent){document.attachEvent("onreadystatechange",function(){if(document.readyState==="complete"){document.detachEvent("onreadystatechange",arguments.callee);n.ready()}});if(document.documentElement.doScroll&&!l.frameElement){(function(){if(n.isReady){return}try{document.documentElement.doScroll("left")}catch(D){setTimeout(arguments.callee,0);return}n.ready()})()}}}n.event.add(l,"load",n.ready)}n.each(("blur,focus,load,resize,scroll,unload,click,dblclick,mousedown,mouseup,mousemove,mouseover,mouseout,mouseenter,mouseleave,change,select,submit,keydown,keypress,keyup,error").split(","),function(E,D){n.fn[D]=function(F){return F?this.bind(D,F):this.trigger(D)}});n(l).bind("unload",function(){for(var D in n.cache){if(D!=1&&n.cache[D].handle){n.event.remove(n.cache[D].handle.elem)}}});(function(){n.support={};var E=document.documentElement,F=document.createElement("script"),J=document.createElement("div"),I="script"+(new Date).getTime();J.style.display="none";J.innerHTML=' <link/><table></table><a href="/a" style="color:red;float:left;opacity:.5;">a</a><select><option>text</option></select><object><param/></object>';var G=J.getElementsByTagName("*"),D=J.getElementsByTagName("a")[0];if(!G||!G.length||!D){return}n.support={leadingWhitespace:J.firstChild.nodeType==3,tbody:!J.getElementsByTagName("tbody").length,objectAll:!!J.getElementsByTagName("object")[0].getElementsByTagName("*").length,htmlSerialize:!!J.getElementsByTagName("link").length,style:/red/.test(D.getAttribute("style")),hrefNormalized:D.getAttribute("href")==="/a",opacity:D.style.opacity==="0.5",cssFloat:!!D.style.cssFloat,scriptEval:false,noCloneEvent:true,boxModel:null};F.type="text/javascript";try{F.appendChild(document.createTextNode("window."+I+"=1;"))}catch(H){}E.insertBefore(F,E.firstChild);if(l[I]){n.support.scriptEval=true;delete l[I]}E.removeChild(F);if(J.attachEvent&&J.fireEvent){J.attachEvent("onclick",function(){n.support.noCloneEvent=false;J.detachEvent("onclick",arguments.callee)});J.cloneNode(true).fireEvent("onclick")}n(function(){var K=document.createElement("div");K.style.width="1px";K.style.paddingLeft="1px";document.body.appendChild(K);n.boxModel=n.support.boxModel=K.offsetWidth===2;document.body.removeChild(K)})})();var v=n.support.cssFloat?"cssFloat":"styleFloat";n.props={"for":"htmlFor","class":"className","float":v,cssFloat:v,styleFloat:v,readonly:"readOnly",maxlength:"maxLength",cellspacing:"cellSpacing",rowspan:"rowSpan",tabindex:"tabIndex"};n.fn.extend({_load:n.fn.load,load:function(F,I,J){if(typeof F!=="string"){return this._load(F)}var H=F.indexOf(" ");if(H>=0){var D=F.slice(H,F.length);F=F.slice(0,H)}var G="GET";if(I){if(n.isFunction(I)){J=I;I=null}else{if(typeof I==="object"){I=n.param(I);G="POST"}}}var E=this;n.ajax({url:F,type:G,dataType:"html",data:I,complete:function(L,K){if(K=="success"||K=="notmodified"){E.html(D?n("<div/>").append(L.responseText.replace(/<script(.|\s)*?\/script>/g,"")).find(D):L.responseText)}if(J){E.each(J,[L.responseText,K,L])}}});return this},serialize:function(){return n.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?n.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||/select|textarea/i.test(this.nodeName)||/text|hidden|password/i.test(this.type))}).map(function(D,E){var F=n(this).val();return F==null?null:n.isArray(F)?n.map(F,function(H,G){return{name:E.name,value:H}}):{name:E.name,value:F}}).get()}});n.each("ajaxStart,ajaxStop,ajaxComplete,ajaxError,ajaxSuccess,ajaxSend".split(","),function(D,E){n.fn[E]=function(F){return this.bind(E,F)}});var q=e();n.extend({get:function(D,F,G,E){if(n.isFunction(F)){G=F;F=null}return n.ajax({type:"GET",url:D,data:F,success:G,dataType:E})},getScript:function(D,E){return n.get(D,null,E,"script")},getJSON:function(D,E,F){return n.get(D,E,F,"json")},post:function(D,F,G,E){if(n.isFunction(F)){G=F;F={}}return n.ajax({type:"POST",url:D,data:F,success:G,dataType:E})},ajaxSetup:function(D){n.extend(n.ajaxSettings,D)},ajaxSettings:{url:location.href,global:true,type:"GET",contentType:"application/x-www-form-urlencoded",processData:true,async:true,xhr:function(){return l.ActiveXObject?new ActiveXObject("Microsoft.XMLHTTP"):new XMLHttpRequest()},accepts:{xml:"application/xml, text/xml",html:"text/html",script:"text/javascript, application/javascript",json:"application/json, text/javascript",text:"text/plain",_default:"*/*"}},lastModified:{},ajax:function(L){L=n.extend(true,L,n.extend(true,{},n.ajaxSettings,L));var V,E=/=\?(&|$)/g,Q,U,F=L.type.toUpperCase();if(L.data&&L.processData&&typeof L.data!=="string"){L.data=n.param(L.data)}if(L.dataType=="jsonp"){if(F=="GET"){if(!L.url.match(E)){L.url+=(L.url.match(/\?/)?"&":"?")+(L.jsonp||"callback")+"=?"}}else{if(!L.data||!L.data.match(E)){L.data=(L.data?L.data+"&":"")+(L.jsonp||"callback")+"=?"}}L.dataType="json"}if(L.dataType=="json"&&(L.data&&L.data.match(E)||L.url.match(E))){V="jsonp"+q++;if(L.data){L.data=(L.data+"").replace(E,"="+V+"$1")}L.url=L.url.replace(E,"="+V+"$1");L.dataType="script";l[V]=function(W){U=W;H();K();l[V]=g;try{delete l[V]}catch(X){}if(G){G.removeChild(S)}}}if(L.dataType=="script"&&L.cache==null){L.cache=false}if(L.cache===false&&F=="GET"){var D=e();var T=L.url.replace(/(\?|&)_=.*?(&|$)/,"$1_="+D+"$2");L.url=T+((T==L.url)?(L.url.match(/\?/)?"&":"?")+"_="+D:"")}if(L.data&&F=="GET"){L.url+=(L.url.match(/\?/)?"&":"?")+L.data;L.data=null}if(L.global&&!n.active++){n.event.trigger("ajaxStart")}var P=/^(\w+:)?\/\/([^\/?#]+)/.exec(L.url);if(L.dataType=="script"&&F=="GET"&&P&&(P[1]&&P[1]!=location.protocol||P[2]!=location.host)){var G=document.getElementsByTagName("head")[0];var S=document.createElement("script");S.src=L.url;if(L.scriptCharset){S.charset=L.scriptCharset}if(!V){var N=false;S.onload=S.onreadystatechange=function(){if(!N&&(!this.readyState||this.readyState=="loaded"||this.readyState=="complete")){N=true;H();K();G.removeChild(S)}}}G.appendChild(S);return g}var J=false;var I=L.xhr();if(L.username){I.open(F,L.url,L.async,L.username,L.password)}else{I.open(F,L.url,L.async)}try{if(L.data){I.setRequestHeader("Content-Type",L.contentType)}if(L.ifModified){I.setRequestHeader("If-Modified-Since",n.lastModified[L.url]||"Thu, 01 Jan 1970 00:00:00 GMT")}I.setRequestHeader("X-Requested-With","XMLHttpRequest");I.setRequestHeader("Accept",L.dataType&&L.accepts[L.dataType]?L.accepts[L.dataType]+", */*":L.accepts._default)}catch(R){}if(L.beforeSend&&L.beforeSend(I,L)===false){if(L.global&&!--n.active){n.event.trigger("ajaxStop")}I.abort();return false}if(L.global){n.event.trigger("ajaxSend",[I,L])}var M=function(W){if(I.readyState==0){if(O){clearInterval(O);O=null;if(L.global&&!--n.active){n.event.trigger("ajaxStop")}}}else{if(!J&&I&&(I.readyState==4||W=="timeout")){J=true;if(O){clearInterval(O);O=null}Q=W=="timeout"?"timeout":!n.httpSuccess(I)?"error":L.ifModified&&n.httpNotModified(I,L.url)?"notmodified":"success";if(Q=="success"){try{U=n.httpData(I,L.dataType,L)}catch(Y){Q="parsererror"}}if(Q=="success"){var X;try{X=I.getResponseHeader("Last-Modified")}catch(Y){}if(L.ifModified&&X){n.lastModified[L.url]=X}if(!V){H()}}else{n.handleError(L,I,Q)}K();if(L.async){I=null}}}};if(L.async){var O=setInterval(M,13);if(L.timeout>0){setTimeout(function(){if(I){if(!J){M("timeout")}if(I){I.abort()}}},L.timeout)}}try{I.send(L.data)}catch(R){n.handleError(L,I,null,R)}if(!L.async){M()}function H(){if(L.success){L.success(U,Q)}if(L.global){n.event.trigger("ajaxSuccess",[I,L])}}function K(){if(L.complete){L.complete(I,Q)}if(L.global){n.event.trigger("ajaxComplete",[I,L])}if(L.global&&!--n.active){n.event.trigger("ajaxStop")}}return I},handleError:function(E,G,D,F){if(E.error){E.error(G,D,F)}if(E.global){n.event.trigger("ajaxError",[G,E,F])}},active:0,httpSuccess:function(E){try{return !E.status&&location.protocol=="file:"||(E.status>=200&&E.status<300)||E.status==304||E.status==1223}catch(D){}return false},httpNotModified:function(F,D){try{var G=F.getResponseHeader("Last-Modified");return F.status==304||G==n.lastModified[D]}catch(E){}return false},httpData:function(I,G,F){var E=I.getResponseHeader("content-type"),D=G=="xml"||!G&&E&&E.indexOf("xml")>=0,H=D?I.responseXML:I.responseText;if(D&&H.documentElement.tagName=="parsererror"){throw"parsererror"}if(F&&F.dataFilter){H=F.dataFilter(H,G)}if(typeof H==="string"){if(G=="script"){n.globalEval(H)}if(G=="json"){H=l["eval"]("("+H+")")}}return H},param:function(D){var F=[];function G(H,I){F[F.length]=encodeURIComponent(H)+"="+encodeURIComponent(I)}if(n.isArray(D)||D.jquery){n.each(D,function(){G(this.name,this.value)})}else{for(var E in D){if(n.isArray(D[E])){n.each(D[E],function(){G(E,this)})}else{G(E,n.isFunction(D[E])?D[E]():D[E])}}}return F.join("&").replace(/%20/g,"+")}});var m={},d=[["height","marginTop","marginBottom","paddingTop","paddingBottom"],["width","marginLeft","marginRight","paddingLeft","paddingRight"],["opacity"]];function s(E,D){var F={};n.each(d.concat.apply([],d.slice(0,D)),function(){F[this]=E});return F}n.fn.extend({show:function(I,K){if(I){return this.animate(s("show",3),I,K)}else{for(var G=0,E=this.length;G<E;G++){var D=n.data(this[G],"olddisplay");this[G].style.display=D||"";if(n.css(this[G],"display")==="none"){var F=this[G].tagName,J;if(m[F]){J=m[F]}else{var H=n("<"+F+" />").appendTo("body");J=H.css("display");if(J==="none"){J="block"}H.remove();m[F]=J}this[G].style.display=n.data(this[G],"olddisplay",J)}}return this}},hide:function(G,H){if(G){return this.animate(s("hide",3),G,H)}else{for(var F=0,E=this.length;F<E;F++){var D=n.data(this[F],"olddisplay");if(!D&&D!=="none"){n.data(this[F],"olddisplay",n.css(this[F],"display"))}this[F].style.display="none"}return this}},_toggle:n.fn.toggle,toggle:function(F,E){var D=typeof F==="boolean";return n.isFunction(F)&&n.isFunction(E)?this._toggle.apply(this,arguments):F==null||D?this.each(function(){var G=D?F:n(this).is(":hidden");n(this)[G?"show":"hide"]()}):this.animate(s("toggle",3),F,E)},fadeTo:function(D,F,E){return this.animate({opacity:F},D,E)},animate:function(H,E,G,F){var D=n.speed(E,G,F);return this[D.queue===false?"each":"queue"](function(){var J=n.extend({},D),L,K=this.nodeType==1&&n(this).is(":hidden"),I=this;for(L in H){if(H[L]=="hide"&&K||H[L]=="show"&&!K){return J.complete.call(this)}if((L=="height"||L=="width")&&this.style){J.display=n.css(this,"display");J.overflow=this.style.overflow}}if(J.overflow!=null){this.style.overflow="hidden"}J.curAnim=n.extend({},H);n.each(H,function(N,R){var Q=new n.fx(I,J,N);if(/toggle|show|hide/.test(R)){Q[R=="toggle"?K?"show":"hide":R](H)}else{var P=R.toString().match(/^([+-]=)?([\d+-.]+)(.*)$/),S=Q.cur(true)||0;if(P){var M=parseFloat(P[2]),O=P[3]||"px";if(O!="px"){I.style[N]=(M||1)+O;S=((M||1)/Q.cur(true))*S;I.style[N]=S+O}if(P[1]){M=((P[1]=="-="?-1:1)*M)+S}Q.custom(S,M,O)}else{Q.custom(S,R,"")}}});return true})},stop:function(E,D){var F=n.timers;if(E){this.queue([])}this.each(function(){for(var G=F.length-1;G>=0;G--){if(F[G].elem==this){if(D){F[G](true)}F.splice(G,1)}}});if(!D){this.dequeue()}return this}});n.each({slideDown:s("show",1),slideUp:s("hide",1),slideToggle:s("toggle",1),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"}},function(D,E){n.fn[D]=function(F,G){return this.animate(E,F,G)}});n.extend({speed:function(F,G,E){var D=typeof F==="object"?F:{complete:E||!E&&G||n.isFunction(F)&&F,duration:F,easing:E&&G||G&&!n.isFunction(G)&&G};D.duration=n.fx.off?0:typeof D.duration==="number"?D.duration:n.fx.speeds[D.duration]||n.fx.speeds._default;D.old=D.complete;D.complete=function(){if(D.queue!==false){n(this).dequeue()}if(n.isFunction(D.old)){D.old.call(this)}};return D},easing:{linear:function(F,G,D,E){return D+E*F},swing:function(F,G,D,E){return((-Math.cos(F*Math.PI)/2)+0.5)*E+D}},timers:[],timerId:null,fx:function(E,D,F){this.options=D;this.elem=E;this.prop=F;if(!D.orig){D.orig={}}}});n.fx.prototype={update:function(){if(this.options.step){this.options.step.call(this.elem,this.now,this)}(n.fx.step[this.prop]||n.fx.step._default)(this);if((this.prop=="height"||this.prop=="width")&&this.elem.style){this.elem.style.display="block"}},cur:function(E){if(this.elem[this.prop]!=null&&(!this.elem.style||this.elem.style[this.prop]==null)){return this.elem[this.prop]}var D=parseFloat(n.css(this.elem,this.prop,E));return D&&D>-10000?D:parseFloat(n.curCSS(this.elem,this.prop))||0},custom:function(H,G,F){this.startTime=e();this.start=H;this.end=G;this.unit=F||this.unit||"px";this.now=this.start;this.pos=this.state=0;var D=this;function E(I){return D.step(I)}E.elem=this.elem;n.timers.push(E);if(E()&&n.timerId==null){n.timerId=setInterval(function(){var J=n.timers;for(var I=0;I<J.length;I++){if(!J[I]()){J.splice(I--,1)}}if(!J.length){clearInterval(n.timerId);n.timerId=null}},13)}},show:function(){this.options.orig[this.prop]=n.attr(this.elem.style,this.prop);this.options.show=true;this.custom(this.prop=="width"||this.prop=="height"?1:0,this.cur());n(this.elem).show()},hide:function(){this.options.orig[this.prop]=n.attr(this.elem.style,this.prop);this.options.hide=true;this.custom(this.cur(),0)},step:function(G){var F=e();if(G||F>=this.options.duration+this.startTime){this.now=this.end;this.pos=this.state=1;this.update();this.options.curAnim[this.prop]=true;var D=true;for(var E in this.options.curAnim){if(this.options.curAnim[E]!==true){D=false}}if(D){if(this.options.display!=null){this.elem.style.overflow=this.options.overflow;this.elem.style.display=this.options.display;if(n.css(this.elem,"display")=="none"){this.elem.style.display="block"}}if(this.options.hide){n(this.elem).hide()}if(this.options.hide||this.options.show){for(var H in this.options.curAnim){n.attr(this.elem.style,H,this.options.orig[H])}}}if(D){this.options.complete.call(this.elem)}return false}else{var I=F-this.startTime;this.state=I/this.options.duration;this.pos=n.easing[this.options.easing||(n.easing.swing?"swing":"linear")](this.state,I,0,1,this.options.duration);this.now=this.start+((this.end-this.start)*this.pos);this.update()}return true}};n.extend(n.fx,{speeds:{slow:600,fast:200,_default:400},step:{opacity:function(D){n.attr(D.elem.style,"opacity",D.now)},_default:function(D){if(D.elem.style&&D.elem.style[D.prop]!=null){D.elem.style[D.prop]=D.now+D.unit}else{D.elem[D.prop]=D.now}}}});if(document.documentElement.getBoundingClientRect){n.fn.offset=function(){if(!this[0]){return{top:0,left:0}}if(this[0]===this[0].ownerDocument.body){return n.offset.bodyOffset(this[0])}var F=this[0].getBoundingClientRect(),I=this[0].ownerDocument,E=I.body,D=I.documentElement,K=D.clientTop||E.clientTop||0,J=D.clientLeft||E.clientLeft||0,H=F.top+(self.pageYOffset||n.boxModel&&D.scrollTop||E.scrollTop)-K,G=F.left+(self.pageXOffset||n.boxModel&&D.scrollLeft||E.scrollLeft)-J;return{top:H,left:G}}}else{n.fn.offset=function(){if(!this[0]){return{top:0,left:0}}if(this[0]===this[0].ownerDocument.body){return n.offset.bodyOffset(this[0])}n.offset.initialized||n.offset.initialize();var I=this[0],F=I.offsetParent,E=I,N=I.ownerDocument,L,G=N.documentElement,J=N.body,K=N.defaultView,D=K.getComputedStyle(I,null),M=I.offsetTop,H=I.offsetLeft;while((I=I.parentNode)&&I!==J&&I!==G){L=K.getComputedStyle(I,null);M-=I.scrollTop,H-=I.scrollLeft;if(I===F){M+=I.offsetTop,H+=I.offsetLeft;if(n.offset.doesNotAddBorder&&!(n.offset.doesAddBorderForTableAndCells&&/^t(able|d|h)$/i.test(I.tagName))){M+=parseInt(L.borderTopWidth,10)||0,H+=parseInt(L.borderLeftWidth,10)||0}E=F,F=I.offsetParent}if(n.offset.subtractsBorderForOverflowNotVisible&&L.overflow!=="visible"){M+=parseInt(L.borderTopWidth,10)||0,H+=parseInt(L.borderLeftWidth,10)||0}D=L}if(D.position==="relative"||D.position==="static"){M+=J.offsetTop,H+=J.offsetLeft}if(D.position==="fixed"){M+=Math.max(G.scrollTop,J.scrollTop),H+=Math.max(G.scrollLeft,J.scrollLeft)}return{top:M,left:H}}}n.offset={initialize:function(){if(this.initialized){return}var K=document.body,E=document.createElement("div"),G,F,M,H,L,D,I=K.style.marginTop,J='<div style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;"><div></div></div><table style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;"cellpadding="0"cellspacing="0"><tr><td></td></tr></table>';L={position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",height:"1px",visibility:"hidden"};for(D in L){E.style[D]=L[D]}E.innerHTML=J;K.insertBefore(E,K.firstChild);G=E.firstChild,F=G.firstChild,H=G.nextSibling.firstChild.firstChild;this.doesNotAddBorder=(F.offsetTop!==5);this.doesAddBorderForTableAndCells=(H.offsetTop===5);G.style.overflow="hidden",G.style.position="relative";this.subtractsBorderForOverflowNotVisible=(F.offsetTop===-5);K.style.marginTop="1px";this.doesNotIncludeMarginInBodyOffset=(K.offsetTop===0);K.style.marginTop=I;K.removeChild(E);this.initialized=true},bodyOffset:function(D){n.offset.initialized||n.offset.initialize();var F=D.offsetTop,E=D.offsetLeft;if(n.offset.doesNotIncludeMarginInBodyOffset){F+=parseInt(n.curCSS(D,"marginTop",true),10)||0,E+=parseInt(n.curCSS(D,"marginLeft",true),10)||0}return{top:F,left:E}}};n.fn.extend({position:function(){var H=0,G=0,E;if(this[0]){var F=this.offsetParent(),I=this.offset(),D=/^body|html$/i.test(F[0].tagName)?{top:0,left:0}:F.offset();I.top-=j(this,"marginTop");I.left-=j(this,"marginLeft");D.top+=j(F,"borderTopWidth");D.left+=j(F,"borderLeftWidth");E={top:I.top-D.top,left:I.left-D.left}}return E},offsetParent:function(){var D=this[0].offsetParent||document.body;while(D&&(!/^body|html$/i.test(D.tagName)&&n.css(D,"position")=="static")){D=D.offsetParent}return n(D)}});n.each(["Left","Top"],function(E,D){var F="scroll"+D;n.fn[F]=function(G){if(!this[0]){return null}return G!==g?this.each(function(){this==l||this==document?l.scrollTo(!E?G:n(l).scrollLeft(),E?G:n(l).scrollTop()):this[F]=G}):this[0]==l||this[0]==document?self[E?"pageYOffset":"pageXOffset"]||n.boxModel&&document.documentElement[F]||document.body[F]:this[0][F]}});n.each(["Height","Width"],function(G,E){var D=G?"Left":"Top",F=G?"Right":"Bottom";n.fn["inner"+E]=function(){return this[E.toLowerCase()]()+j(this,"padding"+D)+j(this,"padding"+F)};n.fn["outer"+E]=function(I){return this["inner"+E]()+j(this,"border"+D+"Width")+j(this,"border"+F+"Width")+(I?j(this,"margin"+D)+j(this,"margin"+F):0)};var H=E.toLowerCase();n.fn[H]=function(I){return this[0]==l?document.compatMode=="CSS1Compat"&&document.documentElement["client"+E]||document.body["client"+E]:this[0]==document?Math.max(document.documentElement["client"+E],document.body["scroll"+E],document.documentElement["scroll"+E],document.body["offset"+E],document.documentElement["offset"+E]):I===g?(this.length?n.css(this[0],H):null):this.css(H,typeof I==="string"?I:I+"px")}})})(); \ No newline at end of file
diff --git a/chef-server/public/merb.fcgi b/chef-server/public/merb.fcgi
deleted file mode 100755
index 9804e0f36d..0000000000
--- a/chef-server/public/merb.fcgi
+++ /dev/null
@@ -1,22 +0,0 @@
-#!/usr/bin/env ruby
-
-require 'rubygems'
-require 'merb-core'
-
-# this is Merb.root, change this if you have some funky setup.
-merb_root = File.expand_path(File.dirname(__FILE__) / '../')
-
-# If the fcgi process runs as apache, make sure
-# we have an inlinedir set for Rubyinline action-args to work
-unless ENV["INLINEDIR"] || ENV["HOME"]
- tmpdir = merb_root / "tmp"
- unless File.directory?(tmpdir)
- Dir.mkdir(tmpdir)
- end
- ENV["INLINEDIR"] = tmpdir
-end
-
-# start merb with the fcgi adapter, add options or change the log dir here
-Merb.start(:adapter => 'fcgi',
- :merb_root => merb_root,
- :log_file => merb_root /'log'/'merb.log') \ No newline at end of file
diff --git a/chef-server/public/robots.txt b/chef-server/public/robots.txt
deleted file mode 100644
index f85a11b3b8..0000000000
--- a/chef-server/public/robots.txt
+++ /dev/null
@@ -1,5 +0,0 @@
-# See http://www.robotstxt.org/wc/norobots.html for documentation on how to use the robots.txt file
-#
-# To ban all spiders from the entire site uncomment the next two lines:
-# User-Agent: *
-# Disallow: / \ No newline at end of file
diff --git a/chef-server/public/stylesheets/master.css b/chef-server/public/stylesheets/master.css
deleted file mode 100644
index c4fa676047..0000000000
--- a/chef-server/public/stylesheets/master.css
+++ /dev/null
@@ -1,119 +0,0 @@
-body {
- font-family: Arial, Verdana, sans-serif;
- font-size: 12px;
- background-color: #fff;
-}
-* {
- margin: 0px;
- padding: 0px;
- text-decoration: none;
-}
-html {
- height: 100%;
- margin-bottom: 1px;
-}
-#container {
- width: 80%;
- text-align: left;
- background-color: #fff;
- margin-right: auto;
- margin-left: auto;
-}
-#header-container {
- width: 100%;
- padding-top: 15px;
-}
-#header-container h1, #header-container h2 {
- margin-left: 6px;
- margin-bottom: 6px;
-}
-.spacer {
- width: 100%;
- height: 15px;
-}
-hr {
- border: 0px;
- color: #ccc;
- background-color: #cdcdcd;
- height: 1px;
- width: 100%;
- text-align: left;
-}
-h1 {
- font-size: 28px;
- color: #c55;
- background-color: #fff;
- font-family: Arial, Verdana, sans-serif;
- font-weight: 300;
-}
-h2 {
- font-size: 15px;
- color: #999;
- font-family: Arial, Verdana, sans-serif;
- font-weight: 300;
- background-color: #fff;
-}
-h3 {
- color: #4d9b12;
- font-size: 15px;
- text-align: left;
- font-weight: 300;
- padding: 5px;
- margin-top: 5px;
-}
-
-#left-container {
- float: left;
- width: 250px;
- background-color: #FFFFFF;
- color: black;
-}
-
-#left-container h3 {
- color: #c55;
-}
-
-#main-container {
- margin: 5px 5px 5px 260px;
- padding: 15px;
- border-left: 1px solid silver;
- min-height: 400px;
-}
-p {
- color: #000;
- background-color: #fff;
- line-height: 20px;
- padding: 5px;
-}
-a {
- color: #4d9b12;
- background-color: #fff;
- text-decoration: none;
-}
-a:hover {
- color: #4d9b12;
- background-color: #fff;
- text-decoration: underline;
-}
-#footer-container {
- clear: both;
- font-size: 12px;
- font-family: Verdana, Arial, sans-serif;
-}
-.right {
- float: right;
- font-size: 100%;
- margin-top: 5px;
- color: #999;
- background-color: #fff;
-}
-.left {
- float: left;
- font-size: 100%;
- margin-top: 5px;
- color: #999;
- background-color: #fff;
-}
-#main-container ul {
- margin-left: 3.0em;
-} \ No newline at end of file
diff --git a/chef-server/spec/spec.opts b/chef-server/spec/spec.opts
deleted file mode 100644
index e69de29bb2..0000000000
--- a/chef-server/spec/spec.opts
+++ /dev/null
diff --git a/chef-server/spec/spec_helper.rb b/chef-server/spec/spec_helper.rb
deleted file mode 100644
index 36ebcd57e2..0000000000
--- a/chef-server/spec/spec_helper.rb
+++ /dev/null
@@ -1,25 +0,0 @@
-require "rubygems"
-
-# Add the local gems dir if found within the app root; any dependencies loaded
-# hereafter will try to load from the local gems before loading system gems.
-if (local_gem_dir = File.join(File.dirname(__FILE__), '..', 'gems')) && $BUNDLE.nil?
- $BUNDLE = true; Gem.clear_paths; Gem.path.unshift(local_gem_dir)
-end
-
-require "merb-core"
-require "spec" # Satisfies Autotest and anyone else not using the Rake tasks
-
-# this loads all plugins required in your init file so don't add them
-# here again, Merb will do it for you
-Merb.start_environment(:testing => true, :adapter => 'runner', :environment => ENV['MERB_ENV'] || 'test')
-
-Spec::Runner.configure do |config|
- config.include(Merb::Test::ViewHelper)
- config.include(Merb::Test::RouteHelper)
- config.include(Merb::Test::ControllerHelper)
-
- config.before(:all) do
- DataMapper.auto_migrate! if Merb.orm == :datamapper
- end
-
-end
diff --git a/chef-server/tasks/doc.thor b/chef-server/tasks/doc.thor
deleted file mode 100644
index 77e3222711..0000000000
--- a/chef-server/tasks/doc.thor
+++ /dev/null
@@ -1,149 +0,0 @@
-$: << File.join("doc")
-require 'rubygems'
-require 'rdoc/rdoc'
-require 'fileutils'
-require 'erb'
-
-module Merb
-
- class GemNotFoundException < Exception
- end
-
- module DocMethods
- def setup_gem_path
- if File.directory?(gems_dir = File.join(File.dirname(__FILE__), 'gems'))
- $BUNDLE = true; Gem.clear_paths; Gem.path.unshift(gems_dir)
- end
- end
-
- def get_more
- libs = []
- more_library = find_library("merb-more")
- File.open("#{more_library}/lib/merb-more.rb").read.each_line do |line|
- if line['require']
- libs << line.gsub("require '", '').gsub("'\n", '')
- end
- end
- return libs
- end
-
- def generate_documentation(file_list, destination, arguments = [])
- output_dir = File.join("/../doc", "rdoc", destination)
- FileUtils.rm_rf(output_dir)
-
- arguments += [
- "--fmt", "merb",
- "--op", output_dir
- ]
- RDoc::RDoc.new.document(arguments + file_list)
- AdvancedDoc.new.index
- end
-
- def find_library(directory_snippet)
- gem_dir = nil
- Gem.path.find do |path|
- dir = Dir.glob("#{path}/gems/#{directory_snippet}*")
- dir.empty? ? false : gem_dir = dir.last
- end
- raise GemNotFoundException if gem_dir.nil?
- return gem_dir
- end
-
- def get_file_list(directory_snippet)
- gem_dir = find_library(directory_snippet)
- files = Dir.glob("#{gem_dir}/**/lib/**/*.rb")
- files += ["#{gem_dir}/README"] if File.exists?("#{gem_dir}/README")
- return files
- end
- end
-
- class AdvancedDoc < Thor
-
- group 'core'
- include DocMethods
-
- def initialize
- super
- setup_gem_path
- end
-
- desc 'index', "Regenerate the index file for your framework documentation"
- def index
- @directories = Dir.entries(File.join(File.dirname(__FILE__) + "/../", "doc", "rdoc"))
- @directories.delete(".")
- @directories.delete("..")
- @directories.delete("generators")
- @directories.delete("index.html")
- index_template = File.read(File.join("doc", "rdoc", "generators", "template", "merb", "index.html.erb"))
-
- File.open(File.join("doc", "rdoc", "index.html"), "w") do |file|
- file.write(ERB.new(index_template).result(binding))
- end
- end
-
- desc 'plugins', 'Generate the rdoc for each merb-plugins seperatly'
- def plugins
- libs = ["merb_activerecord", "merb_builder", "merb_jquery", "merb_laszlo", "merb_parts", "merb_screw_unit", "merb_sequel", "merb_stories", "merb_test_unit"]
-
- libs.each do |lib|
- options[:gem] = lib
- gem
- end
- end
-
- desc 'more', 'Generate the rdoc for each merb-more gem seperatly'
- def more
- libs = get_more
- libs.each do |lib|
- options[:gem] = lib
- gem
- end
- end
-
- desc 'core', 'Generate the rdoc for merb-core'
- def core
- options[:gem] = "merb-core"
- gem
- end
-
- desc 'gem', 'Generate the rdoc for a specific gem'
- method_options "--gem" => :required
- def gem
- file_list = get_file_list(options[:gem])
- readme = File.join(find_library("merb-core"), "README")
- generate_documentation(file_list, options[:gem], ["-m", readme])
- rescue GemNotFoundException
- puts "Can not find the gem in the gem path #{options[:gem]}"
- end
-
- end
-
- class Doc < Thor
-
- include DocMethods
-
- def initialize
- super
- setup_gem_path
-
- end
-
- desc 'stack', 'Generate the rdoc for merb-core, merb-more merged together'
- def stack
- libs = ["merb"]
-
- file_list = []
- libs.each do |gem_name|
- begin
- file_list += get_file_list(gem_name)
- rescue GemNotFoundException
- puts "Could not find #{gem_name} in #{Gem.path}. Continuing with out it."
- end
- end
- readme = File.join(find_library("merb"), "README")
- generate_documentation(file_list, "stack", ["-m", readme])
- end
-
- end
-
-end \ No newline at end of file
diff --git a/chef-server/tasks/merb.thor/app_script.rb b/chef-server/tasks/merb.thor/app_script.rb
deleted file mode 100644
index fb0e1163f5..0000000000
--- a/chef-server/tasks/merb.thor/app_script.rb
+++ /dev/null
@@ -1,31 +0,0 @@
-#!/usr/bin/env ruby
-
-# This was added by Merb's bundler
-
-require "rubygems"
-require File.join(File.dirname(__FILE__), "common")
-
-gems_dir = File.join(File.dirname(__FILE__), '..', 'gems')
-
-if File.directory?(gems_dir)
- $BUNDLE = true
- Gem.clear_paths
- Gem.path.replace([File.expand_path(gems_dir)])
- ENV["PATH"] = "#{File.dirname(__FILE__)}:#{ENV["PATH"]}"
-
- gem_file = File.join(gems_dir, "specifications", "<%= spec.name %>-*.gemspec")
-
- if local_gem = Dir[gem_file].last
- version = File.basename(local_gem)[/-([\.\d]+)\.gemspec$/, 1]
- end
-end
-
-version ||= "<%= Gem::Requirement.default %>"
-
-if ARGV.first =~ /^_(.*)_$/ and Gem::Version.correct? $1 then
- version = $1
- ARGV.shift
-end
-
-gem '<%= @spec.name %>', version
-load '<%= bin_file_name %>' \ No newline at end of file
diff --git a/chef-server/tasks/merb.thor/common.rb b/chef-server/tasks/merb.thor/common.rb
deleted file mode 100644
index 9b722a1943..0000000000
--- a/chef-server/tasks/merb.thor/common.rb
+++ /dev/null
@@ -1,68 +0,0 @@
-# This was added via Merb's bundler
-
-require "rubygems"
-require "rubygems/source_index"
-
-module Gem
- BUNDLED_SPECS = File.join(Dir.pwd, "gems", "specifications")
- MAIN_INDEX = Gem::SourceIndex.from_gems_in(BUNDLED_SPECS)
- FALLBACK_INDEX = Gem::SourceIndex.from_installed_gems
-
- def self.source_index
- MultiSourceIndex.new
- end
-
- def self.searcher
- MultiPathSearcher.new
- end
-
- class ArbitrarySearcher < GemPathSearcher
- def initialize(source_index)
- @source_index = source_index
- super()
- end
-
- def init_gemspecs
- @source_index.map { |_, spec| spec }.sort { |a,b|
- (a.name <=> b.name).nonzero? || (b.version <=> a.version)
- }
- end
- end
-
- class MultiPathSearcher
- def initialize
- @main_searcher = ArbitrarySearcher.new(MAIN_INDEX)
- @fallback_searcher = ArbitrarySearcher.new(FALLBACK_INDEX)
- end
-
- def find(path)
- try = @main_searcher.find(path)
- return try if try
- @fallback_searcher.find(path)
- end
-
- def find_all(path)
- try = @main_searcher.find_all(path)
- return try unless try.empty?
- @fallback_searcher.find_all(path)
- end
- end
-
- class MultiSourceIndex
- # Used by merb.thor to confirm; not needed when MSI is in use
- def load_gems_in(*args)
- end
-
- def search(*args)
- try = MAIN_INDEX.search(*args)
- return try unless try.empty?
- FALLBACK_INDEX.search(*args)
- end
-
- def find_name(*args)
- try = MAIN_INDEX.find_name(*args)
- return try unless try.empty?
- FALLBACK_INDEX.find_name(*args)
- end
- end
-end \ No newline at end of file
diff --git a/chef-server/tasks/merb.thor/gem_ext.rb b/chef-server/tasks/merb.thor/gem_ext.rb
deleted file mode 100644
index 6b605d7c8c..0000000000
--- a/chef-server/tasks/merb.thor/gem_ext.rb
+++ /dev/null
@@ -1,125 +0,0 @@
-require "erb"
-
-Gem.pre_install_hooks.push(proc do |installer|
- unless File.file?(installer.bin_dir / "common.rb")
- FileUtils.mkdir_p(installer.bin_dir)
- FileUtils.cp(File.dirname(__FILE__) / "common.rb", installer.bin_dir / "common.rb")
- end
-
- include ColorfulMessages
- name = installer.spec.name
- if $GEMS && versions = ($GEMS.assoc(name) || [])[1]
- dep = Gem::Dependency.new(name, versions)
- unless dep.version_requirements.satisfied_by?(installer.spec.version)
- error "Cannot install #{installer.spec.full_name} " \
- "for #{$INSTALLING}; " \
- "you required #{dep}"
- ::Thor::Tasks::Merb::Gem.rollback_trans
- exit!
- end
- end
- success "Installing #{installer.spec.full_name}"
-end)
-
-class ::Gem::Uninstaller
- def self._with_silent_ui
-
- ui = Gem::DefaultUserInteraction.ui
- def ui.say(str)
- puts "- #{str}"
- end
-
- yield
-
- class << Gem::DefaultUserInteraction.ui
- remove_method :say
- end
- end
-
- def self._uninstall(source_index, name, op, version)
- unless source_index.find_name(name, "#{op} #{version}").empty?
- uninstaller = Gem::Uninstaller.new(
- name,
- :version => "#{op} #{version}",
- :install_dir => Dir.pwd / "gems",
- :all => true,
- :ignore => true
- )
- _with_silent_ui { uninstaller.uninstall }
- end
- end
-
- def self._uninstall_others(source_index, name, version)
- _uninstall(source_index, name, "<", version)
- _uninstall(source_index, name, ">", version)
- end
-end
-
-Gem.post_install_hooks.push(proc do |installer|
- source_index = installer.instance_variable_get("@source_index")
- ::Gem::Uninstaller._uninstall_others(
- source_index, installer.spec.name, installer.spec.version
- )
-end)
-
-class ::Gem::DependencyInstaller
- alias old_fg find_gems_with_sources
-
- def find_gems_with_sources(dep)
- if @source_index.any? { |_, installed_spec|
- installed_spec.satisfies_requirement?(dep)
- }
- return []
- end
-
- old_fg(dep)
- end
-end
-
-class ::Gem::SpecFetcher
- alias old_fetch fetch
- def fetch(dependency, all = false, matching_platform = true)
- idx = Gem::SourceIndex.from_installed_gems
-
- reqs = dependency.version_requirements.requirements
-
- if reqs.size == 1 && reqs[0][0] == "="
- dep = idx.search(dependency).sort.last
- end
-
- if dep
- file = dep.loaded_from.dup
- file.gsub!(/specifications/, "cache")
- file.gsub!(/gemspec$/, "gem")
- spec = ::Gem::Format.from_file_by_path(file).spec
- [[spec, file]]
- else
- old_fetch(dependency, all, matching_platform)
- end
- end
-end
-
-class ::Gem::Installer
- def app_script_text(bin_file_name)
- template = File.read(File.dirname(__FILE__) / "app_script.rb")
- erb = ERB.new(template)
- erb.result(binding)
- end
-end
-
-class ::Gem::Specification
- def recursive_dependencies(from, index = Gem.source_index)
- specs = self.runtime_dependencies.map do |dep|
- spec = index.search(dep).last
- unless spec
- from_name = from.is_a?(::Gem::Specification) ? from.full_name : from.to_s
- wider_net = index.find_name(dep.name).last
- ThorUI.error "Needed #{dep} for #{from_name}, but could not find it"
- ThorUI.error "Found #{wider_net.full_name}" if wider_net
- ::Thor::Tasks::Merb::Gem.rollback_trans
- end
- spec
- end
- specs + specs.map {|s| s.recursive_dependencies(self, index)}.flatten.uniq
- end
-end \ No newline at end of file
diff --git a/chef-server/tasks/merb.thor/main.thor b/chef-server/tasks/merb.thor/main.thor
deleted file mode 100644
index a4c5e10337..0000000000
--- a/chef-server/tasks/merb.thor/main.thor
+++ /dev/null
@@ -1,150 +0,0 @@
-require "rubygems"
-require "rubygems/source_index"
-require "rubygems/dependency_installer"
-require "rubygems/uninstaller"
-require "fileutils"
-require File.join(File.dirname(__FILE__), "utils")
-require File.join(File.dirname(__FILE__), "gem_ext")
-require File.join(File.dirname(__FILE__), "ops")
-
-$INSTALLING = []
-
-module Merb
-
- class Gem < Thor
- extend ColorfulMessages
-
- def initialize
- dirs = [Dir.pwd, File.dirname(__FILE__) / ".."]
- root = dirs.find {|d| File.file?(d / "config" / "dependencies.rb")}
-
- if root
- @depsrb = root / "config" / "dependencies.rb"
- else
- self.class.error "dependencies.rb was not found"
- exit!
- end
-
- FileUtils.mkdir_p(Dir.pwd / "gems")
-
- @list = Collector.collect(File.read(@depsrb))
- @idx = ::Gem::SourceIndex.new.load_gems_in("gems/specifications")
- end
-
- def list
- require "pp"
- pp @list
- end
-
- desc "redeploy", "Syncs up gems/cache with gems/gems. All gems in the cache " \
- "that are not already installed will be installed from the " \
- "cache. All installed gems that are not in the cache will " \
- "be uninstalled."
- def redeploy
- gem_dir = Dir.pwd / "gems" / "gems"
- cache_dir = Dir.pwd / "gems" / "cache"
-
- gems = Dir[gem_dir / "*"].map! {|n| File.basename(n)}
- cache = Dir[cache_dir / "*.gem"].map! {|n| File.basename(n, ".gem")}
- new_gems = cache - gems
- outdated = gems - cache
- idx = ::Gem::SourceIndex.new
- idx.load_gems_in(Dir.pwd / "gems" / "specifications")
-
- new_gems.each do |g|
- installer = ::Gem::Installer.new(cache_dir / "#{g}.gem",
- :bin_dir => Dir.pwd / "bin",
- :install_dir => Dir.pwd / "gems",
- :ignore_dependencies => true,
- :user_install => false,
- :wrappers => true,
- :source_index => idx)
-
- installer.install
- end
-
- outdated.each do |g|
- /(.*)\-(.*)/ =~ g
- name, version = $1, $2
- uninstaller = ::Gem::Uninstaller.new(name,
- :version => version,
- :bin_dir => Dir.pwd / "bin",
- :install_dir => Dir.pwd / "gems",
- :ignore => true,
- :executables => true
- )
- uninstaller.uninstall
- end
- end
-
- desc "confirm", "Confirm the current setup. merb:gem:install will " \
- "automatically run this task before committing the " \
- "changes it makes."
- def confirm(gems = @list)
- ::Gem.path.replace([Dir.pwd / "gems"])
- ::Gem.source_index.load_gems_in(Dir.pwd / "gems" / "specifications")
-
- self.class.info "Confirming configuration..."
-
- ::Gem.loaded_specs.clear
-
- begin
- gems.each do |name, versions|
- versions ||= []
- ::Gem.activate name, *versions
- end
- rescue ::Gem::LoadError => e
- self.class.error "Configuration could not be confirmed: #{e.message}"
- self.class.rollback_trans
- end
- self.class.info "Confirmed"
- end
-
- desc 'install', 'Sync up your bundled gems with the list in config/dependencies.rb'
- def install(*gems)
- if gems.empty?
- gems = @list
- else
- gems = gems.map {|desc| name, *versions = desc.split(" ") }
- end
-
- $GEMS = gems
-
- self.class.begin_trans
-
- gems.each do |name, versions|
- dep = ::Gem::Dependency.new(name, versions || [])
- unless @idx.search(dep).empty?
- next
- end
-
- rescue_failures do
- $INSTALLING = dep
- _install(dep)
- end
- end
-
- gem_dir = Dir.pwd / "gems" / "gems"
- installed_gems = Dir[gem_dir / "*"].map! {|n| File.basename(n)}
-
- list = full_list.map {|x| x.full_name}.compact
-
- (installed_gems - list).each do |g|
- /^(.*)\-(.*)$/ =~ g
- name, version = $1, $2
- uninstaller = ::Gem::Uninstaller.new(name,
- :version => version,
- :bin_dir => (Dir.pwd / "bin").to_s,
- :install_dir => (Dir.pwd / "gems").to_s,
- :ignore => true,
- :executables => true
- )
- uninstaller.uninstall
- end
-
- confirm(gems)
-
- self.class.commit_trans
- end
- end
-end \ No newline at end of file
diff --git a/chef-server/tasks/merb.thor/ops.rb b/chef-server/tasks/merb.thor/ops.rb
deleted file mode 100644
index c758af23af..0000000000
--- a/chef-server/tasks/merb.thor/ops.rb
+++ /dev/null
@@ -1,93 +0,0 @@
-module Thor::Tasks
- module Merb
- class Collector
- attr_reader :dependencies
-
- def self.collect(str)
- collector = new
- collector.instance_eval(str)
- collector.dependencies
- end
-
- def initialize
- @dependencies = []
- end
-
- def dependency(name, *versions)
- versions.pop if versions.last.is_a?(Hash)
- @dependencies << [name, versions]
- end
- end
-
- class Gem < Thor
- def full_list
- @idx.load_gems_in("gems/specifications")
-
- @list.map do |name, versions|
- dep = ::Gem::Dependency.new(name, versions)
- spec = @idx.search(dep).last
- unless spec
- self.class.error "A required dependency #{dep} was not found"
- self.class.rollback_trans
- end
- deps = spec.recursive_dependencies(dep, @idx)
- [spec] + deps
- end.flatten.uniq
- end
-
- def rescue_failures(error = StandardError, prc = nil)
- begin
- yield
- rescue error => e
- if prc
- prc.call(e)
- else
- puts e.message
- puts e.backtrace
- end
- self.class.rollback_trans
- end
- end
-
- def self.begin_trans
- note "Beginning transaction"
- FileUtils.cp_r(Dir.pwd / "gems", Dir.pwd / ".original_gems")
- end
-
- def self.commit_trans
- note "Committing transaction"
- FileUtils.rm_rf(Dir.pwd / ".original_gems")
- end
-
- def self.rollback_trans
- if File.exist?(Dir.pwd / ".original_gems")
- note "Rolling back transaction"
- FileUtils.rm_rf(Dir.pwd / "gems")
- FileUtils.mv(Dir.pwd / ".original_gems", Dir.pwd / "gems")
- end
- exit!
- end
-
- private
- def _install(dep)
- @idx.load_gems_in("gems/specifications")
- return if @idx.search(dep).last
-
- installer = ::Gem::DependencyInstaller.new(
- :bin_dir => Dir.pwd / "bin",
- :install_dir => Dir.pwd / "gems",
- :user_install => false)
-
- begin
- installer.install dep.name, dep.version_requirements
- rescue ::Gem::GemNotFoundException => e
- puts "Cannot find #{dep}"
- rescue ::Gem::RemoteFetcher::FetchError => e
- puts e.message
- puts "Retrying..."
- retry
- end
- end
- end
- end
-end \ No newline at end of file
diff --git a/chef-server/tasks/merb.thor/utils.rb b/chef-server/tasks/merb.thor/utils.rb
deleted file mode 100644
index 1b1caa6978..0000000000
--- a/chef-server/tasks/merb.thor/utils.rb
+++ /dev/null
@@ -1,40 +0,0 @@
-class String
- def /(other)
- (Pathname.new(self) + other).to_s
- end
-end
-
-module ColorfulMessages
-
- # red
- def error(*messages)
- puts messages.map { |msg| "\033[1;31m#{msg}\033[0m" }
- end
-
- # yellow
- def warning(*messages)
- puts messages.map { |msg| "\033[1;33m#{msg}\033[0m" }
- end
-
- # green
- def success(*messages)
- puts messages.map { |msg| "\033[1;32m#{msg}\033[0m" }
- end
-
- alias_method :message, :success
-
- # magenta
- def note(*messages)
- puts messages.map { |msg| "\033[1;35m#{msg}\033[0m" }
- end
-
- # blue
- def info(*messages)
- puts messages.map { |msg| "\033[1;34m#{msg}\033[0m" }
- end
-
-end
-
-module ThorUI
- extend ColorfulMessages
-end