summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--app-admin/chef-server-api/ChangeLog11
-rw-r--r--app-admin/chef-server-api/chef-server-api-0.9.6.ebuild65
-rw-r--r--app-admin/chef-server-api/files/confd/chef-server-api23
-rw-r--r--app-admin/chef-server-api/files/initd/chef-server-api41
-rw-r--r--app-admin/chef-server-api/files/server.rb130
-rw-r--r--app-admin/chef-server-api/metadata.xml10
6 files changed, 280 insertions, 0 deletions
diff --git a/app-admin/chef-server-api/ChangeLog b/app-admin/chef-server-api/ChangeLog
new file mode 100644
index 000000000000..99f065f10c7d
--- /dev/null
+++ b/app-admin/chef-server-api/ChangeLog
@@ -0,0 +1,11 @@
+# ChangeLog for app-admin/chef-server-api
+# Copyright 1999-2010 Gentoo Foundation; Distributed under the GPL v2
+# $Header: /var/cvsroot/gentoo-x86/app-admin/chef-server-api/ChangeLog,v 1.1 2010/07/03 12:42:13 hollow Exp $
+
+*chef-server-api-0.9.6 (03 Jul 2010)
+
+ 03 Jul 2010; Benedikt Böhm <hollow@gentoo.org>
+ +chef-server-api-0.9.6.ebuild, +files/confd/chef-server-api,
+ +files/initd/chef-server-api, +files/server.rb, +metadata.xml:
+ initial ebuild, thanks to Gábor Vészi
+
diff --git a/app-admin/chef-server-api/chef-server-api-0.9.6.ebuild b/app-admin/chef-server-api/chef-server-api-0.9.6.ebuild
new file mode 100644
index 000000000000..a7e72bd29d1e
--- /dev/null
+++ b/app-admin/chef-server-api/chef-server-api-0.9.6.ebuild
@@ -0,0 +1,65 @@
+# Copyright 1999-2010 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/app-admin/chef-server-api/chef-server-api-0.9.6.ebuild,v 1.1 2010/07/03 12:42:13 hollow Exp $
+
+EAPI="2"
+USE_RUBY="ruby18"
+
+RUBY_FAKEGEM_TASK_DOC=""
+RUBY_FAKEGEM_TASK_TEST=""
+
+inherit ruby-fakegem
+
+DESCRIPTION="Configuration management tool"
+HOMEPAGE="http://wiki.opscode.com/display/chef"
+
+LICENSE="Apache-2.0"
+SLOT="0"
+KEYWORDS="~amd64 ~x86"
+IUSE=""
+
+ruby_add_rdepend "=app-admin/chef-${PV}
+ <=dev-ruby/json-1.4.2
+ >=dev-ruby/merb-assets-1.1.0
+ >=dev-ruby/merb-core-1.1.0
+ >=dev-ruby/merb-helpers-1.1.0
+ >=dev-ruby/merb-param-protection-1.1.0
+ >=dev-ruby/merb-slices-1.1.0
+ >=dev-ruby/uuidtools-2.1.1
+ www-servers/thin"
+
+pkg_setup() {
+ enewgroup chef
+ enewuser chef -1 -1 /var/lib/chef chef
+}
+
+each_ruby_install() {
+ each_fakegem_install
+ ruby_fakegem_doins -r app
+ ruby_fakegem_doins -r config
+ ruby_fakegem_doins -r public
+}
+
+all_ruby_install() {
+ all_fakegem_install
+
+ doinitd "${FILESDIR}/initd/chef-server-api"
+ doconfd "${FILESDIR}/confd/chef-server-api"
+
+ keepdir /etc/chef /var/lib/chef /var/log/chef /var/run/chef \
+ /etc/chef/certificates
+
+ insinto /etc/chef
+ doins "${FILESDIR}/server.rb"
+
+ fperms 0700 /etc/chef/certificates
+ fowners chef:chef /etc/chef/{,server.rb,certificates}
+ fowners chef:chef /var/{lib,log,run}/chef
+}
+
+pkg_postinst() {
+ elog
+ elog "You should edit /etc/chef/server.rb before starting the service with"
+ elog "/etc/init.d/chef-server-api start"
+ elog
+}
diff --git a/app-admin/chef-server-api/files/confd/chef-server-api b/app-admin/chef-server-api/files/confd/chef-server-api
new file mode 100644
index 000000000000..ffdc122c24f0
--- /dev/null
+++ b/app-admin/chef-server-api/files/confd/chef-server-api
@@ -0,0 +1,23 @@
+# /etc/conf.d/chef-server-api: config file for /etc/init.d/chef-server-api
+
+# The configuration file to use.
+#CONFIGFILE="/etc/chef/server.rb"
+
+# Number of merb daemons to run for chef-server.
+#CLUSTER_NODES=1
+
+# The user and group to set privilege to.
+#CHEF_USER="chef"
+#CHEF_GROUP="chef"
+
+# Log file location.
+#CHEF_SERVER_LOGFILE="/var/log/chef/server.log"
+
+# Any radom options you want to pass to chef-server.
+#CHEF_SERVER_OPTS=""
+
+# Path to the chef server binary.
+#CHEF_SERVER_BINARY="/usr/bin/chef-server"
+
+# PID file location.
+#CHEF_SERVER_PIDFILE="/var/run/chef/server.%s.pid"
diff --git a/app-admin/chef-server-api/files/initd/chef-server-api b/app-admin/chef-server-api/files/initd/chef-server-api
new file mode 100644
index 000000000000..81b0dea916dc
--- /dev/null
+++ b/app-admin/chef-server-api/files/initd/chef-server-api
@@ -0,0 +1,41 @@
+#!/sbin/runscript
+# Copyright 1999-2010 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+depend() {
+ need net couchdb rabbitmq chef-solr-indexer
+ before chef-client
+}
+
+CHEF_SERVER_BINARY=${CHEF_SERVER_BINARY:-/usr/bin/chef-server}
+CHEF_SERVER_PIDFILE=${CHEF_SERVER_PIDFILE:-/var/run/chef/server.%s.pid}
+CHEF_SERVER_LOGFILE=${CHEF_SERVER_LOGFILE:-/var/log/chef/server.log}
+CONFIGFILE=${CONFIGFILE:-/etc/chef/server.rb}
+CLUSTER_NODES=${CLUSTER_NODES:-1}
+CHEF_USER=${CHEF_USER:-chef}
+CHEF_GROUP=${CHEF_GROUP:-chef}
+
+# TODO: this could be nicer
+DEFAULT_CHEF_DIRS=( /etc/chef /var/lib/chef /var/log/chef /var/run/chef )
+CHEF_DIRS=( ${CHEF_DIRS[@]:-${DEFAULT_CHEF_DIRS[@]}} )
+
+fix_dir_owners() {
+ for DIR in ${CHEF_DIRS[@]}; do
+ chown ${CHEF_USER}:${CHEF_GROUP} ${DIR}
+ done
+}
+
+start() {
+ ebegin "Starting Chef server"
+ fix_dir_owners
+ ${CHEF_SERVER_BINARY} -d -P ${CHEF_SERVER_PIDFILE} -C ${CONFIGFILE} \
+ -u ${CHEF_USER} -G ${CHEF_GROUP} --name chef-server \
+ -c ${CLUSTER_NODES} -L ${CHEF_SERVER_LOGFILE} > /dev/null
+ eend $?
+}
+
+stop() {
+ ebegin "Shutting down Chef server"
+ ${CHEF_SERVER_BINARY} -K all -P ${CHEF_SERVER_PIDFILE} > /dev/null
+ eend $?
+}
diff --git a/app-admin/chef-server-api/files/server.rb b/app-admin/chef-server-api/files/server.rb
new file mode 100644
index 000000000000..003bafcdaaee
--- /dev/null
+++ b/app-admin/chef-server-api/files/server.rb
@@ -0,0 +1,130 @@
+# Configuration File For Chef (chef-server)
+#
+# chef-server is a Merb application slice. By default it is configured to
+# run via Thin, the default Merb adapter. It can be run as:
+#
+# chef-server -p 4000 -e production -a thin
+#
+# This starts up the RESTful Chef Server API on port 4000 in production mode
+# using the thin server adapter.
+#
+# This file configures the behavior of the running server itself.
+#
+# Chef uses a Ruby DSL for configuration, and this file contains a few
+# Ruby idioms. First, symbols. These are designated by a colon sigil, ie,
+# :value. Second, in Ruby, everything but false and nil (no quotes or other
+# designations) is true, including true, the integer 0 and the string "false".
+# So to set the value of a setting to false, write:
+#
+# some_setting false
+#
+# Third, Ruby class methods can be used, for example we tell the log to show
+# the current time stamp with Chef::Log::Formatter.show_time, below.
+#
+# log_level specifies the level of verbosity for output.
+# valid values are: :debug, :info, :warn, :error, :fatal
+
+log_level :info
+
+# log_location specifies where the server should log to.
+# valid values are: a quoted string specifying a file, or STDOUT with
+# no quotes. This is the application log for the Merb workers that get
+# spawned.
+
+log_location "/var/log/chef/server.log"
+
+# ssl_verify_mode specifies if the REST client should verify SSL certificates.
+# valid values are :verify_none, :verify_peer. The default Chef Server
+# installation will use a self-generated SSL certificate so this should be
+# :verify_none unless you replace the certificate.
+
+ssl_verify_mode :verify_none
+
+# chef_server_url specifies the URL for the server API. The process actually
+# listens on 0.0.0.0:PORT.
+# valid values are any HTTP URL.
+
+chef_server_url "http://localhost:4000"
+
+# cookbook_path is a Ruby array of filesystem locations to search for cookbooks.
+# valid value is a string, or an array of strings of filesystem directory
+# locations. This setting is searched beginning (index 0) to end in order. You
+# might specify multiple search paths for cookbooks if you want to use an
+# upstream source, and provide localised "site" overrides. These should come
+# after the 'upstream' source. The default value, /var/lib/chef/cookbooks does
+# not contain any cookbooks by default.
+# See the Chef Wiki for more information about setting up a local repository
+# for working on cookbooks.
+# http://wiki.opscode.com/display/chef/Chef+Repository
+
+cookbook_path [ "/var/lib/chef/cookbooks" ]
+cookbook_tarball_path "/var/lib/chef/cookbook-tarballs"
+
+# file_cache_path specifies where the client should cache cookbooks, server
+# cookie ID, and openid registration data.
+# valid value is any filesystem directory location.
+
+file_cache_path "/var/lib/chef/cache"
+
+# node_path specifies a location for where to find node-specific recipes.
+# valid values are any filesystem direcory location.
+
+node_path "/var/lib/chef/nodes"
+
+# openid_store_path specifies a location where to keep openid nonces for clients.
+# valid values are any filesystem directory location.
+#
+# NOTE: OpenID is deprecated and this option may not be used, kept for
+# historical purposes.
+
+openid_store_path "/var/lib/chef/openid/store"
+
+# openid_store_path specifies a location where to keep openid nonces for clients.
+# valid values are any filesystem directory location.
+#
+# NOTE: OpenID is deprecated and this option may not be used, kept for
+# historical purposes and may be removed.
+
+openid_cstore_path "/var/lib/chef/openid/cstore"
+
+# role_path designates where the server should load role JSON and Ruby DSL
+# files from.
+# valid values are any filesystem directory location. Roles are a feature
+# that allow you to easily reuse lists of recipes and attribute settings.
+# Please see the Chef Wiki page for information on how to utilize the feature.
+# http://wiki.opscode.com/display/chef/Roles
+#
+# NOTE: The role_path setting is deprecated on the chef-server, as the
+# roles are now stored directly in CouchDB rather than on the filesystem.
+# This option is kept for historical purposes and may be removed.
+
+role_path "/var/lib/chef/roles"
+
+# cache_options sets options used by the moneta library for local cache for
+# checksums of compared objects.
+
+cache_options({
+ :path => "/var/lib/chef/cache/checksums",
+ :skip_expires => true
+})
+
+# Mixlib::Log::Formatter.show_time specifies whether the chef-client log should
+# contain timestamps.
+# valid values are true or false (no quotes, see above about Ruby idioms). The
+# printed timestamp is rfc2822, for example:
+# Fri, 31 Jul 2009 19:19:46 -0600
+
+Mixlib::Log::Formatter.show_time = true
+
+# The following options configure the signing CA so it can be read by
+# non-privileged user for the server daemon.
+
+signing_ca_path "/etc/chef/certificates"
+signing_ca_cert "/etc/chef/certificates/cert.pem"
+signing_ca_key "/etc/chef/certificates/key.pem"
+
+sandbox_path "/var/lib/chef/sandboxes"
+checksum_path "/var/lib/chef/checksums"
+
+openid_store_path "/var/lib/chef/openid/store"
+search_index_path "/var/lib/chef/search_index"
diff --git a/app-admin/chef-server-api/metadata.xml b/app-admin/chef-server-api/metadata.xml
new file mode 100644
index 000000000000..b263a5bc4f28
--- /dev/null
+++ b/app-admin/chef-server-api/metadata.xml
@@ -0,0 +1,10 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd">
+<pkgmetadata>
+ <herd>no-herd</herd>
+ <maintainer>
+ <email>hollow@gentoo.org</email>
+ <name>Benedikt Böhm</name>
+ </maintainer>
+</pkgmetadata>
+