Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
Sonatype Nexus (TM) Open Source Version Copyright (c) 2007-2012 Sonatype, Inc. All rights reserved. Includes the third-party code listed at http://links.sonatype.com/products/nexus/oss/attributions. This program and the accompanying materials are made available under the terms of the Eclipse Public License Version 1.0, which accompanies this distribution and is available at http://www.eclipse.org/legal/epl-v10.html. Sonatype Nexus (TM) Professional Version is available from Sonatype, Inc. "Sonatype" and "Sonatype Nexus" are trademarks of Sonatype, Inc. Apache Maven is a trademark of the Apache Software Foundation. M2eclipse is a trademark of the Eclipse Foundation. All other trademarks are the property of their respective owners.
 
 package org.sonatype.nexus.rest.schedules;
 
 import  javax.ws.rs.DELETE;
 import  javax.ws.rs.GET;
 import  javax.ws.rs.Path;
 import  javax.ws.rs.PathParam;
 import  javax.ws.rs.Produces;
 
 import  org.codehaus.enunciate.contract.jaxrs.ResourceMethodSignature;
 import  org.restlet.Context;
 import  org.restlet.data.Request;
 import  org.restlet.data.Response;
 import  org.restlet.data.Status;
 import  org.restlet.resource.ResourceException;
 import  org.restlet.resource.Variant;

Author(s):
tstevens
 
 @Component( role = PlexusResource.class, hint = "ScheduledServiceRunPlexusResource" )
 @Produces( { "application/xml""application/json" } )
 {
     public static final String RESOURCE_URI = "/schedule_run/{" +  + "}";
 
     {
         setModifiabletrue );
     }
 
     @Override
     public Object getPayloadInstance()
     {
         return null;
     }
 
     @Override
     public String getResourceUri()
     {
         return ;
     }
 
     @Override
     {
         return new PathProtectionDescriptor"/schedule_run/*""authcBasic,perms[nexus:tasksrun]" );
     }

    
Run the specified scheduled task right now. Will then be rescheduled upon completion for normal run.

Parameters:
scheduledServiceId The scheduled task to access.
 
     @Override
     @GET
     @ResourceMethodSignature( pathParams = { @PathParam( . ) }, output = ScheduledServiceResourceStatusResponse.class )
     public Object get( Context context, Request request, Response response, Variant variant )
         throws ResourceException
     {
         ScheduledServiceResourceStatusResponse result = null;
 
         final String scheduledServiceId = getScheduledServiceIdrequest );
 
         try
         {
             ScheduledTask<?> task = getNexusScheduler().getTaskByIdscheduledServiceId );
 
             task.runNow();
 
             ScheduledServiceBaseResource resource = getServiceRestModeltask );
 
             if ( resource != null )
             {
                 ScheduledServiceResourceStatus resourceStatus = new ScheduledServiceResourceStatus();
                 resourceStatus.setResourceresource );
                 resourceStatus.setResourceURIcreateChildReferencerequestthistask.getId() ).toString() );
                resourceStatus.setStatustask.getTaskState().toString() );
                resourceStatus.setReadableStatusgetReadableStatetask.getTaskState() ) );
                resourceStatus.setCreatedtask.getScheduledAt() == null ? "n/a" : task.getScheduledAt().toString() );
                resourceStatus.setLastRunResult..equalstask.getTaskState() ) ? "Error" : "Ok" );
                resourceStatus.setLastRunTimetask.getLastRun() == null ? "n/a" : task.getLastRun().toString() );
                resourceStatus.setNextRunTimetask.getNextRun() == null ? "n/a" : task.getNextRun().toString() );
                if ( task.getScheduledAt() != null )
                {
                    resourceStatus.setCreatedInMillistask.getScheduledAt().getTime() );
                }
                if ( task.getLastRun() != null )
                {
                    resourceStatus.setLastRunTimeInMillistask.getLastRun().getTime() );
                }
                if ( task.getNextRun() != null )
                {
                    resourceStatus.setNextRunTimeInMillistask.getNextRun().getTime() );
                }
                result = new ScheduledServiceResourceStatusResponse();
                result.setDataresourceStatus );
            }
            else
            {
                throw new ResourceException( Status.CLIENT_ERROR_NOT_FOUND, "Invalid schedule id ("
                    + scheduledServiceId + "), can't load task." );
            }
            return result;
        }
        catch ( NoSuchTaskException e )
        {
            throw new ResourceException( Status.CLIENT_ERROR_NOT_FOUND, "There is no task with ID="
                + scheduledServiceId );
        }
    }

    
Cancel the execution of an existing scheduled task.

Parameters:
scheduledServiceId The scheduled task to cancel.
    @Override
    @DELETE
    @ResourceMethodSignature( pathParams = { @PathParam( . ) } )
    public void delete( Context context, Request request, Response response )
        throws ResourceException
    {
        try
        {
            getNexusScheduler().getTaskByIdgetScheduledServiceIdrequest ) ).cancelOnly();
            response.setStatus( Status.SUCCESS_NO_CONTENT );
        }
        catch ( NoSuchTaskException e )
        {
            response.setStatus( Status.CLIENT_ERROR_NOT_FOUND, "Scheduled service not found!" );
        }
    }
    // ==
    protected String getScheduledServiceId( Request request )
    {
        return request.getAttributes().get(  ).toString();
    }
New to GrepCode? Check out our FAQ X