2016-08-25 01:46:29 +03:00
|
|
|
-- Users ---------------------------------------------------------------------------
|
|
|
|
|
2017-01-15 22:26:33 +02:00
|
|
|
-- :name create-user! :<! :1
|
2016-08-21 00:36:09 +03:00
|
|
|
-- :doc creates a new user record
|
|
|
|
INSERT INTO users
|
2017-03-22 22:20:52 +02:00
|
|
|
(id, login, name, email, avatar_url, address, created)
|
2017-01-15 22:26:33 +02:00
|
|
|
SELECT
|
|
|
|
:id,
|
|
|
|
:login,
|
|
|
|
:name,
|
|
|
|
:email,
|
2017-02-12 22:25:32 +02:00
|
|
|
:avatar_url,
|
2017-01-15 22:26:33 +02:00
|
|
|
:address,
|
|
|
|
:created
|
|
|
|
WHERE NOT exists(SELECT 1
|
|
|
|
FROM users
|
|
|
|
WHERE id = :id)
|
2017-03-23 08:29:40 +02:00
|
|
|
RETURNING id, login, name, email, avatar_url, address, created;
|
2016-08-21 00:36:09 +03:00
|
|
|
|
|
|
|
-- :name update-user! :! :n
|
2016-08-25 01:46:29 +03:00
|
|
|
-- :doc updates an existing user record
|
2016-08-21 00:36:09 +03:00
|
|
|
UPDATE users
|
2017-02-24 11:05:13 +02:00
|
|
|
SET login = :login,
|
|
|
|
name = :name,
|
|
|
|
email = :email,
|
|
|
|
address = :address
|
2016-08-22 03:22:39 +03:00
|
|
|
WHERE id = :id;
|
|
|
|
|
|
|
|
-- :name update-user-address! :! :n
|
|
|
|
UPDATE users
|
|
|
|
SET address = :address
|
2016-08-28 23:16:45 +03:00
|
|
|
WHERE id = :id;
|
2016-08-21 00:36:09 +03:00
|
|
|
|
|
|
|
-- :name get-user :? :1
|
2017-03-01 22:09:48 +02:00
|
|
|
-- :doc retrieve a user given the user-id.
|
2016-08-22 03:22:39 +03:00
|
|
|
SELECT *
|
|
|
|
FROM users
|
2016-08-28 23:16:45 +03:00
|
|
|
WHERE id = :id;
|
2016-08-21 00:36:09 +03:00
|
|
|
|
2016-09-09 03:35:28 +03:00
|
|
|
-- :name get-repo-owner :? :1
|
|
|
|
SELECT *
|
2017-02-24 11:05:13 +02:00
|
|
|
FROM users u, repositories r
|
|
|
|
WHERE r.repo_id = :repo_id
|
|
|
|
AND r.user_id = u.id;
|
2016-09-09 03:35:28 +03:00
|
|
|
|
2016-08-25 01:46:29 +03:00
|
|
|
-- Repositories --------------------------------------------------------------------
|
|
|
|
|
2017-02-18 11:07:51 +02:00
|
|
|
-- :name set-repo-state! :<! :1
|
|
|
|
-- :doc sets repository to given state
|
2016-08-25 01:46:29 +03:00
|
|
|
UPDATE repositories
|
2017-02-18 11:07:51 +02:00
|
|
|
SET state = :state
|
2016-08-25 01:46:29 +03:00
|
|
|
WHERE repo_id = :repo_id
|
2017-03-01 22:09:48 +02:00
|
|
|
RETURNING repo_id, owner, repo, state, hook_id;
|
2017-02-18 11:07:51 +02:00
|
|
|
|
|
|
|
|
|
|
|
-- :name get-repo :? :1
|
2017-03-01 22:09:48 +02:00
|
|
|
-- :doc retrieve a repository given owner and repo-name
|
2017-02-18 11:07:51 +02:00
|
|
|
SELECT *
|
|
|
|
FROM repositories
|
2017-03-01 22:09:48 +02:00
|
|
|
WHERE owner = :owner
|
2017-02-18 11:07:51 +02:00
|
|
|
AND repo = :repo;
|
|
|
|
|
2016-08-25 01:46:29 +03:00
|
|
|
|
|
|
|
-- :name create-repository! :<! :1
|
|
|
|
-- :doc creates repository if not exists
|
2017-03-16 22:37:07 +02:00
|
|
|
INSERT INTO repositories (repo_id, user_id, owner, repo, state, owner_avatar_url)
|
2016-08-25 01:46:29 +03:00
|
|
|
SELECT
|
|
|
|
:repo_id,
|
2016-08-30 01:03:09 +03:00
|
|
|
:user_id,
|
2017-03-01 22:09:48 +02:00
|
|
|
:owner,
|
2016-08-25 01:46:29 +03:00
|
|
|
:repo,
|
2017-03-16 22:37:07 +02:00
|
|
|
:state,
|
|
|
|
:owner_avatar_url
|
2016-08-25 01:46:29 +03:00
|
|
|
WHERE NOT exists(SELECT 1
|
|
|
|
FROM repositories
|
|
|
|
WHERE repo_id = :repo_id)
|
2017-03-16 22:37:07 +02:00
|
|
|
RETURNING repo_id, user_id, owner, repo, state, owner_avatar_url;
|
2016-08-25 01:46:29 +03:00
|
|
|
|
|
|
|
-- :name get-enabled-repositories :? :*
|
2017-03-01 22:09:48 +02:00
|
|
|
-- :doc returns enabled repositories for a given user-id
|
2016-08-25 01:46:29 +03:00
|
|
|
SELECT repo_id
|
|
|
|
FROM repositories
|
2017-02-18 11:07:51 +02:00
|
|
|
WHERE user_id = :user_id
|
|
|
|
AND state = 2;
|
|
|
|
|
2016-08-26 04:10:05 +03:00
|
|
|
|
2017-06-13 10:02:58 +03:00
|
|
|
-- :name get-issue-titles :? :*
|
|
|
|
SELECT i.title, i.issue_number, r.repo, r.owner
|
|
|
|
FROM issues i, repositories r
|
|
|
|
WHERE i.repo_id = r.repo_id;
|
|
|
|
|
2017-10-31 12:05:41 -05:00
|
|
|
-- :name get-issues-count :? :1
|
|
|
|
SELECT COUNT(*)
|
2017-10-31 14:50:27 -05:00
|
|
|
FROM issues i
|
|
|
|
WHERE i.repo_id = :repo_id
|
|
|
|
AND i.confirm_hash is null
|
|
|
|
AND i.is_open = true;
|
2017-06-13 10:02:58 +03:00
|
|
|
|
2017-02-18 11:07:51 +02:00
|
|
|
-- :name update-repo-generic :! :n
|
|
|
|
/* :require [clojure.string :as string]
|
|
|
|
[hugsql.parameters :refer [identifier-param-quote]] */
|
2016-08-26 04:10:05 +03:00
|
|
|
UPDATE repositories
|
2017-02-18 11:07:51 +02:00
|
|
|
SET
|
|
|
|
/*~
|
|
|
|
(string/join ","
|
|
|
|
(for [[field _] (:updates params)]
|
|
|
|
(str (identifier-param-quote (name field) options)
|
|
|
|
" = :v:updates." (name field))))
|
|
|
|
~*/
|
|
|
|
where repo_id = :repo_id;
|
|
|
|
|
|
|
|
|
2016-08-28 23:16:45 +03:00
|
|
|
|
|
|
|
-- Issues --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
-- :name create-issue! :! :n
|
|
|
|
-- :doc creates issue
|
2016-09-06 03:18:33 +03:00
|
|
|
INSERT INTO issues (repo_id, issue_id, issue_number, title)
|
2016-08-28 23:16:45 +03:00
|
|
|
SELECT
|
|
|
|
:repo_id,
|
|
|
|
:issue_id,
|
|
|
|
:issue_number,
|
2016-09-06 03:18:33 +03:00
|
|
|
:title
|
2016-08-28 23:16:45 +03:00
|
|
|
WHERE NOT exists(SELECT 1
|
|
|
|
FROM issues
|
|
|
|
WHERE repo_id = :repo_id AND issue_id = :issue_id);
|
|
|
|
|
2017-02-26 23:40:59 +02:00
|
|
|
-- :name update-commit-sha :<! :1
|
|
|
|
-- :doc updates issue with commit_sha
|
2016-08-28 23:16:45 +03:00
|
|
|
UPDATE issues
|
2017-11-02 12:41:27 +02:00
|
|
|
SET commit_sha = :commit_sha
|
2016-08-28 23:16:45 +03:00
|
|
|
WHERE issue_id = :issue_id
|
2017-02-26 23:40:59 +02:00
|
|
|
RETURNING repo_id, issue_id, issue_number, title, commit_sha, contract_address;
|
2016-09-06 03:18:33 +03:00
|
|
|
|
|
|
|
-- :name update-transaction-hash :! :n
|
|
|
|
-- :doc updates transaction-hash for a given issue
|
|
|
|
UPDATE issues
|
2017-11-02 12:41:27 +02:00
|
|
|
SET transaction_hash = :transaction_hash
|
2016-09-06 03:18:33 +03:00
|
|
|
WHERE issue_id = :issue_id;
|
|
|
|
|
2017-02-24 11:05:13 +02:00
|
|
|
|
|
|
|
-- TODO: this is terrible
|
2016-09-07 03:20:17 +03:00
|
|
|
-- :name update-contract-address :<! :1
|
2016-09-06 03:18:33 +03:00
|
|
|
-- :doc updates contract-address for a given issue
|
2016-09-07 03:20:17 +03:00
|
|
|
WITH t AS (
|
|
|
|
SELECT
|
|
|
|
i.issue_id AS issue_id,
|
|
|
|
i.issue_number AS issue_number,
|
|
|
|
i.title AS title,
|
|
|
|
i.transaction_hash AS transaction_hash,
|
|
|
|
i.contract_address AS contract_address,
|
2017-03-06 20:33:42 +02:00
|
|
|
i.comment_id AS comment_id,
|
2016-09-09 03:35:28 +03:00
|
|
|
i.repo_id AS repo_id,
|
2017-03-01 22:09:48 +02:00
|
|
|
r.owner AS owner,
|
2016-09-07 03:20:17 +03:00
|
|
|
r.repo AS repo
|
2017-02-24 11:05:13 +02:00
|
|
|
FROM issues i, repositories r
|
|
|
|
WHERE r.repo_id = i.repo_id
|
|
|
|
AND i.issue_id = :issue_id
|
2016-09-07 03:20:17 +03:00
|
|
|
)
|
|
|
|
UPDATE issues i
|
2017-02-26 23:40:59 +02:00
|
|
|
SET contract_address = :contract_address,
|
|
|
|
updated = timezone('utc'::text, now())
|
2016-09-07 03:20:17 +03:00
|
|
|
FROM t
|
2016-09-20 00:43:32 +03:00
|
|
|
WHERE i.issue_id = :issue_id
|
2017-03-06 20:33:42 +02:00
|
|
|
RETURNING t.issue_id, t.issue_number, t.title, t.transaction_hash, t.comment_id, i.contract_address, t.owner, t.repo, t.repo_id;
|
2016-09-06 03:18:33 +03:00
|
|
|
|
2016-09-12 19:50:32 +03:00
|
|
|
-- :name update-comment-id :! :n
|
2016-09-12 19:44:29 +03:00
|
|
|
-- :doc updates comment-id for a given issue
|
|
|
|
UPDATE issues
|
2017-02-26 23:40:59 +02:00
|
|
|
SET comment_id = :comment_id,
|
|
|
|
updated = timezone('utc'::text, now())
|
2016-09-12 19:44:29 +03:00
|
|
|
WHERE issue_id = :issue_id;
|
|
|
|
|
2017-06-13 10:02:58 +03:00
|
|
|
-- :name update-issue-title :! :n
|
|
|
|
-- :doc updates title for a given issue-id
|
|
|
|
UPDATE issues
|
|
|
|
SET title = :title
|
|
|
|
WHERE issue_id = :issue_id;
|
|
|
|
|
2016-09-06 03:18:33 +03:00
|
|
|
-- :name list-pending-deployments :? :*
|
|
|
|
-- :doc retrieves pending transaction ids
|
|
|
|
SELECT
|
2017-05-31 10:02:07 +03:00
|
|
|
i.issue_id as issue_id,
|
|
|
|
i.transaction_hash as transaction_hash,
|
|
|
|
u.address as owner_address
|
|
|
|
FROM issues i, users u, repositories r
|
|
|
|
WHERE r.user_id = u.id
|
|
|
|
AND i.repo_id = r.repo_id
|
|
|
|
AND i.contract_address IS NULL
|
|
|
|
AND i.transaction_hash IS NOT NULL;
|
2016-08-28 23:16:45 +03:00
|
|
|
|
2017-05-31 10:44:45 +03:00
|
|
|
|
|
|
|
-- :name list-failed-deployments :? :*
|
|
|
|
-- :doc retrieves failed contract deployments
|
|
|
|
SELECT
|
|
|
|
i.issue_id as issue_id,
|
|
|
|
i.transaction_hash as transaction_hash,
|
|
|
|
u.address as owner_address
|
|
|
|
FROM issues i, users u, repositories r
|
|
|
|
WHERE r.user_id = u.id
|
|
|
|
AND i.repo_id = r.repo_id
|
|
|
|
AND i.contract_address IS NULL
|
|
|
|
AND i.transaction_hash IS NOT NULL
|
2017-05-31 11:27:48 +03:00
|
|
|
AND i.updated < now() at time zone 'UTC' - interval '1 hour';
|
2017-05-31 10:44:45 +03:00
|
|
|
|
|
|
|
|
2016-08-28 23:16:45 +03:00
|
|
|
-- Pull Requests -------------------------------------------------------------------
|
|
|
|
|
2017-02-24 11:05:13 +02:00
|
|
|
-- :name save-pull-request! :! :n
|
|
|
|
-- :doc inserts or updates a pull request record
|
|
|
|
INSERT INTO pull_requests (pr_id,
|
|
|
|
repo_id,
|
|
|
|
pr_number,
|
|
|
|
issue_number,
|
2017-02-25 00:15:44 +02:00
|
|
|
issue_id,
|
2017-02-26 23:40:59 +02:00
|
|
|
commit_sha,
|
2017-02-24 11:05:13 +02:00
|
|
|
user_id,
|
|
|
|
state)
|
|
|
|
VALUES(:pr_id,
|
|
|
|
:repo_id,
|
|
|
|
:pr_number,
|
|
|
|
:issue_number,
|
2017-02-25 00:15:44 +02:00
|
|
|
:issue_id,
|
2017-02-26 23:40:59 +02:00
|
|
|
:commit_sha,
|
2017-02-24 11:05:13 +02:00
|
|
|
:user_id,
|
|
|
|
:state)
|
|
|
|
ON CONFLICT (pr_id) DO UPDATE
|
|
|
|
SET
|
|
|
|
state = :state,
|
2017-02-25 00:15:44 +02:00
|
|
|
updated = timezone('utc'::text, now()),
|
2017-02-26 23:40:59 +02:00
|
|
|
commit_sha = :commit_sha;
|
2016-08-28 23:16:45 +03:00
|
|
|
|
|
|
|
-- Bounties ------------------------------------------------------------------------
|
|
|
|
|
2017-03-12 19:50:05 +02:00
|
|
|
|
|
|
|
-- :name pending-contracts :? :*
|
|
|
|
-- :doc bounty issues where deploy contract has failed
|
|
|
|
SELECT
|
|
|
|
i.issue_id AS issue_id,
|
|
|
|
u.address AS owner_address
|
|
|
|
FROM issues i, users u, repositories r
|
|
|
|
WHERE
|
|
|
|
r.user_id = u.id
|
|
|
|
AND i.repo_id = r.repo_id
|
|
|
|
AND i.transaction_hash IS NULL
|
|
|
|
AND i.contract_address IS NULL;
|
|
|
|
|
|
|
|
|
2017-03-19 16:07:42 +02:00
|
|
|
-- :name pending-bounties :? :*
|
2017-03-19 22:13:09 +02:00
|
|
|
-- :doc bounties with merged pull-requests awaiting to be signed
|
2016-09-10 02:06:56 +03:00
|
|
|
SELECT
|
|
|
|
i.contract_address AS contract_address,
|
2017-03-19 22:13:09 +02:00
|
|
|
r.owner AS owner,
|
|
|
|
r.repo AS repo,
|
|
|
|
i.comment_id AS comment_id,
|
|
|
|
i.issue_number AS issue_number,
|
2016-09-10 02:06:56 +03:00
|
|
|
i.issue_id AS issue_id,
|
2017-08-23 23:47:50 +03:00
|
|
|
i.balance_eth AS balance_eth,
|
2017-08-22 16:45:10 +03:00
|
|
|
i.tokens AS tokens,
|
2017-08-23 23:47:50 +03:00
|
|
|
i.value_usd AS value_usd,
|
2017-03-19 22:13:09 +02:00
|
|
|
u.login AS winner_login,
|
2016-09-10 02:06:56 +03:00
|
|
|
u.address AS payout_address
|
2017-03-19 22:13:09 +02:00
|
|
|
FROM issues i, pull_requests p, users u, repositories r
|
2017-02-24 11:05:13 +02:00
|
|
|
WHERE
|
2017-02-25 00:15:44 +02:00
|
|
|
p.issue_id = i.issue_id
|
2017-02-24 11:05:13 +02:00
|
|
|
AND p.repo_id = i.repo_id
|
2017-03-19 22:13:09 +02:00
|
|
|
AND p.commit_sha = i.commit_sha
|
|
|
|
AND r.repo_id = i.repo_id
|
2017-02-24 11:05:13 +02:00
|
|
|
AND u.id = p.user_id
|
|
|
|
AND i.execute_hash IS NULL;
|
2016-10-01 15:29:18 +03:00
|
|
|
|
2017-03-19 16:07:42 +02:00
|
|
|
-- :name pending-payouts :? :*
|
2017-06-13 19:26:48 +03:00
|
|
|
-- :doc recently closed issues awaiting for bot confirmation to be mined
|
2016-10-01 15:29:18 +03:00
|
|
|
SELECT
|
|
|
|
i.contract_address AS contract_address,
|
|
|
|
i.issue_id AS issue_id,
|
2017-02-25 00:15:44 +02:00
|
|
|
u.address AS payout_address,
|
|
|
|
i.execute_hash AS execute_hash
|
2017-02-24 11:05:13 +02:00
|
|
|
FROM issues i, pull_requests p, users u
|
|
|
|
WHERE
|
2017-02-25 00:15:44 +02:00
|
|
|
p.issue_id = i.issue_id
|
2017-02-24 11:05:13 +02:00
|
|
|
AND p.repo_id = i.repo_id
|
|
|
|
AND u.id = p.user_id
|
|
|
|
AND i.confirm_hash IS NULL
|
|
|
|
AND i.execute_hash IS NOT NULL;
|
2016-09-10 02:06:56 +03:00
|
|
|
|
2017-03-19 16:07:42 +02:00
|
|
|
-- :name confirmed-payouts :? :*
|
2016-10-04 03:13:43 +03:00
|
|
|
-- :doc lists all recently confirmed bounty payouts
|
|
|
|
SELECT
|
|
|
|
i.contract_address AS contract_address,
|
2017-03-19 17:10:56 +02:00
|
|
|
r.owner AS owner,
|
|
|
|
r.repo AS repo,
|
|
|
|
i.comment_id AS comment_id,
|
|
|
|
i.issue_number AS issue_number,
|
2016-10-04 03:13:43 +03:00
|
|
|
i.issue_id AS issue_id,
|
2017-08-23 23:47:50 +03:00
|
|
|
i.balance_eth AS balance_eth,
|
2017-08-22 16:45:10 +03:00
|
|
|
i.tokens AS tokens,
|
2017-08-23 23:47:50 +03:00
|
|
|
i.value_usd AS value_usd,
|
2017-02-25 00:15:44 +02:00
|
|
|
u.address AS payout_address,
|
2017-03-19 17:10:56 +02:00
|
|
|
u.login AS payee_login,
|
2017-08-31 11:33:08 +03:00
|
|
|
i.confirm_hash AS confirm_hash,
|
2017-09-15 10:24:55 +03:00
|
|
|
i.payout_hash AS payout_hash,
|
|
|
|
i.updated AS updated
|
2017-03-19 17:10:56 +02:00
|
|
|
FROM issues i, pull_requests p, users u, repositories r
|
2017-02-24 11:05:13 +02:00
|
|
|
WHERE
|
2017-02-25 00:15:44 +02:00
|
|
|
p.issue_id = i.issue_id
|
2017-02-24 11:05:13 +02:00
|
|
|
AND p.repo_id = i.repo_id
|
2017-03-19 17:10:56 +02:00
|
|
|
AND r.repo_id = i.repo_id
|
2017-02-24 11:05:13 +02:00
|
|
|
AND u.id = p.user_id
|
|
|
|
AND i.payout_receipt IS NULL
|
|
|
|
AND i.payout_hash IS NOT NULL;
|
2016-10-04 03:13:43 +03:00
|
|
|
|
2016-09-10 02:06:56 +03:00
|
|
|
-- :name update-confirm-hash :! :n
|
2016-10-01 15:29:18 +03:00
|
|
|
-- :doc updates issue with confirmation hash
|
2016-09-10 02:06:56 +03:00
|
|
|
UPDATE issues
|
2017-02-26 23:40:59 +02:00
|
|
|
SET confirm_hash = :confirm_hash,
|
|
|
|
updated = timezone('utc'::text, now())
|
2016-09-10 02:06:56 +03:00
|
|
|
WHERE issue_id = :issue_id;
|
|
|
|
|
2016-10-01 15:29:18 +03:00
|
|
|
-- :name update-execute-hash :! :n
|
|
|
|
-- :doc updates issue with execute transaction hash
|
|
|
|
UPDATE issues
|
2017-02-26 23:40:59 +02:00
|
|
|
SET execute_hash = :execute_hash,
|
|
|
|
updated = timezone('utc'::text, now())
|
2016-10-01 15:29:18 +03:00
|
|
|
WHERE issue_id = :issue_id;
|
|
|
|
|
2017-11-02 15:48:40 +02:00
|
|
|
-- :name update-winner-login :! :n
|
|
|
|
UPDATE issues
|
|
|
|
SET winner_login = :winner_login
|
|
|
|
WHERE issue_id = :issue_id;
|
|
|
|
|
2016-10-04 03:13:43 +03:00
|
|
|
-- :name update-payout-hash :! :n
|
|
|
|
-- :doc updates issue with payout transaction hash
|
|
|
|
UPDATE issues
|
2017-02-26 23:40:59 +02:00
|
|
|
SET payout_hash = :payout_hash,
|
|
|
|
updated = timezone('utc'::text, now())
|
2016-10-04 03:13:43 +03:00
|
|
|
WHERE issue_id = :issue_id;
|
|
|
|
|
2017-09-15 10:24:55 +03:00
|
|
|
-- :name reset-payout-hash :! :n
|
|
|
|
-- :doc sets issue's payout transaction hash to NULL
|
|
|
|
UPDATE issues
|
2017-11-02 15:48:40 +02:00
|
|
|
SET payout_hash = NULL,
|
|
|
|
winner_login = NULL
|
2017-09-15 10:24:55 +03:00
|
|
|
WHERE issue_id = :issue_id;
|
|
|
|
|
|
|
|
|
2016-10-04 03:13:43 +03:00
|
|
|
-- :name update-payout-receipt :! :n
|
|
|
|
-- :doc updates issue with payout transaction receipt
|
|
|
|
UPDATE issues
|
2017-03-09 21:50:57 +02:00
|
|
|
SET payout_receipt = :payout_receipt::jsonb,
|
2017-02-26 23:40:59 +02:00
|
|
|
updated = timezone('utc'::text, now())
|
2016-10-04 03:13:43 +03:00
|
|
|
WHERE issue_id = :issue_id;
|
|
|
|
|
2016-09-19 23:26:57 +03:00
|
|
|
|
2017-08-22 16:45:10 +03:00
|
|
|
-- :name update-token-balances :! :n
|
|
|
|
-- :doc updates issue with given token balances
|
|
|
|
UPDATE issues
|
|
|
|
SET tokens = :token_balances::jsonb,
|
|
|
|
updated = timezone('utc'::text, now())
|
|
|
|
WHERE contract_address = :contract_address;
|
|
|
|
|
|
|
|
|
2017-08-22 20:27:01 +03:00
|
|
|
-- :name update-usd-value :! :n
|
|
|
|
-- :doc updates issue with given USD value
|
|
|
|
UPDATE issues
|
2017-08-22 22:15:40 +03:00
|
|
|
SET value_usd = :usd_value,
|
|
|
|
value_usd_updated = timezone('utc'::text, now())
|
2017-08-22 20:27:01 +03:00
|
|
|
WHERE contract_address = :contract_address;
|
|
|
|
|
|
|
|
|
2017-09-13 11:09:48 +03:00
|
|
|
-- :name update-issue-open :! :n
|
|
|
|
-- :doc updates issue's open status
|
|
|
|
UPDATE issues
|
|
|
|
SET is_open = :is_open
|
|
|
|
WHERE issue_id = :issue_id;
|
|
|
|
|
|
|
|
|
|
|
|
-- :name issue-exists :1
|
2017-09-13 11:20:11 +03:00
|
|
|
-- :doc returns true if given issue exists
|
2017-09-13 11:09:48 +03:00
|
|
|
SELECT exists(SELECT 1
|
|
|
|
FROM issues
|
|
|
|
WHERE issue_id = :issue_id);
|
|
|
|
|
|
|
|
|
2017-03-17 22:59:03 +02:00
|
|
|
-- :name open-bounties :? :*
|
|
|
|
-- :doc all bounty issues for given owner
|
|
|
|
SELECT
|
|
|
|
i.contract_address AS contract_address,
|
|
|
|
i.issue_id AS issue_id,
|
|
|
|
i.issue_number AS issue_number,
|
|
|
|
i.title AS issue_title,
|
|
|
|
i.repo_id AS repo_id,
|
2017-08-23 23:47:50 +03:00
|
|
|
i.balance_eth AS balance_eth,
|
2017-08-22 16:45:10 +03:00
|
|
|
i.tokens AS tokens,
|
2017-08-23 23:47:50 +03:00
|
|
|
i.value_usd AS value_usd,
|
2017-03-17 22:59:03 +02:00
|
|
|
i.confirm_hash AS confirm_hash,
|
|
|
|
i.payout_hash AS payout_hash,
|
|
|
|
i.payout_receipt AS payout_receipt,
|
|
|
|
i.updated AS updated,
|
|
|
|
r.owner AS repo_owner,
|
|
|
|
r.owner_avatar_url AS repo_owner_avatar_url,
|
|
|
|
r.repo AS repo_name
|
|
|
|
FROM issues i, repositories r
|
|
|
|
WHERE
|
|
|
|
r.repo_id = i.repo_id
|
|
|
|
AND i.confirm_hash is null
|
2017-10-29 20:05:51 +02:00
|
|
|
AND i.is_open = true
|
2017-10-30 22:19:01 +02:00
|
|
|
ORDER BY updated desc;
|
2017-03-17 22:59:03 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
-- :name owner-bounties :? :*
|
2017-02-25 00:15:44 +02:00
|
|
|
-- :doc all bounty issues for given owner
|
2016-08-28 23:16:45 +03:00
|
|
|
SELECT
|
2016-09-06 03:18:33 +03:00
|
|
|
i.contract_address AS contract_address,
|
|
|
|
i.issue_id AS issue_id,
|
|
|
|
i.issue_number AS issue_number,
|
|
|
|
i.title AS issue_title,
|
|
|
|
i.repo_id AS repo_id,
|
2017-08-22 16:45:10 +03:00
|
|
|
i.balance_eth AS balance_eth,
|
|
|
|
i.tokens AS tokens,
|
2017-08-23 23:47:50 +03:00
|
|
|
i.value_usd AS value_usd,
|
2016-09-22 03:44:45 +03:00
|
|
|
i.confirm_hash AS confirm_hash,
|
2016-10-04 03:13:43 +03:00
|
|
|
i.payout_hash AS payout_hash,
|
|
|
|
i.payout_receipt AS payout_receipt,
|
2017-02-27 22:38:41 +02:00
|
|
|
i.updated AS updated,
|
2017-11-02 16:39:59 +02:00
|
|
|
i.winner_login AS winner_login,
|
2017-02-25 00:15:44 +02:00
|
|
|
r.repo AS repo_name,
|
|
|
|
o.address AS owner_address
|
|
|
|
FROM issues i, users o, repositories r
|
|
|
|
WHERE
|
|
|
|
r.repo_id = i.repo_id
|
|
|
|
AND r.user_id = o.id
|
|
|
|
AND r.user_id = :owner_id;
|
|
|
|
|
|
|
|
|
|
|
|
-- :name bounty-claims :? :*
|
|
|
|
-- :doc open, merged and closed PRs referencing given bounty issue
|
|
|
|
SELECT
|
|
|
|
i.contract_address AS contract_address,
|
|
|
|
i.issue_id AS issue_id,
|
|
|
|
i.issue_number AS issue_number,
|
|
|
|
i.title AS issue_title,
|
|
|
|
i.repo_id AS repo_id,
|
2017-08-23 23:47:50 +03:00
|
|
|
i.balance_eth AS balance_eth,
|
2017-08-22 16:45:10 +03:00
|
|
|
i.tokens AS tokens,
|
2017-08-23 23:47:50 +03:00
|
|
|
i.value_usd AS value_usd,
|
2017-02-25 00:15:44 +02:00
|
|
|
i.confirm_hash AS confirm_hash,
|
|
|
|
i.payout_hash AS payout_hash,
|
|
|
|
i.payout_receipt AS payout_receipt,
|
|
|
|
p.state AS pr_state,
|
2016-09-06 03:18:33 +03:00
|
|
|
p.pr_id AS pr_id,
|
|
|
|
p.user_id AS user_id,
|
|
|
|
p.pr_number AS pr_number,
|
|
|
|
u.address AS payout_address,
|
|
|
|
u.login AS user_login,
|
|
|
|
u.name AS user_name,
|
2017-02-25 00:15:44 +02:00
|
|
|
u.avatar_url AS user_avatar_url,
|
2017-03-01 22:09:48 +02:00
|
|
|
r.owner AS repo_owner,
|
2016-09-22 03:44:45 +03:00
|
|
|
r.repo AS repo_name,
|
|
|
|
o.address AS owner_address
|
2017-02-24 11:05:13 +02:00
|
|
|
FROM issues i, pull_requests p, users u, users o, repositories r
|
|
|
|
WHERE
|
2017-02-25 00:15:44 +02:00
|
|
|
p.issue_id = i.issue_id
|
2017-02-24 11:05:13 +02:00
|
|
|
AND p.repo_id = i.repo_id
|
|
|
|
AND u.id = p.user_id
|
|
|
|
AND r.repo_id = i.repo_id
|
|
|
|
AND r.user_id = o.id
|
2017-02-25 00:15:44 +02:00
|
|
|
AND i.issue_id = :issue_id;
|
|
|
|
|
|
|
|
|
2017-02-24 11:05:13 +02:00
|
|
|
-- :name open-bounty-contracts :? :*
|
|
|
|
-- :doc bounty issues with mined bounty contracts
|
2016-09-12 19:44:29 +03:00
|
|
|
SELECT
|
|
|
|
i.contract_address AS contract_address,
|
2017-03-01 22:09:48 +02:00
|
|
|
r.owner AS owner,
|
2016-09-12 19:44:29 +03:00
|
|
|
r.repo AS repo,
|
|
|
|
i.comment_id AS comment_id,
|
2017-02-21 10:49:25 +02:00
|
|
|
i.issue_number AS issue_number,
|
|
|
|
i.issue_id AS issue_id,
|
2017-08-23 23:47:50 +03:00
|
|
|
i.balance_eth AS balance_eth,
|
|
|
|
i.tokens AS tokens,
|
|
|
|
i.value_usd AS value_usd
|
2017-02-24 11:05:13 +02:00
|
|
|
FROM issues i, repositories r
|
|
|
|
WHERE r.repo_id = i.repo_id
|
|
|
|
AND contract_address IS NOT NULL
|
|
|
|
AND i.payout_hash IS NULL;
|
2016-09-10 09:50:13 +03:00
|
|
|
|
2017-02-21 10:49:25 +02:00
|
|
|
-- :name get-bounty :? :1
|
2017-02-24 11:05:13 +02:00
|
|
|
-- :doc details for a bounty issue given owner, repo and issue nunber
|
2016-09-12 02:15:59 +03:00
|
|
|
SELECT
|
|
|
|
i.contract_address AS contract_address,
|
2017-02-21 10:49:25 +02:00
|
|
|
i.issue_id AS issue_id,
|
2016-09-12 02:15:59 +03:00
|
|
|
i.issue_number AS issue_number,
|
2017-08-23 23:47:50 +03:00
|
|
|
i.balance_eth AS balance_eth,
|
2017-08-22 16:45:10 +03:00
|
|
|
i.tokens AS tokens,
|
2017-08-23 23:47:50 +03:00
|
|
|
i.value_usd AS value_usd,
|
2017-03-01 22:09:48 +02:00
|
|
|
r.owner AS owner,
|
2017-02-25 00:15:44 +02:00
|
|
|
r.repo AS repo
|
2017-02-24 11:05:13 +02:00
|
|
|
FROM issues i, repositories r
|
2016-09-10 09:50:13 +03:00
|
|
|
WHERE i.issue_number = :issue_number
|
2017-02-24 11:05:13 +02:00
|
|
|
AND r.repo_id = i.repo_id
|
2017-03-01 22:09:48 +02:00
|
|
|
AND r.owner = :owner
|
2017-02-24 11:05:13 +02:00
|
|
|
AND r.repo = :repo;
|
2016-09-13 19:50:04 +03:00
|
|
|
|
2017-08-22 16:45:10 +03:00
|
|
|
-- :name update-eth-balance :! :n
|
2016-09-13 19:50:04 +03:00
|
|
|
-- :doc updates balance of a wallet attached to a given issue
|
|
|
|
UPDATE issues
|
2017-08-23 23:47:50 +03:00
|
|
|
SET balance_eth = :balance_eth,
|
2017-02-26 23:40:59 +02:00
|
|
|
updated = timezone('utc'::text, now())
|
2016-09-13 19:50:04 +03:00
|
|
|
WHERE contract_address = :contract_address;
|
2017-02-21 10:49:25 +02:00
|
|
|
|
|
|
|
|
|
|
|
-- :name save-issue-comment-image! :<! :1
|
2017-02-24 11:05:13 +02:00
|
|
|
-- :doc insert or update image data for a given issue's github comment
|
2017-03-01 22:09:48 +02:00
|
|
|
INSERT INTO issue_comment (issue_id, comment_hash, png_data)
|
|
|
|
VALUES (:issue_id, :hash, :png_data)
|
|
|
|
ON CONFLICT (issue_id, comment_hash) DO UPDATE
|
2017-02-21 10:49:25 +02:00
|
|
|
SET png_data = :png_data
|
|
|
|
RETURNING id;
|
|
|
|
|
|
|
|
|
|
|
|
-- :name get-issue-comment-image :? :1
|
2017-02-24 11:05:13 +02:00
|
|
|
-- :doc retrieve image data for given issue's github comment
|
2017-02-21 10:49:25 +02:00
|
|
|
SELECT png_data
|
|
|
|
FROM issue_comment
|
2017-03-01 22:09:48 +02:00
|
|
|
WHERE issue_id = :issue_id
|
|
|
|
AND comment_hash = :hash;
|
2017-02-26 16:14:39 +02:00
|
|
|
|
|
|
|
|
|
|
|
-- :name top-hunters :? :*
|
2017-02-26 23:40:59 +02:00
|
|
|
-- :doc list of user that have reveived bounty payouts with sum of
|
|
|
|
-- earnings
|
2017-02-26 16:14:39 +02:00
|
|
|
SELECT
|
|
|
|
u.id AS user_id,
|
|
|
|
u.login AS login,
|
2017-10-25 14:56:24 +03:00
|
|
|
coalesce(u.name, u.login) AS user_name,
|
2017-02-26 16:14:39 +02:00
|
|
|
u.avatar_url AS avatar_url,
|
2017-08-23 23:47:50 +03:00
|
|
|
SUM(i.value_usd) AS total_usd
|
2017-02-26 16:14:39 +02:00
|
|
|
FROM issues i, users u, pull_requests pr
|
|
|
|
WHERE
|
2017-02-26 23:40:59 +02:00
|
|
|
pr.commit_sha = i.commit_sha
|
2017-02-26 16:14:39 +02:00
|
|
|
AND u.id = pr.user_id
|
|
|
|
AND i.payout_receipt IS NOT NULL
|
|
|
|
GROUP BY u.id
|
2017-08-23 23:47:50 +03:00
|
|
|
ORDER BY total_usd DESC;
|
2017-02-26 23:40:59 +02:00
|
|
|
|
|
|
|
|
|
|
|
-- :name bounties-activity :? :*
|
|
|
|
-- :doc data for bounty activity feed
|
|
|
|
SELECT
|
|
|
|
type,
|
|
|
|
issue_title,
|
|
|
|
repo_name,
|
2017-02-27 22:38:41 +02:00
|
|
|
repo_owner,
|
2017-02-26 23:40:59 +02:00
|
|
|
issue_number,
|
|
|
|
user_name,
|
|
|
|
user_avatar_url,
|
2017-08-23 23:47:50 +03:00
|
|
|
balance_eth,
|
|
|
|
tokens,
|
|
|
|
value_usd,
|
2017-02-26 23:40:59 +02:00
|
|
|
updated
|
|
|
|
FROM activity_feed_view
|
|
|
|
ORDER BY updated DESC
|
|
|
|
LIMIT 100;
|
2017-04-02 20:20:44 +03:00
|
|
|
|
2017-10-28 21:10:09 +03:00
|
|
|
-- :name get-new-users-for-welcome-email :? :*
|
|
|
|
-- :doc users who have not been sent a welcome email
|
|
|
|
SELECT
|
|
|
|
id,
|
|
|
|
login,
|
|
|
|
email,
|
|
|
|
name
|
|
|
|
FROM users
|
|
|
|
WHERE welcome_email_sent = 0;
|
|
|
|
|
2017-04-02 20:20:44 +03:00
|
|
|
|
|
|
|
-- :name usage-metrics-by-day :? :*
|
|
|
|
-- :doc data for usage metrics chart
|
|
|
|
SELECT * FROM (
|
|
|
|
SELECT d.DAY,
|
|
|
|
coalesce(max(registered_users), (SELECT max(registered_users) FROM usage_metrics WHERE change_timestamp < d.day)) AS registered_users,
|
|
|
|
coalesce(max(users_with_address), (SELECT max(users_with_address) FROM usage_metrics WHERE change_timestamp < d.day)) AS users_with_address
|
|
|
|
FROM
|
|
|
|
(SELECT day FROM generate_series(CURRENT_DATE - INTERVAL '365 day', CURRENT_DATE, '1 day'::interval) AS day) AS d
|
|
|
|
LEFT OUTER JOIN usage_metrics um
|
|
|
|
ON d.day = date_trunc('day', um.change_timestamp)
|
|
|
|
GROUP BY d.day
|
|
|
|
ORDER BY 1 desc
|
|
|
|
LIMIT :limit_days) AS a
|
|
|
|
ORDER BY a.day ASC;
|