add options to show sites with/without a tag
This commit is contained in:
parent
ac55efeecf
commit
4fd25301b8
@ -22,15 +22,22 @@
|
|||||||
|
|
||||||
define('INSTALLDIR', realpath(dirname(__FILE__) . '/..'));
|
define('INSTALLDIR', realpath(dirname(__FILE__) . '/..'));
|
||||||
|
|
||||||
|
$shortoptions = 't:w:';
|
||||||
|
$longoptions = array('tagged=', 'not-tagged=');
|
||||||
|
|
||||||
$helptext = <<<ENDOFHELP
|
$helptext = <<<ENDOFHELP
|
||||||
allsites.php - list all sites configured for multi-site use
|
allsites.php - list all sites configured for multi-site use
|
||||||
|
USAGE: allsites.php [OPTIONS]
|
||||||
|
|
||||||
returns the nickname of each site configured for multi-site use
|
-t --tagged=tagname List only sites with this tag
|
||||||
|
-w --not-tagged=tagname List only sites without this tag
|
||||||
|
|
||||||
ENDOFHELP;
|
ENDOFHELP;
|
||||||
|
|
||||||
require_once INSTALLDIR.'/scripts/commandline.inc';
|
require_once INSTALLDIR.'/scripts/commandline.inc';
|
||||||
|
|
||||||
|
function print_all_sites() {
|
||||||
|
|
||||||
$sn = new Status_network();
|
$sn = new Status_network();
|
||||||
|
|
||||||
if ($sn->find()) {
|
if ($sn->find()) {
|
||||||
@ -38,3 +45,49 @@ if ($sn->find()) {
|
|||||||
print "$sn->nickname\n";
|
print "$sn->nickname\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
function print_tagged_sites($tag) {
|
||||||
|
|
||||||
|
$sn = new Status_network();
|
||||||
|
|
||||||
|
$sn->query('select status_network.nickname '.
|
||||||
|
'from status_network join status_network_tag '.
|
||||||
|
'on status_network.site_id = status_network_tag.site_id '.
|
||||||
|
'where status_network_tag.tag = "' . $tag . '"');
|
||||||
|
|
||||||
|
while ($sn->fetch()) {
|
||||||
|
print "$sn->nickname\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
function print_untagged_sites($tag) {
|
||||||
|
|
||||||
|
$sn = new Status_network();
|
||||||
|
|
||||||
|
$sn->query('select status_network.nickname '.
|
||||||
|
'from status_network '.
|
||||||
|
'where not exists '.
|
||||||
|
'(select tag from status_network_tag '.
|
||||||
|
'where site_id = status_network.site_id '.
|
||||||
|
'and tag = "'.$tag.'")');
|
||||||
|
|
||||||
|
while ($sn->fetch()) {
|
||||||
|
print "$sn->nickname\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (have_option('t', 'tagged')) {
|
||||||
|
$tag = get_option_value('t', 'tagged');
|
||||||
|
print_tagged_sites($tag);
|
||||||
|
} else if (have_option('w', 'not-tagged')) {
|
||||||
|
$tag = get_option_value('w', 'not-tagged');
|
||||||
|
print_untagged_sites($tag);
|
||||||
|
} else {
|
||||||
|
print_all_sites();
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user