From: Michael Tremer <michael.tremer@ipfire.org>
To: development@lists.ipfire.org
Subject: Re: Peeking at unbound statistics from WUI
Date: Fri, 18 Jan 2019 15:03:56 +0000 [thread overview]
Message-ID: <FA7D5322-5550-4627-866D-02B6E3730E9D@ipfire.org> (raw)
In-Reply-To: =?utf-8?q?=3CAM0PR03MB49325B24A5E13B8EB2369611B6830=40AM0PR03MB?= =?utf-8?q?4932=2Eeurprd03=2Eprod=2Eoutlook=2Ecom=3E?=
[-- Attachment #1: Type: text/plain, Size: 2722 bytes --]
Hallo Rachid,
Thanks for writing :)
> On 17 Jan 2019, at 20:15, Rachid Groeneveld <rachidgroeneveld(a)hotmail.nl> wrote:
>
> Hi all,
>
> I'm fairly new to perl and cgi scripts, I can find most of it on the web, but I've been unable to solve this riddle. Is it possible to query the unbound statistics from a cgi script? I can't seem to figure out how to do this without cron-ing a bash script and reading its output, I want them on-demand when a page is requested.
That depends on what you need.
The CGI scripts can in theory run any shell command. Those commands will be executed as an unprivileged user called “nobody” so that nobody else who gains access through a vulnerability in the web UI can change the system configuration for which root permissions would be required.
For some special actions - for example reboot - we have special binaries that can then gain root privileges and perform very specific actions only.
>
> I think it's a permission issue, as far as I've been able to assess the webpages run under 'nobody' and unbound-control needs elevated rights to execute a peek at the statistics. I'm using the following command to do so: “unbound-control stats_noreset”. That way I can query all the DNS info I want (for reporting purposes), because I don't think unbound was compiled with dnstap enabled. At least I haven't found anything to back that up, that would eliminate the need for peeking at stats, because an up-to-date database can be built (async). I will further investigate dnstap in a later stage.
Running that command fails as follows:
[root(a)ipfire ~]# sudo -u nobody unbound-control stats
error: Error setting up SSL_CTX client cert
/etc/unbound/unbound_control.pem: Permission denied
The certificate that unbound uses is only supposed to be read by root.
>
> Can someone point me in the right direction for peeking unbound statistics from perl/cgi scripts? I’ve tried sudo-ing (I’d rather not, for security reasons), separate bash scripts and qx/backticks, they all seem to fail with exit code 256 which seems to be a permission problem. Running anything from an SSH session obviously succeeds, because then I have all the rights I need.
Depending how fit you are with C, you can build such a “setuid binary” yourself. There is plenty of inspiration here:
https://git.ipfire.org/?p=ipfire-2.x.git;a=tree;f=src/misc-progs;h=a1a3f2c9ca75d8077a6f3d122b7a5e7ffaa71432;hb=HEAD
But since you have said that you are not a developer, this might be a little bit hard :) Let me know where I can help out.
What are you building with all this?
Best,
-Michael
>
> Thanks in advance.
>
> Cheers,
>
> Rachid
next reply other threads:[~2019-01-18 15:03 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-01-18 15:03 Michael Tremer [this message]
2019-01-19 10:44 ` Bob Brewer
2019-01-21 10:51 ` Michael Tremer
2019-01-21 11:50 ` Bob Brewer
2019-01-21 10:28 Bob Brewer
2019-01-21 11:02 Michael Tremer
2019-01-21 11:35 ` Tom Rymes
2019-01-21 11:38 ` Michael Tremer
2019-01-22 14:16 Michael Tremer
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=FA7D5322-5550-4627-866D-02B6E3730E9D@ipfire.org \
--to=michael.tremer@ipfire.org \
--cc=development@lists.ipfire.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox