hide tags from the public
This commit is contained in:
		@@ -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({
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user