Skip to content

pythian/bastion-proxy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

bastion

A solution to streamline user access to MySQL, allowing users to self-serve access using their LDAP credentials, while logging all access.

Table of Contents

  1. Prerequisites
  2. How to use
  3. MySQL
  4. Vault
  5. ProxySQL
  6. LDAP

Prerequisites

this repo

Docker installed (18.04.0-ce)

How to use

From the directory containing the docker-compose.yaml included in this repo, start the cluster:

docker-compose up -d 

Run the following to stop and destroy the cluster:

docker-compose down

Use Kitematic in Docker for Mac or Docker for Windows (recommended) or enter an example container like this:

docker exec -it app bash

Do all of the below on the app server unless otherwise indicated.

MySQL

For a single node of mysql, edit the image line (line 39) as needed for version. The latest mysql image is currently 8.0, and the configured image in the Docker configuration file is 5.7. To run 5.6, for example, edit the line to: image: dataindataout/mysql:5.6

Then start mysql replication on the ops container: source initiate_replication.sh mysqlprimary mysqlreplica

Using Vault

Initialize/unseal Vault

source initiate_vault.sh

Hello world

vault write secret/admin [email protected] password=mysecretpassword

Output

Success! Data written to: secret/admin

vault read secret/admin

Output

Key                 Value
---                 -----
refresh_interval    768h0m0s
email               [email protected]
password            mysecretpassword

Set up vault to save database credentials

vault mount database

Output Successfully mounted 'database' at 'database'!

Assuming the following connection string works: mysql -hmysqlprimary -uroot -ppassword

vault write database/config/mysql \
    plugin_name=mysql-database-plugin \
    connection_url="root:password@tcp(mysqlprimary:3306)/" \
    allowed_roles="readonly"

Expected output

The following warnings were returned from the Vault server:
* Read access to this endpoint should be controlled via ACLs as it will return the connection details as is, including passwords, if any.

Set up credentials for expirable user/role

Write to roles; don't replace the name and password placeholders.

vault write database/roles/readonly \
    db_name=mysql \
    creation_statements="CREATE USER '{{name}}'@'%' IDENTIFIED BY '{{password}}';GRANT SELECT ON *.* TO '{{name}}'@'%';" \
    default_ttl="1h" \
    max_ttl="24h"

Output Success! Data written to: database/roles/readonly

Read from credentials to get user/pass

There is an API to do this, and all of this, programmatically.

vault read database/creds/readonly

Output

Key             Value
---             -----
lease_id        database/creds/readonly/a582cdcc-53b0-0bbb-2bf1-570926f65294
lease_duration  1h0m0s
lease_renewable true
password        A1a-w82s717qy2q26r80
username        v-root-readonly-p0p409z36t7zt4p1

Test login with this user

mysql -hmysqlprimary -uv-root-readonly-p0p409z36t7zt4p1 -pA1a-w82s717qy2q26r80

Using ProxySQL

Create ProxySQL monitor user

source initiate_proxysql.sh

Add login to ProxySQL

mysql -hproxysql -uadmin -padmin -P6032

insert into mysql_users (username,password) values ("v-root-readonly-p0p409z36t7zt4p1","A1a-w82s717qy2q26r80");
LOAD MYSQL USERS TO RUNTIME;
SAVE MYSQL USERS TO DISK;

Connect via ProxySQL

mysql -hproxysql -P3306 -uv-root-readonly-p0p409z36t7zt4p1 -pA1a-w82s717qy2q26r80

Do the user addition programmatically

source create_user.sh

LDAP

Install LDAP packages

source install_ldap.sh

Using web interface

Visit http://localhost:8080 in the browser.

Login as: user = cn=admin,dc=proxysql,dc=com and password = password

Create two OU (groups, users), two posix accounts under groups (developer, bi), and one user account (e.g., vthompson) under users. See the walkthrough on the blog post ____________________ for screenshots and more details on setting up LDAP.

Test from app server

Get IP address to use in statement below:

docker inspect --format='{{ .NetworkSettings.Networks.adjacents_default.IPAddress }}' openldap

ldapwhoami -vvv -H ldap://172.18.0.5 -D cn=vthompson,ou=users,dc=proxysql,dc=com -x -wpassword

Get info for this user

ldapsearch -LL -H ldap://172.18.0.5 -b "ou=users,dc=proxysql,dc=com" -D "cn=admin,dc=proxysql,dc=com" -w "password"

Create and connect ldap backend, test

vault auth-enable ldap

vault auth -methods

vault write auth/ldap/config \
  url="ldap://172.18.0.5" \
  binddn="cn=admin,dc=proxysql,dc=com" \
  bindpass="password" \
  userattr="uid" \
  userdn="ou=users,dc=proxysql,dc=com" \
  discoverdn=true \
  groupdn="ou=groups,dc=proxysql,dc=com" \
  insecure_tls=true

vault write auth/ldap/groups/developer policies=developer

vault write auth/ldap/users/vthompson groups=developer

vault auth -method=ldap username=vthompson
[enter password at command prompt]

And now experiment!

About

Example bastion to lockdown MySQL access

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published