* initial v0 creator * working json api for generic reports * add require login * move report swagger into plugin, and set new default layout of noop * require proper role and also use new util func * start to tidy authn * some work on cleaning up web authn * clean up the authN checks * fix bug * fix the auth for api * fixes to json handling * set swagger sort order * enable most reports for api endpoints * fix doc * add paramters to reports * add missed report * allow api_parameters in reports config * reorganise api * add vlan search * add port search * make sure to enable layout processing * add device search * add v1 to api paths * add Node Search * support api_responses * add device object search; fix spurious ports field in device result class * handle some plugins just returning undef if search fails * errors from api seamlessley * fix error in date range default * more sensible default for prefix * change order of endpoints in swagger-ui * all db row classes can now TO_JSON * add device_port api endpoint * add device ports endpoint * do not expand docs * add swagger ui json tree formatter * add all relations from Device table * add port relations * add nodes retrieve on device or vlan * rename to GetAPIKey * update config for previous commit
		
			
				
	
	
		
			79 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
| package App::Netdisco::Web::AdminTask;
 | |
| 
 | |
| use Dancer ':syntax';
 | |
| use Dancer::Plugin::Ajax;
 | |
| use Dancer::Plugin::DBIC;
 | |
| use Dancer::Plugin::Auth::Extensible;
 | |
| 
 | |
| use NetAddr::IP qw/:rfc3021 :lower/;
 | |
| use App::Netdisco::JobQueue 'jq_insert';
 | |
| use App::Netdisco::Util::Device 'delete_device';
 | |
| 
 | |
| sub add_job {
 | |
|     my ($action, $device, $subaction) = @_;
 | |
| 
 | |
|     my $net = NetAddr::IP->new($device);
 | |
|     return if
 | |
|       ($device and (!$net or $net->num == 0 or $net->addr eq '0.0.0.0'));
 | |
| 
 | |
|     my @hostlist = $device ? ($net->hostenum) : (undef);
 | |
| 
 | |
|     jq_insert([map {{
 | |
|       ($_ ? (device => $_->addr) : ()),
 | |
|       action => $action,
 | |
|       ($subaction ? (subaction => $subaction) : ()),
 | |
|       username => session('logged_in_user'),
 | |
|       userip => request->remote_address,
 | |
|     }} @hostlist]);
 | |
| 
 | |
|     true;
 | |
| }
 | |
| 
 | |
| foreach my $action (@{ setting('job_prio')->{high} },
 | |
|                     @{ setting('job_prio')->{normal} }) {
 | |
| 
 | |
|     ajax "/ajax/control/admin/$action" => require_role admin => sub {
 | |
|         add_job($action, param('device'), param('extra'))
 | |
|           or send_error('Bad device', 400);
 | |
|     };
 | |
| 
 | |
|     post "/admin/$action" => require_role admin => sub {
 | |
|         add_job($action, param('device'), param('extra'))
 | |
|           ? redirect uri_for('/admin/jobqueue')->path
 | |
|           : redirect uri_for('/')->path;
 | |
|     };
 | |
| }
 | |
| 
 | |
| ajax qr{/ajax/control/admin/(?:\w+/)?delete} => require_role setting('defanged_admin') => sub {
 | |
|     send_error('Missing device', 400) unless param('device');
 | |
| 
 | |
|     my $device = NetAddr::IP->new(param('device'));
 | |
|     send_error('Bad device', 400)
 | |
|       if ! $device or $device->addr eq '0.0.0.0';
 | |
| 
 | |
|     return delete_device(
 | |
|       $device->addr, param('archive'), param('log'),
 | |
|     );
 | |
| };
 | |
| 
 | |
| get '/admin/*' => require_role admin => sub {
 | |
|     my ($tag) = splat;
 | |
| 
 | |
|     if (exists setting('_admin_tasks')->{ $tag }) {
 | |
|       # trick the ajax into working as if this were a tabbed page
 | |
|       params->{tab} = $tag;
 | |
| 
 | |
|       var(nav => 'admin');
 | |
|       template 'admintask', {
 | |
|         task => setting('_admin_tasks')->{ $tag },
 | |
|       }, { layout => 'main' };
 | |
|     }
 | |
|     else {
 | |
|       var('notfound' => true);
 | |
|       status 'not_found';
 | |
|       template 'index', {}, { layout => 'main' };
 | |
|     }
 | |
| };
 | |
| 
 | |
| true;
 |