2018-10-04 15:44:15 +03:00
|
|
|
type: bulk
|
|
|
|
args:
|
|
|
|
|
|
|
|
#Author table
|
2021-01-06 19:06:24 +03:00
|
|
|
|
2018-10-04 15:44:15 +03:00
|
|
|
- type: run_sql
|
|
|
|
args:
|
|
|
|
sql: |
|
|
|
|
create table author(
|
|
|
|
id serial primary key,
|
2020-12-02 17:12:06 +03:00
|
|
|
name text unique,
|
|
|
|
user_id int
|
2018-10-04 15:44:15 +03:00
|
|
|
);
|
|
|
|
CREATE TABLE article (
|
|
|
|
id SERIAL,
|
|
|
|
title TEXT,
|
|
|
|
version TEXT,
|
|
|
|
content TEXT,
|
|
|
|
author_id INTEGER REFERENCES author(id),
|
|
|
|
is_published BOOLEAN,
|
|
|
|
published_on TIMESTAMP,
|
|
|
|
PRIMARY KEY (id,version)
|
2020-03-10 15:45:47 +03:00
|
|
|
);
|
|
|
|
|
|
|
|
CREATE FUNCTION fetch_articles(search text, author_row author)
|
|
|
|
RETURNS SETOF article AS $$
|
|
|
|
SELECT *
|
|
|
|
FROM article
|
|
|
|
WHERE
|
|
|
|
( title ilike ('%' || search || '%')
|
|
|
|
OR content ilike ('%' || search || '%')
|
|
|
|
) AND author_id = author_row.id
|
|
|
|
$$ LANGUAGE sql STABLE;
|
2021-01-06 19:06:24 +03:00
|
|
|
CREATE TABLE person (
|
|
|
|
id SERIAL PRIMARY KEY,
|
|
|
|
details JSONB NOT NULL
|
|
|
|
);
|
|
|
|
CREATE TABLE resident (
|
|
|
|
id SERIAL PRIMARY KEY,
|
|
|
|
name TEXT NOT NULL,
|
|
|
|
age INTEGER NOT NULL,
|
|
|
|
city TEXT NOT NULL
|
|
|
|
);
|
|
|
|
create table "user" (
|
|
|
|
id serial primary key,
|
|
|
|
name text not null unique,
|
|
|
|
is_admin boolean default false
|
|
|
|
);
|
|
|
|
|
|
|
|
create table account (
|
|
|
|
id serial primary key,
|
|
|
|
account_no integer not null
|
|
|
|
);
|
|
|
|
|
|
|
|
- type: track_table
|
|
|
|
args:
|
|
|
|
schema: public
|
|
|
|
name: author
|
2020-03-10 15:45:47 +03:00
|
|
|
|
2021-01-06 19:06:24 +03:00
|
|
|
#Article table
|
2018-10-04 15:44:15 +03:00
|
|
|
- type: track_table
|
|
|
|
args:
|
|
|
|
schema: public
|
|
|
|
name: article
|
|
|
|
|
2020-03-10 15:45:47 +03:00
|
|
|
- type: add_computed_field
|
|
|
|
args:
|
|
|
|
table: author
|
|
|
|
name: get_articles
|
|
|
|
definition:
|
|
|
|
function: fetch_articles
|
|
|
|
table_argument: author_row
|
2018-10-04 15:44:15 +03:00
|
|
|
|
|
|
|
#Object relationship
|
|
|
|
- type: create_object_relationship
|
|
|
|
args:
|
|
|
|
table: article
|
|
|
|
name: author
|
|
|
|
using:
|
|
|
|
foreign_key_constraint_on: author_id
|
|
|
|
|
|
|
|
#Array relationship
|
|
|
|
- type: create_array_relationship
|
|
|
|
args:
|
|
|
|
table: author
|
|
|
|
name: articles
|
|
|
|
using:
|
|
|
|
foreign_key_constraint_on:
|
|
|
|
table: article
|
|
|
|
column: author_id
|
|
|
|
|
|
|
|
#Person table
|
|
|
|
|
|
|
|
- type: track_table
|
|
|
|
args:
|
|
|
|
schema: public
|
|
|
|
name: person
|
|
|
|
|
|
|
|
|
|
|
|
#Author select permission for user
|
|
|
|
- type: create_select_permission
|
|
|
|
args:
|
|
|
|
table: author
|
|
|
|
role: user
|
|
|
|
permission:
|
2020-12-02 17:12:06 +03:00
|
|
|
columns: [id, name]
|
2018-10-04 15:44:15 +03:00
|
|
|
filter:
|
|
|
|
id: X-HASURA-USER-ID
|
|
|
|
|
2020-03-10 15:45:47 +03:00
|
|
|
#Author update permission for user
|
|
|
|
- type: create_update_permission
|
|
|
|
args:
|
|
|
|
table: author
|
|
|
|
role: user
|
|
|
|
permission:
|
|
|
|
columns:
|
|
|
|
- name
|
|
|
|
filter:
|
|
|
|
id: X-Hasura-User-Id
|
|
|
|
|
2018-10-04 15:44:15 +03:00
|
|
|
#Article select permission for user
|
|
|
|
- type: create_select_permission
|
|
|
|
args:
|
|
|
|
table: article
|
|
|
|
role: user
|
|
|
|
permission:
|
|
|
|
columns: '*'
|
|
|
|
filter:
|
|
|
|
$or:
|
|
|
|
- author_id: X-HASURA-USER-ID
|
|
|
|
- is_published: true
|
|
|
|
|
|
|
|
#Article update permission for user
|
|
|
|
#Allow modifications only on unpublished articles
|
|
|
|
- type: create_update_permission
|
|
|
|
args:
|
|
|
|
table: article
|
|
|
|
role: user
|
|
|
|
permission:
|
|
|
|
columns:
|
|
|
|
- title
|
|
|
|
- content
|
|
|
|
- is_published
|
|
|
|
- published_on
|
|
|
|
- version
|
|
|
|
filter:
|
|
|
|
$and:
|
|
|
|
- author_id: X-HASURA-USER-ID
|
|
|
|
- is_published: false
|
2020-02-13 10:38:49 +03:00
|
|
|
check:
|
|
|
|
is_published: false
|
2018-10-04 15:44:15 +03:00
|
|
|
|
2019-02-11 15:45:30 +03:00
|
|
|
#Resident table
|
|
|
|
- type: track_table
|
|
|
|
args:
|
|
|
|
name: resident
|
|
|
|
schema: public
|
|
|
|
|
|
|
|
#Permissions
|
|
|
|
- type: create_select_permission
|
|
|
|
args:
|
|
|
|
table: resident
|
|
|
|
role: user1
|
|
|
|
permission:
|
|
|
|
filter: {}
|
|
|
|
columns: '*'
|
|
|
|
- type: create_update_permission
|
|
|
|
args:
|
|
|
|
table: resident
|
|
|
|
role: user1
|
|
|
|
permission:
|
|
|
|
filter: {}
|
|
|
|
columns: '*'
|
|
|
|
set:
|
|
|
|
city: melbourne
|
|
|
|
|
|
|
|
- type: create_select_permission
|
|
|
|
args:
|
|
|
|
table: resident
|
|
|
|
role: user2
|
|
|
|
permission:
|
|
|
|
filter: {}
|
|
|
|
columns: '*'
|
|
|
|
- type: create_update_permission
|
|
|
|
args:
|
|
|
|
table: resident
|
|
|
|
role: user2
|
|
|
|
permission:
|
|
|
|
filter: {}
|
|
|
|
columns: '*'
|
|
|
|
set:
|
|
|
|
city: X-Hasura-City
|
2019-09-05 10:34:53 +03:00
|
|
|
|
|
|
|
# Tables to test '_exist' field
|
|
|
|
- type: track_table
|
|
|
|
args:
|
|
|
|
name: user
|
|
|
|
schema: public
|
|
|
|
|
|
|
|
- type: track_table
|
|
|
|
args:
|
|
|
|
name: account
|
|
|
|
schema: public
|
|
|
|
|
|
|
|
- type: create_update_permission
|
|
|
|
args:
|
|
|
|
table: account
|
|
|
|
role: user
|
|
|
|
permission:
|
|
|
|
columns:
|
|
|
|
- account_no
|
|
|
|
filter:
|
|
|
|
_exists:
|
|
|
|
_table: user
|
|
|
|
_where:
|
|
|
|
id: X-Hasura-User-Id
|
|
|
|
is_admin: true
|
|
|
|
|
|
|
|
- type: create_select_permission
|
|
|
|
args:
|
|
|
|
table: account
|
|
|
|
role: user
|
|
|
|
permission:
|
|
|
|
columns:
|
|
|
|
- id
|
|
|
|
- account_no
|
|
|
|
filter:
|
|
|
|
_exists:
|
|
|
|
_table: user
|
|
|
|
_where:
|
|
|
|
id: X-Hasura-User-Id
|
|
|
|
is_admin: true
|