diff --git a/.sqlx/query-0485ba8682dc98b714d295e5780b5e36fb0fb6224b8628c181bb23bd0c953504.json b/.sqlx/query-0485ba8682dc98b714d295e5780b5e36fb0fb6224b8628c181bb23bd0c953504.json deleted file mode 100644 index 1238770..0000000 --- a/.sqlx/query-0485ba8682dc98b714d295e5780b5e36fb0fb6224b8628c181bb23bd0c953504.json +++ /dev/null @@ -1,101 +0,0 @@ -{ - "db_name": "PostgreSQL", - "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM book_authors\n JOIN authors ON authors.id = book_authors.author\n WHERE book_authors.book = b.id\n ) AS \"authors!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM translations\n JOIN authors ON authors.id = translations.author\n WHERE translations.book = b.id\n ) AS \"translators!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', sequences.id,\n 'name', sequences.name\n )\n )\n FROM book_sequences\n JOIN sequences ON sequences.id = book_sequences.sequence\n WHERE book_sequences.book = b.id\n ) AS \"sequences!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\",\n (\n SELECT\n JSON_BUILD_OBJECT(\n 'id', sources.id,\n 'name', sources.name\n )\n FROM sources\n WHERE sources.id = b.source\n ) AS \"source!: Source\",\n b.remote_id\n FROM books b\n WHERE lang = ANY($1) AND\n ($2::boolean IS NULL OR is_deleted = $2) AND\n ($3::date IS NULL OR uploaded >= $3) AND\n ($4::date IS NULL OR uploaded <= $4) AND\n ($5::integer IS NULL OR id >= $5) AND\n ($6::integer IS NULL OR id <= $6)\n ORDER BY b.id ASC\n OFFSET $7\n LIMIT $8\n ", - "describe": { - "columns": [ - { - "ordinal": 0, - "name": "id", - "type_info": "Int4" - }, - { - "ordinal": 1, - "name": "title", - "type_info": "Varchar" - }, - { - "ordinal": 2, - "name": "lang", - "type_info": "Varchar" - }, - { - "ordinal": 3, - "name": "file_type", - "type_info": "Varchar" - }, - { - "ordinal": 4, - "name": "year", - "type_info": "Int2" - }, - { - "ordinal": 5, - "name": "available_types!: Vec", - "type_info": "VarcharArray" - }, - { - "ordinal": 6, - "name": "uploaded", - "type_info": "Date" - }, - { - "ordinal": 7, - "name": "authors!: Vec", - "type_info": "Json" - }, - { - "ordinal": 8, - "name": "translators!: Vec", - "type_info": "Json" - }, - { - "ordinal": 9, - "name": "sequences!: Vec", - "type_info": "Json" - }, - { - "ordinal": 10, - "name": "annotation_exists!: bool", - "type_info": "Bool" - }, - { - "ordinal": 11, - "name": "source!: Source", - "type_info": "Json" - }, - { - "ordinal": 12, - "name": "remote_id", - "type_info": "Int4" - } - ], - "parameters": { - "Left": [ - "TextArray", - "Bool", - "Date", - "Date", - "Int4", - "Int4", - "Int8", - "Int8" - ] - }, - "nullable": [ - false, - false, - false, - false, - false, - null, - false, - null, - null, - null, - null, - null, - false - ] - }, - "hash": "0485ba8682dc98b714d295e5780b5e36fb0fb6224b8628c181bb23bd0c953504" -} diff --git a/.sqlx/query-14038503cd48456847a8ba692094691cb292a41b0456323b976e996536e20819.json b/.sqlx/query-14038503cd48456847a8ba692094691cb292a41b0456323b976e996536e20819.json deleted file mode 100644 index 7141f18..0000000 --- a/.sqlx/query-14038503cd48456847a8ba692094691cb292a41b0456323b976e996536e20819.json +++ /dev/null @@ -1,85 +0,0 @@ -{ - "db_name": "PostgreSQL", - "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM book_authors\n JOIN authors ON authors.id = book_authors.author\n WHERE book_authors.book = b.id\n ) AS \"authors!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM translations\n JOIN authors ON authors.id = translations.author\n WHERE translations.book = b.id\n ) AS \"translators!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\",\n bs.position\n FROM books b\n JOIN book_sequences bs ON b.id = bs.book\n WHERE\n b.is_deleted = FALSE AND\n bs.sequence = $1 AND\n b.lang = ANY($2)\n ORDER BY bs.position\n LIMIT $3 OFFSET $4\n ", - "describe": { - "columns": [ - { - "ordinal": 0, - "name": "id", - "type_info": "Int4" - }, - { - "ordinal": 1, - "name": "title", - "type_info": "Varchar" - }, - { - "ordinal": 2, - "name": "lang", - "type_info": "Varchar" - }, - { - "ordinal": 3, - "name": "file_type", - "type_info": "Varchar" - }, - { - "ordinal": 4, - "name": "year", - "type_info": "Int2" - }, - { - "ordinal": 5, - "name": "available_types!: Vec", - "type_info": "VarcharArray" - }, - { - "ordinal": 6, - "name": "uploaded", - "type_info": "Date" - }, - { - "ordinal": 7, - "name": "authors!: Vec", - "type_info": "Json" - }, - { - "ordinal": 8, - "name": "translators!: Vec", - "type_info": "Json" - }, - { - "ordinal": 9, - "name": "annotation_exists!: bool", - "type_info": "Bool" - }, - { - "ordinal": 10, - "name": "position", - "type_info": "Int2" - } - ], - "parameters": { - "Left": [ - "Int4", - "TextArray", - "Int8", - "Int8" - ] - }, - "nullable": [ - false, - false, - false, - false, - false, - null, - false, - null, - null, - null, - false - ] - }, - "hash": "14038503cd48456847a8ba692094691cb292a41b0456323b976e996536e20819" -} diff --git a/.sqlx/query-bda85dc33c862019c6bd1bb2a3e22b83e8c1ad2a536901b122dcf6a247d210a0.json b/.sqlx/query-191a5f0ddc1e4631b594f07710157cfdb3e002821f1ebb112fe772b274d08b1c.json similarity index 59% rename from .sqlx/query-bda85dc33c862019c6bd1bb2a3e22b83e8c1ad2a536901b122dcf6a247d210a0.json rename to .sqlx/query-191a5f0ddc1e4631b594f07710157cfdb3e002821f1ebb112fe772b274d08b1c.json index a6265ba..146f39d 100644 --- a/.sqlx/query-bda85dc33c862019c6bd1bb2a3e22b83e8c1ad2a536901b122dcf6a247d210a0.json +++ b/.sqlx/query-191a5f0ddc1e4631b594f07710157cfdb3e002821f1ebb112fe772b274d08b1c.json @@ -1,6 +1,6 @@ { "db_name": "PostgreSQL", - "query": "\n SELECT\n b.id,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS \"available_types!: Vec\"\n FROM books b\n JOIN book_authors ba ON b.id = ba.book\n WHERE b.is_deleted = false AND ba.author = $1 AND b.lang = ANY($2)\n ", + "query": "\n SELECT\n b.id,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS \"available_types!: Vec\"\n FROM books b\n JOIN book_authors ba ON b.id = ba.book\n WHERE b.is_deleted = false AND ba.author = $1 AND b.lang = ANY($2)\n ", "describe": { "columns": [ { @@ -11,7 +11,7 @@ { "ordinal": 1, "name": "available_types!: Vec", - "type_info": "VarcharArray" + "type_info": "TextArray" } ], "parameters": { @@ -25,5 +25,5 @@ null ] }, - "hash": "bda85dc33c862019c6bd1bb2a3e22b83e8c1ad2a536901b122dcf6a247d210a0" + "hash": "191a5f0ddc1e4631b594f07710157cfdb3e002821f1ebb112fe772b274d08b1c" } diff --git a/.sqlx/query-34c2b0f605eddd776433543f2a553324ab61277083a0b6a41f1c43edc596ed60.json b/.sqlx/query-34c2b0f605eddd776433543f2a553324ab61277083a0b6a41f1c43edc596ed60.json new file mode 100644 index 0000000..e49f2ef --- /dev/null +++ b/.sqlx/query-34c2b0f605eddd776433543f2a553324ab61277083a0b6a41f1c43edc596ed60.json @@ -0,0 +1,85 @@ +{ + "db_name": "PostgreSQL", + "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM book_authors\n JOIN authors ON authors.id = book_authors.author\n WHERE book_authors.book = b.id\n ) AS \"authors!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM translations\n JOIN authors ON authors.id = translations.author\n WHERE translations.book = b.id\n ) AS \"translators!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\",\n bs.position\n FROM books b\n JOIN book_sequences bs ON b.id = bs.book\n WHERE\n b.is_deleted = FALSE AND\n bs.sequence = $1 AND\n b.lang = ANY($2)\n ORDER BY bs.position\n LIMIT $3 OFFSET $4\n ", + "describe": { + "columns": [ + { + "ordinal": 0, + "name": "id", + "type_info": "Int4" + }, + { + "ordinal": 1, + "name": "title", + "type_info": "Varchar" + }, + { + "ordinal": 2, + "name": "lang", + "type_info": "Varchar" + }, + { + "ordinal": 3, + "name": "file_type", + "type_info": "Varchar" + }, + { + "ordinal": 4, + "name": "year", + "type_info": "Int2" + }, + { + "ordinal": 5, + "name": "available_types!: Vec", + "type_info": "TextArray" + }, + { + "ordinal": 6, + "name": "uploaded", + "type_info": "Date" + }, + { + "ordinal": 7, + "name": "authors!: Vec", + "type_info": "Json" + }, + { + "ordinal": 8, + "name": "translators!: Vec", + "type_info": "Json" + }, + { + "ordinal": 9, + "name": "annotation_exists!: bool", + "type_info": "Bool" + }, + { + "ordinal": 10, + "name": "position", + "type_info": "Int2" + } + ], + "parameters": { + "Left": [ + "Int4", + "TextArray", + "Int8", + "Int8" + ] + }, + "nullable": [ + false, + false, + false, + false, + false, + null, + false, + null, + null, + null, + false + ] + }, + "hash": "34c2b0f605eddd776433543f2a553324ab61277083a0b6a41f1c43edc596ed60" +} diff --git a/.sqlx/query-3bf3d8ef40b6832eeeb1b5e01a3d7b5ce9586fad68f8f502adfb3cd2f372f0c8.json b/.sqlx/query-3bf3d8ef40b6832eeeb1b5e01a3d7b5ce9586fad68f8f502adfb3cd2f372f0c8.json new file mode 100644 index 0000000..d3b6d4c --- /dev/null +++ b/.sqlx/query-3bf3d8ef40b6832eeeb1b5e01a3d7b5ce9586fad68f8f502adfb3cd2f372f0c8.json @@ -0,0 +1,112 @@ +{ + "db_name": "PostgreSQL", + "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM book_authors\n JOIN authors ON authors.id = book_authors.author\n WHERE book_authors.book = b.id\n ) AS \"authors!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM translations\n JOIN authors ON authors.id = translations.author\n WHERE translations.book = b.id\n ) AS \"translators!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', sequences.id,\n 'name', sequences.name\n )\n )\n FROM book_sequences\n JOIN sequences ON sequences.id = book_sequences.sequence\n WHERE book_sequences.book = b.id\n ) AS \"sequences!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', genres.id,\n 'code', genres.code,\n 'description', genres.description,\n 'meta', genres.meta,\n 'source', JSON_BUILD_OBJECT(\n 'id', sources.id,\n 'name', sources.name\n )\n )\n )\n FROM book_genres\n JOIN genres ON genres.id = book_genres.genre\n JOIN sources ON sources.id = genres.source\n WHERE book_genres.book = b.id\n ) AS \"genres!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\",\n (\n SELECT\n JSON_BUILD_OBJECT(\n 'id', sources.id,\n 'name', sources.name\n )\n FROM sources\n WHERE sources.id = b.source\n ) AS \"source!: Source\",\n b.remote_id,\n b.is_deleted,\n b.pages\n FROM books b\n WHERE b.id = $1\n ", + "describe": { + "columns": [ + { + "ordinal": 0, + "name": "id", + "type_info": "Int4" + }, + { + "ordinal": 1, + "name": "title", + "type_info": "Varchar" + }, + { + "ordinal": 2, + "name": "lang", + "type_info": "Varchar" + }, + { + "ordinal": 3, + "name": "file_type", + "type_info": "Varchar" + }, + { + "ordinal": 4, + "name": "year", + "type_info": "Int2" + }, + { + "ordinal": 5, + "name": "available_types!: Vec", + "type_info": "TextArray" + }, + { + "ordinal": 6, + "name": "uploaded", + "type_info": "Date" + }, + { + "ordinal": 7, + "name": "authors!: Vec", + "type_info": "Json" + }, + { + "ordinal": 8, + "name": "translators!: Vec", + "type_info": "Json" + }, + { + "ordinal": 9, + "name": "sequences!: Vec", + "type_info": "Json" + }, + { + "ordinal": 10, + "name": "genres!: Vec", + "type_info": "Json" + }, + { + "ordinal": 11, + "name": "annotation_exists!: bool", + "type_info": "Bool" + }, + { + "ordinal": 12, + "name": "source!: Source", + "type_info": "Json" + }, + { + "ordinal": 13, + "name": "remote_id", + "type_info": "Int4" + }, + { + "ordinal": 14, + "name": "is_deleted", + "type_info": "Bool" + }, + { + "ordinal": 15, + "name": "pages", + "type_info": "Int4" + } + ], + "parameters": { + "Left": [ + "Int4" + ] + }, + "nullable": [ + false, + false, + false, + false, + false, + null, + false, + null, + null, + null, + null, + null, + null, + false, + false, + true + ] + }, + "hash": "3bf3d8ef40b6832eeeb1b5e01a3d7b5ce9586fad68f8f502adfb3cd2f372f0c8" +} diff --git a/.sqlx/query-9740501d7b3d235efc914e185c9978d04e4d8ef89a2847f36e5f490183180fbb.json b/.sqlx/query-4144af136af6f9a148a87030ce0f7c7625f4296bbee0ffdd24a81571e2afd54e.json similarity index 56% rename from .sqlx/query-9740501d7b3d235efc914e185c9978d04e4d8ef89a2847f36e5f490183180fbb.json rename to .sqlx/query-4144af136af6f9a148a87030ce0f7c7625f4296bbee0ffdd24a81571e2afd54e.json index 25574da..0de22b1 100644 --- a/.sqlx/query-9740501d7b3d235efc914e185c9978d04e4d8ef89a2847f36e5f490183180fbb.json +++ b/.sqlx/query-4144af136af6f9a148a87030ce0f7c7625f4296bbee0ffdd24a81571e2afd54e.json @@ -1,6 +1,6 @@ { "db_name": "PostgreSQL", - "query": "\n SELECT\n b.id,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS \"available_types!: Vec\"\n FROM books b\n JOIN book_sequences bs ON b.id = bs.book\n WHERE\n b.is_deleted = FALSE AND\n bs.sequence = $1 AND\n b.lang = ANY($2)\n ", + "query": "\n SELECT\n b.id,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS \"available_types!: Vec\"\n FROM books b\n JOIN book_authors ba ON b.id = ba.book\n WHERE\n b.is_deleted = false\n AND ba.author = $1\n AND b.lang = ANY($2)\n ", "describe": { "columns": [ { @@ -11,7 +11,7 @@ { "ordinal": 1, "name": "available_types!: Vec", - "type_info": "VarcharArray" + "type_info": "TextArray" } ], "parameters": { @@ -25,5 +25,5 @@ null ] }, - "hash": "9740501d7b3d235efc914e185c9978d04e4d8ef89a2847f36e5f490183180fbb" + "hash": "4144af136af6f9a148a87030ce0f7c7625f4296bbee0ffdd24a81571e2afd54e" } diff --git a/.sqlx/query-51a16072eb796c133dc5e5986c163096084751678a86c60769849f96c79c398d.json b/.sqlx/query-51a16072eb796c133dc5e5986c163096084751678a86c60769849f96c79c398d.json deleted file mode 100644 index b083ee7..0000000 --- a/.sqlx/query-51a16072eb796c133dc5e5986c163096084751678a86c60769849f96c79c398d.json +++ /dev/null @@ -1,82 +0,0 @@ -{ - "db_name": "PostgreSQL", - "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM book_authors\n JOIN authors ON authors.id = book_authors.author\n WHERE book_authors.book = b.id\n ) AS \"authors!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM translations\n JOIN authors ON authors.id = translations.author\n WHERE translations.book = b.id\n ) AS \"translators!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', sequences.id,\n 'name', sequences.name\n )\n )\n FROM book_sequences\n JOIN sequences ON sequences.id = book_sequences.sequence\n WHERE book_sequences.book = b.id\n ) AS \"sequences!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\"\n FROM books b\n WHERE b.id = ANY($1)\n ", - "describe": { - "columns": [ - { - "ordinal": 0, - "name": "id", - "type_info": "Int4" - }, - { - "ordinal": 1, - "name": "title", - "type_info": "Varchar" - }, - { - "ordinal": 2, - "name": "lang", - "type_info": "Varchar" - }, - { - "ordinal": 3, - "name": "file_type", - "type_info": "Varchar" - }, - { - "ordinal": 4, - "name": "year", - "type_info": "Int2" - }, - { - "ordinal": 5, - "name": "available_types!: Vec", - "type_info": "VarcharArray" - }, - { - "ordinal": 6, - "name": "uploaded", - "type_info": "Date" - }, - { - "ordinal": 7, - "name": "authors!: Vec", - "type_info": "Json" - }, - { - "ordinal": 8, - "name": "translators!: Vec", - "type_info": "Json" - }, - { - "ordinal": 9, - "name": "sequences!: Vec", - "type_info": "Json" - }, - { - "ordinal": 10, - "name": "annotation_exists!: bool", - "type_info": "Bool" - } - ], - "parameters": { - "Left": [ - "Int4Array" - ] - }, - "nullable": [ - false, - false, - false, - false, - false, - null, - false, - null, - null, - null, - null - ] - }, - "hash": "51a16072eb796c133dc5e5986c163096084751678a86c60769849f96c79c398d" -} diff --git a/.sqlx/query-5d232f0a9a4cd5bb05d5d246af878bb43fb042f8643bb1a9b98dbafde4fbf50b.json b/.sqlx/query-5d232f0a9a4cd5bb05d5d246af878bb43fb042f8643bb1a9b98dbafde4fbf50b.json new file mode 100644 index 0000000..52d0728 --- /dev/null +++ b/.sqlx/query-5d232f0a9a4cd5bb05d5d246af878bb43fb042f8643bb1a9b98dbafde4fbf50b.json @@ -0,0 +1,101 @@ +{ + "db_name": "PostgreSQL", + "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM book_authors\n JOIN authors ON authors.id = book_authors.author\n WHERE book_authors.book = b.id\n ) AS \"authors!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM translations\n JOIN authors ON authors.id = translations.author\n WHERE translations.book = b.id\n ) AS \"translators!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', sequences.id,\n 'name', sequences.name\n )\n )\n FROM book_sequences\n JOIN sequences ON sequences.id = book_sequences.sequence\n WHERE book_sequences.book = b.id\n ) AS \"sequences!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\",\n (\n SELECT\n JSON_BUILD_OBJECT(\n 'id', sources.id,\n 'name', sources.name\n )\n FROM sources\n WHERE sources.id = b.source\n ) AS \"source!: Source\",\n b.remote_id\n FROM books b\n WHERE lang = ANY($1) AND\n ($2::boolean IS NULL OR is_deleted = $2) AND\n ($3::date IS NULL OR uploaded >= $3) AND\n ($4::date IS NULL OR uploaded <= $4) AND\n ($5::integer IS NULL OR id >= $5) AND\n ($6::integer IS NULL OR id <= $6)\n ORDER BY b.id ASC\n OFFSET $7\n LIMIT $8\n ", + "describe": { + "columns": [ + { + "ordinal": 0, + "name": "id", + "type_info": "Int4" + }, + { + "ordinal": 1, + "name": "title", + "type_info": "Varchar" + }, + { + "ordinal": 2, + "name": "lang", + "type_info": "Varchar" + }, + { + "ordinal": 3, + "name": "file_type", + "type_info": "Varchar" + }, + { + "ordinal": 4, + "name": "year", + "type_info": "Int2" + }, + { + "ordinal": 5, + "name": "available_types!: Vec", + "type_info": "TextArray" + }, + { + "ordinal": 6, + "name": "uploaded", + "type_info": "Date" + }, + { + "ordinal": 7, + "name": "authors!: Vec", + "type_info": "Json" + }, + { + "ordinal": 8, + "name": "translators!: Vec", + "type_info": "Json" + }, + { + "ordinal": 9, + "name": "sequences!: Vec", + "type_info": "Json" + }, + { + "ordinal": 10, + "name": "annotation_exists!: bool", + "type_info": "Bool" + }, + { + "ordinal": 11, + "name": "source!: Source", + "type_info": "Json" + }, + { + "ordinal": 12, + "name": "remote_id", + "type_info": "Int4" + } + ], + "parameters": { + "Left": [ + "TextArray", + "Bool", + "Date", + "Date", + "Int4", + "Int4", + "Int8", + "Int8" + ] + }, + "nullable": [ + false, + false, + false, + false, + false, + null, + false, + null, + null, + null, + null, + null, + false + ] + }, + "hash": "5d232f0a9a4cd5bb05d5d246af878bb43fb042f8643bb1a9b98dbafde4fbf50b" +} diff --git a/.sqlx/query-5ed13002eed0824bd874fc889b765e6e36bcfb7343a8c945bca0f3c46999ec2d.json b/.sqlx/query-5ed13002eed0824bd874fc889b765e6e36bcfb7343a8c945bca0f3c46999ec2d.json deleted file mode 100644 index fcfb6e0..0000000 --- a/.sqlx/query-5ed13002eed0824bd874fc889b765e6e36bcfb7343a8c945bca0f3c46999ec2d.json +++ /dev/null @@ -1,113 +0,0 @@ -{ - "db_name": "PostgreSQL", - "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM book_authors\n JOIN authors ON authors.id = book_authors.author\n WHERE book_authors.book = b.id\n ) AS \"authors!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM translations\n JOIN authors ON authors.id = translations.author\n WHERE translations.book = b.id\n ) AS \"translators!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', sequences.id,\n 'name', sequences.name\n )\n )\n FROM book_sequences\n JOIN sequences ON sequences.id = book_sequences.sequence\n WHERE book_sequences.book = b.id\n ) AS \"sequences!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', genres.id,\n 'code', genres.code,\n 'description', genres.description,\n 'meta', genres.meta,\n 'source', JSON_BUILD_OBJECT(\n 'id', sources.id,\n 'name', sources.name\n )\n )\n )\n FROM book_genres\n JOIN genres ON genres.id = book_genres.genre\n JOIN sources ON sources.id = genres.source\n WHERE book_genres.book = b.id\n ) AS \"genres!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\",\n (\n SELECT\n JSON_BUILD_OBJECT(\n 'id', sources.id,\n 'name', sources.name\n )\n FROM sources\n WHERE sources.id = b.source\n ) AS \"source!: Source\",\n b.remote_id,\n b.is_deleted,\n b.pages\n FROM books b\n WHERE b.source = $1 AND b.remote_id = $2\n ", - "describe": { - "columns": [ - { - "ordinal": 0, - "name": "id", - "type_info": "Int4" - }, - { - "ordinal": 1, - "name": "title", - "type_info": "Varchar" - }, - { - "ordinal": 2, - "name": "lang", - "type_info": "Varchar" - }, - { - "ordinal": 3, - "name": "file_type", - "type_info": "Varchar" - }, - { - "ordinal": 4, - "name": "year", - "type_info": "Int2" - }, - { - "ordinal": 5, - "name": "available_types!: Vec", - "type_info": "VarcharArray" - }, - { - "ordinal": 6, - "name": "uploaded", - "type_info": "Date" - }, - { - "ordinal": 7, - "name": "authors!: Vec", - "type_info": "Json" - }, - { - "ordinal": 8, - "name": "translators!: Vec", - "type_info": "Json" - }, - { - "ordinal": 9, - "name": "sequences!: Vec", - "type_info": "Json" - }, - { - "ordinal": 10, - "name": "genres!: Vec", - "type_info": "Json" - }, - { - "ordinal": 11, - "name": "annotation_exists!: bool", - "type_info": "Bool" - }, - { - "ordinal": 12, - "name": "source!: Source", - "type_info": "Json" - }, - { - "ordinal": 13, - "name": "remote_id", - "type_info": "Int4" - }, - { - "ordinal": 14, - "name": "is_deleted", - "type_info": "Bool" - }, - { - "ordinal": 15, - "name": "pages", - "type_info": "Int4" - } - ], - "parameters": { - "Left": [ - "Int2", - "Int4" - ] - }, - "nullable": [ - false, - false, - false, - false, - false, - null, - false, - null, - null, - null, - null, - null, - null, - false, - false, - true - ] - }, - "hash": "5ed13002eed0824bd874fc889b765e6e36bcfb7343a8c945bca0f3c46999ec2d" -} diff --git a/.sqlx/query-5f884948bcf39879c8d72d979e0638445a79707f55fd5eecb000a4166b3855b4.json b/.sqlx/query-5f884948bcf39879c8d72d979e0638445a79707f55fd5eecb000a4166b3855b4.json deleted file mode 100644 index 0e3ff31..0000000 --- a/.sqlx/query-5f884948bcf39879c8d72d979e0638445a79707f55fd5eecb000a4166b3855b4.json +++ /dev/null @@ -1,112 +0,0 @@ -{ - "db_name": "PostgreSQL", - "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM book_authors\n JOIN authors ON authors.id = book_authors.author\n WHERE book_authors.book = b.id\n ) AS \"authors!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM translations\n JOIN authors ON authors.id = translations.author\n WHERE translations.book = b.id\n ) AS \"translators!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', sequences.id,\n 'name', sequences.name\n )\n )\n FROM book_sequences\n JOIN sequences ON sequences.id = book_sequences.sequence\n WHERE book_sequences.book = b.id\n ) AS \"sequences!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', genres.id,\n 'code', genres.code,\n 'description', genres.description,\n 'meta', genres.meta,\n 'source', JSON_BUILD_OBJECT(\n 'id', sources.id,\n 'name', sources.name\n )\n )\n )\n FROM book_genres\n JOIN genres ON genres.id = book_genres.genre\n JOIN sources ON sources.id = genres.source\n WHERE book_genres.book = b.id\n ) AS \"genres!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\",\n (\n SELECT\n JSON_BUILD_OBJECT(\n 'id', sources.id,\n 'name', sources.name\n )\n FROM sources\n WHERE sources.id = b.source\n ) AS \"source!: Source\",\n b.remote_id,\n b.is_deleted,\n b.pages\n FROM books b\n WHERE b.id = $1\n ", - "describe": { - "columns": [ - { - "ordinal": 0, - "name": "id", - "type_info": "Int4" - }, - { - "ordinal": 1, - "name": "title", - "type_info": "Varchar" - }, - { - "ordinal": 2, - "name": "lang", - "type_info": "Varchar" - }, - { - "ordinal": 3, - "name": "file_type", - "type_info": "Varchar" - }, - { - "ordinal": 4, - "name": "year", - "type_info": "Int2" - }, - { - "ordinal": 5, - "name": "available_types!: Vec", - "type_info": "VarcharArray" - }, - { - "ordinal": 6, - "name": "uploaded", - "type_info": "Date" - }, - { - "ordinal": 7, - "name": "authors!: Vec", - "type_info": "Json" - }, - { - "ordinal": 8, - "name": "translators!: Vec", - "type_info": "Json" - }, - { - "ordinal": 9, - "name": "sequences!: Vec", - "type_info": "Json" - }, - { - "ordinal": 10, - "name": "genres!: Vec", - "type_info": "Json" - }, - { - "ordinal": 11, - "name": "annotation_exists!: bool", - "type_info": "Bool" - }, - { - "ordinal": 12, - "name": "source!: Source", - "type_info": "Json" - }, - { - "ordinal": 13, - "name": "remote_id", - "type_info": "Int4" - }, - { - "ordinal": 14, - "name": "is_deleted", - "type_info": "Bool" - }, - { - "ordinal": 15, - "name": "pages", - "type_info": "Int4" - } - ], - "parameters": { - "Left": [ - "Int4" - ] - }, - "nullable": [ - false, - false, - false, - false, - false, - null, - false, - null, - null, - null, - null, - null, - null, - false, - false, - true - ] - }, - "hash": "5f884948bcf39879c8d72d979e0638445a79707f55fd5eecb000a4166b3855b4" -} diff --git a/.sqlx/query-92f7e43d41bb56fe9ef3207ff4f870e12a02347d479dcda39c72f0ff2fe6a6fd.json b/.sqlx/query-92f7e43d41bb56fe9ef3207ff4f870e12a02347d479dcda39c72f0ff2fe6a6fd.json new file mode 100644 index 0000000..d3ae2fa --- /dev/null +++ b/.sqlx/query-92f7e43d41bb56fe9ef3207ff4f870e12a02347d479dcda39c72f0ff2fe6a6fd.json @@ -0,0 +1,74 @@ +{ + "db_name": "PostgreSQL", + "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM book_authors\n JOIN authors ON authors.id = book_authors.author\n WHERE book_authors.book = b.id\n ) AS \"authors!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', sequences.id,\n 'name', sequences.name\n )\n )\n FROM book_sequences\n JOIN sequences ON sequences.id = book_sequences.sequence\n WHERE book_sequences.book = b.id\n ) AS \"sequences!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\"\n FROM books b\n ", + "describe": { + "columns": [ + { + "ordinal": 0, + "name": "id", + "type_info": "Int4" + }, + { + "ordinal": 1, + "name": "title", + "type_info": "Varchar" + }, + { + "ordinal": 2, + "name": "lang", + "type_info": "Varchar" + }, + { + "ordinal": 3, + "name": "file_type", + "type_info": "Varchar" + }, + { + "ordinal": 4, + "name": "year", + "type_info": "Int2" + }, + { + "ordinal": 5, + "name": "available_types!: Vec", + "type_info": "TextArray" + }, + { + "ordinal": 6, + "name": "uploaded", + "type_info": "Date" + }, + { + "ordinal": 7, + "name": "authors!: Vec", + "type_info": "Json" + }, + { + "ordinal": 8, + "name": "sequences!: Vec", + "type_info": "Json" + }, + { + "ordinal": 9, + "name": "annotation_exists!: bool", + "type_info": "Bool" + } + ], + "parameters": { + "Left": [] + }, + "nullable": [ + false, + false, + false, + false, + false, + null, + false, + null, + null, + null + ] + }, + "hash": "92f7e43d41bb56fe9ef3207ff4f870e12a02347d479dcda39c72f0ff2fe6a6fd" +} diff --git a/.sqlx/query-95c232a0c52d8111e763f02f17b4b2dbe2c96a79c9c99d2011f7f04a1dddf6b3.json b/.sqlx/query-95c232a0c52d8111e763f02f17b4b2dbe2c96a79c9c99d2011f7f04a1dddf6b3.json deleted file mode 100644 index daf7d1f..0000000 --- a/.sqlx/query-95c232a0c52d8111e763f02f17b4b2dbe2c96a79c9c99d2011f7f04a1dddf6b3.json +++ /dev/null @@ -1,74 +0,0 @@ -{ - "db_name": "PostgreSQL", - "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM book_authors\n JOIN authors ON authors.id = book_authors.author\n WHERE book_authors.book = b.id\n ) AS \"authors!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', sequences.id,\n 'name', sequences.name\n )\n )\n FROM book_sequences\n JOIN sequences ON sequences.id = book_sequences.sequence\n WHERE book_sequences.book = b.id\n ) AS \"sequences!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\"\n FROM books b\n ", - "describe": { - "columns": [ - { - "ordinal": 0, - "name": "id", - "type_info": "Int4" - }, - { - "ordinal": 1, - "name": "title", - "type_info": "Varchar" - }, - { - "ordinal": 2, - "name": "lang", - "type_info": "Varchar" - }, - { - "ordinal": 3, - "name": "file_type", - "type_info": "Varchar" - }, - { - "ordinal": 4, - "name": "year", - "type_info": "Int2" - }, - { - "ordinal": 5, - "name": "available_types!: Vec", - "type_info": "VarcharArray" - }, - { - "ordinal": 6, - "name": "uploaded", - "type_info": "Date" - }, - { - "ordinal": 7, - "name": "authors!: Vec", - "type_info": "Json" - }, - { - "ordinal": 8, - "name": "sequences!: Vec", - "type_info": "Json" - }, - { - "ordinal": 9, - "name": "annotation_exists!: bool", - "type_info": "Bool" - } - ], - "parameters": { - "Left": [] - }, - "nullable": [ - false, - false, - false, - false, - false, - null, - false, - null, - null, - null - ] - }, - "hash": "95c232a0c52d8111e763f02f17b4b2dbe2c96a79c9c99d2011f7f04a1dddf6b3" -} diff --git a/.sqlx/query-0f3b01504179579a83609396a1db8423e01626183a48574a9f5a8645eabd88ec.json b/.sqlx/query-9bb82eaa3dcf8ead767d5f9ac9dbe8d70f8e68b12f6b004a9e495aa8ebc6d250.json similarity index 51% rename from .sqlx/query-0f3b01504179579a83609396a1db8423e01626183a48574a9f5a8645eabd88ec.json rename to .sqlx/query-9bb82eaa3dcf8ead767d5f9ac9dbe8d70f8e68b12f6b004a9e495aa8ebc6d250.json index a3908b9..269635c 100644 --- a/.sqlx/query-0f3b01504179579a83609396a1db8423e01626183a48574a9f5a8645eabd88ec.json +++ b/.sqlx/query-9bb82eaa3dcf8ead767d5f9ac9dbe8d70f8e68b12f6b004a9e495aa8ebc6d250.json @@ -1,6 +1,6 @@ { "db_name": "PostgreSQL", - "query": "\n SELECT\n b.id,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS \"available_types!: Vec\"\n FROM books b\n WHERE lang = ANY($1) AND\n ($2::boolean IS NULL OR is_deleted = $2) AND\n ($3::date IS NULL OR uploaded >= $3) AND\n ($4::date IS NULL OR uploaded <= $4) AND\n ($5::integer IS NULL OR id >= $5) AND\n ($6::integer IS NULL OR id <= $6)\n ORDER BY b.id ASC\n OFFSET $7\n LIMIT $8\n ", + "query": "\n SELECT\n b.id,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS \"available_types!: Vec\"\n FROM books b\n WHERE lang = ANY($1) AND\n ($2::boolean IS NULL OR is_deleted = $2) AND\n ($3::date IS NULL OR uploaded >= $3) AND\n ($4::date IS NULL OR uploaded <= $4) AND\n ($5::integer IS NULL OR id >= $5) AND\n ($6::integer IS NULL OR id <= $6)\n ORDER BY b.id ASC\n OFFSET $7\n LIMIT $8\n ", "describe": { "columns": [ { @@ -11,7 +11,7 @@ { "ordinal": 1, "name": "available_types!: Vec", - "type_info": "VarcharArray" + "type_info": "TextArray" } ], "parameters": { @@ -31,5 +31,5 @@ null ] }, - "hash": "0f3b01504179579a83609396a1db8423e01626183a48574a9f5a8645eabd88ec" + "hash": "9bb82eaa3dcf8ead767d5f9ac9dbe8d70f8e68b12f6b004a9e495aa8ebc6d250" } diff --git a/.sqlx/query-a76f04768121b35fdebdf19ea7959227068ccec4bfe2502d064a96ae5bcbc13e.json b/.sqlx/query-a76f04768121b35fdebdf19ea7959227068ccec4bfe2502d064a96ae5bcbc13e.json deleted file mode 100644 index 9945087..0000000 --- a/.sqlx/query-a76f04768121b35fdebdf19ea7959227068ccec4bfe2502d064a96ae5bcbc13e.json +++ /dev/null @@ -1,79 +0,0 @@ -{ - "db_name": "PostgreSQL", - "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM translations\n JOIN authors ON authors.id = translations.author\n WHERE translations.book = b.id\n ) AS \"translators!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', sequences.id,\n 'name', sequences.name\n )\n )\n FROM book_sequences\n JOIN sequences ON sequences.id = book_sequences.sequence\n WHERE book_sequences.book = b.id\n ) AS \"sequences!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\"\n FROM books b\n JOIN book_authors ba ON b.id = ba.book\n WHERE b.is_deleted = false AND ba.author = $1 AND b.lang = ANY($2)\n ORDER BY b.title ASC\n OFFSET $3\n LIMIT $4\n ", - "describe": { - "columns": [ - { - "ordinal": 0, - "name": "id", - "type_info": "Int4" - }, - { - "ordinal": 1, - "name": "title", - "type_info": "Varchar" - }, - { - "ordinal": 2, - "name": "lang", - "type_info": "Varchar" - }, - { - "ordinal": 3, - "name": "file_type", - "type_info": "Varchar" - }, - { - "ordinal": 4, - "name": "year", - "type_info": "Int2" - }, - { - "ordinal": 5, - "name": "available_types!: Vec", - "type_info": "VarcharArray" - }, - { - "ordinal": 6, - "name": "uploaded", - "type_info": "Date" - }, - { - "ordinal": 7, - "name": "translators!: Vec", - "type_info": "Json" - }, - { - "ordinal": 8, - "name": "sequences!: Vec", - "type_info": "Json" - }, - { - "ordinal": 9, - "name": "annotation_exists!: bool", - "type_info": "Bool" - } - ], - "parameters": { - "Left": [ - "Int4", - "TextArray", - "Int8", - "Int8" - ] - }, - "nullable": [ - false, - false, - false, - false, - false, - null, - false, - null, - null, - null - ] - }, - "hash": "a76f04768121b35fdebdf19ea7959227068ccec4bfe2502d064a96ae5bcbc13e" -} diff --git a/.sqlx/query-1f4b55a62fe01008a2a4a040450484785509312d213ea76a0efdd23d55e69a47.json b/.sqlx/query-b4c8511c5b3c157a64e4783ff6acd469abb21c5fda9ed9728e36b5b1d02d9aba.json similarity index 56% rename from .sqlx/query-1f4b55a62fe01008a2a4a040450484785509312d213ea76a0efdd23d55e69a47.json rename to .sqlx/query-b4c8511c5b3c157a64e4783ff6acd469abb21c5fda9ed9728e36b5b1d02d9aba.json index ba314d2..f8ce031 100644 --- a/.sqlx/query-1f4b55a62fe01008a2a4a040450484785509312d213ea76a0efdd23d55e69a47.json +++ b/.sqlx/query-b4c8511c5b3c157a64e4783ff6acd469abb21c5fda9ed9728e36b5b1d02d9aba.json @@ -1,6 +1,6 @@ { "db_name": "PostgreSQL", - "query": "\n SELECT\n b.id,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS \"available_types!: Vec\"\n FROM books b\n JOIN book_authors ba ON b.id = ba.book\n WHERE\n b.is_deleted = false\n AND ba.author = $1\n AND b.lang = ANY($2)\n ", + "query": "\n SELECT\n b.id,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS \"available_types!: Vec\"\n FROM books b\n JOIN book_sequences bs ON b.id = bs.book\n WHERE\n b.is_deleted = FALSE AND\n bs.sequence = $1 AND\n b.lang = ANY($2)\n ", "describe": { "columns": [ { @@ -11,7 +11,7 @@ { "ordinal": 1, "name": "available_types!: Vec", - "type_info": "VarcharArray" + "type_info": "TextArray" } ], "parameters": { @@ -25,5 +25,5 @@ null ] }, - "hash": "1f4b55a62fe01008a2a4a040450484785509312d213ea76a0efdd23d55e69a47" + "hash": "b4c8511c5b3c157a64e4783ff6acd469abb21c5fda9ed9728e36b5b1d02d9aba" } diff --git a/.sqlx/query-cedb65e8561dfff84cfab1eac28e03f082ea8190a47283fb6662e2d9a6246c57.json b/.sqlx/query-cedb65e8561dfff84cfab1eac28e03f082ea8190a47283fb6662e2d9a6246c57.json new file mode 100644 index 0000000..58ce4cc --- /dev/null +++ b/.sqlx/query-cedb65e8561dfff84cfab1eac28e03f082ea8190a47283fb6662e2d9a6246c57.json @@ -0,0 +1,82 @@ +{ + "db_name": "PostgreSQL", + "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM book_authors\n JOIN authors ON authors.id = book_authors.author\n WHERE book_authors.book = b.id\n ) AS \"authors!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM translations\n JOIN authors ON authors.id = translations.author\n WHERE translations.book = b.id\n ) AS \"translators!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', sequences.id,\n 'name', sequences.name\n )\n )\n FROM book_sequences\n JOIN sequences ON sequences.id = book_sequences.sequence\n WHERE book_sequences.book = b.id\n ) AS \"sequences!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\"\n FROM books b\n WHERE b.id = ANY($1)\n ", + "describe": { + "columns": [ + { + "ordinal": 0, + "name": "id", + "type_info": "Int4" + }, + { + "ordinal": 1, + "name": "title", + "type_info": "Varchar" + }, + { + "ordinal": 2, + "name": "lang", + "type_info": "Varchar" + }, + { + "ordinal": 3, + "name": "file_type", + "type_info": "Varchar" + }, + { + "ordinal": 4, + "name": "year", + "type_info": "Int2" + }, + { + "ordinal": 5, + "name": "available_types!: Vec", + "type_info": "TextArray" + }, + { + "ordinal": 6, + "name": "uploaded", + "type_info": "Date" + }, + { + "ordinal": 7, + "name": "authors!: Vec", + "type_info": "Json" + }, + { + "ordinal": 8, + "name": "translators!: Vec", + "type_info": "Json" + }, + { + "ordinal": 9, + "name": "sequences!: Vec", + "type_info": "Json" + }, + { + "ordinal": 10, + "name": "annotation_exists!: bool", + "type_info": "Bool" + } + ], + "parameters": { + "Left": [ + "Int4Array" + ] + }, + "nullable": [ + false, + false, + false, + false, + false, + null, + false, + null, + null, + null, + null + ] + }, + "hash": "cedb65e8561dfff84cfab1eac28e03f082ea8190a47283fb6662e2d9a6246c57" +} diff --git a/.sqlx/query-d6aca7480253eca9b91da9f68aa7156aa3bcf6f8e2d743ea727a2f7abfb69f1b.json b/.sqlx/query-d6aca7480253eca9b91da9f68aa7156aa3bcf6f8e2d743ea727a2f7abfb69f1b.json new file mode 100644 index 0000000..e765aae --- /dev/null +++ b/.sqlx/query-d6aca7480253eca9b91da9f68aa7156aa3bcf6f8e2d743ea727a2f7abfb69f1b.json @@ -0,0 +1,79 @@ +{ + "db_name": "PostgreSQL", + "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM translations\n JOIN authors ON authors.id = translations.author\n WHERE translations.book = b.id\n ) AS \"translators!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', sequences.id,\n 'name', sequences.name\n )\n )\n FROM book_sequences\n JOIN sequences ON sequences.id = book_sequences.sequence\n WHERE book_sequences.book = b.id\n ) AS \"sequences!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\"\n FROM books b\n JOIN book_authors ba ON b.id = ba.book\n WHERE b.is_deleted = false AND ba.author = $1 AND b.lang = ANY($2)\n ORDER BY b.title ASC\n OFFSET $3\n LIMIT $4\n ", + "describe": { + "columns": [ + { + "ordinal": 0, + "name": "id", + "type_info": "Int4" + }, + { + "ordinal": 1, + "name": "title", + "type_info": "Varchar" + }, + { + "ordinal": 2, + "name": "lang", + "type_info": "Varchar" + }, + { + "ordinal": 3, + "name": "file_type", + "type_info": "Varchar" + }, + { + "ordinal": 4, + "name": "year", + "type_info": "Int2" + }, + { + "ordinal": 5, + "name": "available_types!: Vec", + "type_info": "TextArray" + }, + { + "ordinal": 6, + "name": "uploaded", + "type_info": "Date" + }, + { + "ordinal": 7, + "name": "translators!: Vec", + "type_info": "Json" + }, + { + "ordinal": 8, + "name": "sequences!: Vec", + "type_info": "Json" + }, + { + "ordinal": 9, + "name": "annotation_exists!: bool", + "type_info": "Bool" + } + ], + "parameters": { + "Left": [ + "Int4", + "TextArray", + "Int8", + "Int8" + ] + }, + "nullable": [ + false, + false, + false, + false, + false, + null, + false, + null, + null, + null + ] + }, + "hash": "d6aca7480253eca9b91da9f68aa7156aa3bcf6f8e2d743ea727a2f7abfb69f1b" +} diff --git a/.sqlx/query-df08b13f0f084e01ce2e5d9e31ed1dc0e7499483f1bbcdafc2b85c5ad0e3b956.json b/.sqlx/query-df08b13f0f084e01ce2e5d9e31ed1dc0e7499483f1bbcdafc2b85c5ad0e3b956.json new file mode 100644 index 0000000..3dd039d --- /dev/null +++ b/.sqlx/query-df08b13f0f084e01ce2e5d9e31ed1dc0e7499483f1bbcdafc2b85c5ad0e3b956.json @@ -0,0 +1,113 @@ +{ + "db_name": "PostgreSQL", + "query": "\n SELECT\n b.id,\n b.title,\n b.lang,\n b.file_type,\n b.year,\n CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS \"available_types!: Vec\",\n b.uploaded,\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM book_authors\n JOIN authors ON authors.id = book_authors.author\n WHERE book_authors.book = b.id\n ) AS \"authors!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', authors.id,\n 'first_name', authors.first_name,\n 'last_name', authors.last_name,\n 'middle_name', authors.middle_name,\n 'annotation_exists', EXISTS(\n SELECT * FROM author_annotations WHERE author = authors.id\n )\n )\n )\n FROM translations\n JOIN authors ON authors.id = translations.author\n WHERE translations.book = b.id\n ) AS \"translators!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', sequences.id,\n 'name', sequences.name\n )\n )\n FROM book_sequences\n JOIN sequences ON sequences.id = book_sequences.sequence\n WHERE book_sequences.book = b.id\n ) AS \"sequences!: Vec\",\n (\n SELECT\n JSON_AGG(\n JSON_BUILD_OBJECT(\n 'id', genres.id,\n 'code', genres.code,\n 'description', genres.description,\n 'meta', genres.meta,\n 'source', JSON_BUILD_OBJECT(\n 'id', sources.id,\n 'name', sources.name\n )\n )\n )\n FROM book_genres\n JOIN genres ON genres.id = book_genres.genre\n JOIN sources ON sources.id = genres.source\n WHERE book_genres.book = b.id\n ) AS \"genres!: Vec\",\n EXISTS(\n SELECT * FROM book_annotations WHERE book = b.id\n ) AS \"annotation_exists!: bool\",\n (\n SELECT\n JSON_BUILD_OBJECT(\n 'id', sources.id,\n 'name', sources.name\n )\n FROM sources\n WHERE sources.id = b.source\n ) AS \"source!: Source\",\n b.remote_id,\n b.is_deleted,\n b.pages\n FROM books b\n WHERE b.source = $1 AND b.remote_id = $2\n ", + "describe": { + "columns": [ + { + "ordinal": 0, + "name": "id", + "type_info": "Int4" + }, + { + "ordinal": 1, + "name": "title", + "type_info": "Varchar" + }, + { + "ordinal": 2, + "name": "lang", + "type_info": "Varchar" + }, + { + "ordinal": 3, + "name": "file_type", + "type_info": "Varchar" + }, + { + "ordinal": 4, + "name": "year", + "type_info": "Int2" + }, + { + "ordinal": 5, + "name": "available_types!: Vec", + "type_info": "TextArray" + }, + { + "ordinal": 6, + "name": "uploaded", + "type_info": "Date" + }, + { + "ordinal": 7, + "name": "authors!: Vec", + "type_info": "Json" + }, + { + "ordinal": 8, + "name": "translators!: Vec", + "type_info": "Json" + }, + { + "ordinal": 9, + "name": "sequences!: Vec", + "type_info": "Json" + }, + { + "ordinal": 10, + "name": "genres!: Vec", + "type_info": "Json" + }, + { + "ordinal": 11, + "name": "annotation_exists!: bool", + "type_info": "Bool" + }, + { + "ordinal": 12, + "name": "source!: Source", + "type_info": "Json" + }, + { + "ordinal": 13, + "name": "remote_id", + "type_info": "Int4" + }, + { + "ordinal": 14, + "name": "is_deleted", + "type_info": "Bool" + }, + { + "ordinal": 15, + "name": "pages", + "type_info": "Int4" + } + ], + "parameters": { + "Left": [ + "Int2", + "Int4" + ] + }, + "nullable": [ + false, + false, + false, + false, + false, + null, + false, + null, + null, + null, + null, + null, + null, + false, + false, + true + ] + }, + "hash": "df08b13f0f084e01ce2e5d9e31ed1dc0e7499483f1bbcdafc2b85c5ad0e3b956" +} diff --git a/src/views/authors.rs b/src/views/authors.rs index 338bfae..364d81e 100644 --- a/src/views/authors.rs +++ b/src/views/authors.rs @@ -212,7 +212,7 @@ async fn get_author_books( b.lang, b.file_type, b.year, - CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS "available_types!: Vec", + CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS "available_types!: Vec", b.uploaded, ( SELECT @@ -282,7 +282,7 @@ async fn get_author_books_available_types( r#" SELECT b.id, - CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS "available_types!: Vec" + CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS "available_types!: Vec" FROM books b JOIN book_authors ba ON b.id = ba.book WHERE b.is_deleted = false AND ba.author = $1 AND b.lang = ANY($2) diff --git a/src/views/books.rs b/src/views/books.rs index 9a68780..b96fb20 100644 --- a/src/views/books.rs +++ b/src/views/books.rs @@ -58,7 +58,7 @@ pub async fn get_books( b.lang, b.file_type, b.year, - CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS "available_types!: Vec", + CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS "available_types!: Vec", b.uploaded, ( SELECT @@ -180,7 +180,7 @@ pub async fn get_base_books( r#" SELECT b.id, - CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS "available_types!: Vec" + CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS "available_types!: Vec" FROM books b WHERE lang = ANY($1) AND ($2::boolean IS NULL OR is_deleted = $2) AND @@ -241,7 +241,7 @@ pub async fn get_random_book( b.lang, b.file_type, b.year, - CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS "available_types!: Vec", + CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS "available_types!: Vec", b.uploaded, ( SELECT @@ -349,7 +349,7 @@ pub async fn get_remote_book( b.lang, b.file_type, b.year, - CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS "available_types!: Vec", + CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS "available_types!: Vec", b.uploaded, ( SELECT @@ -487,7 +487,7 @@ pub async fn search_books( b.lang, b.file_type, b.year, - CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS "available_types!: Vec", + CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS "available_types!: Vec", b.uploaded, ( SELECT @@ -569,7 +569,7 @@ pub async fn get_book(db: Database, Path(book_id): Path) -> impl IntoRespon b.lang, b.file_type, b.year, - CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS "available_types!: Vec", + CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS "available_types!: Vec", b.uploaded, ( SELECT diff --git a/src/views/sequences.rs b/src/views/sequences.rs index 592f75b..f549354 100644 --- a/src/views/sequences.rs +++ b/src/views/sequences.rs @@ -137,7 +137,7 @@ async fn get_sequence_available_types( r#" SELECT b.id, - CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS "available_types!: Vec" + CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS "available_types!: Vec" FROM books b JOIN book_sequences bs ON b.id = bs.book WHERE @@ -211,7 +211,7 @@ async fn get_sequence_books( b.lang, b.file_type, b.year, - CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS "available_types!: Vec", + CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS "available_types!: Vec", b.uploaded, ( SELECT diff --git a/src/views/translators.rs b/src/views/translators.rs index 835d162..d2acd15 100644 --- a/src/views/translators.rs +++ b/src/views/translators.rs @@ -84,7 +84,7 @@ async fn get_translated_books( b.lang, b.file_type, b.year, - CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS "available_types!: Vec", + CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS "available_types!: Vec", b.uploaded, ( SELECT @@ -145,7 +145,7 @@ async fn get_translated_books_available_types( r#" SELECT b.id, - CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip'] ELSE ARRAY[b.file_type] END AS "available_types!: Vec" + CASE WHEN b.file_type = 'fb2' THEN ARRAY['fb2', 'epub', 'mobi', 'fb2zip']::text[] ELSE ARRAY[b.file_type]::text[] END AS "available_types!: Vec" FROM books b JOIN book_authors ba ON b.id = ba.book WHERE