/*
* Funambol is a mobile platform developed by Funambol, Inc.
* Copyright (C) 2003 - 2007 Funambol, Inc.
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU Affero General Public License version 3 as published by
* the Free Software Foundation with the addition of the following permission
* added to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED
* WORK IN WHICH THE COPYRIGHT IS OWNED BY FUNAMBOL, FUNAMBOL DISCLAIMS THE
* WARRANTY OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program; if not, see http://www.gnu.org/licenses or write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301 USA.
*
* You can contact Funambol, Inc. headquarters at 643 Bair Island Road, Suite
* 305, Redwood City, CA 94063, USA, or at email address info@funambol.com.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU Affero General Public License version 3.
*
* In accordance with Section 7(b) of the GNU Affero General Public License
* version 3, these Appropriate Legal Notices must retain the display of the
* "Powered by Funambol" logo. If the display of the logo is not reasonably
* feasible for technical reasons, the Appropriate Legal Notices must display
* the words "Powered by Funambol".
*/
package com.funambol.syncml.protocol;
import java.util.*;
/**
* This is the base (and abstract) class for response commands
*/
public abstract class ResponseCommand extends ItemizedCommand {
// ---------------------------------------------------------- Protected data
/**
* Message reference
*/
protected String msgRef;
/**
* Command reference
*/
protected String cmdRef;
/**
* Target references
*/
protected Vector targetRef = new Vector();
/**
* Source references
*/
protected Vector sourceRef = new Vector();
// ------------------------------------------------------------ Constructors
/**
* For serialization purposes
*/
protected ResponseCommand() {}
/**
* Creates a new ResponseCommand object.
*
* @param cmdID the command idendifier - NOT NULL
* @param msgRef message reference
* @param cmdRef command reference - NOT NULL
* @param targetRefs target references
* @param sourceRefs source references
* @param items command items
*
* @throws IllegalArgumentException if any of the NOT NULL parameter is null
*/
public ResponseCommand(
final String cmdID ,
final String msgRef ,
final String cmdRef ,
final Vector targetRefs,
final Vector sourceRefs,
final Vector items ) {
super(cmdID, items);
setCmdRef(cmdRef);
this.msgRef = msgRef;
setTargetRef(targetRefs);
setSourceRef(sourceRefs);
}
// ---------------------------------------------------------- Public methods
public void init() {
super.init();
msgRef = null;
cmdRef = null;
targetRef.removeAllElements();
sourceRef.removeAllElements();
}
/**
* Returns the message reference
*
* @return the message reference
*
*/
public String getMsgRef() {
return this.msgRef;
}
/**
* Sets the message reference
*
* @param msgRef message reference
*/
public void setMsgRef(String msgRef) {
this.msgRef = msgRef;
}
/**
* Returns the command reference
*
* @return the command reference
*
*/
public String getCmdRef() {
return cmdRef;
}
/**
* Sets the command reference
*
* @param cmdRef commandreference - NOT NULL
*
* @throws IllegalArgumentException if cmdRef is null
*/
public void setCmdRef(String cmdRef) {
if (cmdRef == null) {
throw new IllegalArgumentException("cmdRef cannot be null");
}
this.cmdRef = cmdRef;
}
/**
* Returns the target references
*
* @return the target references
*
*/
public Vector getTargetRef() {
return this.targetRef;
}
/**
* Sets the target references
*
* @param targetRefs target refrences
*/
public void setTargetRef(Vector targetRef) {
this.targetRef = targetRef;
}
/**
* Sets a single target reference (remove all existing ones)
*/
public void setTargetRef(TargetRef ref) {
Vector refs = new Vector();
refs.addElement(ref);
setTargetRef(refs);
}
/**
* Returns the source references
*
* @return the source references
*
*/
public Vector getSourceRef() {
return this.sourceRef;
}
/**
* Sets the source references
*
* @param sourceRefs source refrences
*/
public void setSourceRef(Vector sourceRef) {
this.sourceRef = sourceRef;
}
/**
* Sets a single target reference (remove all existing ones)
*/
public void setSourceRef(SourceRef ref) {
Vector refs = new Vector();
refs.addElement(ref);
setSourceRef(refs);
}
/**
* Returns the command name. It must be redefined by subclasses.
*
* @return the command name
*/
abstract public String getName();
}