Thanks Luciano.

I got some help from Bob Healey with a copy of his working configuration
and I finally have a functioning installation.  I inherited a bunch of
settings I wasn't too familiar with from previous installations.  Looks
like dropping by add_header from:

add_header Referrer-Policy "no-referrer";
              add_header Strict-Transport-Security "max-age=15768000;
includeSubDomains" always;
      add_header Content-Security-Policy "connect-src 'self'; object-src
'self'; frame-src 'self'; img-src 'self' d
ata:; style-src 'self' 'unsafe-inline'; font-src 'self'; form-action
'self'; base-uri 'self'; frame-ancestors 'self'
;" always;

to:
add_header Strict-Transport-Security "max-age=63072000; includeSubDomains;
preload";
       add_header X-Frame-Options DENY;
       add_header X-Content-Type-Options nosniff;
       add_header X-XSS-Protection "1; mode=block";

did the job for me.  When I have some time I plan to dissect this a little
further and see if I can isolate this down a little more.  But the box is
now in user testing so I don't want to break it.  Thanks for all the help
on this one.

Thanks


Matt Fox
Systems Engineer
IT Department
Augustana University
2001 S Summit Ave | Sioux Falls, SD 57197
[email protected]
605-274-5059
www.augie.edu


On Fri, May 6, 2022 at 3:06 PM Luciano Oliveira <[email protected]>
wrote:

