| # lib/marconi | 
 | # Install and start **Marconi** service | 
 |  | 
 | # To enable a minimal set of Marconi services, add the following to localrc: | 
 | #   enable_service marconi-server | 
 | # | 
 | # Dependencies: | 
 | # - functions | 
 | # - OS_AUTH_URL for auth in api | 
 | # - DEST set to the destination directory | 
 | # - SERVICE_PASSWORD, SERVICE_TENANT_NAME for auth in api | 
 | # - STACK_USER service user | 
 |  | 
 | # stack.sh | 
 | # --------- | 
 | # install_marconi | 
 | # configure_marconi | 
 | # init_marconi | 
 | # start_marconi | 
 | # stop_marconi | 
 | # cleanup_marconi | 
 |  | 
 | # Save trace setting | 
 | XTRACE=$(set +o | grep xtrace) | 
 | set +o xtrace | 
 |  | 
 |  | 
 | # Defaults | 
 | # -------- | 
 |  | 
 | # Set up default directories | 
 | MARCONI_DIR=$DEST/marconi | 
 | MARCONICLIENT_DIR=$DEST/python-marconiclient | 
 | MARCONI_CONF_DIR=/etc/marconi | 
 | MARCONI_CONF=$MARCONI_CONF_DIR/marconi.conf | 
 | MARCONI_API_LOG_DIR=/var/log/marconi-api | 
 | MARCONI_AUTH_CACHE_DIR=${MARCONI_AUTH_CACHE_DIR:-/var/cache/marconi} | 
 |  | 
 | # Support potential entry-points console scripts | 
 | MARCONI_BIN_DIR=$(get_python_exec_prefix) | 
 |  | 
 | # Set up database backend | 
 | MARCONI_BACKEND=${MARCONI_BACKEND:-mongodb} | 
 |  | 
 |  | 
 | # Set Marconi repository | 
 | MARCONI_REPO=${MARCONI_REPO:-${GIT_BASE}/openstack/marconi.git} | 
 | MARCONI_BRANCH=${MARCONI_BRANCH:-master} | 
 |  | 
 | # Set client library repository | 
 | MARCONICLIENT_REPO=${MARCONICLIENT_REPO:-${GIT_BASE}/openstack/python-marconiclient.git} | 
 | MARCONICLIENT_BRANCH=${MARCONICLIENT_BRANCH:-master} | 
 |  | 
 | # Functions | 
 | # --------- | 
 |  | 
 | # cleanup_marconi() - Remove residual data files, anything left over from previous | 
 | # runs that a clean run would need to clean up | 
 | function cleanup_marconi() { | 
 |     mongo marconi --eval "db.dropDatabase();" | 
 | } | 
 |  | 
 | # configure_marconiclient() - Set config files, create data dirs, etc | 
 | function configure_marconiclient() { | 
 |     setup_develop $MARCONICLIENT_DIR | 
 | } | 
 |  | 
 | # configure_marconi() - Set config files, create data dirs, etc | 
 | function configure_marconi() { | 
 |     setup_develop $MARCONI_DIR | 
 |  | 
 |     [ ! -d $MARCONI_CONF_DIR ] && sudo mkdir -m 755 -p $MARCONI_CONF_DIR | 
 |     sudo chown $USER $MARCONI_CONF_DIR | 
 |  | 
 |     [ ! -d $MARCONI_API_LOG_DIR ] &&  sudo mkdir -m 755 -p $MARCONI_API_LOG_DIR | 
 |     sudo chown $USER $MARCONI_API_LOG_DIR | 
 |  | 
 |     iniset $MARCONI_CONF DEFAULT verbose True | 
 |     iniset $MARCONI_CONF 'drivers:transport:wsgi' bind '0.0.0.0' | 
 |  | 
 |     # Install the policy file for the API server | 
 |     cp $MARCONI_DIR/etc/marconi/policy.json $MARCONI_CONF_DIR | 
 |     iniset $MARCONI_CONF DEFAULT policy_file $MARCONI_CONF_DIR/policy.json | 
 |  | 
 |     iniset $MARCONI_CONF keystone_authtoken auth_protocol http | 
 |     iniset $MARCONI_CONF keystone_authtoken admin_user marconi | 
 |     iniset $MARCONI_CONF keystone_authtoken admin_password $SERVICE_PASSWORD | 
 |     iniset $MARCONI_CONF keystone_authtoken admin_tenant_name $SERVICE_TENANT_NAME | 
 |     iniset $MARCONI_CONF keystone_authtoken signing_dir $MARCONI_AUTH_CACHE_DIR | 
 |  | 
 |     if [[ "$MARCONI_BACKEND" = 'mongodb' ]]; then | 
 |         iniset $MARCONI_CONF database connection mongodb://localhost:27017/marconi | 
 |         configure_mongodb | 
 |         cleanup_marconi | 
 |     fi | 
 | } | 
 |  | 
 | function configure_mongodb() { | 
 |     # Set nssize to 2GB. This increases the number of namespaces supported | 
 |     # # per database. | 
 |     sudo sed -i '/--nssize/!s/OPTIONS=\"/OPTIONS=\"--nssize 2047 /' /etc/sysconfig/mongod | 
 |  | 
 |     restart_service mongod | 
 | } | 
 |  | 
 | # init_marconi() - Initialize etc. | 
 | function init_marconi() { | 
 |     # Create cache dir | 
 |     sudo mkdir -p $MARCONI_AUTH_CACHE_DIR | 
 |     sudo chown $STACK_USER $MARCONI_AUTH_CACHE_DIR | 
 |     rm -f $MARCONI_AUTH_CACHE_DIR/* | 
 | } | 
 |  | 
 | # install_marconi() - Collect source and prepare | 
 | function install_marconi() { | 
 |     git_clone $MARCONI_REPO $MARCONI_DIR $MARCONI_BRANCH | 
 |     setup_develop $MARCONI_DIR | 
 | } | 
 |  | 
 | # install_marconiclient() - Collect source and prepare | 
 | function install_marconiclient() { | 
 |     git_clone $MARCONICLIENT_REPO $MARCONICLIENT_DIR $MARCONICLIENT_BRANCH | 
 |     setup_develop $MARCONICLIENT_DIR | 
 | } | 
 |  | 
 | # start_marconi() - Start running processes, including screen | 
 | function start_marconi() { | 
 |     screen_it marconi-server "marconi-server --config-file $MARCONI_CONF" | 
 | } | 
 |  | 
 | # stop_marconi() - Stop running processes | 
 | function stop_marconi() { | 
 |     # Kill the marconi screen windows | 
 |     for serv in marconi-server; do | 
 |         screen -S $SCREEN_NAME -p $serv -X kill | 
 |     done | 
 | } | 
 |  | 
 | function create_marconi_accounts() { | 
 |     SERVICE_TENANT=$(keystone tenant-list | awk "/ $SERVICE_TENANT_NAME / { print \$2 }") | 
 |     ADMIN_ROLE=$(keystone role-list | awk "/ admin / { print \$2 }") | 
 |  | 
 |     MARCONI_USER=$(get_id keystone user-create --name=marconi \ | 
 |                                                 --pass="$SERVICE_PASSWORD" \ | 
 |                                                 --tenant_id $SERVICE_TENANT \ | 
 |                                                 --email=marconi@example.com) | 
 |     keystone user-role-add --tenant-id $SERVICE_TENANT \ | 
 |                             --user-id $MARCONI_USER \ | 
 |                             --role-id $ADMIN_ROLE | 
 |     if [[ "$KEYSTONE_CATALOG_BACKEND" = 'sql' ]]; then | 
 |         MARCONI_SERVICE=$(keystone service-create \ | 
 |             --name=marconi \ | 
 |             --type=queuing \ | 
 |             --description="Marconi Service" \ | 
 |             | grep " id " | get_field 2) | 
 |         keystone endpoint-create \ | 
 |             --region RegionOne \ | 
 |             --service_id $MARCONI_SERVICE \ | 
 |             --publicurl "http://$SERVICE_HOST:8888" \ | 
 |             --adminurl "http://$SERVICE_HOST:8888" \ | 
 |             --internalurl "http://$SERVICE_HOST:8888" | 
 |     fi | 
 |  | 
 | } | 
 |  | 
 |  | 
 | # Restore xtrace | 
 | $XTRACE | 
 |  | 
 | # Local variables: | 
 | # mode: shell-script | 
 | # End: |