Commit graph

138 commits

Author SHA1 Message Date
Yorhel
83ab6c3671 Get rid of package categories
Whether or not the package name itself or the (category,name) tuple
uniquely identified a package within a system has been a source of
confusion for a long time. Back in
03d278e4ff I ended up playing playing it
"safe" by going for (category,name), but in practice this doesn't make a
whole lot of sense. While it's *possible* for the same package name to
refer to completely different packages in different "categories", in
reality distributions can't sanely support this anyway.

For distributions where the category referred to a repository, the only
cases where the same package name was used in different repos was when
the package has moved from one repo to another. Those should certainly
not be treated as different packages.

For distributions where the category really referred to a category,
there's the Debian approach where the category is purely a tag and
doesn't help identify the package in any way, and then there's FreeBSD
where the category technically ought to be part of the name.  There were
a few cases where FreeBSD used categories to separate out different
versions of the same package (e.g. ipv6 vs non-ipv6), but none were
relevant for man pages so I ended up merging those as well.

Getting rid of the categories simplifies and shortens URLs, unclutters
the UI a little bit and merges the packages in listings that should've
been merged all along.

Migration script:

  -- Merge packages that are in multiple categories.
  -- All versions are moved to the package with the lowest ID.
  -- If the same version already exists in a lower ID, the higher-ID version is deleted.
  BEGIN;
  WITH migrate(old, new, second) AS (
    SELECT q.id, MIN(p.id), MAX(p.id)
      FROM packages p
      JOIN packages q ON q.id > p.id AND p.system = q.system AND p.name = q.name
     GROUP BY q.id
  ), ded(n) AS (
    UPDATE packages SET dead = false
      FROM migrate m
      JOIN packages q ON q.id = m.old
     WHERE packages.id = m.new AND packages.dead AND NOT q.dead
    RETURNING 1
  ), mov(n) AS (
    UPDATE package_versions SET package = m.new
      FROM migrate m
     WHERE package_versions.package = m.old
       AND NOT EXISTS(
          SELECT 1
            FROM package_versions v
           WHERE v.package IN(m.new, m.second)
             AND v.version = package_versions.version)
    RETURNING 1
  ), del(n) AS (
    DELETE FROM packages WHERE id IN(SELECT old FROM migrate)
    RETURNING 1
  ) SELECT (SELECT count(*) FROM migrate) AS migrate,
           (SELECT count(*) FROM ded) AS ded,
           (SELECT count(*) FROM mov) AS mov,
           (SELECT count(*) FROM del) AS del;

  ALTER TABLE packages DROP CONSTRAINT packages_system_name_category_key;
  CREATE UNIQUE INDEX packages_system_name_key ON packages (system, name);
  ALTER TABLE packages DROP COLUMN category;
  COMMIT;
2024-04-28 10:37:04 +02:00
Yorhel
bc26633fc7 UI: Replace "locations" tab with separate page
Removing the JS requirement and (hopefully) providing a more useful
view into the same data.

This view now also lists other man pages that happen to have the same
contents.
2024-04-27 12:56:10 +02:00
Yorhel
d8f452e47e Add OpenBSD 2024-04-23 13:40:10 +02:00
Yorhel
30a8353089 www: Fix link to schema.sql 2024-04-14 12:54:07 +02:00
Yorhel
bb28e17bbd www: Keep links to other man pages within the same system
The sidebar links should actually stay within the same system as well,
it's quite confusing this way. Meh.
2024-04-14 12:35:54 +02:00
Yorhel
c9eef9e10a Index NetBSD 2024-04-14 11:35:04 +02:00
Yorhel
4356620d1f Fix URL to NetBSD man pages 2024-02-02 19:55:22 +01:00
Yorhel
c2a1dd6416 Some fixes and repo updates 2023-11-26 10:33:30 +01:00
Yorhel
f5b35efdc3 www: Prefer <name>.<section> pages over <name> 2023-05-26 12:22:47 +02:00
Yorhel
962ded97f5 Fix a shorthash encoding confusion 2023-04-30 09:01:38 +02:00
Yorhel
33efd07715 Fix the "prefer lower sections" man page selection rule 2022-07-26 14:58:29 +02:00
Yorhel
fa8e084879 Bunch of fixes 2022-01-10 20:05:09 +01:00
Yorhel
997dd8728c www: Add some new flexible URL formats
New canonical permalink format is now:

  /man.<hash>/<system>/<name>.<section>

Including the system name makes for more predictable navigation between
man pages of the same system.

This new URL format also fixes a problem with not being able to browse
from a package's page to the correct page when the package has multiple
versions of the same man.

