💾 Archived View for gmn.clttr.info › sources › gmnifaq.git › tree › faqs.pl.txt captured on 2024-12-17 at 10:07:02.

View Raw

More Information

⬅️ Previous capture (2023-01-29)

-=-=-=-=-=-=-

#!/usr/bin/perl
# Copyright René Wagner 2020
# licenced under BSD 3-Clause licence
# https://src.clttr.info/rwa/gmnifaq

use strict;
use DBI;
use URI::Escape;
use lib 'lib/';
use gmnifaq;

# enable UTF-8 mode for everything	
use utf8;
binmode STDOUT, ':utf8';
binmode STDERR, ':utf8';

config();

if (!defined($ENV{'SERVER_PROTOCOL'}) || $ENV{'SERVER_PROTOCOL'} ne 'GEMINI') {
	write_response('CGI_ERROR', 'CGI execution error', undef);
}
 
my @body = ();
push @body, header();
push @body, faqs();
push @body, footer();

write_response('SUCCESS', 'text/gemini', @body);

exit;

sub sql
{
	my $query = lc(uri_unescape($ENV{'QUERY_STRING'}));

	if ( $query eq '' ) {
		return "SELECT * FROM questions q ORDER BY question;";
	}

	if ( $query =~ /tag=([0-9]+)/i ) {
		return "SELECT q.* FROM questions q LEFT JOIN tags_questions tq ON q.id = tq.q_id WHERE tq.t_id = $1";
	}
	
	if ( $query =~ /faq=([0-9]+)/i ) {
		return "SELECT q.* FROM questions q LEFT JOIN tags_questions tq ON q.id = tq.q_id WHERE q.id = $1";
	}
	write_response('CGI_ERROR', 'invalid query string', undef);
}

sub faqs
{
	my @return;
	my $dbh = DBI->connect($CONF{'dsn'}, '', '', { RaiseError => 1 }) or die $DBI::errstr;

	my @rows = $dbh->selectall_array(sql());

	if ( !scalar @rows ) {
		push @return, ('No faqs found!', '');
	}
	else {
		foreach (@rows) {
			push @return, sprintf("## %s", @$_[1]);
			push @return, (@$_[2], '');
			my @tags = $dbh->selectall_array("SELECT id, name FROM tags t LEFT JOIN tags_questions tq ON tq.t_id = t.id WHERE tq.q_id = @$_[0];");
			
			if ( scalar @tags ) {
				push @return, ('### tags');
				foreach (@tags) {
					push @return, sprintf("=> ./faqs.pl?tag=%d %s", @$_[0], @$_[1]);
				}
				push @return, '';
			}
		}
	}
	$dbh->disconnect();
	return @return;
}

sub header
{
	return ( '# '. $CONF{'name'}, '');
}