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

org.osgi.service.upnp.UPnPService Maven / Gradle / Ivy

There is a newer version: 0.10.0
Show newest version
/*
 * Copyright (c) OSGi Alliance (2002, 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.upnp;

/**
 * A representation of a UPnP Service.
 * 
 * Each UPnP device contains zero or more services. The UPnP description for a
 * service defines actions, their arguments, and event characteristics.
 * 
 * @author $Id: 08eea1f048b12e9259685d2fc6f4daf5161ec5ea $
 */
public interface UPnPService {
	/**
	 * Property key for the optional service type uri.
	 * 
	 * The service type property is used when registering UPnP Device services
	 * and UPnP Event Listener services. The property contains a {@code String}
	 * array ({@code String[]}) of service types. A UPnP Device service can thus
	 * announce what types of services it contains. A UPnP Event Listener
	 * service can announce for what type of UPnP services it wants
	 * notifications. The service version is encoded in the type string as
	 * specified in the UPnP specification. A {@code null} value is a wildcard,
	 * matching all  service types. Value is "UPnP.service.type".
	 * 
	 * @see UPnPService#getType()
	 */
	String	TYPE	= "UPnP.service.type";
	/**
	 * Property key for the optional service id.
	 * 
	 * The service id property is used when registering UPnP Device services or
	 * UPnP Event Listener services. The value of the property contains a
	 * {@code String} array ({@code String[]}) of service ids. A UPnP Device
	 * service can thus announce what service ids it contains. A UPnP Event
	 * Listener service can announce for what UPnP service ids it wants
	 * notifications. A service id does not  have to be universally
	 * unique. It must be unique only within a device. A {@code null} value is a
	 * wildcard, matching all  services. The value is "UPnP.service.id".
	 */
	String	ID		= "UPnP.service.id";

	/**
	 * Returns the {@code serviceId} field in the UPnP service description.
	 * 
	 * 
	 * 

* For standard services defined by a UPnP Forum working committee, the * serviceId must contain the following components in the indicated order: *

    *
  • {@code urn:upnp-org:serviceId:}
  • *
  • service ID suffix
  • *
* Example: {@code urn:upnp-org:serviceId:serviceID}. * *

* Note that {@code upnp-org} is used instead of {@code schemas-upnp-org} in * this example because an XML schema is not defined for each serviceId. *

* *

* For non-standard services specified by UPnP vendors, the serviceId must * contain the following components in the indicated order: *

    *
  • {@code urn:}
  • *
  • ICANN domain name owned by the vendor
  • *
  • {@code :serviceId:}
  • *
  • service ID suffix
  • *
* Example: {@code urn:domain-name:serviceId:serviceID}. * *

* This method must continue to return the service id after the UPnP service * has been removed from the network. * * @return The service ID suffix defined by a UPnP Forum working committee * or specified by a UPnP vendor. Must be <= 64 characters. * Single URI. */ String getId(); /** * Returns the {@code serviceType} field in the UPnP service description. * *

* For standard services defined by a UPnP Forum working committee, the * serviceType must contain the following components in the indicated order: *

    *
  • {@code urn:schemas-upnp-org:service:}
  • *
  • service type suffix:
  • *
  • integer service version
  • *
* Example: {@code urn:schemas-upnp-org:service:serviceType:v}. * *

* For non-standard services specified by UPnP vendors, the * {@code serviceType} must contain the following components in the * indicated order: *

    *
  • {@code urn:}
  • *
  • ICANN domain name owned by the vendor
  • *
  • {@code :service:}
  • *
  • service type suffix:
  • *
  • integer service version
  • *
* Example: {@code urn:domain-name:service:serviceType:v}. * *

* This method must continue to return the service type after the UPnP * service has been removed from the network. * * @return The service type suffix defined by a UPnP Forum working committee * or specified by a UPnP vendor. Must be <= 64 characters, not * including the version suffix and separating colon. Single URI. */ String getType(); /** * Returns the version suffix encoded in the {@code serviceType} field in * the UPnP service description. * *

* This method must continue to return the service version after the UPnP * service has been removed from the network. * * @return The integer service version defined by a UPnP Forum working * committee or specified by a UPnP vendor. */ String getVersion(); /** * Locates a specific action by name. * * Looks up an action by its name. * * @param name Name of action. Must not contain hyphen or hash characters. * Should be < 32 characters. * * @return The requested action or {@code null} if no action is found. * * @throws IllegalStateException if the UPnP service has been removed from * the network. */ UPnPAction getAction(String name); /** * Lists all actions provided by this service. * * @return Array of actions ({@code UPnPAction[]} )or {@code null} if no * actions are defined for this service. * * @throws IllegalStateException if the UPnP service has been removed from * the network. */ UPnPAction[] getActions(); /** * Lists all {@code UPnPStateVariable} objects provided by this service. * * @return Array of state variables or {@code null} if none are defined for * this service. * * @throws IllegalStateException if the UPnP service has been removed from * the network. */ UPnPStateVariable[] getStateVariables(); /** * Gets a {@code UPnPStateVariable} objects provided by this service by name * * @param name Name of the State Variable * * @return State variable or {@code null} if no such state variable exists * for this service. * * @throws IllegalStateException if the UPnP service has been removed from * the network. */ UPnPStateVariable getStateVariable(String name); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy