| Dean Troyer | 05f2365 | 2012-08-29 15:20:21 -0500 | [diff] [blame] | 1 | # lib/template | 
 | 2 | # Functions to control the configuration and operation of the XXXX service | 
 | 3 | # <do not include this template file in ``stack.sh``!> | 
 | 4 |  | 
 | 5 | # Dependencies: | 
| Adam Spiers | 6a5aa7c | 2013-10-24 11:27:02 +0100 | [diff] [blame] | 6 | # | 
 | 7 | # - ``functions`` file | 
 | 8 | # - ``SERVICE_{TENANT_NAME|PASSWORD}`` must be defined | 
 | 9 | # - <list other global vars that are assumed to be defined> | 
| Dean Troyer | 05f2365 | 2012-08-29 15:20:21 -0500 | [diff] [blame] | 10 |  | 
 | 11 | # ``stack.sh`` calls the entry points in this order: | 
 | 12 | # | 
| Dean Troyer | e4fa721 | 2014-01-15 15:04:49 -0600 | [diff] [blame] | 13 | # - is_XXXX_enabled | 
| Adam Spiers | 6a5aa7c | 2013-10-24 11:27:02 +0100 | [diff] [blame] | 14 | # - install_XXXX | 
 | 15 | # - configure_XXXX | 
 | 16 | # - init_XXXX | 
 | 17 | # - start_XXXX | 
 | 18 | # - stop_XXXX | 
 | 19 | # - cleanup_XXXX | 
| Dean Troyer | 05f2365 | 2012-08-29 15:20:21 -0500 | [diff] [blame] | 20 |  | 
| Dean Troyer | 7903b79 | 2012-09-13 17:16:12 -0500 | [diff] [blame] | 21 | # Save trace setting | 
 | 22 | XTRACE=$(set +o | grep xtrace) | 
 | 23 | set +o xtrace | 
| Dean Troyer | 05f2365 | 2012-08-29 15:20:21 -0500 | [diff] [blame] | 24 |  | 
 | 25 |  | 
 | 26 | # Defaults | 
 | 27 | # -------- | 
 | 28 |  | 
 | 29 | # <define global variables here that belong to this project> | 
 | 30 |  | 
 | 31 | # Set up default directories | 
 | 32 | XXXX_DIR=$DEST/XXXX | 
 | 33 | XXX_CONF_DIR=/etc/XXXX | 
 | 34 |  | 
 | 35 |  | 
 | 36 | # Entry Points | 
 | 37 | # ------------ | 
 | 38 |  | 
| Dean Troyer | e4fa721 | 2014-01-15 15:04:49 -0600 | [diff] [blame] | 39 | # Test if any XXXX services are enabled | 
 | 40 | # is_XXXX_enabled | 
 | 41 | function is_XXXX_enabled { | 
 | 42 |     [[ ,${ENABLED_SERVICES} =~ ,"XX-" ]] && return 0 | 
 | 43 |     return 1 | 
 | 44 | } | 
 | 45 |  | 
| Dean Troyer | 05f2365 | 2012-08-29 15:20:21 -0500 | [diff] [blame] | 46 | # cleanup_XXXX() - Remove residual data files, anything left over from previous | 
 | 47 | # runs that a clean run would need to clean up | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 48 | function cleanup_XXXX { | 
| Dean Troyer | 05f2365 | 2012-08-29 15:20:21 -0500 | [diff] [blame] | 49 |     # kill instances (nova) | 
 | 50 |     # delete image files (glance) | 
 | 51 |     # This function intentionally left blank | 
 | 52 |     : | 
 | 53 | } | 
 | 54 |  | 
 | 55 | # configure_XXXX() - Set config files, create data dirs, etc | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 56 | function configure_XXXX { | 
| Dean Troyer | 05f2365 | 2012-08-29 15:20:21 -0500 | [diff] [blame] | 57 |     # sudo python setup.py deploy | 
 | 58 |     # iniset $XXXX_CONF ... | 
 | 59 |     # This function intentionally left blank | 
 | 60 |     : | 
 | 61 | } | 
 | 62 |  | 
 | 63 | # init_XXXX() - Initialize databases, etc. | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 64 | function init_XXXX { | 
| Dean Troyer | 05f2365 | 2012-08-29 15:20:21 -0500 | [diff] [blame] | 65 |     # clean up from previous (possibly aborted) runs | 
 | 66 |     # create required data files | 
 | 67 |     : | 
 | 68 | } | 
 | 69 |  | 
 | 70 | # install_XXXX() - Collect source and prepare | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 71 | function install_XXXX { | 
| Dean Troyer | 05f2365 | 2012-08-29 15:20:21 -0500 | [diff] [blame] | 72 |     # git clone xxx | 
 | 73 |     : | 
 | 74 | } | 
 | 75 |  | 
 | 76 | # start_XXXX() - Start running processes, including screen | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 77 | function start_XXXX { | 
| Chris Dent | 2f27a0e | 2014-09-09 13:46:02 +0100 | [diff] [blame] | 78 |     # The quoted command must be a single command and not include an | 
 | 79 |     # shell metacharacters, redirections or shell builtins. | 
 | 80 |     # run_process XXXX "$XXXX_DIR/bin/XXXX-bin" | 
| Dean Troyer | 05f2365 | 2012-08-29 15:20:21 -0500 | [diff] [blame] | 81 |     : | 
 | 82 | } | 
 | 83 |  | 
 | 84 | # stop_XXXX() - Stop running processes (non-screen) | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 85 | function stop_XXXX { | 
| Chris Dent | 2f27a0e | 2014-09-09 13:46:02 +0100 | [diff] [blame] | 86 |     # for serv in serv-a serv-b; do | 
 | 87 |     #     stop_process $serv | 
 | 88 |     # done | 
| Dean Troyer | 05f2365 | 2012-08-29 15:20:21 -0500 | [diff] [blame] | 89 |     : | 
 | 90 | } | 
| Dean Troyer | 7903b79 | 2012-09-13 17:16:12 -0500 | [diff] [blame] | 91 |  | 
 | 92 | # Restore xtrace | 
 | 93 | $XTRACE | 
| Sean Dague | 584d90e | 2013-03-29 14:34:53 -0400 | [diff] [blame] | 94 |  | 
| Adam Spiers | 6a5aa7c | 2013-10-24 11:27:02 +0100 | [diff] [blame] | 95 | # Tell emacs to use shell-script-mode | 
 | 96 | ## Local variables: | 
 | 97 | ## mode: shell-script | 
 | 98 | ## End: |