Module: PgRls::Database::Prepared

Defined in:
lib/pg_rls/database/prepared.rb

Overview

Prepare database for test unit

Class Method Summary collapse

Class Method Details

.grant_user_credentials(name: PgRls::SECURE_USERNAME, password: 'password') ⇒ Object



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# File 'lib/pg_rls/database/prepared.rb', line 8

def grant_user_credentials(name: PgRls::SECURE_USERNAME, password: 'password')
  return unless Rails.env.test? || PgRls.default_connection?

  PgRls.admin_execute <<-SQL
    DO
    $do$
    BEGIN
      IF NOT EXISTS (
        SELECT FROM pg_catalog.pg_roles AS r
        WHERE r.rolname = '#{name}') THEN

          CREATE USER #{name} WITH PASSWORD '#{password}';
      END IF;
    END
    $do$;
    GRANT USAGE ON SCHEMA public TO #{name};
    ALTER DEFAULT PRIVILEGES IN SCHEMA public
      GRANT SELECT, INSERT, UPDATE, DELETE
      ON TABLES TO #{name};
    GRANT SELECT, INSERT, UPDATE, DELETE
      ON ALL TABLES IN SCHEMA public
      TO #{name};
    GRANT USAGE, SELECT
      ON ALL SEQUENCES IN SCHEMA public
      TO #{name};
  SQL
end