This is also yak shaving for some new navigation and formatting features
I have planned.
2021-12-19 17:38:14 +01:00
Yorhel
46b4a5f7e0 Change contact email
contact@manned.org works fine, too, except I don't have outgoing mail
setup to go through an smtp proxy so I can't reply to Outlook and gmail
(and a few others). Seriously, fuck providers who can't see the
difference between spam messages and human replies to legitimate mails.
2021-12-17 10:17:09 +01:00
Yorhel
b39d038811 html: Apply appropriate "lang" attributes
Primarily so that browsers can choose the correct font for CJK pages.
2021-12-16 16:26:00 +01:00
Yorhel
f57c474932 Fixup: remove experimental shorthash URL format 2021-12-16 13:51:10 +01:00
Yorhel
c6f53fb0fb Add system selector to man pages + other stuff
The /man/* URLs now directly open man pages rather than redirecting to
the permalink format, so that the extra source information can be used
to provide a better UI for switching between systems and packages
(currently only between systems).

Step one in getting rid of the JS location/version selection thingies.
Still quite a bit more to do, but I haven't worked it all out yet.
2021-12-16 13:12:14 +01:00
Yorhel
5194ed95cf A few more about page tweaks 2021-12-15 09:52:07 +01:00
Yorhel
2d1dca24e5 Update about page with new license 2021-12-14 15:56:33 +01:00
Yorhel
f376f1f137 Large-ish SQL schema revamp/optimizations
Primarily aimed at reducing the size of the old 'man' (now: files)
table, using smaller integers to refer to man contents and text fields,
and storing a shorthash as an integer for quick lookups. This better
normalization also removes the need to keep a separate 'man_index' cache
for the search function.

The old schema wasn't necessarily bad, but I was in the mood for some
optimizations. And a little cleanup.

Prolly introduces a bunch of new bugs, I haven't tested this too well.
2021-12-14 15:08:54 +01:00
Yorhel
6f7f59c6df Fix homepage reflow while images are loading
Apparently setting the image sizes in CSS wasn't enough, it was still
reflowing in Firefox.
2021-12-14 11:40:14 +01:00
Yorhel
b27d55215a Arch: Mark deleted packages as dead and hide them from listings
We've got a lot of packages in the DB that have long been removed from
the Arch repos. These are still indexed, but won't clutter the package
listing anymore.

Also fixed an issue with packages.id numbers getting rather large
because the indexer allocates a new ID for every package on every
update.
2021-12-13 08:18:17 +01:00
Yorhel
f3323de5e4 churn: Remove systems.relorder column + misc cleanup 2021-12-13 06:56:22 +01:00
Yorhel
3db1283a16 Change to more minimalistic website design + few HTML modernizations
I didn't touch the actual man page pages yet, but they seem to have
mostly survived my CSS changes. There's a LOT of general UI improvements
to be done, while this commit is really just a different style of paint.
2021-12-12 17:29:26 +01:00
Yorhel
b531f71ab0 Index available Alpine Linux repositories 2021-12-11 18:08:46 +01:00
Yorhel
82a626b7d4 indexer+www: Support Alpine Linux repos 2021-12-11 16:18:07 +01:00
Yorhel
29a6f784f5 wwww: Fix escape_like() to also escape backslash 2021-10-12 13:53:01 +02:00
Yorhel
d0896806c1 Add Debian testing + prefer that instead of Ubuntu 2021-06-10 09:33:32 +02:00
Yorhel
a96aeb6310 Fix /man/* redirects
Forgot to update these functions in the rewrite.
2021-06-09 16:56:43 +02:00
Yorhel
98e4f014ba Rewrite Perl web backend to modern TUWF style
Lots of churn for no real benefit. \o/
2021-06-09 13:43:42 +02:00
Yorhel
c7f85a5685 Workaround issue with spawning child processes in TUWF debug mode
I had applied the same workaround to VNDB's code some time ago. Really
need to figure out why this happens...
2021-04-19 07:45:15 +02:00
Yorhel
212fc725ba Update man page selection algortihm to bias Ubuntu
Should really be Debian, but we only index Debian stable at the moment
and it tends to lag behind Ubuntu a bit. This extra bias is intended to
solve (part of) the issue with distro-specific tooling like 'ifup'.

This really should be updated to have a generic preference order for all
distros, but that's not as easy to implement.

Fixes #1.
2021-04-19 07:39:27 +02:00
Yorhel
89fc82f391 Handle version-indepentend distro man-page redirects
E.g. /man/debian/ncdu
As proposed in issue #1.
2021-04-19 07:26:04 +02:00
Yorhel
92bc63bbde Typo fix on about page 2021-04-17 10:20:08 +02:00
Yorhel
4093dc1911 Fix external link to Arch man pages site 2021-04-14 09:01:06 +02:00
Yorhel
91b43d220b Fix attempts to resolve man pages without name
A bot triggered 'GET /.env', resulting in a lookup on section='env' but
no name. Slow and useless...
2020-10-16 12:49:49 +02:00
Yorhel
bf3c97f981 index.pl: Serve static files when in direct HTTP server mode
Makes it easier to setup a quick development server.
2020-08-07 10:23:40 +02:00
Yorhel
ea0a7a4b71 Link updates 2019-10-22 17:17:05 +02:00
Yorhel
1ce29f7c3f Fix dbManPref(name => "0")
Fixes a timeout and eventual 500 error on https://manned.org/0
2019-06-25 18:54:43 +02:00
Yorhel
958e957791 Add link to mankier.com 2019-03-27 10:50:19 +01:00
Yorhel
cfc656bf12 Convert README to markdown + update git URLs 2018-06-15 10:52:21 +02:00
Yorhel
5480fc206e Link updates 2018-03-25 08:14:53 +02:00
Yorhel
b382189fb6 Hopefully properly fixed the weird system layout on home page 2018-01-21 08:34:01 +01:00
Yorhel
8031a90989 Some improvements to the about text + link to the new Arch man pages 2018-01-21 08:23:57 +01:00
Yorhel
035538f156 Add CentOS 2018-01-21 08:13:05 +01:00
Yorhel
fd657824b3 Add database downloads 2017-12-23 14:28:16 +01:00
Yorhel
aedb1795c1 Favor more recent packages in man page selection 2017-10-27 09:00:46 +02:00
Yorhel
2388aaefcc Stop syncing Fedora 24; Add FreeBSD 11.1 and Ubuntu 17.10 2017-10-20 21:37:33 +02:00
Yorhel
72cb1ff184 Add Ubuntu 17.04 2017-04-14 17:09:18 +02:00
Yorhel
34e8ee8603 Add link to Debian man pages 2017-02-26 09:07:37 +01:00