path: root/lib/VNDB
AgeCommit message (Collapse)AuthorFilesLines
9 hoursTraitPage: Rewrite to use new AdvSearch systemHEADmasterYorhel1-1/+1
Largely a copy-paste from TagPage.
9 hoursChars::List: Switch to new AdvSearch systemYorhel1-4/+4
TODO: Add VN subquery and migrate trait pages.
6 daysv2rw: Convert /opensearch.xml description + ancient typo fixYorhel1-20/+0
6 daysv2rw: Convert /r/engines (+ make it link to new AdvSearch system)Yorhel1-30/+0
6 daysReplace references to old /v/all pathYorhel1-2/+2
Old /v/<char> URLs are still supported, but the main listing is at /v.
6 daysAdvSearch: Time to put this live.2.29Yorhel3-14/+15
Moved old release browser, VN browser and tag pages to /old/, moved /experimental/ pages to /, removed warnings and updated some references.
12 daysrefactor: Move & simplify SkinFile into VNDB::SkinsYorhel1-0/+29
VNDB::Skins now behaves the same way as VNDB::Config - it provides a single function that returns all the info you'll need. This removes the tuwf->{skins} global variable, making skin-querying code independent of the TUWF object, and, again, moving some library-related functionality out of
12 daysVNDB::Util::LayoutHTML: Fix reference to config params in old codeYorhel1-1/+2
Turns out I forgot something in 3fc190f1898342d63b1308a83152fe45a88f7c3f
12 daysv2rw: Some cleanup; Move some functionality out of; Move config out ↵Yorhel2-65/+17
of tuwf->{..} Config had been in a separate config->{..} object for a while now, old code doesn't need it anymore so we can finally get rid of the tuwf->{..} compact. is not really the place for library code, so moved that around. The old imgpath() and imgurl() functions weren't used anymore, so could be safely replaced with the new functions that take the new vndbid format. (All this to make it easier to write separate scripts that call into VNDB::/VNWeb:: code as a library) Remove Image::Magick dependency + use new indentation styleYorhel1-0/+1
Just pointless cleanup because I'm not in the mood to do meaningful work...
2020-12-24Convert images by running convert instead of loading Image::MagickYorhel1-0/+1
This has three potential advantages: - Memory used for image processing is released immediately, thus resulting in lower average memory usage. I've yet to test how significant this is in practice... I'm not entirely sure how VNDB's memory use is distributed (not that it's really a problem, but if I see something that could be optimized I try to optimize it. First world engineering problems) - The 'convert' command can be better sandboxed for increased security. - Removes a dependency on a Perl module... except still uses it, but that can be rewritten as well if necessary. In the process I found out that the old code's attempt to sharpen the image after resizing was buggy and the sharpening was never applied. This new code *does* apply the sharpen filter, so newly uploaded images will be visually different (if resized). I also found that imagemagick's built-in ratio-preserving resize sometimes ends up with different image dimensions than my imgsize(). I think that's a bug in my imgsize function, but it does result in a discrepancy that should prolly be resolved as it may result in screenshot thumbnails being displayed incorrectly.
2020-12-16ExtLinks/cleanup: Remove dependency on duplicated urls in VNDB::ConfigYorhel2-10/+3
The duplication has tripped me up before, in f3420b701aa033c90678216bd36d374c10e3ac9f
2020-12-15Release/ExtLinks: Gyutto regex fix + Fakku + NovelGameYorhel1-1/+9
2020-12-14Releases/ExtLinks: + Freem, App Store, Google Play, Animate GamesYorhel1-0/+16
2020-11-11AdvSearch: Fix using encoded form on pagination + abstraction changesYorhel1-1/+2
I was originally planning to have only two query encoding forms: Fully normalized JSON form and compact encoded form. But converting between the two is kind of annoying and requires lookup tables, which makes the normalized JSON form inconvenient for Elm. Hence I added a third form: compact JSON form, which has the same data type transformations applied as the compact encoded form, but still retains the JSON encoding and structure. Converting between compact JSON form and compact encoded form is fairly trivial. Downside is that this also implies that Query handling in Elm needs to be done through field numbers rather than names, which is more error prone - but this can be solved by generating an Elm module with a variable for each field numer. Another downside is that this makes it impossible to implement a normalized-form query viewer and editor in Elm without hitting the server for conversions - but such a feature is not very important anyway. Other abstraction change is that now exposes an object-oriented interface, the object can keep track of the different query forms and seems like a more suitable solution in this case.
2020-11-10Add Persian languageYorhel1-0/+1 Flag is based on with a light green brackground.
2020-11-03Multi::Denpa: Update affiliate crawler to use their new siteYorhel2-2/+2
2020-11-02ExtLinks: Also fix URL format in the default configYorhel1-1/+1
2020-11-02ExtLinks: Denpa URL changeYorhel1-2/+2
2020-10-16v2rw: Convert producers listing & searchYorhel1-58/+0
Now featuring full pagination & flexible columns.
2020-10-13notifications: Add subscribing for (un)applications of traitsYorhel1-0/+1
2020-10-02v2rw: Move redirects + cleanup some moreYorhel3-69/+1
2020-09-30Fix old reference to VNWeb::Tags::*Yorhel1-1/+1
2020-09-30v2rw/Tags::Index: Re-use tag index for trait indexYorhel1-80/+0
This code is pretty easy to re-use.
2020-09-30v2rw/Tags::Index: Rewrite the tag indexYorhel1-79/+0
Nothing new, but I do see more avenues for consolidation with traits.
2020-09-29v2rw/Tag::List: Re-use tag listing to implement trait listingYorhel1-72/+0
Duplicating that code was really too much, the listings are way too similar.
2020-09-29v2rw/TraitEdit: Rewrite trait edit form + cleanup bunch of old codeYorhel5-553/+3
This was the last form in the old v2 code, so this allowed me to get rid of the old form validation and generation abstractions. The form is mostly a duplicate of the tag editing form, as expected. It's really annoying to have to maintain pretty much duplicate code for tags and traits, but there are just enough differences that the complexity of sharing code or creating a new abstraction outweigh the benefits. :(
2020-09-27v2rw/Tags::List: Re-implement & improve the tag listYorhel2-70/+1
Now supports full pagination, displaying & sorting on VN count and displaying & filtering the searchable and applicable flags.
2020-09-27v2rw: Delete old tag edit formYorhel2-221/+1
2020-09-27v2rw/TagEdit: Rewrite tag edit form to elmYorhel1-4/+4
It's still missing a few mod features, will add those later.
2020-09-17Feeds: Move feed generation form Multi to VNWebYorhel1-1/+0
This means the feeds are now generated on demand rather than every 15 minutes. Main reason for originally implementing this into Multi was because RSS feeds tended to get requested a *lot* and I didn't want those requests to impact site performance, but now that RSS is almost dead it doesn't really matter that much anymore. A caching layer can still be added anyway. Be sure to restart Multi and delete www/feeds/ after this change.
2020-09-12v2rw: Add new filter querying framework + rewrite homepageYorhel4-524/+1
The new filter framework hasn't been extensively tested yet, but seems to mostly work. No real changes to the homepage, but I did manage to make a few queries a little bit faster. The most significant source of slowness is the releases listing, but I can't optimize that without adding indices.
2020-09-10v2rw/filters: Add experimental validation + move compat to VNWebYorhel2-17/+4
This is a minor start towards rewriting the filter logic in the new v2rw code. Filters were never validated before (I didn't have a good framework for it - now I do) and invalid filters would result in a 500. The new validation code is not yet applied, but failed validations will be logged so that I can see if it's working correctly. I mean, what better way to test than to throw it in production? I'll write new (and more flexible) SQL generation functions for these filters later, so that v2rw code can get filtered results and I can make a start on rewriting the pages that depend on the functionality. The validation schema can also be used to validate the filters stored in the DB, so I can use it to get rid of the complex handling of stored invalid filters.
2020-09-02BBCode: Consolidate bb2html & bb2text + only convert ids in thread titlesYorhel6-74/+68
Fixing bb2html to only convert ids would complicate options a lot, adding a new formatting function to only convert ids would make sense, but then all formatting functions kind of look alike, so I figured a single bb_format() to support all use cases may be a better approach. Trigger for this was that people do (understandably) put [spoiler] in thread titles, and that should not be interpreted as the spoiler tag.
2020-09-01Handler::Misc: Bring back random VNs, split new reviews and add recent commentsYorhel1-11/+68
2020-08-31Config: Fix extraction of version when there is no commit ID in git describe2.28Yorhel1-1/+1
...which happens when I tag a new release. And let's tag this 2.28.
2020-08-31Handler::Misc: Replace "Random VNs" section with "New Reviews"Yorhel1-7/+12
Still need a place to dump "latest review comments". Perhaps merge with "recent posts"? Not sure...
2020-08-31BBCode: Add support for w+ and w+.+ dblinksYorhel1-2/+2
2020-08-24reviews: Get rid of summary field & split mini/full reviewsYorhel2-8/+8
Much to my disappointment, people don't write proper summaries and, as such, summaries are not useful to be considered a "short review" on their own right. This necessitates splitting the reviews onto different pages.
2020-08-07Discussions: Fix handling of user deletionYorhel1-3/+3
Which I broke by removing the DEFAULT clause on threads_posts.uid. That column still used the old uid=0 for deleted users rather than the uid=NULL that I was planning to migrate the entire DB to. So while I'm fixing up the threads schema, may as well update this too. There's still a bunch of columns relying on uid=0, but I can fix that later.
2020-08-06Discussions: Allow discontinuous post numbers + ignore hidden posts in ↵Yorhel2-3/+3
counts/lastpost This solves a few problems: - 'hidden' posts will no longer cause the thread to be bumped to the front page. - Deleting posts will no longer cause other posts to be renumbered (and hence will not break existing links to posts) - Numbers of deleted posts will no longer be re-used (except when they were the last post in the thread - fixing this would require an additional column in 'threads', but it didn't seem worth the trouble)
2020-08-06Discussions: Make /t#.# load the correct page without redirectYorhel1-1/+1
This removes the need for the post_url() function. This is a small step towards supporting non-continuous post numbers.
2020-08-06SQL: Use vndbid for thread identifiersYorhel1-1/+1
Also drop the thread_poll_votes.tid column, as it's not really necessary. And add ON DELETE CASCADEs to threads_posts and threads_boards to simplify thread deletion. Relatively invasive change, prolly broke something.
2020-07-22BBCode: Add support for [b], [i], [s], and [u] formatting codesYorhel1-13/+46
2020-07-21Delete old producer edit form + a few more cleanupsYorhel5-472/+3
2020-07-19Producers::Edit: v2rw rewrite producer add/edit formYorhel1-4/+4
The copy-pasting here is ridiculous. But at the same time, that did allow me to quickly rewrite the form in a single commit. Here's hoping I didn't introduce too many copy-paste errors.
2020-07-19Delete old VN edit form + some other unreferenced codeYorhel3-630/+7
There's a lot more unreferenced code in VNDB::DB::*, but I'll not spend too much effort cleaning that up right now. All of it can be deleted in bulk at some point.
2020-07-12DB::VN: Exclude deleted VNs in random screenshot selectionYorhel1-0/+1
Deleted VNs could only be selected in the rare scenario where the screenshots from the deleted entry have also been assigned to another (non-deleted) entry. Fully deleted screenshots would already have been excluded with the c_weight check. Fixes
2020-07-10DB::VN: Use image flagging status for random screenshots with filterYorhel1-4/+5
Instead of the old NSFW flag.
2020-06-29VN::Edit: Start rewrite of the VN edit formYorhel1-4/+4
This is mostly a copy-paste of the Char::Edit form.