All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.osgi.service.application.ScheduledApplication Maven / Gradle / Ivy

/*
 * Copyright (c) OSGi Alliance (2004, 2013). All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.osgi.service.application;

import java.util.Map;

/**
 * It is allowed to schedule an application based on a specific event.
 * ScheduledApplication service keeps the schedule information. When the
 * specified event is fired a new instance must be launched. Note that launching
 * operation may fail because e.g. the application is locked.
 * 

* Each {@code ScheduledApplication} instance has an identifier which is unique * within the scope of the application being scheduled. *

* {@code ScheduledApplication} instances are registered as services. The * {@link #APPLICATION_PID} service property contains the PID of the application * being scheduled, the {@link #SCHEDULE_ID} service property contains the * schedule identifier. * * @author $Id: 69c9a4995399ff1619ec236dcb9ae2553a12d1ae $ */ public interface ScheduledApplication { /** * The property key for the identifier of the application being scheduled. */ public static final String APPLICATION_PID = ApplicationDescriptor.APPLICATION_PID; /** * The property key for the schedule identifier. The identifier is unique * within the scope of the application being scheduled. */ public static final String SCHEDULE_ID = "schedule.id"; /** * The key for the startup argument used to pass the event object that * triggered the schedule to launch the application instance. The event is * passed in a {@link java.security.GuardedObject} protected by the * corresponding {@link org.osgi.service.event.TopicPermission}. */ public static final String TRIGGERING_EVENT = "org.osgi.triggeringevent"; /** * The topic name for the virtual timer topic. Time based schedules should * be created using this topic. */ public static final String TIMER_TOPIC = "org/osgi/application/timer"; /** * The name of the year attribute of a virtual timer event. The value * is defined by {@link java.util.Calendar#YEAR}. */ public static final String YEAR = "year"; /** * The name of the month attribute of a virtual timer event. The * value is defined by {@link java.util.Calendar#MONTH}. */ public static final String MONTH = "month"; /** * The name of the day of month attribute of a virtual timer event. * The value is defined by {@link java.util.Calendar#DAY_OF_MONTH}. */ public static final String DAY_OF_MONTH = "day_of_month"; /** * The name of the day of week attribute of a virtual timer event. * The value is defined by {@link java.util.Calendar#DAY_OF_WEEK}. */ public static final String DAY_OF_WEEK = "day_of_week"; /** * The name of the hour of day attribute of a virtual timer event. * The value is defined by {@link java.util.Calendar#HOUR_OF_DAY}. */ public static final String HOUR_OF_DAY = "hour_of_day"; /** * The name of the minute attribute of a virtual timer event. The * value is defined by {@link java.util.Calendar#MINUTE}. */ public static final String MINUTE = "minute"; /** * Returns the identifier of this schedule. The identifier is unique within * the scope of the application that the schedule is related to. * * @return the identifier of this schedule * */ public String getScheduleId(); /** * Queries the topic of the triggering event. The topic may contain a * trailing asterisk as wildcard. * * @return the topic of the triggering event * * @throws IllegalStateException if the scheduled application service is * unregistered */ public String getTopic(); /** * Queries the event filter for the triggering event. * * @return the event filter for triggering event * * @throws IllegalStateException if the scheduled application service is * unregistered */ public String getEventFilter(); /** * Queries if the schedule is recurring. * * @return true if the schedule is recurring, otherwise returns false * * @throws IllegalStateException if the scheduled application service is * unregistered */ public boolean isRecurring(); /** * Retrieves the ApplicationDescriptor which represents the application and * necessary for launching. * * @return the application descriptor that represents the scheduled * application * * @throws IllegalStateException if the scheduled application service is * unregistered */ public ApplicationDescriptor getApplicationDescriptor(); /** * Queries the startup arguments specified when the application was * scheduled. The method returns a copy of the arguments, it is not possible * to modify the arguments after scheduling. * * @return the startup arguments of the scheduled application. It may be * null if null argument was specified. * * @throws IllegalStateException if the scheduled application service is * unregistered */ public Map getArguments(); /** * Cancels this schedule of the application. * * @throws SecurityException if the caller doesn't have "schedule" * ApplicationAdminPermission for the scheduled application. * @throws IllegalStateException if the scheduled application service is * unregistered */ public void remove(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy