<div dir="ltr">Thanks Richard,<div><br></div><div>I am not sure where to look ...</div><div><br></div><div>







<p class=""># pwd</p>
<p class="">/etc/puppetlabs/puppet/environments/production/modules</p>
<p class=""># ls</p>
<p class="">apache<span class="">  </span>apt<span class="">  </span>concat<span class="">  </span>firewall<span class="">  </span>inifile<span class="">  </span>keystone<span class="">  </span>mysql<span class="">  </span>openstacklib<span class="">  </span>postgresql<span class="">  </span>rabbitmq<span class="">  </span>staging<span class="">  </span>stdlib</p>
<p class=""># find . -type f -exec grep -i SECURE_PROXY_SSL_HEADER {} \;</p><p class="">no output. :)</p><p class=""><br></p></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Jan 14, 2016 at 1:01 PM, Richard Raseley <span dir="ltr"><<a href="mailto:richard@raseley.com" target="_blank">richard@raseley.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">If you’re terminating SSL at HAproxy, look into the ‘SECURE_PROXY_SSL_HEADER’ and related parameters.<br>
<div class="HOEnZb"><div class="h5"><br>
> On Jan 14, 2016, at 9:50 AM, Russell Cecala <<a href="mailto:red.cricket.blog@gmail.com">red.cricket.blog@gmail.com</a>> wrote:<br>
><br>
> Thanks for helping out.  I hope that I am not being too much of a pest, but I really want my group to adopt the Openstack community's puppet modules for deploying Openstack.  Now that I have keystone working on one node I want to expand on that.  I have an HAProxy cluster and I have a signed certificate.  I want to use ssl and use my HAProxy cluster.  I assume that I need to change my POC puppet manifest like so ...<br>
><br>
> class { '::keystone::endpoint':<br>
><br>
>        public_url     => "https://${controller_vip_name}:5000",<br>
><br>
>        admin_url      => "https://${controller_vip_name}:35357",<br>
><br>
>        internal_url     => "https://${controller_vip_name}:5000",<br>
><br>
>        region         => 'example-1',<br>
><br>
>     }<br>
><br>
> Where $controller_vip_name is the hostname (or IP address) of the virtual interface for my HAProxy<br>
><br>
><br>
><br>
> In my haproxy.cfg I have these lines:<br>
><br>
> frontend keystone-admin-vip<br>
><br>
>   bind <a href="http://10.29.103.39:35357" rel="noreferrer" target="_blank">10.29.103.39:35357</a> ssl crt /etc/haproxy/<a href="http://svl-ost-el7.cisco.com" rel="noreferrer" target="_blank">svl-ost-el7.cisco.com</a> no-sslv3 ciphers AES128-SHA:AES256-SHA<br>
><br>
>   default_backend  keystone-admin-api<br>
><br>
><br>
><br>
> frontend keystone-public-vip<br>
><br>
>   bind <a href="http://10.29.103.39:5000" rel="noreferrer" target="_blank">10.29.103.39:5000</a> ssl crt /etc/haproxy/<a href="http://svl-ost-el7.cisco.com" rel="noreferrer" target="_blank">svl-ost-el7.cisco.com</a> no-sslv3 ciphers AES128-SHA:AES256-SHA<br>
><br>
><br>
>   default_backend  keystone-public-api<br>
><br>
> So I guess my question is, "Is there any thing else I need to do besides changing the values I pass to my keystone::endpoint resource?".<br>
><br>
><br>
><br>
> Thanks!<br>
><br>
><br>
> On Fri, Jan 8, 2016 at 10:13 AM, Russell Cecala <<a href="mailto:red.cricket.blog@gmail.com">red.cricket.blog@gmail.com</a>> wrote:<br>
> oops.  I figured it out ...<br>
><br>
> MariaDB [keystone_db_name]> select * from project;<br>
><br>
> +----------------------------------+-----------+-------+-----------------------------------+---------+-----------+-----------+<br>
><br>
> | id                               | name      | extra | description                       | enabled | domain_id | parent_id |<br>
><br>
> +----------------------------------+-----------+-------+-----------------------------------+---------+-----------+-----------+<br>
><br>
> | af4e7a8966fb4665aaac22a8b9687c8f | openstack | {}    | admin tenant                      |       1 | default   | NULL      |<br>
><br>
> | b83b33cc7d314181af50a2a80c995b0c | services  | {}    | Tenant for the openstack services |       1 | default   | NULL      |<br>
><br>
> +----------------------------------+-----------+-------+-----------------------------------+---------+-----------+-----------+<br>
><br>
> 2 rows in set (0.01 sec)<br>
><br>
><br>
><br>
> MariaDB [keystone_db_name]> quit<br>
><br>
> Bye<br>
><br>
> [root@ost-services-centos-001 ~]# exit<br>
><br>
> logout<br>
><br>
> Connection to ost-services-centos-001 closed.<br>
><br>
> [root@ost-mgmt-centos-001 ~]# openstack --os-auth-url <a href="http://127.0.0.1:35357" rel="noreferrer" target="_blank">http://127.0.0.1:35357</a>    --os-project-name openstack --os-username admin --os-auth-type password   token issue<br>
><br>
> Password:<br>
><br>
> +------------+----------------------------------+<br>
><br>
> | Field      | Value                            |<br>
><br>
> +------------+----------------------------------+<br>
><br>
> | expires    | 2016-01-08T19:12:14Z             |<br>
><br>
> | id         | 581a5c2e8a074740a510cbadebf17815 |<br>
><br>
> | project_id | af4e7a8966fb4665aaac22a8b9687c8f |<br>
><br>
> | user_id    | b3f1f4bcfb114559a05378bd6ce39e55 |<br>
><br>
> +------------+----------------------------------+<br>
><br>
><br>
> On Fri, Jan 8, 2016 at 10:09 AM, Russell Cecala <<a href="mailto:red.cricket.blog@gmail.com">red.cricket.blog@gmail.com</a>> wrote:<br>
> Hi Rich,<br>
><br>
> Thanks for all your help so far.<br>
> I am getting clean puppet runs (I still get depreciation warnings) but "puppet agent -t" is running without error now:<br>
><br>
> [root@ost-mgmt-centos-001 ~]# puppet agent -t<br>
><br>
> Info: Retrieving pluginfacts<br>
><br>
> Info: Retrieving plugin<br>
><br>
> Info: Loading facts<br>
><br>
> Error: NetworkManager is not running.<br>
><br>
> Info: Caching catalog for <a href="http://ost-mgmt-centos-001.example.com" rel="noreferrer" target="_blank">ost-mgmt-centos-001.example.com</a><br>
><br>
> Warning: The tenant parameter is deprecated and will be removed in the future. Please use keystone_user_role to assign a user to a project.<br>
><br>
> Warning: The ignore_default_tenant parameter is deprecated and will be removed in the future.<br>
><br>
> Info: Applying configuration version '1452275612'<br>
><br>
> Notice: /Stage[main]/Wrapcontroller/Exec[/usr/bin/curl <a href="http://git.openstack.org/cgit/openstack/keystone/plain/httpd/keystone.py?h=stable/kilo" rel="noreferrer" target="_blank">http://git.openstack.org/cgit/openstack/keystone/plain/httpd/keystone.py?h=stable/kilo</a> | /usr/bin/tee /var/www/cgi-bin/keystone/main /var/www/cgi-bin/keystone/admin]/returns: executed successfully<br>
><br>
> Notice: Finished catalog run in 11.53 seconds<br>
><br>
><br>
> Here is the puppet module I am using currently:<br>
><br>
> class wrapcontroller(<br>
><br>
> ... long list of parameters I am not using yet ...<br>
><br>
> ) {<br>
><br>
>     class {'my-openstack::disable_firewall':} -><br>
><br>
>     class {'my-openstack::disable_selinux':} -><br>
><br>
>     class {'my-openstack::disable_network_manager':} -><br>
><br>
><br>
><br>
>     exec { '/bin/yum -y install <a href="http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-5.noarch.rpm" rel="noreferrer" target="_blank">http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-5.noarch.rpm</a>': unless => '/bin/rpm -q epel-release', }<br>
><br>
>     exec { '/bin/yum -y install <a href="http://rdo.fedorapeople.org/openstack-kilo/rdo-release-kilo.rpm" rel="noreferrer" target="_blank">http://rdo.fedorapeople.org/openstack-kilo/rdo-release-kilo.rpm</a>': unless => '/bin/rpm -q rdo-release', }<br>
><br>
>     exec { '/usr/bin/curl <a href="http://git.openstack.org/cgit/openstack/keystone/plain/httpd/keystone.py?h=stable/kilo" rel="noreferrer" target="_blank">http://git.openstack.org/cgit/openstack/keystone/plain/httpd/keystone.py?h=stable/kilo</a> | /usr/bin/tee /var/www/cgi-bin/keystone/main /var/www/cgi-bin/keystone/admin':}<br>
><br>
>     $packages = ['mariadb', 'mod_wsgi', 'memcached', 'python-memcached']<br>
><br>
>     package { $packages : ensure => present, }<br>
><br>
><br>
><br>
>     exec { 'keystone_database_init':<br>
><br>
>         command => '/usr/bin/keystone-manage db_sync',<br>
><br>
>         onlyif => [<br>
><br>
>             "/usr/bin/mysql -u$keystone_db_user -p$keystone_db_pass -h$db_host -P$db_port $keystone_db_name -e 'show tables'",<br>
><br>
>             "/usr/bin/test -z \"`/usr/bin/mysql -u$keystone_db_user -p$keystone_db_pass -h$db_host -P$db_port $keystone_db_name -e 'show tables'`\""<br>
><br>
>         ],<br>
><br>
>         require => Package['mariadb'],<br>
><br>
>     }<br>
><br>
>     $services = ['memcached']<br>
><br>
>     service { $services : ensure => running, enable => true, }<br>
><br>
>     # found out that you shouldn't create the wsgi-ketstone.conf file as it prevents httpd from starting<br>
><br>
>     file { '/etc/httpd/conf.d/wsgi-keystone.conf':<br>
><br>
>         ensure  => absent,<br>
><br>
> #        content => template( "wrapcontroller/wsgi-keystone.conf.erb" ),<br>
><br>
>     }<br>
><br>
>     class {'::keystone':<br>
><br>
>         admin_token                => $keystone_auth_token,<br>
><br>
>         catalog_type               => 'sql',<br>
><br>
>         database_connection        => "mysql://${keystone_db_user}:${keystone_db_pass}@${db_host}:${db_port}/${keystone_db_name}",<br>
><br>
>         debug                      => $debug,<br>
><br>
>         verbose                    => $debug,<br>
><br>
>     }<br>
><br>
><br>
><br>
> #    include ::apache<br>
><br>
> #    class { '::keystone::wsgi::apache': ssl => false, }<br>
><br>
>     class { '::keystone::roles::admin':<br>
><br>
>        email        => $keystone_admin_email,<br>
><br>
>        password     => $keystone_admin_password,<br>
><br>
>     }<br>
><br>
>     class { '::keystone::endpoint':<br>
><br>
>        public_url     => "<a href="http://127.0.0.1:5000" rel="noreferrer" target="_blank">http://127.0.0.1:5000</a>",<br>
><br>
>        admin_url      => "<a href="http://127.0.0.1:35357" rel="noreferrer" target="_blank">http://127.0.0.1:35357</a>",<br>
><br>
>        internal_url     => "<a href="http://127.0.0.1:5000" rel="noreferrer" target="_blank">http://127.0.0.1:5000</a>",<br>
><br>
>        region         => 'example-1',<br>
><br>
>     }<br>
><br>
> }<br>
><br>
> The above runs but I am unable to verify that keystone is working as per the docs here:<br>
><br>
> <a href="http://docs.openstack.org/kilo/install-guide/install/yum/content/keystone-verify.html" rel="noreferrer" target="_blank">http://docs.openstack.org/kilo/install-guide/install/yum/content/keystone-verify.html</a><br>
><br>
> [root@ost-mgmt-centos-001 ~]# openstack --os-auth-url <a href="http://127.0.0.1:35357" rel="noreferrer" target="_blank">http://127.0.0.1:35357</a>    --os-project-name admin --os-username admin --os-auth-type password   token issue<br>
><br>
> Password:<br>
><br>
> ERROR: openstack Invalid user / password (Disable debug mode to suppress these details.) (HTTP 401) (Request-ID: req-7c9b4b3b-dfe8-48a9-98eb-668b18e9b3bb)<br>
><br>
> [root@ost-mgmt-centos-001 ~]# openstack --os-auth-url <a href="http://127.0.0.1:35357" rel="noreferrer" target="_blank">http://127.0.0.1:35357</a>    --os-project-name admin --os-username admin --os-auth-type password   token issue<br>
><br>
> Password:<br>
><br>
> ERROR: openstack Could not find project: admin (Disable debug mode to suppress these details.) (HTTP 401) (Request-ID: req-c42ee03c-eb7b-4858-9743-a376fda0dc1f)<br>
><br>
><br>
><br>
><br>
><br>
> openstack Could not find project: admin<br>
><br>
> Hmm what is the project's name?  How can I figure that out?<br>
><br>
><br>
><br>
> Thanks,<br>
><br>
> Russ<br>
><br>
><br>
> On Tue, Jan 5, 2016 at 2:22 PM, Rich Megginson <<a href="mailto:rmeggins@redhat.com">rmeggins@redhat.com</a>> wrote:<br>
> On 01/05/2016 02:42 PM, Russell Cecala wrote:<br>
>> Hi Rich,<br>
>><br>
>> I guess I am kind of confused. I thought "class { '::keystone::roles::admin':" was suppose to create the "admin" user and set the password to $keystone_admin_password.  If class { '::keystone::roles::admin' doesn't create the admin user what does?<br>
><br>
> It either creates it, or ensures that it has the specified properties, if it already exists.  In this case, it seems that it already exists, so it attempts to ensure that it has the specified properties.<br>
><br>
>> And what kind of user are we talking about?  A user that shows up in the /etc/passwd file or an mysql user or a keystone user of some sort?<br>
><br>
> a keystone user - a user that shows up when you do "$ openstack user list" as an admin user.<br>
><br>
><br>
>> Sorry I am pretty confused :)<br>
>><br>
>> After I truncate my /var/log/keystone/keystone.log and run puppet agent -t I get this output to my keystone.log<br>
>><br>
>> 2016-01-05 16:28:38.342 10596 DEBUG keystone.middleware.core [-] RBAC: auth_context: {} process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:239<br>
>><br>
>> 2016-01-05 16:28:38.346 10596 INFO keystone.common.wsgi [-] GET /projects?<br>
>><br>
>> 2016-01-05 16:28:38.347 10596 WARNING keystone.common.controller [-] RBAC: Bypassing authorization<br>
>><br>
>> 2016-01-05 16:28:38.352 10596 INFO eventlet.wsgi.server [-] 127.0.0.1 - - [05/Jan/2016 16:28:38] "GET /v3/projects HTTP/1.1" 200 884 0.011000<br>
>><br>
>> 2016-01-05 16:28:39.144 10596 DEBUG keystone.middleware.core [-] RBAC: auth_context: {} process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:239<br>
>><br>
>> 2016-01-05 16:28:39.147 10596 INFO keystone.common.wsgi [-] GET /domains?<br>
>><br>
>> 2016-01-05 16:28:39.148 10596 WARNING keystone.common.controller [-] RBAC: Bypassing authorization<br>
>><br>
>> 2016-01-05 16:28:39.152 10596 INFO eventlet.wsgi.server [-] 127.0.0.1 - - [05/Jan/2016 16:28:39] "GET /v3/domains HTTP/1.1" 200 702 0.009214<br>
>><br>
>> 2016-01-05 16:28:39.929 10596 DEBUG keystone.middleware.core [-] RBAC: auth_context: {} process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:239<br>
>><br>
>> 2016-01-05 16:28:39.932 10596 INFO keystone.common.wsgi [-] GET /roles?<br>
>><br>
>> 2016-01-05 16:28:39.933 10596 WARNING keystone.common.controller [-] RBAC: Bypassing authorization<br>
>><br>
>> 2016-01-05 16:28:39.938 10596 INFO eventlet.wsgi.server [-] 127.0.0.1 - - [05/Jan/2016 16:28:39] "GET /v3/roles HTTP/1.1" 200 615 0.009210<br>
>><br>
>> 2016-01-05 16:28:40.712 10596 DEBUG keystone.middleware.core [-] RBAC: auth_context: {} process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:239<br>
>><br>
>> 2016-01-05 16:28:40.716 10596 INFO keystone.common.wsgi [-] GET /users?<br>
>><br>
>> 2016-01-05 16:28:40.716 10596 WARNING keystone.common.controller [-] RBAC: Bypassing authorization<br>
>><br>
>> 2016-01-05 16:28:40.721 10596 INFO eventlet.wsgi.server [-] 127.0.0.1 - - [05/Jan/2016 16:28:40] "GET /v3/users HTTP/1.1" 200 820 0.008919<br>
>><br>
>> 2016-01-05 16:28:41.562 10596 DEBUG keystone.middleware.core [-] RBAC: auth_context: {} process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:239<br>
>><br>
>> 2016-01-05 16:28:41.565 10596 INFO keystone.common.wsgi [-] GET /domains?<br>
>><br>
>> 2016-01-05 16:28:41.566 10596 WARNING keystone.common.controller [-] RBAC: Bypassing authorization<br>
>><br>
>> 2016-01-05 16:28:41.571 10596 INFO eventlet.wsgi.server [-] 127.0.0.1 - - [05/Jan/2016 16:28:41] "GET /v3/domains HTTP/1.1" 200 702 0.009300<br>
>><br>
>> 2016-01-05 16:28:42.331 10596 DEBUG keystone.middleware.core [-] RBAC: auth_context: {} process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:239<br>
>><br>
>> 2016-01-05 16:28:42.335 10596 INFO keystone.common.wsgi [-] GET /users/5ec5abf83d164d439b603d72606b99fd?<br>
>><br>
>> 2016-01-05 16:28:42.335 10596 WARNING keystone.common.controller [-] RBAC: Bypassing authorization<br>
>><br>
>> 2016-01-05 16:28:42.340 10596 INFO eventlet.wsgi.server [-] 127.0.0.1 - - [05/Jan/2016 16:28:42] "GET /v3/users/5ec5abf83d164d439b603d72606b99fd HTTP/1.1" 200 472 0.009393<br>
>><br>
>> 2016-01-05 16:28:42.353 10596 DEBUG keystone.middleware.core [-] RBAC: auth_context: {} process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:239<br>
>><br>
>> 2016-01-05 16:28:42.356 10596 INFO keystone.common.wsgi [-] GET /users/5ec5abf83d164d439b603d72606b99fd/projects?<br>
>><br>
>> 2016-01-05 16:28:42.357 10596 WARNING keystone.common.controller [-] RBAC: Bypassing authorization<br>
>><br>
>> 2016-01-05 16:28:42.370 10596 INFO eventlet.wsgi.server [-] 127.0.0.1 - - [05/Jan/2016 16:28:42] "GET /v3/users/5ec5abf83d164d439b603d72606b99fd/projects HTTP/1.1" 200 632 0.016973<br>
>><br>
>> 2016-01-05 16:28:43.217 10599 DEBUG keystone.middleware.core [-] Auth token not in the request header. Will not build auth context. process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:229<br>
>><br>
>> 2016-01-05 16:28:43.220 10599 INFO eventlet.wsgi.server [-] 10.29.103.19 - - [05/Jan/2016 16:28:43] "POST /v2.0/auth/tokens HTTP/1.1" 404 318 0.002948<br>
>><br>
>> 2016-01-05 16:28:43.318 10599 DEBUG keystone.middleware.core [-] Auth token not in the request header. Will not build auth context. process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:229<br>
>><br>
>> 2016-01-05 16:28:43.321 10599 INFO eventlet.wsgi.server [-] 10.29.103.19 - - [05/Jan/2016 16:28:43] "POST /v2.0/auth/tokens HTTP/1.1" 404 318 0.002887<br>
>><br>
><br>
> This is strange.  /v2.0/auth/tokens does not exist.  It is /v2.0/tokens for v2, and /v3/auth/tokens for v3.  This would indicate that perhaps your openrc setting with the "/v2.0" suffix is polluting the puppet run?<br>
><br>
><br>
>> 2016-01-05 16:28:44.076 10596 DEBUG keystone.middleware.core [-] RBAC: auth_context: {} process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:239<br>
>><br>
>> 2016-01-05 16:28:44.079 10596 INFO keystone.common.wsgi [-] GET /services?<br>
>><br>
>> 2016-01-05 16:28:44.079 10596 WARNING keystone.common.controller [-] RBAC: Bypassing authorization<br>
>><br>
>> 2016-01-05 16:28:44.084 10596 INFO eventlet.wsgi.server [-] 127.0.0.1 - - [05/Jan/2016 16:28:44] "GET /v3/services HTTP/1.1" 200 558 0.008541<br>
>><br>
>> 2016-01-05 16:28:44.871 10596 DEBUG keystone.middleware.core [-] RBAC: auth_context: {} process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:239<br>
>><br>
>> 2016-01-05 16:28:44.873 10596 INFO keystone.common.wsgi [-] GET /endpoints?<br>
>><br>
>> 2016-01-05 16:28:44.878 10596 INFO eventlet.wsgi.server [-] 127.0.0.1 - - [05/Jan/2016 16:28:44] "GET /v2.0/endpoints HTTP/1.1" 200 764 0.006931<br>
>><br>
>> 2016-01-05 16:28:44.891 10596 DEBUG keystone.middleware.core [-] RBAC: auth_context: {} process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:239<br>
>><br>
>> 2016-01-05 16:28:44.892 10596 INFO keystone.common.wsgi [-] GET /OS-KSADM/services/07622af16010436aadb463adffff4099?<br>
>><br>
>> 2016-01-05 16:28:44.896 10596 INFO eventlet.wsgi.server [-] 127.0.0.1 - - [05/Jan/2016 16:28:44] "GET /v2.0/OS-KSADM/services/07622af16010436aadb463adffff4099 HTTP/1.1" 200 385 0.005287<br>
>><br>
>> 2016-01-05 16:28:44.899 10596 DEBUG keystone.middleware.core [-] RBAC: auth_context: {} process_request /usr/lib/python2.7/site-packages/keystone/middleware/core.py:239<br>
>><br>
>> 2016-01-05 16:28:44.900 10596 INFO keystone.common.wsgi [-] GET /OS-KSADM/services/07622af16010436aadb463adffff4099?<br>
>><br>
>> 2016-01-05 16:28:44.904 10596 INFO eventlet.wsgi.server [-] 127.0.0.1 - - [05/Jan/2016 16:28:44] "GET /v2.0/OS-KSADM/services/07622af16010436aadb463adffff4099 HTTP/1.1" 200 385 0.005030<br>
>><br>
>><br>
>> On Mon, Jan 4, 2016 at 3:22 PM, Rich Megginson <<a href="mailto:rmeggins@redhat.com">rmeggins@redhat.com</a>> wrote:<br>
>> On 01/04/2016 03:07 PM, Russell Cecala wrote:<br>
>>> Thank you for the reply Rich,<br>
>>><br>
>>> Here are the versions of my puppet modules:<br>
>>><br>
>>> [root@ost-puppet-centos-001 keystone]# puppet module list<br>
>>><br>
>>> /etc/puppetlabs/puppet/environments/production/modules<br>
>>><br>
>>> ├── nanliu-staging (v1.0.3)<br>
>>><br>
>>> ├── openstack-keystone (v6.1.0)<br>
>>><br>
>>> ├── openstack-openstacklib (v6.1.0)<br>
>>><br>
>>> ├── puppetlabs-apache (v1.7.0)<br>
>>><br>
>>> ├── puppetlabs-apt (v1.8.0)<br>
>>><br>
>>> ├── puppetlabs-concat (v1.2.4)<br>
>>><br>
>>> ├── puppetlabs-firewall (v1.7.1)<br>
>>><br>
>>> ├── puppetlabs-inifile (v1.4.2)<br>
>>><br>
>>> ├── puppetlabs-mysql (v3.6.1)<br>
>>><br>
>>> ├── puppetlabs-postgresql (v3.4.2)<br>
>>><br>
>>> ├── puppetlabs-rabbitmq (v5.3.1)<br>
>>><br>
>>> └── puppetlabs-stdlib (v4.9.0)<br>
>>><br>
>>> /etc/puppetlabs/puppet/modules<br>
>>><br>
>>> ├── cisco-gis-openstack (???)<br>
>>><br>
>>> ├── haproxy (???)<br>
>>><br>
>>> ├── keepalived (???)<br>
>>><br>
>>> ├── mikduart-unnamed (v0.1.0)<br>
>>><br>
>>> ├── mikduart-unnamed (v0.1.0)<br>
>>><br>
>>> ├── mikduart-unnamed (v0.1.0)<br>
>>><br>
>>> ├── puppetlabs-mongodb (v0.10.0)<br>
>>><br>
>>> ├── saz-memcached (v2.4.0)<br>
>>><br>
>>> ├── setup_mariadb_script (???)<br>
>>><br>
>>> ├── sysctl (???)<br>
>>><br>
>>> └── wrapmongodb (???)<br>
>>><br>
>>> /opt/puppet/share/puppet/modules<br>
>>><br>
>>> ├── puppetlabs-pe_accounts (v2.0.2-8-g8acc04e)<br>
>>><br>
>>> ├── puppetlabs-pe_concat (v1.1.2-4-g2b7bba2)<br>
>>><br>
>>> ├── puppetlabs-pe_console_prune (v0.1.1-4-g293f45b)<br>
>>><br>
>>> ├── puppetlabs-pe_inifile (v1.1.4-16-gcb39966)<br>
>>><br>
>>> ├── puppetlabs-pe_java_ks (v1.2.4-35-g44fbb26)<br>
>>><br>
>>> ├── puppetlabs-pe_postgresql (v3.4.4-15-g32e56ed)<br>
>>><br>
>>> ├── puppetlabs-pe_razor (v0.2.1-9-g8d78ec2)<br>
>>><br>
>>> ├── puppetlabs-pe_repo (v0.7.7-59-g4514315)<br>
>>><br>
>>> ├── puppetlabs-pe_staging (v0.3.3-6-gbd9db2b)<br>
>>><br>
>>> └── puppetlabs-puppet_enterprise (v3.7.1-117-g9c48e73)<br>
>>><br>
>>><br>
>>> I am not sure I have the right values in my openrc but I have been using:<br>
>>><br>
>>><br>
>>> # cat openrc.localhost<br>
>>><br>
>>> export OS_AUTH_URL=<a href="http://127.0.0.1:5000/v2.0" rel="noreferrer" target="_blank">http://127.0.0.1:5000/v2.0</a><br>
>>><br>
>>> export OS_PASSWORD=xxxxxxxxxxxxxxxx<br>
>>><br>
>>> export OS_TENANT_NAME=admin<br>
>>><br>
>>><br>
>>> export OS_USERNAME=admin<br>
>>><br>
>><br>
>> Is this sourced into the environment where puppet is running?  It should not be.<br>
>><br>
>><br>
>>><br>
>>> I believe this is the openstackclient version I am using:<br>
>>><br>
>>><br>
>>> [root@ost-mgmt-centos-001 ~]# rpm -qa | grep openstackclient<br>
>>><br>
>>><br>
>>> python-openstackclient-1.0.3-2.el7.noarch<br>
>>><br>
>>><br>
>>> On Mon, Jan 4, 2016 at 1:19 PM, Rich Megginson <<a href="mailto:rmeggins@redhat.com">rmeggins@redhat.com</a>> wrote:<br>
>>> On 01/04/2016 02:06 PM, Russell Cecala wrote:<br>
>>>> Hi Emilien,<br>
>>>><br>
>>>><br>
>>>> I am trying to use <a href="https://github.com/openstack/puppet-keystone" rel="noreferrer" target="_blank">https://github.com/openstack/puppet-keystone</a> to set up a Kilo keystone node.<br>
>>><br>
>>> I'm assuming you're using the kilo branch there?<br>
>>><br>
>>>> I was hoping to could help me out so I can get my team to adopt puppet for setting up OpenStack.<br>
>>>><br>
>>>> On my keystone node I am running centos7 with selinux disabled ...<br>
>>><br>
>>> What version of openstackclient are you using?<br>
>>><br>
>>> Do you have a $HOME/openrc or /root/openrc, or are you otherwise defining OS_* environment variables in the environment before running puppet?<br>
>>><br>
>>>><br>
>>>> [root@svl-ost-mgmt-centos-001 ~]# sestatus<br>
>>>><br>
>>>> SELinux status:                 disabled<br>
>>>><br>
>>>> ... and I have flushed my iptables ...<br>
>>>><br>
>>>><br>
>>>> [root@svl-ost-mgmt-centos-001 ~]# iptables -L<br>
>>>><br>
>>>> Chain INPUT (policy ACCEPT)<br>
>>>><br>
>>>> target     prot opt source               destination<br>
>>>><br>
>>>><br>
>>>> Chain FORWARD (policy ACCEPT)<br>
>>>><br>
>>>> target     prot opt source               destination<br>
>>>><br>
>>>><br>
>>>> Chain OUTPUT (policy ACCEPT)<br>
>>>><br>
>>>><br>
>>>> target     prot opt source               destination<br>
>>>><br>
>>>><br>
>>>> Yet when I run "puppet agent -t"  I get these errors:<br>
>>>><br>
>>>><br>
>>>> [root@ost-mgmt-centos-001 ~]# puppet agent -t<br>
>>>><br>
>>>> Info: Retrieving pluginfacts<br>
>>>><br>
>>>> Info: Retrieving plugin<br>
>>>><br>
>>>> Info: Loading facts<br>
>>>><br>
>>>> Error: NetworkManager is not running.<br>
>>>><br>
>>>> Info: Caching catalog for <a href="http://ost-mgmt-centos-001.example.com" rel="noreferrer" target="_blank">ost-mgmt-centos-001.example.com</a><br>
>>>><br>
>>>> Warning: The tenant parameter is deprecated and will be removed in the future. Please use keystone_user_role to assign a user to a project.<br>
>>>><br>
>>>> Warning: The ignore_default_tenant parameter is deprecated and will be removed in the future.<br>
>>>><br>
>>>> Info: Applying configuration version '1451940682'<br>
>>>><br>
>>>> Error: /Stage[main]/Keystone::Roles::Admin/Keystone_user[admin]: Could not evaluate: Execution of '/usr/bin/openstack token issue --format value' returned 1: ERROR: openstack The resource could not be found. (HTTP 404) (Request-ID: req-ca2a6dd1-fdb6-48f4-94fe-8f736fcc01dd)<br>
>>>><br>
>><br>
>> This usually indicates that it is trying to ensure that the user "admin" exists but the password is incorrect.  That is, the class { '::keystone::roles::admin':        password     => $keystone_admin_password is not correct.<br>
>><br>
>> If you are sure it is correct, then it could be a mismatch between the identity api version used by the puppet module and the one specified in the environment.  Check the keystone access logs to see what URL this is trying to access - something with /token or /tokens, or something with /auth/token or /auth/tokens<br>
>><br>
>>>> Notice: /Stage[main]/Keystone::Roles::Admin/Keystone_user_role[admin@openstack]: Dependency Keystone_user[admin] has failures: true<br>
>>>><br>
>>>> Warning: /Stage[main]/Keystone::Roles::Admin/Keystone_user_role[admin@openstack]: Skipping because of failed dependencies<br>
>>>><br>
>>>><br>
>>>> Notice: Finished catalog run in 12.38 seconds<br>
>>>><br>
>>>> Here's code I am using on my puppet master ...<br>
>>>><br>
>>>> class wrapcontroller(<br>
>>>><br>
>>>><br>
>>>> ... big list of parameters I am not using until I can get keystone going ...<br>
>>>><br>
>>>> ) {<br>
>>>><br>
>>>><br>
>>>>     exec { '/bin/yum -y install <a href="http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-5.noarch.rpm" rel="noreferrer" target="_blank">http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-5.noarch.rpm</a>': unless => '/bin/rpm -q epel-release', }<br>
>>>><br>
>>>>     exec { '/bin/yum -y install <a href="http://rdo.fedorapeople.org/openstack-kilo/rdo-release-kilo.rpm" rel="noreferrer" target="_blank">http://rdo.fedorapeople.org/openstack-kilo/rdo-release-kilo.rpm</a>': unless => '/bin/rpm -q rdo-release', }<br>
>>>><br>
>>>><br>
>>>>     package { 'mariadb': ensure => present, }<br>
>>>><br>
>>>>     exec { 'keystone_database_init':<br>
>>>><br>
>>>>         command => '/usr/bin/keystone-manage db_sync',<br>
>>>><br>
>>>>         onlyif => [<br>
>>>><br>
>>>>             "/usr/bin/mysql -u$keystone_db_user -p$keystone_db_pass -h$db_host -P$db_port $keystone_db_name -e 'show tables'",<br>
>>>><br>
>>>>             "/usr/bin/test -z \"`/usr/bin/mysql -u$keystone_db_user -p$keystone_db_pass -h$db_host -P$db_port $keystone_db_name -e 'show tables'`\""<br>
>>>><br>
>>>>         ],<br>
>>>><br>
>>>>         require => Package['mariadb'],<br>
>>>><br>
>>>>     }<br>
>>>><br>
>>>><br>
>>>>     class {'::keystone':<br>
>>>><br>
>>>>         admin_token                => $keystone_auth_token,<br>
>>>><br>
>>>>         database_connection        => "mysql://${keystone_db_user}:${keystone_db_pass}@${db_host}:${db_port}/${keystone_db_name}",<br>
>>>><br>
>>>>         debug                      => $debug,<br>
>>>><br>
>>>>         enabled                    => true,<br>
>>>><br>
>>>>         enable_ssl                 => false,<br>
>>>><br>
>>>>         service_name               => 'httpd', # this is a kilo thing<br>
>>>><br>
>>>>         verbose                    => $debug,<br>
>>>><br>
>>>>     }<br>
>>>><br>
>>>><br>
>>>>     include ::apache<br>
>>>><br>
>>>>     class { '::keystone::wsgi::apache': ssl => false, }<br>
>>>><br>
>>>>     class { '::keystone::roles::admin':<br>
>>>><br>
>>>>        email        => $keystone_admin_email,<br>
>>>><br>
>>>>        password     => $keystone_admin_password,<br>
>>>><br>
>>>>     }<br>
>>>><br>
>>>>     class { '::keystone::endpoint':<br>
>>>><br>
>>>>        public_url     => "<a href="http://127.0.0.1:5000" rel="noreferrer" target="_blank">http://127.0.0.1:5000</a>",<br>
>>>><br>
>>>>        admin_url      => "<a href="http://127.0.0.1:35357" rel="noreferrer" target="_blank">http://127.0.0.1:35357</a>",<br>
>>>><br>
>>>>        default_domain => 'admin',<br>
>>>><br>
>>>>     }<br>
>>>><br>
>>>><br>
>>>> }<br>
>>>><br>
>>>> Thanks! And Happy New Year to you :)<br>
>>>> Red<br>
>>>><br>
>>>><br>
>>>><br>
>>>> On Tue, Nov 24, 2015 at 2:38 PM, Emilien Macchi <<a href="mailto:emilien@redhat.com">emilien@redhat.com</a>> wrote:<br>
>>>><br>
>>>><br>
>>>> On 11/24/2015 11:21 PM, Russell Cecala wrote:<br>
>>>> > I am trying to use the OpenStack community puppet modules.  Here's the<br>
>>>> > keystone module I am using:  <a href="https://github.com/openstack/puppet-keystone" rel="noreferrer" target="_blank">https://github.com/openstack/puppet-keystone</a><br>
>>>> > I am using the stable juno branch.  I have in my puppet manifest for my<br>
>>>> > controller nodes this resource definition:<br>
>>>> ><br>
>>>> >     class { '::keystone::roles::admin':<br>
>>>> >         admin        => $keystone_admin_user,<br>
>>>> >         email        => $keystone_admin_email,<br>
>>>> >         password     => $keystone_admin_password,<br>
>>>> >     } -><br>
>>>> ><br>
>>>> > And when puppet runs that code I get this error:<br>
>>>> ><br>
>>>> >     Error:<br>
>>>> > /Stage[main]/Keystone::Roles::Admin/Keystone_user_role[keystone_admin_user@openstack]:<br>
>>>> > Could not evaluate: Execution of '/usr/bin/openstack domain show<br>
>>>> > --format shell' returned 2: usage: openstack domain show [-h] [-f<br>
>>>> > {shell,table,value}] [-c COLUMN]<br>
>>>> >                                  [--max-width <integer>] [--prefix PREFIX]<br>
>>>> >                                  <domain><br>
>>>> >     openstack domain show: error: too few arguments<br>
>>>><br>
>>>> Sounds like an issue with your version of openstackclient, can you<br>
>>>> provide it?<br>
>>>><br>
>>>> ><br>
>>>> > Can anyone help me?  Are these Puppet modules still being supported?<br>
>>>><br>
>>>> Yes :-)<br>
>>>><br>
>>>> > Does anyone use them?  Thanks!<br>
>>>><br>
>>>> Double yes.<br>
>>>> --<br>
>>>> Emilien Macchi<br>
>>>><br>
>>>><br>
>>>><br>
>>>><br>
>>>><br>
>>>> _______________________________________________<br>
>>>> OpenStack-operators mailing list<br>
>>>><br>
>>>> <a href="mailto:OpenStack-operators@lists.openstack.org">OpenStack-operators@lists.openstack.org</a><br>
>>>> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-operators" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-operators</a><br>
>>><br>
>>><br>
>>> _______________________________________________<br>
>>> OpenStack-operators mailing list<br>
>>> <a href="mailto:OpenStack-operators@lists.openstack.org">OpenStack-operators@lists.openstack.org</a><br>
>>> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-operators" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-operators</a><br>
>>><br>
>>><br>
>><br>
>><br>
><br>
><br>
><br>
><br>
> _______________________________________________<br>
> OpenStack-operators mailing list<br>
> <a href="mailto:OpenStack-operators@lists.openstack.org">OpenStack-operators@lists.openstack.org</a><br>
> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-operators" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-operators</a><br>
<br>
</div></div></blockquote></div><br></div>