-/*
-** Copyright (C) 2006- Sami Kerola <kerolasa@iki.fi>
-**
-** This program is free software; you can redistribute it and/or modify
+/* http://dhcpd-pools.sourceforge.net/
+** Copyright 2006- Sami Kerola <kerolasa@iki.fi>
+**
+** This program is free software: you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
-** the Free Software Foundation; either version 2 of the License, or
+** the Free Software Foundation, either version 3 of the License, or
** (at your option) any later version.
-**
+**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
-**
+**
** You should have received a copy of the GNU General Public License
-** along with this program; if not, write to the Free Software
-** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+** along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifdef HAVE_CONFIG_H
struct in_addr first, last;
struct range_t *range_p;
struct shared_network_t *shared_p;
+ struct macaddr_t *macaddr_p;
int ret;
FILE *outfile;
range_p = ranges;
shared_p = shared_networks;
+ fprintf(outfile, "<dhcpstatus>\n");
+
+ if (macaddr != NULL) {
+ for (macaddr_p = macaddr; macaddr_p->next != NULL;
+ macaddr_p = macaddr_p->next) {
+ fprintf(outfile,
+ "<active_lease>\n\t<ip>%s</ip>\n\t<macaddress>%s</macaddress>\n</active_lease>\n",
+ macaddr_p->ip, macaddr_p->ethernet);
+ }
+ }
+
if (config.output_limit[1] & output_limit_bit_1) {
for (i = 0; i < num_ranges; i++) {
first.s_addr = ntohl(range_p->first_ip + 1);
last.s_addr = ntohl(range_p->last_ip - 1);
-
fprintf(outfile, "<subnet>\n");
-
if (range_p->shared_net) {
fprintf(outfile,
"\t<location>%s</location>\n",
fprintf(outfile, "\t<free>%lu</free>\n",
range_p->last_ip - range_p->first_ip - 1 -
range_p->count);
-
range_p++;
-
fprintf(outfile, "</subnet>\n");
}
}
if (config.output_limit[1] & output_limit_bit_2) {
for (i = 0; i < num_shared_networks; i++) {
shared_p++;
-
fprintf(outfile, "<shared-network>\n");
fprintf(outfile, "\t<location>%s</location>\n",
shared_p->name);
fprintf(outfile, "</summary>\n");
}
+ fprintf(outfile, "</dhcpstatus>\n");
if (outfile == stdout) {
ret = fflush(stdout);
if (ret) {
fprintf(f, "<p class=created>\nData generated by ");
fprintf(f, "<a href=\"%s\">", PACKAGE_URL);
fprintf(f, "dhcpd-pools</a>.\n</p>\n");
-
fprintf(f, "<p class=updated>\n");
fprintf(f, "<script type=\"text/javascript\">\n");
fprintf(f, " document.write(\"Last Updated On \" + ");
newrow(f);
output_line(f, "td", "calign", " ");
endrow(f);
-
newrow(f);
output_line(f, "th", "section", title);
endrow(f);
struct shared_network_t *shared_p;
int ret;
FILE *outfile;
-
if (config.output_file[0]) {
outfile = fopen(config.output_file, "w+");
if (outfile == NULL) {
range_p = ranges;
shared_p = shared_networks;
-
if (fullhtml) {
html_header(outfile);
}
for (i = 0; i < num_ranges; i++) {
first.s_addr = ntohl(range_p->first_ip + 1);
last.s_addr = ntohl(range_p->last_ip - 1);
-
newrow(outfile);
if (range_p->shared_net) {
output_line(outfile, "td", "calign",
table_start(outfile);
if (config.output_limit[0] & output_limit_bit_2) {
newsection(outfile, "Shared networks:");
-
newrow(outfile);
output_line(outfile, "th", "calign", "name");
output_line(outfile, "th", "ralign", "max");
}
if (config.output_limit[0] & output_limit_bit_3) {
newsection(outfile, "Sum of all ranges:");
-
newrow(outfile);
output_line(outfile, "th", "calign", "name");
output_line(outfile, "th", "ralign", "max");
struct shared_network_t *shared_p;
FILE *outfile;
int ret;
-
if (config.output_file[0]) {
outfile = fopen(config.output_file, "w+");
if (outfile == NULL) {
range_p = ranges;
shared_p = shared_networks;
-
if (config.output_limit[0] & output_limit_bit_1) {
fprintf(outfile, "\"Ranges:\"\n");
fprintf
fprintf(outfile, ",\"bu\",\"bu perc\"");
}
fprintf(outfile, "\n");
-
}
if (config.output_limit[1] & output_limit_bit_1) {
for (i = 0; i < num_ranges; i++) {
first.s_addr = ntohl(range_p->first_ip + 1);
last.s_addr = ntohl(range_p->last_ip - 1);
-
if (range_p->shared_net) {
fprintf(outfile, "\"%s\",",
range_p->shared_net->name);
range_p->first_ip - 1));
}
-
fprintf(outfile, "\n");
range_p++;
}
}
fprintf(outfile, "\n");
-
-
}
fprintf(outfile, "\n");
}
shared_networks->available);
}
fprintf(outfile, "\n");
-
}
if (outfile == stdout) {
ret = fflush(stdout);