2019-02-06 16:14:44 +00:00
|
|
|
(define-module (guix-data-service model package)
|
|
|
|
|
#:use-module (srfi srfi-1)
|
|
|
|
|
#:use-module (ice-9 vlist)
|
|
|
|
|
#:use-module (ice-9 match)
|
|
|
|
|
#:use-module (squee)
|
|
|
|
|
#:use-module (guix inferior)
|
|
|
|
|
#:use-module (guix-data-service model utils)
|
|
|
|
|
#:export (select-existing-package-entries
|
2019-03-06 22:59:27 +00:00
|
|
|
select-packages-in-revision
|
2019-05-12 21:16:10 +01:00
|
|
|
search-packages-in-revision
|
2019-03-11 22:11:14 +00:00
|
|
|
count-packages-in-revision
|
2019-02-06 16:14:44 +00:00
|
|
|
insert-into-package-entries
|
|
|
|
|
inferior-packages->package-ids))
|
|
|
|
|
|
|
|
|
|
(define (select-existing-package-entries package-entries)
|
|
|
|
|
(string-append "SELECT id, packages.name, packages.version, "
|
2019-03-11 22:11:14 +00:00
|
|
|
"packages.package_metadata_id "
|
2019-02-06 16:14:44 +00:00
|
|
|
"FROM packages "
|
|
|
|
|
"JOIN (VALUES "
|
|
|
|
|
(string-join (map (lambda (package-entry)
|
|
|
|
|
(apply
|
|
|
|
|
simple-format
|
2019-03-11 22:11:14 +00:00
|
|
|
#f "('~A', '~A', ~A)"
|
2019-02-06 16:14:44 +00:00
|
|
|
package-entry))
|
|
|
|
|
package-entries)
|
|
|
|
|
", ")
|
2019-03-11 22:11:14 +00:00
|
|
|
") AS vals (name, version, package_metadata_id) "
|
2019-02-06 16:14:44 +00:00
|
|
|
"ON packages.name = vals.name AND "
|
|
|
|
|
"packages.version = vals.version AND "
|
2019-03-11 22:11:14 +00:00
|
|
|
"packages.package_metadata_id = vals.package_metadata_id"))
|
2019-02-06 16:14:44 +00:00
|
|
|
|
2019-05-12 19:51:44 +01:00
|
|
|
(define* (select-packages-in-revision conn commit-hash
|
|
|
|
|
#:key limit-results
|
|
|
|
|
after-name)
|
2019-03-06 22:59:27 +00:00
|
|
|
(define query
|
2019-05-12 19:51:44 +01:00
|
|
|
(string-append "
|
|
|
|
|
WITH data AS (
|
|
|
|
|
SELECT packages.name, packages.version, package_metadata.synopsis
|
|
|
|
|
FROM packages
|
|
|
|
|
INNER JOIN package_metadata
|
|
|
|
|
ON packages.package_metadata_id = package_metadata.id
|
|
|
|
|
WHERE packages.id IN (
|
|
|
|
|
SELECT package_derivations.package_id
|
|
|
|
|
FROM package_derivations
|
|
|
|
|
INNER JOIN guix_revision_package_derivations
|
|
|
|
|
ON package_derivations.id = guix_revision_package_derivations.package_derivation_id
|
|
|
|
|
INNER JOIN guix_revisions
|
|
|
|
|
ON guix_revision_package_derivations.revision_id = guix_revisions.id
|
|
|
|
|
WHERE guix_revisions.commit = $1
|
|
|
|
|
)
|
|
|
|
|
ORDER BY packages.name, packages.version
|
|
|
|
|
), package_names AS (
|
|
|
|
|
SELECT DISTINCT name
|
|
|
|
|
FROM data"
|
|
|
|
|
(if after-name
|
|
|
|
|
"\nWHERE name > $2\n"
|
|
|
|
|
"")
|
|
|
|
|
" ORDER BY name"
|
|
|
|
|
(if limit-results
|
|
|
|
|
(string-append " LIMIT " (number->string limit-results))
|
|
|
|
|
"")
|
|
|
|
|
")
|
|
|
|
|
SELECT data.*
|
|
|
|
|
FROM data
|
|
|
|
|
WHERE data.name IN (SELECT name FROM package_names);"))
|
2019-03-11 22:11:14 +00:00
|
|
|
|
2019-05-12 19:51:44 +01:00
|
|
|
(exec-query conn query
|
|
|
|
|
`(,commit-hash
|
|
|
|
|
,@(if after-name
|
|
|
|
|
(list after-name)
|
|
|
|
|
'()))))
|
2019-03-11 22:11:14 +00:00
|
|
|
|
2019-05-12 21:16:10 +01:00
|
|
|
(define* (search-packages-in-revision conn commit-hash
|
|
|
|
|
search-query
|
|
|
|
|
#:key limit-results)
|
|
|
|
|
(define query
|
|
|
|
|
(string-append
|
|
|
|
|
"
|
|
|
|
|
SELECT packages.name,
|
|
|
|
|
packages.version,
|
|
|
|
|
package_metadata.synopsis
|
|
|
|
|
FROM packages
|
|
|
|
|
INNER JOIN package_metadata
|
|
|
|
|
ON packages.package_metadata_id = package_metadata.id
|
|
|
|
|
WHERE packages.id IN (
|
|
|
|
|
SELECT package_derivations.package_id
|
|
|
|
|
FROM package_derivations
|
|
|
|
|
INNER JOIN guix_revision_package_derivations
|
|
|
|
|
ON package_derivations.id = guix_revision_package_derivations.package_derivation_id
|
|
|
|
|
INNER JOIN guix_revisions
|
|
|
|
|
ON guix_revision_package_derivations.revision_id = guix_revisions.id
|
|
|
|
|
WHERE guix_revisions.commit = $1
|
|
|
|
|
)
|
|
|
|
|
AND to_tsvector(name || ' ' || synopsis) @@ plainto_tsquery($2)
|
|
|
|
|
ORDER BY ts_rank_cd(to_tsvector(name || ' ' || synopsis), plainto_tsquery($2)) DESC"
|
|
|
|
|
(if limit-results
|
|
|
|
|
(string-append "\nLIMIT " (number->string limit-results))
|
|
|
|
|
"")))
|
|
|
|
|
|
|
|
|
|
(exec-query conn query
|
|
|
|
|
(list commit-hash search-query)))
|
|
|
|
|
|
2019-03-11 22:11:14 +00:00
|
|
|
(define (count-packages-in-revision conn commit-hash)
|
|
|
|
|
(define query
|
|
|
|
|
"
|
|
|
|
|
SELECT COUNT(DISTINCT packages.name)
|
|
|
|
|
FROM packages
|
|
|
|
|
WHERE packages.id IN (
|
|
|
|
|
SELECT package_derivations.package_id
|
|
|
|
|
FROM package_derivations
|
|
|
|
|
INNER JOIN guix_revision_package_derivations
|
|
|
|
|
ON package_derivations.id = guix_revision_package_derivations.package_derivation_id
|
|
|
|
|
INNER JOIN guix_revisions
|
|
|
|
|
ON guix_revision_package_derivations.revision_id = guix_revisions.id
|
|
|
|
|
WHERE guix_revisions.commit = $1
|
|
|
|
|
)")
|
2019-03-06 22:59:27 +00:00
|
|
|
|
|
|
|
|
(exec-query conn query (list commit-hash)))
|
|
|
|
|
|
2019-02-06 16:14:44 +00:00
|
|
|
(define (insert-into-package-entries package-entries)
|
|
|
|
|
(string-append "INSERT INTO packages "
|
2019-03-11 22:11:14 +00:00
|
|
|
"(name, version, package_metadata_id) VALUES "
|
2019-02-06 16:14:44 +00:00
|
|
|
(string-join
|
|
|
|
|
(map
|
|
|
|
|
(match-lambda
|
2019-03-11 22:11:14 +00:00
|
|
|
((name version package_metadata_id)
|
|
|
|
|
(simple-format #f "('~A', '~A', ~A)"
|
2019-02-06 16:14:44 +00:00
|
|
|
name
|
|
|
|
|
version
|
2019-03-11 22:11:14 +00:00
|
|
|
package_metadata_id)))
|
2019-02-06 16:14:44 +00:00
|
|
|
package-entries)
|
|
|
|
|
",")
|
|
|
|
|
" RETURNING id"
|
|
|
|
|
";"))
|
|
|
|
|
|
2019-03-11 22:11:14 +00:00
|
|
|
(define (inferior-packages->package-ids conn packages metadata-ids)
|
2019-02-06 16:14:44 +00:00
|
|
|
(define package-entries
|
2019-03-11 22:11:14 +00:00
|
|
|
(map (lambda (package metadata-id)
|
2019-02-06 16:14:44 +00:00
|
|
|
(list (inferior-package-name package)
|
|
|
|
|
(inferior-package-version package)
|
2019-03-11 22:11:14 +00:00
|
|
|
metadata-id))
|
2019-02-06 16:14:44 +00:00
|
|
|
packages
|
2019-03-11 22:11:14 +00:00
|
|
|
metadata-ids))
|
2019-02-06 16:14:44 +00:00
|
|
|
|
|
|
|
|
(let* ((existing-package-entry-ids
|
|
|
|
|
(exec-query->vhash conn
|
|
|
|
|
(select-existing-package-entries package-entries)
|
2019-03-11 22:11:14 +00:00
|
|
|
;; name, version and package_metadata_id
|
2019-02-06 16:14:44 +00:00
|
|
|
cdr
|
|
|
|
|
first)) ;;id
|
|
|
|
|
(missing-package-entries
|
|
|
|
|
(filter (lambda (package-entry)
|
|
|
|
|
(not (vhash-assoc package-entry
|
|
|
|
|
existing-package-entry-ids)))
|
2019-03-28 22:42:18 +00:00
|
|
|
(delete-duplicates package-entries)))
|
2019-02-06 16:14:44 +00:00
|
|
|
(new-package-entry-ids
|
|
|
|
|
(if (null? missing-package-entries)
|
|
|
|
|
'()
|
|
|
|
|
(map car
|
|
|
|
|
(exec-query
|
|
|
|
|
conn
|
|
|
|
|
(insert-into-package-entries
|
|
|
|
|
missing-package-entries)))))
|
|
|
|
|
(new-entries-id-lookup-vhash
|
|
|
|
|
(two-lists->vhash missing-package-entries
|
|
|
|
|
new-package-entry-ids)))
|
|
|
|
|
|
|
|
|
|
(map (lambda (package-entry)
|
|
|
|
|
(cdr
|
|
|
|
|
(or (vhash-assoc package-entry
|
|
|
|
|
existing-package-entry-ids)
|
|
|
|
|
(vhash-assoc package-entry
|
|
|
|
|
new-entries-id-lookup-vhash)
|
|
|
|
|
(error "missing package entry"))))
|
|
|
|
|
package-entries)))
|