hide tags from the public
This commit is contained in:
parent
d0f8cb5acb
commit
af4c48f351
|
@ -14,6 +14,7 @@
|
|||
},
|
||||
"allowedModes": [ "sfw", "nsfw", "untagged", "all" ],
|
||||
"allowedMimes": [ "audio", "image", "video" ],
|
||||
"nsfp": [],
|
||||
"websrv": {
|
||||
"port": "8080",
|
||||
"paths": {
|
||||
|
|
|
@ -4,8 +4,10 @@ import cfg from "../config.mjs";
|
|||
import fs from "fs";
|
||||
import url from "url";
|
||||
|
||||
const globalfilter = cfg.nsfp.map(n => `tag_id = ${n}`).join(' or ');
|
||||
|
||||
export default {
|
||||
getf0cks: async (o = { user, tag, mime, page, mode, fav }) => {
|
||||
getf0cks: async (o = { user, tag, mime, page, mode, fav, session }) => {
|
||||
const user = o.user ? decodeURI(o.user) : null;
|
||||
const tag = lib.parseTag(o.tag ?? null);
|
||||
const mime = o.mime ?? null;
|
||||
|
@ -29,7 +31,7 @@ export default {
|
|||
${ o.fav ? db`and "user".user ilike ${'%'+user+'%'}` : db`` }
|
||||
${ user ? db`and items.username ilike ${'%'+user+'%'}` : db`` }
|
||||
${ mime ? db`and items.mime ilike ${smime}` : db`` }
|
||||
and items.id not in (select item_id from tags_assign where item_id = items.id and tag_id = 9912) --public filter
|
||||
${ !o.session ? db`and items.id not in (select item_id from tags_assign where item_id = items.id and (${db.unsafe(globalfilter)}))` : db`` }
|
||||
group by items.id, tags.tag
|
||||
`)?.length || 0;
|
||||
|
||||
|
@ -62,7 +64,7 @@ export default {
|
|||
${ o.fav ? db`and "user".user ilike ${'%'+user+'%'}` : db`` }
|
||||
${ user ? db`and items.username ilike ${'%'+user+'%'}` : db`` }
|
||||
${ mime ? db`and items.mime ilike ${smime}` : db`` }
|
||||
and items.id not in (select item_id from tags_assign where item_id = items.id and tag_id = 9912) --public filter
|
||||
${ !o.session ? db`and items.id not in (select item_id from tags_assign where item_id = items.id and (${db.unsafe(globalfilter)}))` : db`` }
|
||||
group by items.id, tags.tag, ta.tag_id
|
||||
order by items.id desc
|
||||
offset ${offset}
|
||||
|
@ -90,7 +92,7 @@ export default {
|
|||
tmp
|
||||
};
|
||||
},
|
||||
getf0ck: async (o = ({ user, tag, mime, itemid, mode })) => {
|
||||
getf0ck: async (o = ({ user, tag, mime, itemid, mode, session })) => {
|
||||
const user = o.user ? decodeURI(o.user) : null;
|
||||
const tag = lib.parseTag(o.tag ?? null);
|
||||
const mime = (o.mime ?? "");
|
||||
|
@ -108,75 +110,26 @@ export default {
|
|||
};
|
||||
}
|
||||
|
||||
let items;
|
||||
|
||||
if(o.fav) {
|
||||
items = db`
|
||||
select "items".*
|
||||
from "favorites"
|
||||
left join "items" on "items".id = "favorites".item_id
|
||||
left join "user" on "user".id = "favorites".user_id
|
||||
${ tag
|
||||
? db`
|
||||
inner join (
|
||||
select "tags_assign".item_id, "tags".tag
|
||||
from "tags"
|
||||
left join "tags_assign" on "tags_assign".tag_id = "tags".id
|
||||
where "tags".tag ilike ${'%' + tag + '%'}
|
||||
group by "tags_assign".item_id, "tags".tag
|
||||
) as st on st.item_id = "items".id`
|
||||
: db``
|
||||
}
|
||||
where ${db.unsafe(modequery)}
|
||||
and "user".user ilike ${user}
|
||||
${ mime
|
||||
? db`and "items".mime ilike ${mime + '/%'}`
|
||||
: db``
|
||||
}
|
||||
${ tag
|
||||
? db`group by st.tag, st.item_id, "items".id`
|
||||
: db`group by "items".id, "favorites".user_id, "favorites".item_id, "user".id`
|
||||
}
|
||||
order by "items".id desc
|
||||
`;
|
||||
}
|
||||
else {
|
||||
items = db`
|
||||
select "items".*
|
||||
from "items"
|
||||
${ tag
|
||||
? db`
|
||||
inner join (
|
||||
select "tags_assign".item_id, "tags_assign".tag_id, "tags".tag
|
||||
from "tags"
|
||||
left join "tags_assign" on "tags_assign".tag_id = "tags".id
|
||||
where "tags".tag ilike ${'%' + tag + '%'}
|
||||
group by "tags_assign".item_id, "tags".tag, "tags_assign".tag_id
|
||||
) as st on st.item_id = "items".id`
|
||||
: db``
|
||||
}
|
||||
where ${db.unsafe(modequery)}
|
||||
${ user
|
||||
? db`and "items".username ilike ${'%' + user + '%'}`
|
||||
: db``
|
||||
}
|
||||
${ mime
|
||||
? db`and "items".mime ilike ${mime + '/%'}`
|
||||
: db``
|
||||
}
|
||||
${ tag
|
||||
? db`group by st.item_id, "items".id, st.tag_id`
|
||||
: db`group by "items".id`
|
||||
}
|
||||
order by "items".id desc
|
||||
`;
|
||||
}
|
||||
const items = await db`
|
||||
select distinct on (items.id)
|
||||
items.*
|
||||
from items
|
||||
left join tags_assign on tags_assign.item_id = items.id
|
||||
left join tags on tags.id = tags_assign.tag_id
|
||||
left join favorites on favorites.item_id = items.id
|
||||
left join "user" on "user".id = favorites.user_id
|
||||
left join tags_assign ta on ta.item_id = items.id and (ta.tag_id = 1 or ta.tag_id = 2)
|
||||
where
|
||||
${ db.unsafe(modequery) }
|
||||
${ tag ? db`and tags.normalized ilike ${'%'+tag+'%'}` : db`` }
|
||||
${ o.fav ? db`and "user".user ilike ${'%'+user+'%'}` : db`` }
|
||||
${ user ? db`and items.username ilike ${'%'+user+'%'}` : db`` }
|
||||
${ mime ? db`and items.mime ilike ${smime}` : db`` }
|
||||
${ !o.session ? db`and items.id not in (select item_id from tags_assign where item_id = items.id and (${db.unsafe(globalfilter)}))` : db`` }
|
||||
group by items.id, tags.tag, ta.tag_id
|
||||
order by items.id desc
|
||||
`;
|
||||
|
||||
items = await items;
|
||||
|
||||
if(tag)
|
||||
items = items.filter((v, i, s) => i === s.findIndex(t => t.id === v.id));
|
||||
|
||||
const item = items.findIndex(i => i.id === itemid);
|
||||
const actitem = items[item];
|
||||
|
||||
|
@ -245,71 +198,33 @@ export default {
|
|||
};
|
||||
return data;
|
||||
},
|
||||
getRandom: async (o = ({ user, tag, mime, mode })) => {
|
||||
getRandom: async (o = ({ user, tag, mime, mode, session })) => {
|
||||
const user = o.user ? decodeURI(o.user) : null;
|
||||
const tag = lib.parseTag(o.tag ?? null);
|
||||
const mime = (o.mime ?? "");
|
||||
const smime = cfg.allowedMimes.includes(mime) ? mime + "/%" : mime === "" ? "%" : "%";
|
||||
|
||||
const modequery = mime == "audio" ? lib.getMode(0) : lib.getMode(o.mode ?? 0);
|
||||
|
||||
let item;
|
||||
if(o.fav) { // dood lol
|
||||
item = db`
|
||||
select "items".*
|
||||
from "favorites"
|
||||
left join "items" on "items".id = "favorites".item_id
|
||||
left join "user" on "user".id = "favorites".user_id
|
||||
${ tag
|
||||
? db`
|
||||
inner join (
|
||||
select "tags_assign".item_id, "tags".tag
|
||||
from "tags"
|
||||
left join "tags_assign" on "tags_assign".tag_id = "tags".id
|
||||
where "tags".tag ilike ${'%' + tag + '%'}
|
||||
group by "tags_assign".item_id, "tags".tag
|
||||
) as st on st.item_id = "items".id`
|
||||
: db``
|
||||
}
|
||||
where ${db.unsafe(modequery)}
|
||||
and "user".user ilike ${user}
|
||||
${ mime
|
||||
? db`and "items".mime ilike ${mime + '/%'}`
|
||||
: db``
|
||||
}
|
||||
order by random()
|
||||
limit 1
|
||||
`;
|
||||
}
|
||||
else {
|
||||
item = db`
|
||||
select *
|
||||
from "items"
|
||||
${ tag
|
||||
? db`
|
||||
inner join (
|
||||
select "tags_assign".item_id, "tags".tag
|
||||
from "tags"
|
||||
left join "tags_assign" on "tags_assign".tag_id = "tags".id
|
||||
where "tags".tag ilike ${'%' + tag + '%'}
|
||||
group by "tags_assign".item_id, "tags".tag
|
||||
) as st on st.item_id = "items".id`
|
||||
: db``
|
||||
}
|
||||
where ${db.unsafe(modequery)}
|
||||
${ user
|
||||
? db`and "items".username ilike ${'%' + user + '%'}`
|
||||
: db``
|
||||
}
|
||||
${ mime
|
||||
? db`and "items".mime ilike ${mime + '/%'}`
|
||||
: db``
|
||||
}
|
||||
order by random()
|
||||
limit 1
|
||||
`;
|
||||
}
|
||||
|
||||
item = await item;
|
||||
const item = await db`
|
||||
select
|
||||
items.id
|
||||
from items
|
||||
left join tags_assign on tags_assign.item_id = items.id
|
||||
left join tags on tags.id = tags_assign.tag_id
|
||||
left join favorites on favorites.item_id = items.id
|
||||
left join "user" on "user".id = favorites.user_id
|
||||
where
|
||||
${ db.unsafe(modequery) }
|
||||
${ tag ? db`and tags.normalized ilike ${'%'+tag+'%'}` : db`` }
|
||||
${ o.fav ? db`and "user".user ilike ${'%'+user+'%'}` : db`` }
|
||||
${ user ? db`and items.username ilike ${'%'+user+'%'}` : db`` }
|
||||
${ mime ? db`and items.mime ilike ${smime}` : db`` }
|
||||
${ !o.session ? db`and items.id not in (select item_id from tags_assign where item_id = items.id and (${db.unsafe(globalfilter)}))` : db`` }
|
||||
group by items.id, tags.tag
|
||||
order by random()
|
||||
limit 1
|
||||
`;
|
||||
|
||||
if(item.length === 0) {
|
||||
return {
|
||||
|
|
|
@ -34,12 +34,14 @@ export default (router, tpl) => {
|
|||
const f0cks = await f0cklib.getf0cks({
|
||||
user: user,
|
||||
mode: req.session.mode,
|
||||
fav: false
|
||||
fav: false,
|
||||
session: !!req.session
|
||||
});
|
||||
const favs = await f0cklib.getf0cks({
|
||||
user: user,
|
||||
mode: req.session.mode,
|
||||
fav: true
|
||||
fav: true,
|
||||
session: !!req.session
|
||||
});
|
||||
|
||||
if('items' in f0cks)
|
||||
|
@ -66,7 +68,8 @@ export default (router, tpl) => {
|
|||
page: req.params.page,
|
||||
itemid: req.params.itemid,
|
||||
fav: req.params.mode == 'favs',
|
||||
mode: req.session.mode
|
||||
mode: req.session.mode,
|
||||
session: !!req.session
|
||||
});
|
||||
if(!data.success) {
|
||||
return res.reply({
|
||||
|
|
Loading…
Reference in New Issue
Block a user