> Hello, Matt!
>
> My configs:
>
> Guacamole 1.4.0, NGINX, Duo Auth, MariaDB
>
> guacamole.properties:
>
> guacd-hostname: 127.0.0.1
> guacd-port: 4822
> user-mapping: /etc/guacamole/user-mapping.xml
> #auth-provider:
> net.sourceforge.guacamole.net.basic.BasicFileAuthenticationProvider
> #auth-provider:
> net.sourceforge.guacamole.net.auth.mysql.MySQLAuthenticationProvider
> auth-provider:
> net.sourceforge.guacamole.net.auth.ldap.LDAPAuthenticationProvider
>
> # >>>>>>>>>>>>> MySQL Start config
> mysql-hostname: <<dbserver.domain.local>>
> mysql-port: 3306
> mysql-database: guacamole
> mysql-username: usrguacamole
> mysql-password: <<password>>
> mysql-user-password-min-length: 8
> mysql-user-password-require-multiple-case: true
> mysql-user-password-require-symbol: true
> mysql-user-password-require-digit: true
> mysql-user-password-prohibit-username: true
> mysql-user-password-min-age: 7
> mysql-user-password-max-age: 60
> mysql-user-required: false
> mysql-auto-create-accounts: true
> # <<<<<<<<<<<<< end
>
> # >>>>>>>>>>>>> LDAP Start config
> ldap-hostname: <<adserver.domain.local>>
> ldap-port: 389
> ldap-encryption-method: none
> ldap-user-base-dn: DC=domain,DC=local
> ldap-username-attribute: sAMAccountName
> ldap-search-bind-dn:
> CN=<<user_ad_login>>,OU=UsersServices,DC=domain,DC=local
> ldap-search-bind-password: <<password>>
> ldap-group-name-attribute: cn
> ldap-member-attribute: member
>
> ldap-user-search-filter:(&(&(objectClass=user)(objectCategory=person))(memberof=CN=access_guacamole,OU=GroupsServices,DC=domain,DC=local))
> # <<<<<<<<<<<<< end
>
> # >>>>>>>>>>>> MFA Start config
> duo-api-hostname: <<api_hostname>>.duosecurity.com
> duo-integration-key: <<integration_key>>
> duo-secret-key: <<secret_key>>
> duo-application-key: <<application_key>>
>
> # <<<<<<<<<<<< end
>
> nginx default file start config
> ##
> upstream guacamole {
>         server guacanew:8080;
> }
>
> server {
>         listen 80;
>         server_name guacamole.domain.loca;
>         return 301 https://$host$request_uri;
>         location / {
>                 proxy_pass http://guacamole/guacamole/;
>                 set_real_ip_from guacamole.domain.loca;
>                 real_ip_header X-Forwarded-For;
>                 real_ip_recursive on;
>                 proxy_buffering off;
>                 proxy_set_header X-Forwarded-For
> $proxy_add_x_forwarded_for;
>                 proxy_http_version 1.1;
>                 proxy_set_header Upgrade $http_upgrade;
>                 proxy_set_header Connection $http_connection;
>                 proxy_set_header X-Real-IP $remote_addr;
>                 proxy_set_header X-Forwarded-Host $host;
>                 proxy_set_header X-Forwarded-Server $host;
>                 proxy_set_header X-Forwarded-For
> $proxy_add_x_forwarded_for;
>                 access_log off;
>         }
> }
>
> server {
>         listen 443 ssl default_server;
>         listen [::]:443 ssl default_server;
>         ssl_certificate /etc/ssl/private/cert2022.crt;
>         ssl_certificate_key /etc/ssl/private/cert2022.key;
>         ssl_session_timeout 5m;
>         ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
>         ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
>         ssl_prefer_server_ciphers on;
>         location / {
>                 proxy_pass http://guacamole/guacamole/;
>                 set_real_ip_from guacamole.domain.local;
>                 real_ip_header X-Forwarded-For;
>                 real_ip_recursive on;
>                 proxy_buffering off;
>                 proxy_set_header X-Forwarded-For
> $proxy_add_x_forwarded_for;
>                 proxy_http_version 1.1;
>                 proxy_set_header Upgrade $http_upgrade;
>                 proxy_set_header Connection $http_connection;
>                 proxy_set_header X-Real-IP $remote_addr;
>                 proxy_set_header X-Forwarded-Host $host;
>                 proxy_set_header X-Forwarded-Server $host;
>                 proxy_set_header X-Forwarded-For
> $proxy_add_x_forwarded_for;
>                 access_log off;
>         }
>
> }
>
>
> [ ]'s
> *Luciano*
>
> ------------------------------
> *De:* Matt Fox <[email protected]>
> *Enviado:* sexta-feira, 29 de abril de 2022 16:31
> *Para:* [email protected] <[email protected]>
> *Assunto:* NGINX LDAP Mariadb and DUO
>
> Hi,
>
> I have a functioning deployment of Guacamole 1.4 with matching extensions
> for LDAP and JDBC-MYSQL behind a NGINX proxy for SSL.  All appears to work
> fine.  When I configure and deploy the DUO plugin authentication breaks.
> If I remove the NGINX proxy and attach to Tomcat directly, DUO secondary
> authentication works.  Does anybody know of any document I could study for
> guidance on fixing my NGINX configuration?
> My current config is:
>
> server {
>                listen 443 ssl http2 default_server;
>                listen [::]:443 ssl http2 default_server;
>                server_name taurus3.augie.edu;
>                server_tokens off;
>                ssl_certificate guacamole.crt;
>                ssl_certificate_key guacamole.key;
>        ssl_ciphers
> 'TLS_CHACHA20_POLY1305_SHA256:TLS_AES_256_GCM_SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-SHA384';
>
>        ssl_protocols TLSv1.3 TLSv1.2;
>                ssl_ecdh_curve secp521r1:secp384r1:prime256v1;
>                ssl_prefer_server_ciphers on;
>                ssl_session_cache shared:SSL:10m;
>                ssl_session_timeout 1d;
>                ssl_session_tickets off;
>                add_header Referrer-Policy "no-referrer";
>                add_header Strict-Transport-Security "max-age=15768000;
> includeSubDomains" always;
>        add_header Content-Security-Policy "connect-src 'self'; object-src
> 'self'; frame-src 'self'; img-src 'self' data:; style-src 'self'
> 'unsafe-inline'; font-src 'self'; form-action 'self'; base-uri 'self';
> frame-ancestors 'self';" always;
>                add_header X-Content-Type-Options "nosniff" always;
>                add_header X-XSS-Protection "1; mode=block" always;
>                proxy_hide_header Server;
>                proxy_hide_header X-Powered-By;
>                client_body_timeout 10;
>                client_header_timeout 10;
>
>                location /guacamole/ {
>                proxy_pass http://127.0.0.1:8080/guacamole/;
>                proxy_buffering off;
>                proxy_http_version 1.1;
>                proxy_set_header X-Forwarded-For
> $proxy_add_x_forwarded_for;
>                proxy_set_header Upgrade $http_upgrade;
>                proxy_set_header Connection $http_connection;
>                proxy_cookie_path /guacamole/ "/guacamole/;";
>                access_log /var/log/nginx/guac_access.log;
>                error_log /var/log/nginx/guac_error.log;
>                }
>        }
>
> Thanks,
>
>
> Matt Fox
>
>

Reply via email to