/**
* Copyright 2012-2013 Maciej Jaworski, Mariusz Kapcia, Paweł Kędzia, Mateusz Kubuszok
*
* <p>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</p>
*
* <p>http://www.apache.org/licenses/LICENSE-2.0</p>
*
* <p>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.</p>
*/
package com.autoupdater.client.utils.services;
/**
* Interface common to all services used in the library.
*
* @see com.autoupdater.client.utils.services.IService
* @see com.autoupdater.client.installation.services.InstallationService
* @see com.autoupdater.client.download.services.AbstractDownloadService
* @see com.autoupdater.client.download.services.PackagesInfoDownloadService
* @see com.autoupdater.client.download.services.UpdateInfoDownloadService
* @see com.autoupdater.client.download.services.ChangelogInfoDownloadService
* @see com.autoupdater.client.download.services.FileDownloadService
* @see com.autoupdater.client.download.services.FileDownloadService
*
* @param <Message>
* type of message that will be sent to Observers
*/
public interface IService<Message> {
/**
* Adds observer to set of the notified.
*
* <p>
* Since observer is added, it will be notified about all changes of
* service.
* </p>
*
* @param observer
* added observer
*/
public void addObserver(IObserver<Message> observer);
/**
* Removes observer from set of the notified.
*
* <p>
* Since observer is removed, it won't be notified about any changes of
* service.
* </p>
*
* @param observer
* removed observer
*/
public void removeObserver(IObserver<Message> observer);
/**
* Mark object as changes - it won't sent a notification about change
* without settings that marker.
*
* @see #notifyObservers(Object)
*/
public void hasChanged();
/**
* Sends message to all Observers.
*
* <p>
* Has to be marked as changed first. After sending message it should remove
* marker.
* </p>
*
* @see #hasChanged()
*
* @param message
* sent message
*/
public void notifyObservers(Message message);
}